Sync 2024-08-15 16:27

This commit is contained in:
github-actions[bot] 2024-08-15 16:27:49 +08:00
parent ca6b1edbb5
commit 2e031d9d7d
12 changed files with 120 additions and 124 deletions

View File

@ -10,7 +10,7 @@ PKG_NAME:=luci-app-cloudflarespeedtest
LUCI_TITLE:=LuCI support for Cloudflares Speed Test LUCI_TITLE:=LuCI support for Cloudflares Speed Test
LUCI_DEPENDS:=+cdnspeedtest +openssl-util +curl LUCI_DEPENDS:=+cdnspeedtest +openssl-util +curl
LUCI_PKGARCH:=all LUCI_PKGARCH:=all
PKG_VERSION:=1.5.3 PKG_VERSION:=1.5.4
PKG_RELEASE:=0 PKG_RELEASE:=0
PKG_LICENSE:=AGPL-3.0 PKG_LICENSE:=AGPL-3.0
PKG_MAINTAINER:=mingxiaoyu <fengying0347@163.com> PKG_MAINTAINER:=mingxiaoyu <fengying0347@163.com>

View File

@ -24,7 +24,7 @@ o.rmempty=false
o=s:option(Value,"speed",translate("Broadband speed")) o=s:option(Value,"speed",translate("Broadband speed"))
o.description =translate("100M broadband download speed is about 12M/s. It is not recommended to fill in an excessively large value, and it may run all the time."); o.description =translate("100M broadband download speed is about 12M/s. It is not recommended to fill in an excessively large value, and it may run all the time.");
o.datatype ="uinteger" o.datatype ="uinteger"
o.rmempty=false o.rmempty=false
o=s:option(Value,"custome_url",translate("Custome Url")) o=s:option(Value,"custome_url",translate("Custome Url"))
@ -59,46 +59,46 @@ o.default = 0
o.rmempty=false o.rmempty=false
o = s:option(Value, "threads", translate("Thread")) o = s:option(Value, "threads", translate("Thread"))
o.datatype ="uinteger" o.datatype ="uinteger"
o.default = 200 o.default = 200
o.rmempty=true o.rmempty=true
o:depends("advanced", 1) o:depends("advanced", 1)
o = s:option(Value, "tl", translate("Average Latency Cap")) o = s:option(Value, "tl", translate("Average Latency Cap"))
o.datatype ="uinteger" o.datatype ="uinteger"
o.default = 200 o.default = 200
o.rmempty=true o.rmempty=true
o:depends("advanced", 1) o:depends("advanced", 1)
o = s:option(Value, "tll", translate("Average Latency Lower Bound")) o = s:option(Value, "tll", translate("Average Latency Lower Bound"))
o.datatype ="uinteger" o.datatype ="uinteger"
o.default = 40 o.default = 40
o.rmempty=true o.rmempty=true
o:depends("advanced", 1) o:depends("advanced", 1)
o = s:option(Value, "t", translate("Delayed speed measurement time")) o = s:option(Value, "t", translate("Delayed speed measurement time"))
o.datatype ="uinteger" o.datatype ="uinteger"
o.default = 4 o.default = 4
o.rmempty=true o.rmempty=true
o:depends("advanced", 1) o:depends("advanced", 1)
o = s:option(Value, "dt", translate("Download speed test time")) o = s:option(Value, "dt", translate("Download speed test time"))
o.datatype ="uinteger" o.datatype ="uinteger"
o.default = 10 o.default = 10
o.rmempty=true o.rmempty=true
o:depends("advanced", 1) o:depends("advanced", 1)
o = s:option(Value, "dn", translate("Number of download speed tests")) o = s:option(Value, "dn", translate("Number of download speed tests"))
o.datatype ="uinteger" o.datatype ="uinteger"
o.default = 1 o.default = 1
o.rmempty=true o.rmempty=true
o:depends("advanced", 1) o:depends("advanced", 1)
o = s:option(Flag, "dd", translate("Disable download speed test")) o = s:option(Flag, "dd", translate("Disable download speed test"))
o.default = 0 o.default = 0
o.rmempty=true o.rmempty=true
o:depends("advanced", 1) o:depends("advanced", 1)
o = s:option(Value, "tp", translate("Port")) o = s:option(Value, "tp", translate("Port"))
o.rmempty=true o.rmempty=true
o.default = 443 o.default = 443
@ -112,10 +112,10 @@ o.template = "cloudflarespeedtest/actions"
s = m:section(NamedSection, "servers", "section", translate("Third party applications settings")) s = m:section(NamedSection, "servers", "section", translate("Third party applications settings"))
if nixio.fs.access("/etc/config/shadowsocksr") then if nixio.fs.access("/etc/config/shadowsocksr") then
s:tab("ssr", translate("Shadowsocksr Plus+")) s:tab("ssr", translate("Shadowsocksr Plus+"))
o=s:taboption("ssr", Flag, "ssr_enabled",translate("Shadowsocksr Plus+ Enabled")) o=s:taboption("ssr", Flag, "ssr_enabled",translate("Shadowsocksr Plus+ Enabled"))
o.rmempty=true o.rmempty=true
local ssr_server_table = {} local ssr_server_table = {}
uci:foreach("shadowsocksr", "servers", function(s) uci:foreach("shadowsocksr", "servers", function(s)
@ -136,7 +136,7 @@ if nixio.fs.access("/etc/config/shadowsocksr") then
o = s:taboption("ssr", DynamicList, "ssr_services", o = s:taboption("ssr", DynamicList, "ssr_services",
translate("Shadowsocksr Servers"), translate("Shadowsocksr Servers"),
translate("Please select a service")) translate("Please select a service"))
for _, key in pairs(ssr_key_table) do for _, key in pairs(ssr_key_table) do
o:value(key, ssr_server_table[key]) o:value(key, ssr_server_table[key])
end end
@ -150,7 +150,7 @@ if nixio.fs.access("/etc/config/passwall") then
s:tab("passwalltab", translate("passwall")) s:tab("passwalltab", translate("passwall"))
o=s:taboption("passwalltab", Flag, "passwall_enabled",translate("Passwall Enabled")) o=s:taboption("passwalltab", Flag, "passwall_enabled",translate("Passwall Enabled"))
o.rmempty=true o.rmempty=true
local passwall_server_table = {} local passwall_server_table = {}
uci:foreach("passwall", "nodes", function(s) uci:foreach("passwall", "nodes", function(s)
@ -169,7 +169,7 @@ if nixio.fs.access("/etc/config/passwall") then
o = s:taboption("passwalltab", DynamicList, "passwall_services", o = s:taboption("passwalltab", DynamicList, "passwall_services",
translate("Passwall Servers"), translate("Passwall Servers"),
translate("Please select a service")) translate("Please select a service"))
for _, key in pairs(passwall_key_table) do for _, key in pairs(passwall_key_table) do
o:value(key, passwall_server_table[key]) o:value(key, passwall_server_table[key])
end end
@ -182,7 +182,7 @@ if nixio.fs.access("/etc/config/passwall2") then
s:tab("passwall2tab", translate("passwall2")) s:tab("passwall2tab", translate("passwall2"))
o=s:taboption("passwall2tab", Flag, "passwall2_enabled",translate("PassWall2 Enabled")) o=s:taboption("passwall2tab", Flag, "passwall2_enabled",translate("PassWall2 Enabled"))
o.rmempty=true o.rmempty=true
local passwall2_server_table = {} local passwall2_server_table = {}
uci:foreach("passwall2", "nodes", function(s) uci:foreach("passwall2", "nodes", function(s)
@ -201,7 +201,7 @@ if nixio.fs.access("/etc/config/passwall2") then
o = s:taboption("passwall2tab", DynamicList, "passwall2_services", o = s:taboption("passwall2tab", DynamicList, "passwall2_services",
translate("Passwall2 Servers"), translate("Passwall2 Servers"),
translate("Please select a service")) translate("Please select a service"))
for _, key in pairs(passwall2_key_table) do for _, key in pairs(passwall2_key_table) do
o:value(key, passwall2_server_table[key]) o:value(key, passwall2_server_table[key])
end end
@ -212,9 +212,9 @@ end
s:tab("bypasstab", translate("Bypass")) s:tab("bypasstab", translate("Bypass"))
if nixio.fs.access("/etc/config/bypass") then if nixio.fs.access("/etc/config/bypass") then
o=s:taboption("bypasstab", Flag, "bypass_enabled",translate("Bypass Enabled")) o=s:taboption("bypasstab", Flag, "bypass_enabled",translate("Bypass Enabled"))
o.rmempty=true o.rmempty=true
local bypass_server_table = {} local bypass_server_table = {}
uci:foreach("bypass", "servers", function(s) uci:foreach("bypass", "servers", function(s)
@ -235,7 +235,7 @@ if nixio.fs.access("/etc/config/bypass") then
o = s:taboption("bypasstab", DynamicList, "bypass_services", o = s:taboption("bypasstab", DynamicList, "bypass_services",
translate("Bypass Servers"), translate("Bypass Servers"),
translate("Please select a service")) translate("Please select a service"))
for _, key in pairs(bypass_key_table) do for _, key in pairs(bypass_key_table) do
o:value(key, bypass_server_table[key]) o:value(key, bypass_server_table[key])
end end
@ -246,9 +246,9 @@ end
s:tab("vssrtab", translate("Vssr")) s:tab("vssrtab", translate("Vssr"))
if nixio.fs.access("/etc/config/vssr") then if nixio.fs.access("/etc/config/vssr") then
o=s:taboption("vssrtab", Flag, "vssr_enabled",translate("Vssr Enabled")) o=s:taboption("vssrtab", Flag, "vssr_enabled",translate("Vssr Enabled"))
o.rmempty=true o.rmempty=true
local vssr_server_table = {} local vssr_server_table = {}
uci:foreach("vssr", "servers", function(s) uci:foreach("vssr", "servers", function(s)
@ -269,7 +269,7 @@ if nixio.fs.access("/etc/config/vssr") then
o = s:taboption("vssrtab", DynamicList, "vssr_services", o = s:taboption("vssrtab", DynamicList, "vssr_services",
translate("Vssr Servers"), translate("Vssr Servers"),
translate("Please select a service")) translate("Please select a service"))
for _, key in pairs(vssr_key_table) do for _, key in pairs(vssr_key_table) do
o:value(key, vssr_server_table[key]) o:value(key, vssr_server_table[key])
end end
@ -314,6 +314,11 @@ o=s:taboption("dnshost", Value,"host_domain",translate("Domain"))
o.rmempty=true o.rmempty=true
o:depends("HOST_enabled", 1) o:depends("HOST_enabled", 1)
s:tab("mosdns", translate("MosDNS"))
o=s:taboption("mosdns", Flag, "MosDNS_enabled",translate("MosDNS Enabled"))
o=s:taboption("mosdns", Flag, "openclash_restart",translate("OpenClash Restart"))
o:depends("MosDNS_enabled", 1)
e=m:section(TypedSection,"global",translate("Best IP")) e=m:section(TypedSection,"global",translate("Best IP"))
e.anonymous=true e.anonymous=true
local a="/usr/share/cloudflarespeedtestresult.txt" local a="/usr/share/cloudflarespeedtestresult.txt"

View File

@ -114,7 +114,7 @@ msgstr "启用IPv6"
msgid "Delayed speed measurement time" msgid "Delayed speed measurement time"
msgstr "延迟测速次数" msgstr "延迟测速次数"
msgid "Download speed test time" msgid "Download speed test time"
msgstr "下载测速时间" msgstr "下载测速时间"
@ -136,7 +136,7 @@ msgstr "IPv4和IPv6只能选一个"
msgid "<a href=\"https://github.com/XIU2/CloudflareSpeedTest/issues/168\" target=\"_blank\">How to create</a>" msgid "<a href=\"https://github.com/XIU2/CloudflareSpeedTest/issues/168\" target=\"_blank\">How to create</a>"
msgstr "<a href=\"https://github.com/XIU2/CloudflareSpeedTest/issues/168\" target=\"_blank\">如何创建</a>" msgstr "<a href=\"https://github.com/XIU2/CloudflareSpeedTest/issues/168\" target=\"_blank\">如何创建</a>"
msgid "RUNNING" msgid "RUNNING"
msgstr "运行中" msgstr "运行中"
msgid "NOT RUNNING" msgid "NOT RUNNING"
@ -219,3 +219,9 @@ msgstr "启用HOST"
msgid "Domain" msgid "Domain"
msgstr "域名" msgstr "域名"
msgid "MosDNS Enabled"
msgstr "写入 MosDNS"
msgid "OpenClash Restart"
msgstr "重启 OpenClash"

View File

@ -114,7 +114,7 @@ msgstr "启用IPv6"
msgid "Delayed speed measurement time" msgid "Delayed speed measurement time"
msgstr "延迟测速次数" msgstr "延迟测速次数"
msgid "Download speed test time" msgid "Download speed test time"
msgstr "下载测速时间" msgstr "下载测速时间"
@ -136,7 +136,7 @@ msgstr "IPv4和IPv6只能选一个"
msgid "<a href=\"https://github.com/XIU2/CloudflareSpeedTest/issues/168\" target=\"_blank\">How to create</a>" msgid "<a href=\"https://github.com/XIU2/CloudflareSpeedTest/issues/168\" target=\"_blank\">How to create</a>"
msgstr "<a href=\"https://github.com/XIU2/CloudflareSpeedTest/issues/168\" target=\"_blank\">如何创建</a>" msgstr "<a href=\"https://github.com/XIU2/CloudflareSpeedTest/issues/168\" target=\"_blank\">如何创建</a>"
msgid "RUNNING" msgid "RUNNING"
msgstr "运行中" msgstr "运行中"
msgid "NOT RUNNING" msgid "NOT RUNNING"
@ -219,3 +219,9 @@ msgstr "启用HOST"
msgid "Domain" msgid "Domain"
msgstr "域名" msgstr "域名"
msgid "MosDNS Enabled"
msgstr "写入 MosDNS"
msgid "OpenClash Restart"
msgstr "重启 OpenClash"

View File

@ -27,7 +27,7 @@ echolog() {
function read_config(){ function read_config(){
get_global_config "enabled" "speed" "custome_url" "threads" "custome_cors_enabled" "custome_cron" "t" "tp" "dt" "dn" "dd" "tl" "tll" "ipv6_enabled" "advanced" "proxy_mode" get_global_config "enabled" "speed" "custome_url" "threads" "custome_cors_enabled" "custome_cron" "t" "tp" "dt" "dn" "dd" "tl" "tll" "ipv6_enabled" "advanced" "proxy_mode"
get_servers_config "ssr_services" "ssr_enabled" "passwall_enabled" "passwall_services" "passwall2_enabled" "passwall2_services" "bypass_enabled" "bypass_services" "vssr_enabled" "vssr_services" "DNS_enabled" "HOST_enabled" get_servers_config "ssr_services" "ssr_enabled" "passwall_enabled" "passwall_services" "passwall2_enabled" "passwall2_services" "bypass_enabled" "bypass_services" "vssr_enabled" "vssr_services" "DNS_enabled" "HOST_enabled" "MosDNS_enabled" "openclash_restart"
} }
function appinit(){ function appinit(){
@ -39,17 +39,17 @@ function appinit(){
} }
function speed_test(){ function speed_test(){
rm -rf $LOG_FILE rm -rf $LOG_FILE
command="/usr/bin/cdnspeedtest -sl $((speed*125/1000)) -url ${custome_url} -o ${IP_FILE}" command="/usr/bin/cdnspeedtest -sl $((speed*125/1000)) -url ${custome_url} -o ${IP_FILE}"
if [ $ipv6_enabled -eq "1" ] ;then if [ $ipv6_enabled -eq "1" ] ;then
command="${command} -f ${IPV6_TXT}" command="${command} -f ${IPV6_TXT}"
else else
command="${command} -f ${IPV4_TXT}" command="${command} -f ${IPV4_TXT}"
fi fi
if [ $advanced -eq "1" ] ; then if [ $advanced -eq "1" ] ; then
command="${command} -tl ${tl} -tll ${tll} -n ${threads} -t ${t} -dt ${dt} -dn ${dn}" command="${command} -tl ${tl} -tll ${tll} -n ${threads} -t ${t} -dt ${dt} -dn ${dn}"
if [ $dd -eq "1" ] ; then if [ $dd -eq "1" ] ; then
@ -61,9 +61,9 @@ function speed_test(){
else else
command="${command} -tl 200 -tll 40 -n 200 -t 4 -dt 10 -dn 1" command="${command} -tl 200 -tll 40 -n 200 -t 4 -dt 10 -dn 1"
fi fi
appinit appinit
ssr_original_server=$(uci get shadowsocksr.@global[0].global_server 2>/dev/null) ssr_original_server=$(uci get shadowsocksr.@global[0].global_server 2>/dev/null)
ssr_original_run_mode=$(uci get shadowsocksr.@global[0].run_mode 2>/dev/null) ssr_original_run_mode=$(uci get shadowsocksr.@global[0].run_mode 2>/dev/null)
if [ "x${ssr_original_server}" != "xnil" ] && [ "x${ssr_original_server}" != "x" ] ;then if [ "x${ssr_original_server}" != "xnil" ] && [ "x${ssr_original_server}" != "x" ] ;then
@ -76,7 +76,7 @@ function speed_test(){
uci commit shadowsocksr uci commit shadowsocksr
/etc/init.d/shadowsocksr restart /etc/init.d/shadowsocksr restart
fi fi
passwall_server_enabled=$(uci get passwall.@global[0].enabled 2>/dev/null) passwall_server_enabled=$(uci get passwall.@global[0].enabled 2>/dev/null)
passwall_original_run_mode=$(uci get passwall.@global[0].tcp_proxy_mode 2>/dev/null) passwall_original_run_mode=$(uci get passwall.@global[0].tcp_proxy_mode 2>/dev/null)
if [ "x${passwall_server_enabled}" == "x1" ] ;then if [ "x${passwall_server_enabled}" == "x1" ] ;then
@ -89,7 +89,7 @@ function speed_test(){
uci commit passwall uci commit passwall
/etc/init.d/passwall restart 2>/dev/null /etc/init.d/passwall restart 2>/dev/null
fi fi
passwall2_server_enabled=$(uci get passwall2.@global[0].enabled 2>/dev/null) passwall2_server_enabled=$(uci get passwall2.@global[0].enabled 2>/dev/null)
passwall2_original_run_mode=$(uci get passwall2.@global[0].tcp_proxy_mode 2>/dev/null) passwall2_original_run_mode=$(uci get passwall2.@global[0].tcp_proxy_mode 2>/dev/null)
if [ "x${passwall2_server_enabled}" == "x1" ] ;then if [ "x${passwall2_server_enabled}" == "x1" ] ;then
@ -102,11 +102,11 @@ function speed_test(){
uci commit passwall2 uci commit passwall2
/etc/init.d/passwall2 restart 2>/dev/null /etc/init.d/passwall2 restart 2>/dev/null
fi fi
vssr_original_server=$(uci get vssr.@global[0].global_server 2>/dev/null) vssr_original_server=$(uci get vssr.@global[0].global_server 2>/dev/null)
vssr_original_run_mode=$(uci get vssr.@global[0].run_mode 2>/dev/null) vssr_original_run_mode=$(uci get vssr.@global[0].run_mode 2>/dev/null)
if [ "x${vssr_original_server}" != "xnil" ] && [ "x${vssr_original_server}" != "x" ] ;then if [ "x${vssr_original_server}" != "xnil" ] && [ "x${vssr_original_server}" != "x" ] ;then
if [ $proxy_mode == "close" ] ;then if [ $proxy_mode == "close" ] ;then
uci set vssr.@global[0].global_server="nil" uci set vssr.@global[0].global_server="nil"
elif [ $proxy_mode == "gfw" ] ;then elif [ $proxy_mode == "gfw" ] ;then
@ -116,7 +116,7 @@ function speed_test(){
uci commit vssr uci commit vssr
/etc/init.d/vssr restart /etc/init.d/vssr restart
fi fi
bypass_original_server=$(uci get bypass.@global[0].global_server 2>/dev/null) bypass_original_server=$(uci get bypass.@global[0].global_server 2>/dev/null)
bypass_original_run_mode=$(uci get bypass.@global[0].run_mode 2>/dev/null) bypass_original_run_mode=$(uci get bypass.@global[0].run_mode 2>/dev/null)
if [ "x${bypass_original_server}" != "x" ] ;then if [ "x${bypass_original_server}" != "x" ] ;then
@ -129,7 +129,20 @@ function speed_test(){
uci commit bypass uci commit bypass
/etc/init.d/bypass restart /etc/init.d/bypass restart
fi fi
if [ "x${MosDNS_enabled}" == "x1" ] ;then
if [ -n "$(grep 'option cloudflare' /etc/config/mosdns)" ]
then
sed -i".bak" "/option cloudflare/d" /etc/config/mosdns
fi
sed -i '/^$/d' /etc/config/mosdns && echo -e "\toption cloudflare '0'" >> /etc/config/mosdns
/etc/init.d/mosdns restart &>/dev/null
if [ "x${openclash_restart}" == "x1" ] ;then
/etc/init.d/openclash restart &>/dev/null
fi
fi
echo $command >> $LOG_FILE 2>&1 echo $command >> $LOG_FILE 2>&1
echolog "-----------start----------" echolog "-----------start----------"
$command >> $LOG_FILE 2>&1 $command >> $LOG_FILE 2>&1
@ -137,13 +150,14 @@ function speed_test(){
} }
function ip_replace(){ function ip_replace(){
# 获取最快 IP从 result.csv 结果文件中获取第一个 IP # 获取最快 IP从 result.csv 结果文件中获取第一个 IP
bestip=$(sed -n "2,1p" $IP_FILE | awk -F, '{print $1}') bestip=$(sed -n "2,1p" $IP_FILE | awk -F, '{print $1}')
if [[ -z "${bestip}" ]]; then if [[ -z "${bestip}" ]]; then
echolog "CloudflareST 测速结果 IP 数量为 0,跳过下面步骤..." echolog "CloudflareST 测速结果 IP 数量为 0,跳过下面步骤..."
else else
host_ip host_ip
mosdns_ip
alidns_ip alidns_ip
ssr_best_ip ssr_best_ip
vssr_best_ip vssr_best_ip
@ -151,7 +165,7 @@ function ip_replace(){
passwall_best_ip passwall_best_ip
passwall2_best_ip passwall2_best_ip
restart_app restart_app
fi fi
} }
@ -174,6 +188,26 @@ function host_ip() {
fi fi
} }
function mosdns_ip() {
if [ "x${MosDNS_enabled}" == "x1" ] ;then
if [ -n "$(grep 'option cloudflare' /etc/config/mosdns)" ]
then
sed -i".bak" "/option cloudflare/d" /etc/config/mosdns
fi
if [ -n "$(grep 'list cloudflare_ip' /etc/config/mosdns)" ]
then
sed -i".bak" "/list cloudflare_ip/d" /etc/config/mosdns
fi
sed -i '/^$/d' /etc/config/mosdns && echo -e "\toption cloudflare '1'\n\tlist cloudflare_ip '$bestip'" >> /etc/config/mosdns
/etc/init.d/mosdns restart &>/dev/null
if [ "x${openclash_restart}" == "x1" ] ;then
/etc/init.d/openclash restart &>/dev/null
fi
echolog "MosDNS 写入完成"
fi
}
function passwall_best_ip(){ function passwall_best_ip(){
if [ "x${passwall_enabled}" == "x1" ] ;then if [ "x${passwall_enabled}" == "x1" ] ;then
echolog "设置passwall IP" echolog "设置passwall IP"
@ -246,7 +280,7 @@ function restart_app(){
/etc/init.d/shadowsocksr restart &>/dev/null /etc/init.d/shadowsocksr restart &>/dev/null
echolog "ssr重启完成" echolog "ssr重启完成"
fi fi
if [ "x${passwall_started}" == "x1" ] ;then if [ "x${passwall_started}" == "x1" ] ;then
if [ $proxy_mode == "close" ] ;then if [ $proxy_mode == "close" ] ;then
uci set passwall.@global[0].enabled="${passwall_server_enabled}" uci set passwall.@global[0].enabled="${passwall_server_enabled}"
@ -257,7 +291,7 @@ function restart_app(){
/etc/init.d/passwall restart 2>/dev/null /etc/init.d/passwall restart 2>/dev/null
echolog "passwall重启完成" echolog "passwall重启完成"
fi fi
if [ "x${passwall2_started}" == "x1" ] ;then if [ "x${passwall2_started}" == "x1" ] ;then
if [ $proxy_mode == "close" ] ;then if [ $proxy_mode == "close" ] ;then
uci set passwall2.@global[0].enabled="${passwall2_server_enabled}" uci set passwall2.@global[0].enabled="${passwall2_server_enabled}"
@ -268,7 +302,7 @@ function restart_app(){
/etc/init.d/passwall2 restart 2>/dev/null /etc/init.d/passwall2 restart 2>/dev/null
echolog "passwall2重启完成" echolog "passwall2重启完成"
fi fi
if [ "x${vssr_started}" == "x1" ] ;then if [ "x${vssr_started}" == "x1" ] ;then
if [ $proxy_mode == "close" ] ;then if [ $proxy_mode == "close" ] ;then
uci set vssr.@global[0].global_server="${vssr_original_server}" uci set vssr.@global[0].global_server="${vssr_original_server}"
@ -279,7 +313,7 @@ function restart_app(){
/etc/init.d/vssr restart &>/dev/null /etc/init.d/vssr restart &>/dev/null
echolog "Vssr重启完成" echolog "Vssr重启完成"
fi fi
if [ "x${bypass_started}" == "x1" ] ;then if [ "x${bypass_started}" == "x1" ] ;then
if [ $proxy_mode == "close" ] ;then if [ $proxy_mode == "close" ] ;then
uci set bypass.@global[0].global_server="${bypass_original_server}" uci set bypass.@global[0].global_server="${bypass_original_server}"

View File

@ -37,6 +37,12 @@ function renderStatus(isRunning) {
} }
return view.extend({ return view.extend({
load: function() {
return Promise.all([
L.resolveDefault(fs.exec('/usr/bin/mosdns', ['version']), null),
]);
},
handleFlushCache: function (m, section_id, ev) { handleFlushCache: function (m, section_id, ev) {
return fs.exec('/usr/share/mosdns/mosdns.sh', ['flush']) return fs.exec('/usr/share/mosdns/mosdns.sh', ['flush'])
.then(function (lazy_cache) { .then(function (lazy_cache) {
@ -49,10 +55,14 @@ return view.extend({
}); });
}, },
render: function () { render: function (basic) {
var m, s, o; var m, s, o, v;
v = '';
m = new form.Map('mosdns', _('MosDNS'), if (basic[0] && basic[0].code === 0) {
v = basic[0].stdout.trim();
}
m = new form.Map('mosdns', _('MosDNS') + '&#160;' + v,
_('MosDNS is a plugin-based DNS forwarder/traffic splitter.')); _('MosDNS is a plugin-based DNS forwarder/traffic splitter.'));
s = m.section(form.TypedSection); s = m.section(form.TypedSection);

View File

@ -14,6 +14,7 @@
"/etc/mosdns/rule/redirect.txt": [ "read" ], "/etc/mosdns/rule/redirect.txt": [ "read" ],
"/etc/mosdns/rule/streaming.txt": [ "read" ], "/etc/mosdns/rule/streaming.txt": [ "read" ],
"/etc/mosdns/rule/whitelist.txt": [ "read" ], "/etc/mosdns/rule/whitelist.txt": [ "read" ],
"/usr/bin/mosdns": [ "exec" ],
"/usr/share/mosdns/mosdns.sh": [ "exec" ] "/usr/share/mosdns/mosdns.sh": [ "exec" ]
}, },
"ubus": { "ubus": {

View File

@ -5,12 +5,12 @@
include $(TOPDIR)/rules.mk include $(TOPDIR)/rules.mk
PKG_NAME:=mosdns PKG_NAME:=mosdns
PKG_VERSION:=5.3.1 PKG_VERSION:=5.3.3
PKG_RELEASE:=1 PKG_RELEASE:=1
PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
PKG_SOURCE_URL:=https://codeload.github.com/IrineSistiana/mosdns/tar.gz/v$(PKG_VERSION)? PKG_SOURCE_URL:=https://codeload.github.com/IrineSistiana/mosdns/tar.gz/v$(PKG_VERSION)?
PKG_HASH:=7c8c795de794df52fd2b51214826aea9ebde0dcd0da78d8dda9cc5e4ab98cd80 PKG_HASH:=1d7eeaa735cb48ed2d436797d7f2a82541699f74647cd293ee411a72cdc65f5f
PKG_LICENSE:=GPL-3.0 PKG_LICENSE:=GPL-3.0
PKG_LICENSE_FILE:=LICENSE PKG_LICENSE_FILE:=LICENSE

View File

@ -1,51 +0,0 @@
From 329ba9ca89d25da58d1b51b8107f164beae816bb Mon Sep 17 00:00:00 2001
From: sbwml <admin@cooluc.com>
Date: Tue, 19 Sep 2023 21:15:12 +0800
Subject: [PATCH 1/5] compatible with go1.20
---
go.mod | 6 ++----
go.sum | 4 ++--
2 files changed, 4 insertions(+), 6 deletions(-)
diff --git a/go.mod b/go.mod
index 1839776..1b4cc4b 100644
--- a/go.mod
+++ b/go.mod
@@ -1,8 +1,6 @@
module github.com/IrineSistiana/mosdns/v5
-go 1.21
-
-toolchain go1.21.1
+go 1.20
require (
github.com/IrineSistiana/go-bytes-pool v0.0.0-20230918115058-c72bd9761c57
@@ -45,7 +43,7 @@ require (
github.com/magiconair/properties v1.8.7 // indirect
github.com/matttproud/golang_protobuf_extensions/v2 v2.0.0 // indirect
github.com/mdlayher/netlink v1.7.2 // indirect
- github.com/mdlayher/socket v0.5.0 // indirect
+ github.com/mdlayher/socket v0.4.1 // indirect
github.com/onsi/ginkgo/v2 v2.13.0 // indirect
github.com/pelletier/go-toml/v2 v2.1.0 // indirect
github.com/pmezard/go-difflib v1.0.1-0.20181226105442-5d4384ee4fb2 // indirect
diff --git a/go.sum b/go.sum
index 41a59b2..ad95d6d 100644
--- a/go.sum
+++ b/go.sum
@@ -173,8 +173,8 @@ github.com/matttproud/golang_protobuf_extensions/v2 v2.0.0 h1:jWpvCLoY8Z/e3VKvls
github.com/matttproud/golang_protobuf_extensions/v2 v2.0.0/go.mod h1:QUyp042oQthUoa9bqDv0ER0wrtXnBruoNd7aNjkbP+k=
github.com/mdlayher/netlink v1.7.2 h1:/UtM3ofJap7Vl4QWCPDGXY8d3GIY2UGSDbK+QWmY8/g=
github.com/mdlayher/netlink v1.7.2/go.mod h1:xraEF7uJbxLhc5fpHL4cPe221LI2bdttWlU+ZGLfQSw=
-github.com/mdlayher/socket v0.5.0 h1:ilICZmJcQz70vrWVes1MFera4jGiWNocSkykwwoy3XI=
-github.com/mdlayher/socket v0.5.0/go.mod h1:WkcBFfvyG8QENs5+hfQPl1X6Jpd2yeLIYgrGFmJiJxI=
+github.com/mdlayher/socket v0.4.1 h1:eM9y2/jlbs1M615oshPQOHZzj6R6wMT7bX5NPiQvn2U=
+github.com/mdlayher/socket v0.4.1/go.mod h1:cAqeGjoufqdxWkD7DkpyS+wcefOtmu5OQ8KuoJGIReA=
github.com/miekg/dns v1.1.56 h1:5imZaSeoRNvpM9SzWNhEcP9QliKiz20/dA2QabIGVnE=
github.com/miekg/dns v1.1.56/go.mod h1:cRm6Oo2C8TY9ZS/TqsSrseAcncm74lfK5G+ikN2SWWY=
github.com/mitchellh/mapstructure v1.5.0 h1:jeMsZIYE/09sWLaz43PL7Gy6RuMjD2eJVyuac5Z2hdY=
--
2.42.0

View File

@ -7,11 +7,9 @@ Subject: [PATCH 3/5] add response for bad request in ServeHTTP handler
pkg/server/http_handler.go | 1 + pkg/server/http_handler.go | 1 +
1 file changed, 1 insertion(+) 1 file changed, 1 insertion(+)
diff --git a/pkg/server/http_handler.go b/pkg/server/http_handler.go
index 5a41314..8f33b3f 100644
--- a/pkg/server/http_handler.go --- a/pkg/server/http_handler.go
+++ b/pkg/server/http_handler.go +++ b/pkg/server/http_handler.go
@@ -93,6 +93,7 @@ func (h *HttpHandler) ServeHTTP(w http.ResponseWriter, req *http.Request) { @@ -93,6 +93,7 @@ func (h *HttpHandler) ServeHTTP(w http.R
if err != nil { if err != nil {
h.warnErr(req, "invalid request", err) h.warnErr(req, "invalid request", err)
w.WriteHeader(http.StatusBadRequest) w.WriteHeader(http.StatusBadRequest)
@ -19,6 +17,3 @@ index 5a41314..8f33b3f 100644
return return
} }
--
2.42.0

View File

@ -8,8 +8,6 @@ Subject: [PATCH 4/5] black_hole: apply Fisher-Yates shuffle algorithm to
plugin/executable/black_hole/black_hole.go | 15 +++++++++++++++ plugin/executable/black_hole/black_hole.go | 15 +++++++++++++++
1 file changed, 15 insertions(+) 1 file changed, 15 insertions(+)
diff --git a/plugin/executable/black_hole/black_hole.go b/plugin/executable/black_hole/black_hole.go
index 775253d..f955019 100644
--- a/plugin/executable/black_hole/black_hole.go --- a/plugin/executable/black_hole/black_hole.go
+++ b/plugin/executable/black_hole/black_hole.go +++ b/plugin/executable/black_hole/black_hole.go
@@ -27,6 +27,8 @@ import ( @@ -27,6 +27,8 @@ import (
@ -21,7 +19,7 @@ index 775253d..f955019 100644
) )
const PluginType = "black_hole" const PluginType = "black_hole"
@@ -40,6 +42,7 @@ var _ sequence.Executable = (*BlackHole)(nil) @@ -40,6 +42,7 @@ var _ sequence.Executable = (*BlackHole)
type BlackHole struct { type BlackHole struct {
ipv4 []netip.Addr ipv4 []netip.Addr
ipv6 []netip.Addr ipv6 []netip.Addr
@ -29,7 +27,7 @@ index 775253d..f955019 100644
} }
// QuickSetup format: [ipv4|ipv6] ... // QuickSetup format: [ipv4|ipv6] ...
@@ -65,9 +68,21 @@ func NewBlackHole(ips []string) (*BlackHole, error) { @@ -65,9 +68,21 @@ func NewBlackHole(ips []string) (*BlackH
return b, nil return b, nil
} }
@ -51,6 +49,3 @@ index 775253d..f955019 100644
if r := b.Response(qCtx.Q()); r != nil { if r := b.Response(qCtx.Q()); r != nil {
qCtx.SetResponse(r) qCtx.SetResponse(r)
} }
--
2.42.0

View File

@ -7,8 +7,6 @@ Subject: [PATCH 5/5] format logtime
mlog/logger.go | 18 ++++++++++++++---- mlog/logger.go | 18 ++++++++++++++----
1 file changed, 14 insertions(+), 4 deletions(-) 1 file changed, 14 insertions(+), 4 deletions(-)
diff --git a/mlog/logger.go b/mlog/logger.go
index 861f091..1508db0 100644
--- a/mlog/logger.go --- a/mlog/logger.go
+++ b/mlog/logger.go +++ b/mlog/logger.go
@@ -21,9 +21,11 @@ package mlog @@ -21,9 +21,11 @@ package mlog
@ -24,7 +22,7 @@ index 861f091..1508db0 100644
) )
type LogConfig struct { type LogConfig struct {
@@ -64,10 +66,18 @@ func NewLogger(lc LogConfig) (*zap.Logger, error) { @@ -64,10 +66,18 @@ func NewLogger(lc LogConfig) (*zap.Logge
out = stderr out = stderr
} }
@ -46,6 +44,3 @@ index 861f091..1508db0 100644
} }
// L is a global logger. // L is a global logger.
--
2.42.0