nebula: initial commit 14548/head
authorStan Grishin <stangri@melmac.net>
Sun, 24 Jan 2021 01:37:44 +0000 (01:37 +0000)
committerStan Grishin <stangri@melmac.net>
Mon, 8 Feb 2021 16:50:43 +0000 (16:50 +0000)
Signed-off-by: Stan Grishin <stangri@melmac.net>
initial commit

net/nebula/Makefile [new file with mode: 0644]
net/nebula/files/nebula.init [new file with mode: 0755]
net/nebula/files/nebula.upgrade [new file with mode: 0644]
net/nebula/test.sh [new file with mode: 0644]

diff --git a/net/nebula/Makefile b/net/nebula/Makefile
new file mode 100644 (file)
index 0000000..a06ca1b
--- /dev/null
@@ -0,0 +1,74 @@
+# Copyright 2021 Stan Grishin (stangri@melmac.net)
+# This is free software, licensed under the MIT License.
+
+include $(TOPDIR)/rules.mk
+
+PKG_NAME:=nebula
+PKG_VERSION:=1.3.0
+PKG_RELEASE:=1
+PKG_MAINTAINER:=Stan Grishin <stangri@melmac.net>
+
+PKG_SOURCE:=v$(PKG_VERSION).tar.gz
+PKG_SOURCE_URL:=https://github.com/slackhq/nebula/archive/
+PKG_HASH:=b94fba0251a4a436e25b127d0b9bc0181b991631f1dc8e344b1c8e895b55375d
+PKG_LICENSE:=MIT
+PKG_LICENSE_FILES:=LICENSE
+
+PKG_BUILD_DEPENDS:=golang/host
+PKG_BUILD_PARALLEL:=1
+PKG_USE_MIPS16:=0
+GO_PKG:=github.com/slackhq/nebula
+GO_PKG_LDFLAGS_X:=main.Build=$(PKG_VERSION)
+
+include $(INCLUDE_DIR)/package.mk
+include ../../lang/golang/golang-package.mk
+
+define Package/nebula
+  SECTION:=net
+  CATEGORY:=Network
+  TITLE:=nebula
+  URL:=https://github.com/slackhq/nebula
+  DEPENDS:=$(GO_ARCH_DEPENDS) +kmod-tun
+endef
+
+define Package/nebula-cert
+  SECTION:=net
+  CATEGORY:=Network
+  TITLE:=nebula-cert
+  URL:=https://github.com/slackhq/nebula
+  DEPENDS:=$(GO_ARCH_DEPENDS)
+endef
+
+define Package/nebula/description
+  Nebula is a scalable overlay networking tool with a focus on performance, simplicity
+  and security. It lets you seamlessly connect computers anywhere in the world.
+endef
+
+define Package/nebula-cert/description
+$(call Package/nebula/description)
+  This package contains only nebula-cert binary.
+endef
+
+define Package/nebula/install
+       $(call GoPackage/Package/Install/Bin,$(PKG_INSTALL_DIR))
+       $(INSTALL_DIR) $(1)/etc/init.d $(1)/usr/sbin $(1)/usr/share/doc/nebula $(1)/lib/upgrade/keep.d 
+       $(INSTALL_BIN) ./files/nebula.init $(1)/etc/init.d/nebula
+       $(SED) "s|^\(PKG_VERSION\).*|\1='$(PKG_VERSION)-$(PKG_RELEASE)'|" $(1)/etc/init.d/nebula
+       $(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/bin/nebula $(1)/usr/sbin/nebula
+       $(INSTALL_DATA) $(PKG_BUILD_DIR)/LICENSE $(1)/usr/share/doc/nebula/LICENSE
+       $(INSTALL_DATA) ./files/nebula.upgrade $(1)/lib/upgrade/keep.d/nebula
+endef
+
+define Package/nebula-cert/install
+       $(call GoPackage/Package/Install/Bin,$(PKG_INSTALL_DIR))
+       $(INSTALL_DIR) $(1)/usr/sbin $(1)/usr/share/doc/nebula-cert $(1)/lib/upgrade/keep.d
+       $(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/bin/nebula-cert $(1)/usr/sbin/nebula-cert
+       $(INSTALL_DATA) $(PKG_BUILD_DIR)/LICENSE $(1)/usr/share/doc/nebula-cert/LICENSE
+       $(INSTALL_DATA) ./files/nebula.upgrade $(1)/lib/upgrade/keep.d/nebula-cert
+endef
+
+$(eval $(call GoBinPackage,nebula))
+$(eval $(call BuildPackage,nebula))
+
+$(eval $(call GoBinPackage,nebula-cert))
+$(eval $(call BuildPackage,nebula-cert))
diff --git a/net/nebula/files/nebula.init b/net/nebula/files/nebula.init
new file mode 100755 (executable)
index 0000000..d594a4e
--- /dev/null
@@ -0,0 +1,53 @@
+#!/bin/sh /etc/rc.common
+# Copyright 2021 Stan Grishin (stangri@melmac.net)
+# shellcheck disable=SC2039
+PKG_VERSION='dev-test'
+
+# shellcheck disable=SC2034
+START=80
+# shellcheck disable=SC2034
+USE_PROCD=1
+
+if type extra_command 1>/dev/null 2>&1; then
+       extra_command 'version' 'Show version information'
+else
+# shellcheck disable=SC2034
+       EXTRA_COMMANDS='version'
+fi
+
+readonly PROG=/usr/sbin/nebula
+
+version() { echo "Version: $PKG_VERSION"; }
+
+start_instance() {
+       local cfg="$1" port name="${1##*/}"
+       port="$(grep -A2 "^listen:" "$cfg" | grep "port: " | awk '{print $2}')"
+       procd_open_instance
+       procd_set_param command ${PROG} -config "${cfg}"
+       procd_set_param stderr 1
+       procd_set_param stdout 1
+       procd_set_param respawn
+       procd_open_data
+       json_add_array firewall
+               json_add_object ''
+               json_add_string type 'rule'
+               json_add_string name "Allow-$name"
+               json_add_string src 'wan'
+               json_add_string dest_port "$port"
+               json_add_string proto 'udp'
+               json_add_string target 'ACCEPT'
+               json_close_object
+       json_close_array
+       procd_close_data
+       procd_close_instance
+}
+
+start_service() {
+       local f
+       for f in /etc/nebula/*.yml; do
+               [ -s "$f" ] && start_instance "$f"
+       done
+}
+
+service_started() { procd_set_config_changed firewall; }
+service_stopped() { procd_set_config_changed firewall; }
diff --git a/net/nebula/files/nebula.upgrade b/net/nebula/files/nebula.upgrade
new file mode 100644 (file)
index 0000000..0614c3c
--- /dev/null
@@ -0,0 +1 @@
+/etc/nebula/
diff --git a/net/nebula/test.sh b/net/nebula/test.sh
new file mode 100644 (file)
index 0000000..847e507
--- /dev/null
@@ -0,0 +1,4 @@
+#!/bin/sh
+# shellcheck disable=SC2039
+
+"/usr/sbin/${1//-full}" -version 2>&1 | grep "$2"