From: Moritz Warning Date: Sun, 9 Sep 2018 09:32:38 +0000 (+0200) Subject: zerotier: fix multiple instance handling and port setting X-Git-Url: http://git.lede-project.org./?a=commitdiff_plain;h=df8328b3b63e11af7d02a1a4b17f344e70c341ae;p=feed%2Fpackages.git zerotier: fix multiple instance handling and port setting Signed-off-by: Moritz Warning --- diff --git a/net/zerotier/Makefile b/net/zerotier/Makefile index 816b181839..c5725aad98 100644 --- a/net/zerotier/Makefile +++ b/net/zerotier/Makefile @@ -7,7 +7,7 @@ include $(TOPDIR)/rules.mk PKG_NAME:=zerotier PKG_VERSION:=1.2.12 -PKG_RELEASE:=1 +PKG_RELEASE:=2 PKG_LICENSE:=GPL-3.0 @@ -66,10 +66,7 @@ ifeq ($(CONFIG_ZEROTIER_ENABLE_SELFTEST),y) $(INSTALL_BIN) $(PKG_BUILD_DIR)/zerotier-selftest $(1)/usr/bin/ endif - $(INSTALL_DIR) $(1)/etc/init.d/ - $(INSTALL_BIN) files/zerotier.init $(1)/etc/init.d/zerotier - $(INSTALL_DIR) $(1)/etc/config - $(INSTALL_CONF) files/zerotier.config $(1)/etc/config/zerotier + $(CP) ./files/* $(1)/ endef $(eval $(call BuildPackage,zerotier)) diff --git a/net/zerotier/files/etc/config/zerotier b/net/zerotier/files/etc/config/zerotier new file mode 100644 index 0000000000..1a016ebcfb --- /dev/null +++ b/net/zerotier/files/etc/config/zerotier @@ -0,0 +1,15 @@ + +config zerotier sample_config + option enabled 0 + + # persistent configuration folder (for ZT controller mode) + #option config_path '/etc/zerotier' + + #option port '9993' + + # Generate secret on first start + option secret '' + + # Join a public network called Earth + list join '8056c2e21c000001' + #list join '' diff --git a/net/zerotier/files/etc/init.d/zerotier b/net/zerotier/files/etc/init.d/zerotier new file mode 100755 index 0000000000..ba6b427fa7 --- /dev/null +++ b/net/zerotier/files/etc/init.d/zerotier @@ -0,0 +1,103 @@ +#!/bin/sh /etc/rc.common + +START=90 + +USE_PROCD=1 + +PROG=/usr/bin/zerotier-one +CONFIG_PATH=/var/lib/zerotier-one + +section_enabled() { + config_get_bool enabled "$1" 'enabled' 0 + [ $enabled -ne 0 ] +} + +start_instance() { + local cfg="$1" + local port secret config_path path + local args="" + + if ! section_enabled "$cfg"; then + echo "disabled in config" + return 1 + fi + + config_get config_path $cfg 'config_path' + config_get port $cfg 'port' + config_get secret $cfg 'secret' + + path=${CONFIG_PATH}_$cfg + + # Remove existing link or folder + rm -rf $path + + # Create link from CONFIG_PATH to config_path + if [ -n "$config_path" -a "$config_path" != "$path" ]; then + if [ ! -d "$config_path" ]; then + echo "ZeroTier config_path does not exist: $config_path" 1>&2 + return + fi + + ln -s $config_path $path + fi + + mkdir -p $path/networks.d + + # link latest default config path to latest config path + rm -f $CONFIG_PATH + ln -s $path $CONFIG_PATH + + if [ -n "$port" ]; then + args="$args -p${port}" + fi + + if [ -z "$secret" ]; then + echo "Generate secret - please wait..." + local sf="/tmp/zt.$cfg.secret" + + zerotier-idtool generate "$sf" > /dev/null + [ $? -ne 0 ] && return 1 + + secret="$(cat $sf)" + rm "$sf" + + uci set zerotier.$cfg.secret="$secret" + uci commit zerotier + fi + + if [ -n "$secret" ]; then + echo "$secret" > $path/identity.secret + # make sure there is not previous identity.public + rm -f $path/identity.public + fi + + add_join() { + # an (empty) config file will cause ZT to join a network + touch $path/networks.d/$1.conf + } + + config_list_foreach $cfg 'join' add_join + + procd_open_instance + procd_set_param command $PROG $args $path + procd_set_param stderr 1 + procd_close_instance +} + +start_service() { + config_load 'zerotier' + config_foreach start_instance 'zerotier' +} + +stop_instance() { + local cfg="$1" + + # Remove existing link or folder + rm -rf ${CONFIG_PATH}_${cfg} +} + +stop_service() { + config_load 'zerotier' + config_foreach stop_instance 'zerotier' + rm -f ${CONFIG_PATH} +} diff --git a/net/zerotier/files/zerotier.config b/net/zerotier/files/zerotier.config deleted file mode 100644 index b62e15532d..0000000000 --- a/net/zerotier/files/zerotier.config +++ /dev/null @@ -1,14 +0,0 @@ - -config zerotier sample_config - option enabled 0 - - # persistent configuration folder (for ZT controller mode) - #option config_path '/etc/zerotier' - - #option port '9993' - - # Generate secret on first start - option secret 'generate' - - # Join a public network called Earth - list join '8056c2e21c000001' diff --git a/net/zerotier/files/zerotier.init b/net/zerotier/files/zerotier.init deleted file mode 100644 index 390dbd3127..0000000000 --- a/net/zerotier/files/zerotier.init +++ /dev/null @@ -1,96 +0,0 @@ -#!/bin/sh /etc/rc.common - -START=90 - -USE_PROCD=1 - -PROG=/usr/bin/zerotier-one -CONFIG_PATH=/var/lib/zerotier-one - -section_enabled() { - config_get_bool enabled "$1" 'enabled' 0 - [ $enabled -gt 0 ] -} - -start_instance() { - local cfg="$1" - local port secret config_path - local ARGS="" - - if ! section_enabled "$cfg"; then - echo "disabled in config" - return 1 - fi - - config_get config_path $cfg 'config_path' - config_get_bool port $cfg 'port' - config_get secret $cfg 'secret' - - # Remove existing link or folder - rm -rf $CONFIG_PATH - - # Create link from CONFIG_PATH to config_path - if [ -n "$config_path" -a "$config_path" != $CONFIG_PATH ]; then - if [ ! -d "$config_path" ]; then - echo "ZeroTier config_path does not exist: $config_path" - return - fi - - ln -s $config_path $CONFIG_PATH - fi - - mkdir -p $CONFIG_PATH/networks.d - - if [ -n "$port" ]; then - ARGS="$ARGS -p$port" - fi - - if [ "$secret" = "generate" ]; then - echo "Generate secret - please wait..." - local sf="/tmp/zt.$cfg.secret" - - zerotier-idtool generate "$sf" > /dev/null - [ $? -ne 0 ] && return 1 - - secret="$(cat $sf)" - rm "$sf" - - uci set zerotier.$cfg.secret="$secret" - uci commit zerotier - fi - - if [ -n "$secret" ]; then - echo "$secret" > $CONFIG_PATH/identity.secret - # make sure there is not previous identity.public - rm -f $CONFIG_PATH/identity.public - fi - - add_join() { - # an (empty) config file will cause ZT to join a network - touch $CONFIG_PATH/networks.d/$1.conf - } - - config_list_foreach $cfg 'join' add_join - - procd_open_instance - procd_set_param command $PROG $ARGS $CONFIG_PATH - procd_set_param stderr 1 - procd_close_instance -} - -start_service() { - config_load 'zerotier' - config_foreach start_instance 'zerotier' -} - -stop_instance() { - local cfg="$1" - - # Remove existing link or folder - rm -rf $CONFIG_PATH -} - -stop_service() { - config_load 'zerotier' - config_foreach stop_instance 'zerotier' -}