mirror of
https://github.com/openwrt/packages.git
synced 2025-12-21 21:24:31 +04:00
syncthing: improve relay argument parsing
Fixes: 47644ba46 ("syncthing: fix discovery and relay extra args")
Signed-off-by: George Sapkin <george@sapk.in>
This commit is contained in:
committed by
Hannu Nyman
parent
6ccb3b6174
commit
d75075ce8e
@@ -2,7 +2,7 @@ include $(TOPDIR)/rules.mk
|
|||||||
|
|
||||||
PKG_NAME:=syncthing
|
PKG_NAME:=syncthing
|
||||||
PKG_VERSION:=1.30.0
|
PKG_VERSION:=1.30.0
|
||||||
PKG_RELEASE:=2
|
PKG_RELEASE:=3
|
||||||
|
|
||||||
PKG_SOURCE:=syncthing-source-v$(PKG_VERSION).tar.gz
|
PKG_SOURCE:=syncthing-source-v$(PKG_VERSION).tar.gz
|
||||||
PKG_SOURCE_URL:=https://github.com/syncthing/syncthing/releases/download/v$(PKG_VERSION)
|
PKG_SOURCE_URL:=https://github.com/syncthing/syncthing/releases/download/v$(PKG_VERSION)
|
||||||
|
|||||||
@@ -20,8 +20,10 @@ config strelaysrv 'strelaysrv'
|
|||||||
# option status_srv ':22070'
|
# option status_srv ':22070'
|
||||||
# option token ''
|
# option token ''
|
||||||
|
|
||||||
# CLI options with no value should be defined as booleans and theirs names
|
# Running as 'root' is possible, but not recommended
|
||||||
# should be prefixed with '_'.
|
# option user 'syncthing'
|
||||||
# option _debug '0'
|
|
||||||
# option _nat '0'
|
# CLI options with no value should be defined as booleans
|
||||||
# option _pprof '0'
|
# option debug '0'
|
||||||
|
# option nat '0'
|
||||||
|
# option pprof '0'
|
||||||
|
|||||||
@@ -13,39 +13,44 @@ config_cb() {
|
|||||||
option_cb() {
|
option_cb() {
|
||||||
local option="$1"
|
local option="$1"
|
||||||
local value="$2"
|
local value="$2"
|
||||||
case $option in
|
# Remove the leading underscore from the option name for backward
|
||||||
enabled|keys|pools|status_srv)
|
# compatibility
|
||||||
eval $option=$value
|
option="${option#_}"
|
||||||
;;
|
eval $option="$value"
|
||||||
_*)
|
|
||||||
[ "$value" = "0" ] || extra_args="$extra_args ${option//_/-}"
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
extra_args="$extra_args -${option//_/-}='$value'"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
list_cb() {
|
|
||||||
local name="$1"
|
|
||||||
local value="$2"
|
|
||||||
[ "$name" = "_" ] && extra_args="$extra_args -${value//_/-}" || return 0
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
service_triggers() {
|
service_triggers() {
|
||||||
procd_add_reload_trigger "strelaysrv"
|
procd_add_reload_trigger 'strelaysrv'
|
||||||
}
|
}
|
||||||
|
|
||||||
start_service() {
|
start_service() {
|
||||||
local pools status_srv extra_args
|
# Options with default value different with the syncthing should be defined
|
||||||
# Options with default value different with the syncthing should be defined explicitly here
|
# explicitly here
|
||||||
local enabled=0
|
local enabled=0
|
||||||
local keys="/etc/strelaysrv"
|
local debug=0
|
||||||
|
local ext_address=''
|
||||||
|
local global_rate=''
|
||||||
|
local keys='/etc/strelaysrv'
|
||||||
|
local listen=':22067'
|
||||||
|
local message_timeout=''
|
||||||
|
local nat=0
|
||||||
|
local nat_lease=''
|
||||||
|
local nat_renewal=''
|
||||||
|
local nat_timeout=''
|
||||||
|
local network_timeout=''
|
||||||
local nice=0
|
local nice=0
|
||||||
local user="syncthing"
|
local per_session_rate=''
|
||||||
|
local ping_interval=''
|
||||||
|
local pools=''
|
||||||
|
local pprof=0
|
||||||
|
local protocol=''
|
||||||
|
local provided_by=''
|
||||||
|
local status_srv=''
|
||||||
|
local token=''
|
||||||
|
local user='syncthing'
|
||||||
|
|
||||||
config_load "strelaysrv"
|
config_load 'strelaysrv'
|
||||||
|
|
||||||
[ "$enabled" -gt 0 ] || return 0
|
[ "$enabled" -gt 0 ] || return 0
|
||||||
|
|
||||||
@@ -58,16 +63,32 @@ start_service() {
|
|||||||
|
|
||||||
procd_open_instance
|
procd_open_instance
|
||||||
procd_set_param command "$PROG"
|
procd_set_param command "$PROG"
|
||||||
|
[ "$debug" -eq 0 ] || procd_append_param command -debug
|
||||||
|
[ -z "$ext_address" ] || procd_append_param command -ext-address="$ext_address"
|
||||||
|
[ -z "$global_rate" ] || procd_append_param command -global-rate="$global_rate"
|
||||||
procd_append_param command -keys="$keys"
|
procd_append_param command -keys="$keys"
|
||||||
|
[ -z "$listen" ] || procd_append_param command -listen="$listen"
|
||||||
# pools and status-srv are set to empty value by default
|
[ -z "$message_timeout" ] || procd_append_param command -message-timeout="$message_timeout"
|
||||||
|
[ "$nat" -eq 0 ] || procd_append_param command -nat
|
||||||
|
[ -z "$nat_lease" ] || procd_append_param command -nat-lease="$nat_lease"
|
||||||
|
[ -z "$nat_renewal" ] || procd_append_param command -nat-renewal="$nat_renewal"
|
||||||
|
[ -z "$nat_timeout" ] || procd_append_param command -nat-timeout="$nat_timeout"
|
||||||
|
[ -z "$network_timeout" ] || procd_append_param command -network-timeout="$network_timeout"
|
||||||
|
[ -z "$per_session_rate" ] || procd_append_param command -per-session-rate="$per_session_rate"
|
||||||
|
[ -z "$ping_interval" ] || procd_append_param command -ping-interval="$ping_interval"
|
||||||
|
# pools is set to an empty value by default
|
||||||
procd_append_param command -pools="$pools"
|
procd_append_param command -pools="$pools"
|
||||||
|
[ "$pprof" -eq 0 ] || procd_append_param command -pprof
|
||||||
|
[ -z "$protocol" ] || procd_append_param command -protocol="$protocol"
|
||||||
|
[ -z "$provided_by" ] || procd_append_param command -provided-by="$provided_by"
|
||||||
|
# status-srv is set to an empty value by default
|
||||||
procd_append_param command -status-srv="$status_srv"
|
procd_append_param command -status-srv="$status_srv"
|
||||||
[ -z "$extra_args" ] || procd_append_param command $extra_args
|
[ -z "$token" ] || procd_append_param command -token="$token"
|
||||||
|
|
||||||
procd_set_param nice "$nice"
|
procd_set_param nice "$nice"
|
||||||
procd_set_param term_timeout 15
|
procd_set_param term_timeout 15
|
||||||
procd_set_param user "$user"
|
procd_set_param user "$user"
|
||||||
|
procd_set_param group "$group"
|
||||||
procd_set_param respawn
|
procd_set_param respawn
|
||||||
procd_set_param stdout 1
|
procd_set_param stdout 1
|
||||||
procd_set_param stderr 1
|
procd_set_param stderr 1
|
||||||
|
|||||||
Reference in New Issue
Block a user