diff --git a/sagernet-core/Makefile b/sagernet-core/Makefile index 7195e3741..4533a7df1 100644 --- a/sagernet-core/Makefile +++ b/sagernet-core/Makefile @@ -45,6 +45,14 @@ define Package/sagernet-core CONFLICTS:=v2ray-core xray-core endef +define Package/sagernet-example + $(call Package/sagernet/template) + TITLE+= (example configs) + DEPENDS:=sagernet-core + CONFLICTS:=v2ray-example + PKGARCH:=all +endef + define Package/sagernet-extra $(call Package/sagernet/template) TITLE+= (extra resources) @@ -64,17 +72,42 @@ define Package/sagernet-core/description This is a v2ray-core fork for SagerNet. endef +define Package/sagernet-example/description + $(call Package/sagernet/description) + + This includes example configuration files for sagernet-core. +endef + define Package/sagernet-extra/description $(call Package/sagernet/description) This includes extra resources for sagernet-core. endef +define Package/sagernet-core/conffiles +/etc/config/v2ray +/etc/v2ray/ +endef + define Package/sagernet-core/install $(call GoPackage/Package/Install/Bin,$(PKG_INSTALL_DIR)) $(INSTALL_DIR) $(1)/usr/bin/ $(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/bin/main $(1)/usr/bin/v2ray $(LN) v2ray $(1)/usr/bin/xray + + $(INSTALL_DIR) $(1)/etc/v2ray/ + $(INSTALL_DATA) $(PKG_BUILD_DIR)/release/config/config.json $(1)/etc/v2ray/ + + $(INSTALL_DIR) $(1)/etc/config/ + $(INSTALL_CONF) $(CURDIR)/files/v2ray.conf $(1)/etc/config/v2ray + $(INSTALL_DIR) $(1)/etc/init.d/ + $(INSTALL_BIN) $(CURDIR)/files/v2ray.init $(1)/etc/init.d/v2ray +endef + +define Package/sagernet-example/install + $(INSTALL_DIR) $(1)/etc/v2ray/ + $(INSTALL_DATA) $(PKG_BUILD_DIR)/release/config/vpoint_socks_vmess.json $(1)/etc/v2ray/ + $(INSTALL_DATA) $(PKG_BUILD_DIR)/release/config/vpoint_vmess_freedom.json $(1)/etc/v2ray/ endef define Package/sagernet-extra/install @@ -83,4 +116,5 @@ define Package/sagernet-extra/install endef $(eval $(call BuildPackage,sagernet-core)) +$(eval $(call BuildPackage,sagernet-example)) $(eval $(call BuildPackage,sagernet-extra)) diff --git a/sagernet-core/files/v2ray.conf b/sagernet-core/files/v2ray.conf new file mode 100644 index 000000000..6df1e10fd --- /dev/null +++ b/sagernet-core/files/v2ray.conf @@ -0,0 +1,11 @@ + +config v2ray 'enabled' + option enabled '0' + +config v2ray 'config' + option confdir '/etc/v2ray' + list conffiles '/etc/v2ray/config.json' + option datadir '/usr/share/v2ray' + option format 'json' + option memconservative '1' + diff --git a/sagernet-core/files/v2ray.init b/sagernet-core/files/v2ray.init new file mode 100755 index 000000000..e43f51183 --- /dev/null +++ b/sagernet-core/files/v2ray.init @@ -0,0 +1,57 @@ +#!/bin/sh /etc/rc.common + +USE_PROCD=1 +START=99 + +CONF="v2ray" +PROG="/usr/bin/v2ray" + +start_service() { + config_load "$CONF" + + local enabled + config_get_bool enabled "enabled" "enabled" "0" + [ "$enabled" -eq "0" ] && exit 1 + + local confdir + local conffiles + local datadir + local format + + config_get confdir "config" "confdir" + config_get conffiles "config" "conffiles" + config_get datadir "config" "datadir" "/usr/share/v2ray" + config_get format "config" "format" "json" + config_get_bool memconservative "config" "memconservative" "1" + + procd_open_instance "$CONF" + procd_set_param command "$PROG" run + [ -n "$confdir" ] && procd_append_param command -confdir "$confdir" + [ -n "$conffiles" ] && { + for i in $conffiles + do + procd_append_param command -config "$i" + done + } + [ -n "$format" ] && procd_append_param command -format "$format" + procd_set_param env v2ray.local.asset="$datadir" + [ "$memconservative" -eq "1" ] && procd_append_param env V2RAY_CONF_GEOLOADER="memconservative" + procd_set_param file $conffiles + + procd_set_param limits core="unlimited" + procd_set_param limits nofile="1000000 1000000" + procd_set_param stdout 1 + procd_set_param stderr 1 + procd_set_param respawn + + procd_close_instance +} + +reload_service() { + stop + start +} + +service_triggers() { + procd_add_reload_trigger "$CONF" +}