mirror of
https://github.com/coolsnowwolf/lede.git
synced 2025-04-16 14:23:38 +00:00
luci-app-xlnetacc: fix bug (#6660)
This commit is contained in:
parent
8db35e67f2
commit
c41c174be8
@ -2,7 +2,7 @@ include $(TOPDIR)/rules.mk
|
||||
|
||||
PKG_NAME:=luci-app-xlnetacc
|
||||
PKG_VERSION:=1.0.5
|
||||
PKG_RELEASE:=4
|
||||
PKG_RELEASE:=2
|
||||
|
||||
include $(INCLUDE_DIR)/package.mk
|
||||
|
||||
@ -12,7 +12,7 @@ define Package/$(PKG_NAME)
|
||||
SUBMENU:=3. Applications
|
||||
TITLE:=LuCI Support for XLNetAcc
|
||||
PKGARCH:=all
|
||||
DEPENDS:=+jshn +wget +openssl-util
|
||||
DEPENDS:=+jshn +curl +openssl-util +luci-compat
|
||||
MAINTAINER:=Sense <sensec@gmail.com>
|
||||
endef
|
||||
|
||||
@ -32,12 +32,4 @@ define Package/$(PKG_NAME)/install
|
||||
po2lmo ./po/zh-cn/xlnetacc.po $(1)/usr/lib/lua/luci/i18n/xlnetacc.zh-cn.lmo
|
||||
endef
|
||||
|
||||
define Package/$(PKG_NAME)/postinst
|
||||
#!/bin/sh
|
||||
if [ -z "$${IPKG_INSTROOT}" ]; then
|
||||
( . /etc/uci-defaults/luci-xlnetacc ) && rm -f /etc/uci-defaults/luci-xlnetacc
|
||||
fi
|
||||
exit 0
|
||||
endef
|
||||
|
||||
$(eval $(call BuildPackage,$(PKG_NAME)))
|
||||
|
@ -1,43 +1,37 @@
|
||||
module("luci.controller.xlnetacc", package.seeall)
|
||||
module("luci.controller.xlnetacc",package.seeall)
|
||||
|
||||
function index()
|
||||
if not nixio.fs.access("/etc/config/xlnetacc") then
|
||||
return
|
||||
end
|
||||
|
||||
entry({"admin", "services", "xlnetacc"},
|
||||
firstchild(), _("XLNetAcc")).dependent = false
|
||||
|
||||
entry({"admin", "services", "xlnetacc", "general"},
|
||||
cbi("xlnetacc"), _("Settings"), 1)
|
||||
|
||||
entry({"admin", "services", "xlnetacc", "log"},
|
||||
template("xlnetacc/logview"), _("Log"), 2)
|
||||
|
||||
entry({"admin", "services", "xlnetacc", "status"}, call("action_status"))
|
||||
entry({"admin", "services", "xlnetacc", "logdata"}, call("action_log"))
|
||||
local e=entry({"admin","services","xlnetacc"},firstchild(),_("XLNetAcc"))
|
||||
e.dependent=false
|
||||
e.acl_depends={ "luci-app-xlnetacc" }
|
||||
entry({"admin","services","xlnetacc","general"},cbi("xlnetacc"),_("Settings"),1)
|
||||
entry({"admin","services","xlnetacc","log"},template("xlnetacc/logview"),_("Log"),2)
|
||||
entry({"admin","services","xlnetacc","status"},call("action_status"))
|
||||
entry({"admin","services","xlnetacc","logdata"},call("action_log"))
|
||||
end
|
||||
|
||||
function action_status()
|
||||
luci.http.prepare_content("application/json")
|
||||
luci.http.write_json({
|
||||
run_state = luci.sys.call("(ps | grep xlnetacc | grep -v 'grep') >/dev/null" ) == 0,
|
||||
down_state = nixio.fs.readfile("/var/state/xlnetacc_down_state") or "",
|
||||
up_state = nixio.fs.readfile("/var/state/xlnetacc_up_state") or ""
|
||||
run_state=luci.sys.call("ps -w | grep xlnetacc.sh | grep -v grep >/dev/null")==0,
|
||||
down_state=nixio.fs.readfile("/var/state/xlnetacc_down_state") or "",
|
||||
up_state=nixio.fs.readfile("/var/state/xlnetacc_up_state") or ""
|
||||
})
|
||||
end
|
||||
|
||||
function action_log()
|
||||
local uci = require "luci.model.uci".cursor()
|
||||
local util = require "luci.util"
|
||||
local log_data = { }
|
||||
local uci=require "luci.model.uci".cursor()
|
||||
local util=require "luci.util"
|
||||
local log_data={}
|
||||
|
||||
log_data.syslog = util.trim(util.exec("logread | grep xlnetacc"))
|
||||
if uci:get("xlnetacc", "general", "logging") ~= "0" then
|
||||
log_data.client = nixio.fs.readfile("/var/log/xlnetacc.log") or ""
|
||||
log_data.syslog=util.trim(util.exec("logread | grep xlnetacc"))
|
||||
if uci:get("xlnetacc","general","logging")~="0" then
|
||||
log_data.client=nixio.fs.readfile("/var/log/xlnetacc.log") or ""
|
||||
end
|
||||
uci:unload("xlnetacc")
|
||||
|
||||
luci.http.prepare_content("application/json")
|
||||
luci.http.write_json(log_data)
|
||||
end
|
||||
|
@ -1,51 +1,51 @@
|
||||
local m, s, o
|
||||
local uci = luci.model.uci.cursor()
|
||||
local m,s,o
|
||||
local uci=luci.model.uci.cursor()
|
||||
|
||||
m = Map("xlnetacc", "%s - %s" %{translate("XLNetAcc"), translate("Settings")}, translate("XLNetAcc is a Thunder joint broadband operators launched a commitment to help users solve the low broadband, slow Internet access, poor Internet experience of professional-grade broadband upgrade software."))
|
||||
m=Map("xlnetacc","%s - %s"%{translate("XLNetAcc"),translate("Settings")},translate("XLNetAcc is a Thunder joint broadband operators launched a commitment to help users solve the low broadband, slow Internet access, poor Internet experience of professional-grade broadband upgrade software."))
|
||||
m:append(Template("xlnetacc/xlnetacc_status"))
|
||||
|
||||
s = m:section(NamedSection, "general", "general", translate("General Settings"))
|
||||
s.anonymous = true
|
||||
s.addremove = false
|
||||
s=m:section(NamedSection,"general","general",translate("General Settings"))
|
||||
s.anonymous=true
|
||||
s.addremove=false
|
||||
|
||||
o = s:option(Flag, "enabled", translate("Enabled"))
|
||||
o.rmempty = false
|
||||
o=s:option(Flag,"enabled",translate("Enabled"))
|
||||
o.rmempty=false
|
||||
|
||||
o = s:option(Flag, "down_acc", translate("Enable DownLink Upgrade"))
|
||||
o=s:option(Flag,"down_acc",translate("Enable DownLink Upgrade"))
|
||||
|
||||
o = s:option(Flag, "up_acc", translate("Enable UpLink Upgrade"))
|
||||
o=s:option(Flag,"up_acc",translate("Enable UpLink Upgrade"))
|
||||
|
||||
o = s:option(Flag, "logging", translate("Enable Logging"))
|
||||
o.default = "1"
|
||||
o=s:option(Flag,"logging",translate("Enable Logging"))
|
||||
o.default=1
|
||||
|
||||
o = s:option(Flag, "verbose", translate("Enable verbose logging"))
|
||||
o:depends("logging", "1")
|
||||
o=s:option(Flag,"verbose",translate("Enable verbose logging"))
|
||||
o:depends("logging",1)
|
||||
|
||||
o = s:option(ListValue, "network", translate("Upgrade interface"))
|
||||
uci:foreach("network", "interface", function(section)
|
||||
if section[".name"] ~= "loopback" then
|
||||
o=s:option(ListValue,"network",translate("Upgrade interface"))
|
||||
uci:foreach("network","interface",function(section)
|
||||
if section[".name"]~="loopback" then
|
||||
o:value(section[".name"])
|
||||
end
|
||||
end)
|
||||
|
||||
o = s:option(Value, "keepalive", translate("Keepalive interval"), "5-60 " .. translate("minutes"))
|
||||
for _, v in ipairs({5, 10, 20, 30, 60}) do
|
||||
o:value(v, v .. " " .. translate("minutes"))
|
||||
o=s:option(Value,"keepalive",translate("Keepalive interval"),"5-60 "..translate("minutes"))
|
||||
for _,v in ipairs({5,10,20,30,60}) do
|
||||
o:value(v,v.." "..translate("minutes"))
|
||||
end
|
||||
o.datatype = "range(5, 60)"
|
||||
o.default = 10
|
||||
o.datatype="range(5,60)"
|
||||
o.default=10
|
||||
|
||||
o = s:option(Value, "relogin", translate("Account relogin"), "1-48 " .. translate("hours"))
|
||||
o:value(0, translate("Not enabled"))
|
||||
for _, v in ipairs({3, 12, 18, 24, 30}) do
|
||||
o:value(v, v .. " " .. translate("hours"))
|
||||
o=s:option(Value,"relogin",translate("Account relogin"),"1-48 "..translate("hours"))
|
||||
o:value(0,translate("Not enabled"))
|
||||
for _,v in ipairs({3,12,18,24,30}) do
|
||||
o:value(v,v.." "..translate("hours"))
|
||||
end
|
||||
o.datatype = "max(48)"
|
||||
o.default = 0
|
||||
o.datatype="max(48)"
|
||||
o.default=0
|
||||
|
||||
o = s:option(Value, "account", translate("XLNetAcc account"))
|
||||
o=s:option(Value,"account",translate("XLNetAcc account"))
|
||||
|
||||
o = s:option(Value, "password", translate("XLNetAcc password"))
|
||||
o.password = true
|
||||
o=s:option(Value,"password",translate("XLNetAcc password"))
|
||||
o.password=true
|
||||
|
||||
return m
|
||||
|
@ -1,17 +1,17 @@
|
||||
<% css = [[
|
||||
#log_text {
|
||||
padding: 10px;
|
||||
text-align: left;
|
||||
height: 500px;
|
||||
overflow: auto;
|
||||
<%css=[[
|
||||
#log_text{
|
||||
padding:10px;
|
||||
text-align:left;
|
||||
height:500px;
|
||||
overflow:auto;
|
||||
}
|
||||
#log_text pre {
|
||||
word-break: break-all;
|
||||
margin: 0;
|
||||
#log_text pre{
|
||||
word-break:break-all;
|
||||
margin:0;
|
||||
}
|
||||
.description {
|
||||
color: #ffffff;
|
||||
background-color: #0099ff;
|
||||
.description{
|
||||
color:#ffffff;
|
||||
background-color:#0099ff;
|
||||
}
|
||||
]]
|
||||
%>
|
||||
@ -22,7 +22,7 @@
|
||||
<h2 name="content"><%:XLNetAcc%> - <%:Log Data%></h2>
|
||||
<fieldset class="cbi-section">
|
||||
<fieldset class="cbi-section-node">
|
||||
<div id="log_text"><img src="<%=resource%>/icons/loading.gif" alt="<%:Loading...%>" style="vertical-align:middle" /><%:Collecting data...%></div>
|
||||
<div id="log_text"><img src="<%=resource%>/icons/loading.gif" alt="<%:Loading...%>" style="vertical-align:middle"/><%:Collecting data...%></div>
|
||||
<div style="text-align:right"><small><%:Refresh every 5 seconds.%></small></div>
|
||||
</fieldset>
|
||||
</fieldset>
|
||||
@ -30,18 +30,18 @@
|
||||
|
||||
<script type="text/javascript" src="<%=resource%>/cbi.js"></script>
|
||||
<script type="text/javascript">//<![CDATA[
|
||||
var log_id = document.getElementById('log_text');
|
||||
XHR.poll(5, '<%=luci.dispatcher.build_url("admin", "services", "xlnetacc", "logdata")%>', null, function(x, data) {
|
||||
if ( log_id && data ) {
|
||||
log_id.innerHTML = String.format(
|
||||
var log_id=document.getElementById('log_text');
|
||||
XHR.poll(5,'<%=luci.dispatcher.build_url("admin","services","xlnetacc","logdata")%>',null,function(x,data){
|
||||
if (log_id&&data){
|
||||
log_id.innerHTML=String.format(
|
||||
'<pre>%s%s%s%s</pre>',
|
||||
'<span class="description"><strong><%:syslog:%></strong></span><br/>',
|
||||
data.syslog || '<%:No log data.%>',
|
||||
'<br/><br/><span class="description"><strong><%:log file:%></strong></span><br/>',
|
||||
data.client || '<%:No log data.%>'
|
||||
);
|
||||
} else if ( log_id ) {
|
||||
log_id.innerHTML = '<strong><%:Error get log data.%></strong>';
|
||||
}else if (log_id){
|
||||
log_id.innerHTML='<strong><%:Error get log data.%></strong>';
|
||||
}
|
||||
});
|
||||
//]]></script>
|
||||
|
@ -8,14 +8,14 @@
|
||||
</fieldset>
|
||||
|
||||
<script type="text/javascript">//<![CDATA[
|
||||
var run_state = document.getElementById('_run_state');
|
||||
var down_state = document.getElementById('_down_state');
|
||||
var up_state = document.getElementById('_up_state');
|
||||
XHR.poll(5, '<%=luci.dispatcher.build_url("admin", "services", "xlnetacc", "status")%>', null, function(x, status) {
|
||||
if ( x && x.status == 200 ) {
|
||||
run_state.innerHTML = status.run_state ? '<em><b><font color=green><%:RUNNING%></font></b></em>' : '<em><b><font color=red><%:NOT RUNNING%></font></b></em>';
|
||||
down_state.innerHTML = status.down_state ? status.down_state : '<%:No upgrade information%>';
|
||||
up_state.innerHTML = status.up_state ? status.up_state : '<%:No upgrade information%>';
|
||||
var run_state=document.getElementById('_run_state');
|
||||
var down_state=document.getElementById('_down_state');
|
||||
var up_state=document.getElementById('_up_state');
|
||||
XHR.poll(5,'<%=luci.dispatcher.build_url("admin","services","xlnetacc","status")%>',null,function(x,status){
|
||||
if ( x&&x.status==200 ){
|
||||
run_state.innerHTML=status.run_state?'<em><b><font color=green><%:RUNNING%></font></b></em>':'<em><b><font color=red><%:NOT RUNNING%></font></b></em>';
|
||||
down_state.innerHTML=status.down_state?status.down_state:'<%:No upgrade information%>';
|
||||
up_state.innerHTML=status.up_state?status.up_state:'<%:No upgrade information%>';
|
||||
}
|
||||
});
|
||||
//]]></script>
|
||||
|
@ -1,6 +1,3 @@
|
||||
msgid ""
|
||||
msgstr "Content-Type: text/plain; charset=UTF-8\n"
|
||||
|
||||
msgid "XLNetAcc"
|
||||
msgstr "迅雷快鸟"
|
||||
|
||||
|
@ -5,9 +5,9 @@
|
||||
|
||||
case "$ACTION" in
|
||||
ifup)
|
||||
/etc/init.d/xlnetacc restart
|
||||
/etc/init.d/xlnetacc start
|
||||
;;
|
||||
ifdown)
|
||||
#/etc/init.d/xlnetacc stop
|
||||
/etc/init.d/xlnetacc stop
|
||||
;;
|
||||
esac
|
||||
|
@ -8,10 +8,11 @@ NAME=xlnetacc
|
||||
|
||||
start() {
|
||||
local retry=1
|
||||
while pidof "${NAME}" >/dev/null 2>&1; do
|
||||
while ps -w | grep ${NAME}.sh | grep -v grep >/dev/null 2>&1; do
|
||||
[ $retry -ge 10 ] && return 1 || let retry++
|
||||
sleep 1
|
||||
done
|
||||
rm -f /var/lock/xlnetacc.lock
|
||||
|
||||
config_load "$NAME"
|
||||
config_get_bool enabled "general" "enabled" 0
|
||||
@ -23,14 +24,13 @@ start() {
|
||||
( [ $enabled -eq 0 ] || [ $down_acc -eq 0 -a $up_acc -eq 0 ] || [ -z "$username" -o -z "$password" -o -z "$network" ] ) && return 2
|
||||
|
||||
logger -p "daemon.notice" -t "$NAME" "XLNetAcc is starting ..."
|
||||
service_start /usr/bin/${NAME} --start
|
||||
service_start /usr/bin/${NAME}.sh --start
|
||||
}
|
||||
|
||||
stop() {
|
||||
ps | grep xlnetacc | grep -v 'grep' >/dev/null 2>&1 || return 1
|
||||
|
||||
ps -w | grep ${NAME}.sh | grep -v grep >/dev/null 2>&1 || return 1
|
||||
local pid spid
|
||||
for pid in $(ps | grep xlnetacc | grep -v 'grep' | awk '{print $1}'); do
|
||||
for pid in $(ps -w | grep ${NAME}.sh | grep -v grep | awk '{print $1}'); do
|
||||
echo "Stop XLNetAcc process PID: $pid"
|
||||
kill $pid >/dev/null 2>&1
|
||||
for spid in $(pgrep -P $pid "sleep"); do
|
||||
@ -38,12 +38,12 @@ stop() {
|
||||
kill $spid >/dev/null 2>&1
|
||||
done
|
||||
done
|
||||
rm -f /var/lock/xlnetacc.lock
|
||||
logger -p "daemon.notice" -t "$NAME" "XLNetAcc has stoped."
|
||||
return 0
|
||||
}
|
||||
|
||||
restart() {
|
||||
rm -rf /tmp/state/xlnetacc*
|
||||
stop && sleep 1
|
||||
start
|
||||
}
|
||||
|
@ -1,22 +1,6 @@
|
||||
#!/bin/sh
|
||||
|
||||
uci -q batch <<-EOF >/dev/null
|
||||
uci batch <<EOF
|
||||
delete ucitrack.@xlnetacc[-1]
|
||||
add ucitrack xlnetacc
|
||||
set ucitrack.@xlnetacc[-1].init=xlnetacc
|
||||
commit ucitrack
|
||||
EOF
|
||||
|
||||
general=$(uci -q get xlnetacc.@general[-1])
|
||||
if [ -z "$general" ]; then
|
||||
uci -q add xlnetacc general
|
||||
fi
|
||||
if [ "$general"x != "general"x ]; then
|
||||
uci -q batch <<-EOF >/dev/null
|
||||
rename xlnetacc.@general[-1]="general"
|
||||
commit xlnetacc
|
||||
EOF
|
||||
fi
|
||||
|
||||
rm -rf /tmp/luci-indexcache /tmp/luci-modulecache
|
||||
exit 0
|
||||
|
@ -1,710 +0,0 @@
|
||||
#!/bin/sh
|
||||
|
||||
# 声明常量
|
||||
readonly packageName='com.xunlei.vip.swjsq'
|
||||
readonly protocolVersion=300
|
||||
readonly businessType=68
|
||||
readonly sdkVersion='3.1.2.185150'
|
||||
readonly clientVersion='2.7.2.0'
|
||||
readonly agent_xl="android-ok-http-client/xl-acc-sdk/version-$sdkVersion"
|
||||
readonly agent_down='okhttp/3.9.1'
|
||||
readonly agent_up='android-async-http/xl-acc-sdk/version-1.0.0.1'
|
||||
readonly client_type_down='android-swjsq'
|
||||
readonly client_type_up='android-uplink'
|
||||
|
||||
# 声明全局变量
|
||||
_bind_ip=
|
||||
_http_cmd=
|
||||
_peerid=
|
||||
_devicesign=
|
||||
_userid=
|
||||
_loginkey=
|
||||
_sessionid=
|
||||
_portal_down=
|
||||
_portal_up=
|
||||
_dial_account=
|
||||
access_url=
|
||||
http_args=
|
||||
user_agent=
|
||||
link_cn=
|
||||
lasterr=
|
||||
sequence_xl=1000000
|
||||
sequence_down=$(( $(date +%s) / 6 ))
|
||||
sequence_up=$sequence_down
|
||||
|
||||
# 包含用于解析 JSON 格式返回值的函数
|
||||
. /usr/share/libubox/jshn.sh
|
||||
|
||||
# 读取 UCI 设置相关函数
|
||||
uci_get_by_name() {
|
||||
local ret=$(uci get $NAME.$1.$2 2> /dev/null)
|
||||
echo -n ${ret:=$3}
|
||||
}
|
||||
uci_get_by_type() {
|
||||
local ret=$(uci get $NAME.@$1[-1].$2 2> /dev/null)
|
||||
echo -n ${ret:=$3}
|
||||
}
|
||||
uci_get_by_bool() {
|
||||
case $(uci_get_by_name "$1" "$2" "$3") in
|
||||
1|on|true|yes|enabled) echo -n 1;;
|
||||
*) echo -n 0;;
|
||||
esac
|
||||
}
|
||||
|
||||
# 日志和状态栏输出。1 日志文件, 2 系统日志, 4 详细模式, 8 下行状态栏, 16 上行状态栏, 32 失败状态
|
||||
_log() {
|
||||
local msg=$1 flag=$2 timestamp=$(date +'%Y/%m/%d %H:%M:%S')
|
||||
[ -z "$msg" ] && return
|
||||
[ -z "$flag" ] && flag=1
|
||||
|
||||
[ $logging -eq 0 -a $(( $flag & 1 )) -ne 0 ] && flag=$(( $flag ^ 1 ))
|
||||
if [ $verbose -eq 0 -a $(( $flag & 4 )) -ne 0 ]; then
|
||||
[ $(( $flag & 1 )) -ne 0 ] && flag=$(( $flag ^ 1 ))
|
||||
[ $(( $flag & 2 )) -ne 0 ] && flag=$(( $flag ^ 2 ))
|
||||
fi
|
||||
if [ $down_acc -eq 0 -a $(( $flag & 8 )) -ne 0 ]; then
|
||||
flag=$(( $flag ^ 8 ))
|
||||
[ $up_acc -ne 0 ] && flag=$(( $flag | 16 ))
|
||||
fi
|
||||
if [ $up_acc -eq 0 -a $(( $flag & 16 )) -ne 0 ]; then
|
||||
flag=$(( $flag ^ 16 ))
|
||||
[ $down_acc -ne 0 ] && flag=$(( $flag | 8 ))
|
||||
fi
|
||||
|
||||
[ $(( $flag & 1 )) -ne 0 ] && echo "$timestamp $msg" >> $LOGFILE 2> /dev/null
|
||||
[ $(( $flag & 2 )) -ne 0 ] && logger -p "daemon.info" -t "$NAME" "$msg"
|
||||
|
||||
[ $(( $flag & 32 )) -eq 0 ] && local color="green" || local color="red"
|
||||
[ $(( $flag & 8 )) -ne 0 ] && echo -n "<font color=$color>$timestamp $msg</font>" > $down_state_file 2> /dev/null
|
||||
[ $(( $flag & 16 )) -ne 0 ] && echo -n "<font color=$color>$timestamp $msg</font>" > $up_state_file 2> /dev/null
|
||||
}
|
||||
|
||||
# 清理日志
|
||||
clean_log() {
|
||||
[ $logging -eq 1 -a -f "$LOGFILE" ] || return
|
||||
[ $(wc -l "$LOGFILE" | awk '{print $1}') -le 800 ] && return
|
||||
_log "清理日志文件"
|
||||
local logdata=$(tail -n 500 "$LOGFILE")
|
||||
echo "$logdata" > $LOGFILE 2> /dev/null
|
||||
unset logdata
|
||||
}
|
||||
|
||||
# 获取接口IP地址
|
||||
get_bind_ip() {
|
||||
json_cleanup; json_load "$(ubus call network.interface.$network status 2> /dev/null)" >/dev/null 2>&1
|
||||
json_select "ipv4-address" >/dev/null 2>&1; json_select 1 >/dev/null 2>&1
|
||||
json_get_var _bind_ip "address"
|
||||
if [ -z "$_bind_ip" -o "$_bind_ip"x == "0.0.0.0"x ]; then
|
||||
_log "获取网络 $network IP地址失败"
|
||||
return 1
|
||||
else
|
||||
_log "绑定IP地址: $_bind_ip"
|
||||
return 0
|
||||
fi
|
||||
}
|
||||
|
||||
# 定义基本 HTTP 命令和参数
|
||||
gen_http_cmd() {
|
||||
_http_cmd="wget-ssl -nv -t 1 -T 5 -O - --no-check-certificate"
|
||||
_http_cmd="$_http_cmd --bind-address=$_bind_ip"
|
||||
}
|
||||
|
||||
# 生成设备标识
|
||||
gen_device_sign() {
|
||||
local ifname macaddr
|
||||
while : ; do
|
||||
ifname=$(uci get "network.$network.ifname" 2> /dev/null)
|
||||
[ "${ifname:0:1}" == "@" ] && network="${ifname:1}" || break
|
||||
done
|
||||
[ -z "$ifname" ] && { _log "获取网络 $network 信息出错"; return; }
|
||||
json_cleanup; json_load "$(ubus call network.device status {\"name\":\"$ifname\"} 2> /dev/null)" >/dev/null 2>&1
|
||||
json_get_var macaddr "macaddr"
|
||||
[ -z "$macaddr" ] && { _log "获取网络 $network MAC地址出错"; return; }
|
||||
macaddr=$(echo -n "$macaddr" | awk '{print toupper($0)}')
|
||||
|
||||
# 计算peerID
|
||||
local fake_peerid=$(awk -F- '{print toupper($5)}' '/proc/sys/kernel/random/uuid')
|
||||
readonly _peerid="${fake_peerid}004V"
|
||||
_log "_peerid is $_peerid" $(( 1 | 4 ))
|
||||
|
||||
# 计算devicesign
|
||||
# sign = div.10?.device_id + md5(sha1(packageName + businessType + md5(a protocolVersion specific GUID)))
|
||||
local fake_device_id=$(echo -n "${macaddr//:/}" | openssl dgst -md5 | awk '{print $2}')
|
||||
local fake_device_sign=$(echo -n "${fake_device_id}${packageName}${businessType}c7f21687eed3cdb400ca11fc2263c998" \
|
||||
| openssl dgst -sha1 | awk '{print $2}')
|
||||
readonly _devicesign="div101.${fake_device_id}"$(echo -n "$fake_device_sign" | openssl dgst -md5 | awk '{print $2}')
|
||||
_log "_devicesign is $_devicesign" $(( 1 | 4 ))
|
||||
}
|
||||
|
||||
# 快鸟帐号通用参数
|
||||
swjsq_json() {
|
||||
let sequence_xl++
|
||||
# 生成POST数据
|
||||
json_init
|
||||
json_add_string protocolVersion "$protocolVersion"
|
||||
json_add_string sequenceNo "$sequence_xl"
|
||||
json_add_string platformVersion '10'
|
||||
json_add_string isCompressed '0'
|
||||
json_add_string appid "$businessType"
|
||||
json_add_string clientVersion "$clientVersion"
|
||||
json_add_string peerID "$_peerid"
|
||||
json_add_string appName "ANDROID-$packageName"
|
||||
json_add_string sdkVersion "${sdkVersion##*.}"
|
||||
json_add_string devicesign "$_devicesign"
|
||||
json_add_string netWorkType 'WIFI'
|
||||
json_add_string providerName 'OTHER'
|
||||
json_add_string deviceModel 'MI'
|
||||
json_add_string deviceName 'Xiaomi Mi'
|
||||
json_add_string OSVersion "7.1.1"
|
||||
}
|
||||
|
||||
# 帐号登录
|
||||
swjsq_login() {
|
||||
swjsq_json
|
||||
if [ -z "$_userid" -o -z "$_loginkey" ]; then
|
||||
access_url='https://mobile-login.xunlei.com/login'
|
||||
json_add_string userName "$username"
|
||||
json_add_string passWord "$password"
|
||||
json_add_string verifyKey
|
||||
json_add_string verifyCode
|
||||
json_add_string isMd5Pwd '0'
|
||||
else
|
||||
access_url='https://mobile-login.xunlei.com/loginkey'
|
||||
json_add_string userName "$_userid"
|
||||
json_add_string loginKey "$_loginkey"
|
||||
fi
|
||||
json_close_object
|
||||
|
||||
local ret=$($_http_cmd --user-agent="$agent_xl" "$access_url" --post-data="$(json_dump)")
|
||||
case $? in
|
||||
0)
|
||||
_log "login is $ret" $(( 1 | 4 ))
|
||||
json_cleanup; json_load "$ret" >/dev/null 2>&1
|
||||
json_get_var lasterr "errorCode"
|
||||
;;
|
||||
2) lasterr=-2;;
|
||||
4) lasterr=-3;;
|
||||
*) lasterr=-1;;
|
||||
esac
|
||||
|
||||
case ${lasterr:=-1} in
|
||||
0)
|
||||
json_get_var _userid "userID"
|
||||
json_get_var _loginkey "loginKey"
|
||||
json_get_var _sessionid "sessionID"
|
||||
_log "_sessionid is $_sessionid" $(( 1 | 4 ))
|
||||
local outmsg="帐号登录成功"; _log "$outmsg" $(( 1 | 8 ))
|
||||
;;
|
||||
15) # 身份信息已失效
|
||||
_userid=; _loginkey=;;
|
||||
-1)
|
||||
local outmsg="帐号登录失败。迅雷服务器未响应,请稍候"; _log "$outmsg";;
|
||||
-2)
|
||||
local outmsg="Wget 参数解析错误,请更新 GNU Wget"; _log "$outmsg" $(( 1 | 8 | 32 ));;
|
||||
-3)
|
||||
local outmsg="Wget 网络通信失败,请稍候"; _log "$outmsg";;
|
||||
*)
|
||||
local errorDesc; json_get_var errorDesc "errorDesc"
|
||||
local outmsg="帐号登录失败。错误代码: ${lasterr}"; \
|
||||
[ -n "$errorDesc" ] && outmsg="${outmsg},原因: $errorDesc"; _log "$outmsg" $(( 1 | 8 | 32 ));;
|
||||
esac
|
||||
|
||||
[ $lasterr -eq 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 帐号注销
|
||||
swjsq_logout() {
|
||||
swjsq_json
|
||||
json_add_string userID "$_userid"
|
||||
json_add_string sessionID "$_sessionid"
|
||||
json_close_object
|
||||
|
||||
local ret=$($_http_cmd --user-agent="$agent_xl" 'https://mobile-login.xunlei.com/logout' --post-data="$(json_dump)")
|
||||
_log "logout is $ret" $(( 1 | 4 ))
|
||||
json_cleanup; json_load "$ret" >/dev/null 2>&1
|
||||
json_get_var lasterr "errorCode"
|
||||
|
||||
case ${lasterr:=-1} in
|
||||
0)
|
||||
_sessionid=
|
||||
local outmsg="帐号注销成功"; _log "$outmsg" $(( 1 | 8 ));;
|
||||
-1)
|
||||
local outmsg="帐号注销失败。迅雷服务器未响应,请稍候"; _log "$outmsg";;
|
||||
*)
|
||||
local errorDesc; json_get_var errorDesc "errorDesc"
|
||||
local outmsg="帐号注销失败。错误代码: ${lasterr}"; \
|
||||
[ -n "$errorDesc" ] && outmsg="${outmsg},原因: $errorDesc"; _log "$outmsg" $(( 1 | 8 | 32 ));;
|
||||
esac
|
||||
|
||||
[ $lasterr -eq 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 获取用户信息
|
||||
swjsq_getuserinfo() {
|
||||
local _vasid vasid_down=14 vasid_up=33 outmsg
|
||||
[ $down_acc -ne 0 ] && _vasid="${_vasid}${vasid_down},"; [ $up_acc -ne 0 ] && _vasid="${_vasid}${vasid_up},"
|
||||
swjsq_json
|
||||
json_add_string userID "$_userid"
|
||||
json_add_string sessionID "$_sessionid"
|
||||
json_add_string vasid "$_vasid"
|
||||
json_close_object
|
||||
|
||||
local ret=$($_http_cmd --user-agent="$agent_xl" 'https://mobile-login.xunlei.com/getuserinfo' --post-data="$(json_dump)")
|
||||
_log "getuserinfo is $ret" $(( 1 | 4 ))
|
||||
json_cleanup; json_load "$ret" >/dev/null 2>&1
|
||||
json_get_var lasterr "errorCode"
|
||||
|
||||
case ${lasterr:=-1} in
|
||||
0)
|
||||
local index=1 can_down=0 vasid isVip isYear expireDate
|
||||
json_select "vipList" >/dev/null 2>&1
|
||||
while : ; do
|
||||
json_select $index >/dev/null 2>&1
|
||||
[ $? -ne 0 ] && break
|
||||
json_get_var vasid "vasid"
|
||||
json_get_var isVip "isVip"
|
||||
json_get_var isYear "isYear"
|
||||
json_get_var expireDate "expireDate"
|
||||
json_select ".." >/dev/null 2>&1
|
||||
let index++
|
||||
case ${vasid:-0} in
|
||||
2) [ $down_acc -ne 0 ] && outmsg="迅雷超级会员" || continue;;
|
||||
$vasid_down) outmsg="迅雷快鸟会员";;
|
||||
$vasid_up) outmsg="上行提速会员";;
|
||||
*) continue;;
|
||||
esac
|
||||
if [ ${isVip:-0} -eq 1 -o ${isYear:-0} -eq 1 ]; then
|
||||
outmsg="${outmsg}有效。会员到期时间:${expireDate:0:4}-${expireDate:4:2}-${expireDate:6:2}"
|
||||
[ $vasid -eq $vasid_up ] && _log "$outmsg" $(( 1 | 16 )) || _log "$outmsg" $(( 1 | 8 ))
|
||||
[ $vasid -ne $vasid_up ] && can_down=$(( $can_down | 1 ))
|
||||
else
|
||||
if [ ${#expireDate} -ge 8 ]; then
|
||||
outmsg="${outmsg}已到期。会员到期时间:${expireDate:0:4}-${expireDate:4:2}-${expireDate:6:2}"
|
||||
else
|
||||
outmsg="${outmsg}无效"
|
||||
fi
|
||||
[ $vasid -eq $vasid_up ] && _log "$outmsg" $(( 1 | 16 | 32 )) || _log "$outmsg" $(( 1 | 8 | 32 ))
|
||||
[ $vasid -eq $vasid_up ] && up_acc=0
|
||||
fi
|
||||
done
|
||||
[ $can_down -eq 0 ] && down_acc=0
|
||||
;;
|
||||
-1)
|
||||
outmsg="获取迅雷会员信息失败。迅雷服务器未响应,请稍候"; _log "$outmsg";;
|
||||
*)
|
||||
local errorDesc; json_get_var errorDesc "errorDesc"
|
||||
outmsg="获取迅雷会员信息失败。错误代码: ${lasterr}"; \
|
||||
[ -n "$errorDesc" ] && outmsg="${outmsg},原因: $errorDesc"; _log "$outmsg" $(( 1 | 8 | 32 ));;
|
||||
esac
|
||||
|
||||
[ $lasterr -eq 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 登录时间更新
|
||||
swjsq_renewal() {
|
||||
xlnetacc_var 1
|
||||
local limitdate=$(date +%Y%m%d -d "1970.01.01-00:00:$(( $(date +%s) + 30 * 24 * 60 * 60 ))")
|
||||
|
||||
access_url='http://api.ext.swjsq.vip.xunlei.com'
|
||||
local ret=$($_http_cmd --user-agent="$user_agent" "$access_url/renewal?${http_args%&dial_account=*}&limitdate=$limitdate")
|
||||
_log "renewal is $ret" $(( 1 | 4 ))
|
||||
json_cleanup; json_load "$ret" >/dev/null 2>&1
|
||||
json_get_var lasterr "errno"
|
||||
|
||||
case ${lasterr:=-1} in
|
||||
0)
|
||||
local outmsg="更新登录时间成功。帐号登录展期:${limitdate:0:4}-${limitdate:4:2}-${limitdate:6:2}"; _log "$outmsg";;
|
||||
-1)
|
||||
local outmsg="更新登录时间失败。迅雷服务器未响应,请稍候"; _log "$outmsg";;
|
||||
*)
|
||||
local message; json_get_var message "richmessage"
|
||||
local outmsg="更新登录时间失败。错误代码: ${lasterr}"; \
|
||||
[ -n "$message" ] && outmsg="${outmsg},原因: $message"; _log "$outmsg" $(( 1 | 8 | 32 ));;
|
||||
esac
|
||||
|
||||
[ $lasterr -eq 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 获取提速入口
|
||||
swjsq_portal() {
|
||||
xlnetacc_var $1
|
||||
|
||||
[ $1 -eq 1 ] && access_url='http://api.portal.swjsq.vip.xunlei.com:81/v2/queryportal' || \
|
||||
access_url='http://api.upportal.swjsq.vip.xunlei.com/v2/queryportal'
|
||||
local ret=$($_http_cmd --user-agent="$user_agent" "$access_url")
|
||||
_log "portal $1 is $ret" $(( 1 | 4 ))
|
||||
json_cleanup; json_load "$ret" >/dev/null 2>&1
|
||||
json_get_var lasterr "errno"
|
||||
|
||||
case ${lasterr:=-1} in
|
||||
0)
|
||||
local interface_ip interface_port province sp
|
||||
json_get_var interface_ip "interface_ip"
|
||||
json_get_var interface_port "interface_port"
|
||||
json_get_var province "province_name"
|
||||
json_get_var sp "sp_name"
|
||||
if [ $1 -eq 1 ]; then
|
||||
_portal_down="http://$interface_ip:$interface_port/v2"
|
||||
_log "_portal_down is $_portal_down" $(( 1 | 4 ))
|
||||
else
|
||||
_portal_up="http://$interface_ip:$interface_port/v2"
|
||||
_log "_portal_up is $_portal_up" $(( 1 | 4 ))
|
||||
fi
|
||||
local outmsg="获取${link_cn}提速入口成功"; \
|
||||
[ -n "$province" -a -n "$sp" ] && outmsg="${outmsg}。运营商:${province}${sp}"; _log "$outmsg" $(( 1 | $1 * 8 ))
|
||||
;;
|
||||
-1)
|
||||
local outmsg="获取${link_cn}提速入口失败。迅雷服务器未响应,请稍候"; _log "$outmsg";;
|
||||
*)
|
||||
local message; json_get_var message "message"
|
||||
local outmsg="获取${link_cn}提速入口失败。错误代码: ${lasterr}"; \
|
||||
[ -n "$message" ] && outmsg="${outmsg},原因: $message"; _log "$outmsg" $(( 1 | $1 * 8 | 32 ));;
|
||||
esac
|
||||
|
||||
[ $lasterr -eq 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 获取网络带宽信息
|
||||
isp_bandwidth() {
|
||||
xlnetacc_var $1
|
||||
|
||||
local ret=$($_http_cmd --user-agent="$user_agent" "$access_url/bandwidth?${http_args%&dial_account=*}")
|
||||
_log "bandwidth $1 is $ret" $(( 1 | 4 ))
|
||||
json_cleanup; json_load "$ret" >/dev/null 2>&1
|
||||
json_get_var lasterr "errno"
|
||||
|
||||
case ${lasterr:=-1} in
|
||||
0)
|
||||
# 获取带宽数据
|
||||
local can_upgrade bind_dial_account dial_account stream cur_bandwidth max_bandwidth
|
||||
[ $1 -eq 1 ] && stream="downstream" || stream="upstream"
|
||||
json_get_var can_upgrade "can_upgrade"
|
||||
json_get_var bind_dial_account "bind_dial_account"
|
||||
json_get_var dial_account "dial_account"
|
||||
json_select; json_select "bandwidth" >/dev/null 2>&1
|
||||
json_get_var cur_bandwidth "$stream"
|
||||
json_select; json_select "max_bandwidth" >/dev/null 2>&1
|
||||
json_get_var max_bandwidth "$stream"
|
||||
json_select
|
||||
cur_bandwidth=$(( ${cur_bandwidth:-0} / 1024 ))
|
||||
max_bandwidth=$(( ${max_bandwidth:-0} / 1024 ))
|
||||
|
||||
if [ -n "$bind_dial_account" -a "$bind_dial_account" != "$dial_account" ]; then
|
||||
local outmsg="绑定宽带账号 $bind_dial_account 与当前宽带账号 $dial_account 不一致,请联系迅雷客服解绑(每月仅一次)"; \
|
||||
_log "$outmsg" $(( 1 | 8 | 32 ))
|
||||
down_acc=0; up_acc=0
|
||||
elif [ $can_upgrade -eq 0 ]; then
|
||||
local message; json_get_var message "richmessage"; [ -z "$message" ] && json_get_var message "message"
|
||||
local outmsg="${link_cn}无法提速"; \
|
||||
[ -n "$message" ] && outmsg="${outmsg},原因: $message"; _log "$outmsg" $(( 1 | $1 * 8 | 32 ))
|
||||
[ $1 -eq 1 ] && down_acc=0 || up_acc=0
|
||||
elif [ $cur_bandwidth -ge $max_bandwidth ]; then
|
||||
local outmsg="${link_cn}无需提速。当前带宽 ${cur_bandwidth}M,超过最大可提升带宽 ${max_bandwidth}M"; \
|
||||
_log "$outmsg" $(( 1 | $1 * 8 ))
|
||||
[ $1 -eq 1 ] && down_acc=0 || up_acc=0
|
||||
else
|
||||
if [ -z "$_dial_account" -a -n "$dial_account" ]; then
|
||||
_dial_account=$dial_account
|
||||
_log "_dial_account is $_dial_account" $(( 1 | 4 ))
|
||||
fi
|
||||
local outmsg="${link_cn}可以提速。当前带宽 ${cur_bandwidth}M,可提升至 ${max_bandwidth}M"; _log "$outmsg" $(( 1 | $1 * 8 ))
|
||||
fi
|
||||
;;
|
||||
724) # 724 账号存在异常
|
||||
lasterr=-2
|
||||
local outmsg="获取${link_cn}网络带宽信息失败。原因: 您的账号存在异常,请联系迅雷客服反馈"; _log "$outmsg" $(( 1 | $1 * 8 | 32 ));;
|
||||
3103) # 3103 线路暂不支持
|
||||
lasterr=0
|
||||
local province sp
|
||||
json_get_var province "province_name"; json_get_var sp "sp_name"
|
||||
local outmsg="${link_cn}无法提速。原因: ${province}${sp}线路暂不支持"; _log "$outmsg" $(( 1 | $1 * 8 | 32 ))
|
||||
[ $1 -eq 1 ] && down_acc=0 || up_acc=0
|
||||
;;
|
||||
-1)
|
||||
local outmsg="获取${link_cn}网络带宽信息失败。运营商服务器未响应,请稍候"; _log "$outmsg";;
|
||||
*)
|
||||
local message; json_get_var message "richmessage"; [ -z "$message" ] && json_get_var message "message"
|
||||
local outmsg="获取${link_cn}网络带宽信息失败。错误代码: ${lasterr}"; \
|
||||
[ -n "$message" ] && outmsg="${outmsg},原因: $message"; _log "$outmsg" $(( 1 | $1 * 8 | 32 ));;
|
||||
esac
|
||||
|
||||
[ $lasterr -eq 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 发送带宽提速信号
|
||||
isp_upgrade() {
|
||||
xlnetacc_var $1
|
||||
|
||||
local ret=$($_http_cmd --user-agent="$user_agent" "$access_url/upgrade?$http_args")
|
||||
_log "upgrade $1 is $ret" $(( 1 | 4 ))
|
||||
json_cleanup; json_load "$ret" >/dev/null 2>&1
|
||||
json_get_var lasterr "errno"
|
||||
|
||||
case ${lasterr:=-1} in
|
||||
0)
|
||||
local bandwidth
|
||||
json_select "bandwidth" >/dev/null 2>&1
|
||||
json_get_var bandwidth "downstream"
|
||||
[ ${bandwidth:=0} -ge 1024 ] && bandwidth=$(( $bandwidth / 1024 ))
|
||||
local outmsg="${link_cn}提速成功,带宽已提升到 ${bandwidth}M"; _log "$outmsg" $(( 1 | $1 * 8 ))
|
||||
[ $1 -eq 1 ] && down_acc=2 || up_acc=2
|
||||
;;
|
||||
812) # 812 已处于提速状态
|
||||
lasterr=0
|
||||
local outmsg="${link_cn}提速成功,当前宽带已处于提速状态"; _log "$outmsg" $(( 1 | $1 * 8 ))
|
||||
[ $1 -eq 1 ] && down_acc=2 || up_acc=2
|
||||
;;
|
||||
724) # 724 账号存在异常
|
||||
lasterr=-2
|
||||
local outmsg="${link_cn}提速失败。原因: 您的账号存在异常,请联系迅雷客服反馈"; _log "$outmsg" $(( 1 | $1 * 8 | 32 ));;
|
||||
-1)
|
||||
local outmsg="${link_cn}提速失败。运营商服务器未响应,请稍候"; _log "$outmsg";;
|
||||
*)
|
||||
local message; json_get_var message "richmessage"; [ -z "$message" ] && json_get_var message "message"
|
||||
local outmsg="${link_cn}提速失败。错误代码: ${lasterr}"; \
|
||||
[ -n "$message" ] && outmsg="${outmsg},原因: $message"; _log "$outmsg" $(( 1 | $1 * 8 | 32 ));;
|
||||
esac
|
||||
|
||||
[ $lasterr -eq 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 发送提速心跳信号
|
||||
isp_keepalive() {
|
||||
xlnetacc_var $1
|
||||
|
||||
local ret=$($_http_cmd --user-agent="$user_agent" "$access_url/keepalive?$http_args")
|
||||
_log "keepalive $1 is $ret" $(( 1 | 4 ))
|
||||
json_cleanup; json_load "$ret" >/dev/null 2>&1
|
||||
json_get_var lasterr "errno"
|
||||
|
||||
case ${lasterr:=-1} in
|
||||
0)
|
||||
local outmsg="${link_cn}心跳信号返回正常"; _log "$outmsg";;
|
||||
513) # 513 提速通道不存在
|
||||
lasterr=-2
|
||||
local outmsg="${link_cn}提速超时,提速通道不存在"; _log "$outmsg" $(( 1 | $1 * 8 | 32 ));;
|
||||
-1)
|
||||
local outmsg="${link_cn}心跳信号发送失败。运营商服务器未响应,请稍候"; _log "$outmsg";;
|
||||
*)
|
||||
local message; json_get_var message "richmessage"; [ -z "$message" ] && json_get_var message "message"
|
||||
local outmsg="${link_cn}提速失效。错误代码: ${lasterr}"; \
|
||||
[ -n "$message" ] && outmsg="${outmsg},原因: $message"; _log "$outmsg" $(( 1 | $1 * 8 | 32 ));;
|
||||
esac
|
||||
|
||||
[ $lasterr -eq 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 发送带宽恢复信号
|
||||
isp_recover() {
|
||||
xlnetacc_var $1
|
||||
|
||||
local ret=$($_http_cmd --user-agent="$user_agent" "$access_url/recover?$http_args")
|
||||
_log "recover $1 is $ret" $(( 1 | 4 ))
|
||||
json_cleanup; json_load "$ret" >/dev/null 2>&1
|
||||
json_get_var lasterr "errno"
|
||||
|
||||
case ${lasterr:=-1} in
|
||||
0)
|
||||
local outmsg="${link_cn}带宽已恢复"; _log "$outmsg" $(( 1 | $1 * 8 ))
|
||||
[ $1 -eq 1 ] && down_acc=1 || up_acc=1;;
|
||||
-1)
|
||||
local outmsg="${link_cn}带宽恢复失败。运营商服务器未响应,请稍候"; _log "$outmsg";;
|
||||
*)
|
||||
local message; json_get_var message "richmessage"; [ -z "$message" ] && json_get_var message "message"
|
||||
local outmsg="${link_cn}带宽恢复失败。错误代码: ${lasterr}"; \
|
||||
[ -n "$message" ] && outmsg="${outmsg},原因: $message"; _log "$outmsg" $(( 1 | $1 * 8 | 32 ));;
|
||||
esac
|
||||
|
||||
[ $lasterr -eq 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 查询提速信息,未使用
|
||||
isp_query() {
|
||||
xlnetacc_var $1
|
||||
|
||||
local ret=$($_http_cmd --user-agent="$user_agent" "$access_url/query_try_info?$http_args")
|
||||
_log "query_try_info $1 is $ret" $(( 1 | 4 ))
|
||||
json_cleanup; json_load "$ret" >/dev/null 2>&1
|
||||
json_get_var lasterr "errno"
|
||||
|
||||
[ $lasterr -eq 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 设置参数变量
|
||||
xlnetacc_var() {
|
||||
if [ $1 -eq 1 ]; then
|
||||
let sequence_down++
|
||||
access_url=$_portal_down
|
||||
http_args="sequence=${sequence_down}&client_type=${client_type_down}-${clientVersion}&client_version=${client_type_down//-/}-${clientVersion}&chanel=umeng-10900011&time_and=$(date +%s)000"
|
||||
user_agent=$agent_down
|
||||
link_cn="下行"
|
||||
else
|
||||
let sequence_up++
|
||||
access_url=$_portal_up
|
||||
http_args="sequence=${sequence_up}&client_type=${client_type_up}-${clientVersion}&client_version=${client_type_up//-/}-${clientVersion}"
|
||||
user_agent=$agent_down
|
||||
link_cn="上行"
|
||||
fi
|
||||
http_args="${http_args}&peerid=${_peerid}&userid=${_userid}&sessionid=${_sessionid}&user_type=1&os=android-7.1.1"
|
||||
[ -n "$_dial_account" ] && http_args="${http_args}&dial_account=${_dial_account}"
|
||||
}
|
||||
|
||||
# 重试循环
|
||||
xlnetacc_retry() {
|
||||
if [ $# -ge 3 -a $3 -ne 0 ]; then
|
||||
[ $2 -eq 1 -a $down_acc -ne $3 ] && return 0
|
||||
[ $2 -eq 2 -a $up_acc -ne $3 ] && return 0
|
||||
fi
|
||||
|
||||
local retry=1
|
||||
while : ; do
|
||||
lasterr=
|
||||
eval $1 $2 && break # 成功
|
||||
[ $# -ge 4 -a $retry -ge $4 ] && break || let retry++ # 重试超时
|
||||
case $lasterr in
|
||||
-1) sleep 5s;; # 服务器未响应
|
||||
-2) break;; # 严重错误
|
||||
*) sleep 3s;; # 其它错误
|
||||
esac
|
||||
done
|
||||
|
||||
[ ${lasterr:-0} -eq 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 注销已登录帐号
|
||||
xlnetacc_logout() {
|
||||
[ -z "$_sessionid" ] && return 2
|
||||
[ $# -ge 1 ] && local retry=$1 || local retry=1
|
||||
|
||||
xlnetacc_retry 'isp_recover' 1 2 $retry
|
||||
xlnetacc_retry 'isp_recover' 2 2 $retry
|
||||
xlnetacc_retry 'swjsq_logout' 0 0 $retry
|
||||
[ $down_acc -ne 0 ] && down_acc=1; [ $up_acc -ne 0 ] && up_acc=1
|
||||
_sessionid=; _dial_account=
|
||||
|
||||
[ $lasterr -eq 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 中止信号处理
|
||||
sigterm() {
|
||||
_log "trap sigterm, exit" $(( 1 | 4 ))
|
||||
xlnetacc_logout
|
||||
rm -f "$down_state_file" "$up_state_file"
|
||||
exit 0
|
||||
}
|
||||
|
||||
# 初始化
|
||||
xlnetacc_init() {
|
||||
[ "$1" != "--start" ] && return 1
|
||||
|
||||
# 防止重复启动
|
||||
local pid
|
||||
for pid in $(pidof "${0##*/}"); do
|
||||
[ $pid -ne $$ ] && return 1
|
||||
done
|
||||
|
||||
# 读取设置
|
||||
readonly NAME=xlnetacc
|
||||
readonly LOGFILE=/var/log/${NAME}.log
|
||||
readonly down_state_file=/var/state/${NAME}_down_state
|
||||
readonly up_state_file=/var/state/${NAME}_up_state
|
||||
down_acc=$(uci_get_by_bool "general" "down_acc" 0)
|
||||
up_acc=$(uci_get_by_bool "general" "up_acc" 0)
|
||||
readonly logging=$(uci_get_by_bool "general" "logging" 1)
|
||||
readonly verbose=$(uci_get_by_bool "general" "verbose" 0)
|
||||
network=$(uci_get_by_name "general" "network" "wan")
|
||||
keepalive=$(uci_get_by_name "general" "keepalive" 10)
|
||||
relogin=$(uci_get_by_name "general" "relogin" 0)
|
||||
readonly username=$(uci_get_by_name "general" "account")
|
||||
readonly password=$(uci_get_by_name "general" "password")
|
||||
local enabled=$(uci_get_by_bool "general" "enabled" 0)
|
||||
([ $enabled -eq 0 ] || [ $down_acc -eq 0 -a $up_acc -eq 0 ] || [ -z "$username" -o -z "$password" -o -z "$network" ]) && return 2
|
||||
([ -z "$keepalive" -o -n "${keepalive//[0-9]/}" ] || [ $keepalive -lt 5 -o $keepalive -gt 60 ]) && keepalive=10
|
||||
readonly keepalive=$(( $keepalive ))
|
||||
([ -z "$relogin" -o -n "${relogin//[0-9]/}" ] || [ $relogin -gt 48 ]) && relogin=0
|
||||
readonly relogin=$(( $relogin * 60 * 60 ))
|
||||
|
||||
[ $logging -eq 1 ] && [ ! -d /var/log ] && mkdir -p /var/log
|
||||
[ -f "$LOGFILE" ] && _log "------------------------------"
|
||||
_log "迅雷快鸟正在启动..."
|
||||
|
||||
# 检查外部调用工具
|
||||
command -v wget-ssl >/dev/null || { _log "GNU Wget 未安装"; return 3; }
|
||||
local opensslchk=$(echo -n 'openssl' | openssl dgst -sha1 | awk '{print $2}')
|
||||
[ "$opensslchk" != 'c898fa1e7226427010e329971e82c669f8d8abb4' ] && { _log "openssl-util 未安装或计算错误"; return 3; }
|
||||
|
||||
# 捕获中止信号
|
||||
trap 'sigterm' INT # Ctrl-C
|
||||
trap 'sigterm' QUIT # Ctrl-\
|
||||
trap 'sigterm' TERM # kill
|
||||
|
||||
# 生成设备标识
|
||||
gen_device_sign
|
||||
[ ${#_peerid} -ne 16 -o ${#_devicesign} -ne 71 ] && return 4
|
||||
|
||||
clean_log
|
||||
[ -d /var/state ] || mkdir -p /var/state
|
||||
rm -f "$down_state_file" "$up_state_file"
|
||||
return 0
|
||||
}
|
||||
|
||||
# 程序主体
|
||||
xlnetacc_main() {
|
||||
while : ; do
|
||||
# 获取外网IP地址
|
||||
xlnetacc_retry 'get_bind_ip'
|
||||
gen_http_cmd
|
||||
|
||||
# 注销快鸟帐号
|
||||
xlnetacc_logout 3 && sleep 3s
|
||||
|
||||
# 登录快鸟帐号
|
||||
while : ; do
|
||||
lasterr=
|
||||
swjsq_login
|
||||
case $lasterr in
|
||||
0) break;; # 登录成功
|
||||
-1) sleep 5s;; # 服务器未响应
|
||||
-2) return 7;; # Wget 参数解析错误
|
||||
-3) sleep 3s;; # Wget 网络通信失败
|
||||
6) sleep 130m;; # 需要输入验证码
|
||||
8) sleep 3m;; # 服务器系统维护
|
||||
15) sleep 1s;; # 身份信息已失效
|
||||
*) return 5;; # 登录失败
|
||||
esac
|
||||
done
|
||||
|
||||
# 获取用户信息
|
||||
xlnetacc_retry 'swjsq_getuserinfo'
|
||||
[ $down_acc -eq 0 -a $up_acc -eq 0 ] && break
|
||||
# 登录时间更新
|
||||
xlnetacc_retry 'swjsq_renewal'
|
||||
# 获取提速入口
|
||||
xlnetacc_retry 'swjsq_portal' 1 1
|
||||
xlnetacc_retry 'swjsq_portal' 2 1
|
||||
# 获取带宽信息
|
||||
xlnetacc_retry 'isp_bandwidth' 1 1 10 || { sleep 3m; continue; }
|
||||
xlnetacc_retry 'isp_bandwidth' 2 1 10 || { sleep 3m; continue; }
|
||||
[ $down_acc -eq 0 -a $up_acc -eq 0 ] && break
|
||||
# 带宽提速
|
||||
xlnetacc_retry 'isp_upgrade' 1 1 10 || { sleep 3m; continue; }
|
||||
xlnetacc_retry 'isp_upgrade' 2 1 10 || { sleep 3m; continue; }
|
||||
|
||||
# 心跳保持
|
||||
local timer=$(date +%s)
|
||||
while : ; do
|
||||
clean_log # 清理日志
|
||||
sleep ${keepalive}m
|
||||
[ $relogin -ne 0 -a $(( $(date +%s) - $timer )) -ge $relogin ] && break # 登录超时
|
||||
xlnetacc_retry 'isp_keepalive' 1 2 5 || break
|
||||
xlnetacc_retry 'isp_keepalive' 2 2 5 || break
|
||||
done
|
||||
done
|
||||
xlnetacc_logout
|
||||
_log "无法提速,迅雷快鸟已停止。"
|
||||
return 6
|
||||
}
|
||||
|
||||
# 程序入口
|
||||
xlnetacc_init "$@" && xlnetacc_main
|
||||
exit $?
|
609
package/lean/luci-app-xlnetacc/root/usr/bin/xlnetacc.sh
Executable file
609
package/lean/luci-app-xlnetacc/root/usr/bin/xlnetacc.sh
Executable file
@ -0,0 +1,609 @@
|
||||
#!/bin/sh
|
||||
|
||||
# 声明常量
|
||||
readonly packageName='com.xunlei.vip.swjsq'
|
||||
readonly protocolVersion=300
|
||||
readonly businessType=68
|
||||
readonly sdkVersion='3.1.2.185150'
|
||||
readonly clientVersion='2.7.2.0'
|
||||
readonly agent_xl="android-ok-http-client/xl-acc-sdk/version-$sdkVersion"
|
||||
readonly agent_down='okhttp/3.9.1'
|
||||
readonly agent_up='android-async-http/xl-acc-sdk/version-1.0.0.1'
|
||||
readonly client_type_down='android-swjsq'
|
||||
readonly client_type_up='android-uplink'
|
||||
|
||||
# 声明全局变量
|
||||
_bind_ip=
|
||||
_http_cmd=
|
||||
_peerid=
|
||||
_devicesign=
|
||||
_userid=
|
||||
_loginkey=
|
||||
_sessionid=
|
||||
_portal_down=
|
||||
_portal_up=
|
||||
_dial_account=
|
||||
access_url=
|
||||
http_args=
|
||||
user_agent=
|
||||
link_cn=
|
||||
lasterr=
|
||||
sequence_xl=1000000
|
||||
sequence_down=$(( $(date +%s) / 6 ))
|
||||
sequence_up=$sequence_down
|
||||
|
||||
# 包含用于解析 JSON 格式返回值的函数
|
||||
. /usr/share/libubox/jshn.sh
|
||||
|
||||
# 读取 UCI 设置相关函数
|
||||
uci_get_by_name(){
|
||||
local ret=$(uci -q get $NAME.$1.$2)
|
||||
echo -n ${ret:=$3}
|
||||
}
|
||||
|
||||
uci_get_by_bool(){
|
||||
case $(uci_get_by_name "$1" "$2" "$3") in
|
||||
1|on|true|yes|enabled)echo -n 1;;
|
||||
*)echo -n 0;;
|
||||
esac
|
||||
}
|
||||
|
||||
# 日志和状态栏输出。1 日志文件, 2 系统日志, 4 详细模式, 8 下行状态栏, 16 上行状态栏, 32 失败状态
|
||||
_log(){
|
||||
local msg=$1 flag=$2 timestamp=$(date +'%Y/%m/%d %H:%M:%S')
|
||||
[ -z "$msg" ] && return
|
||||
[ -z "$flag" ] && flag=1
|
||||
|
||||
[ $logging = 0 -a $(( $flag & 1 )) -ne 0 ] && flag=$(( $flag ^ 1 ))
|
||||
if [ $verbose = 0 -a $(( $flag & 4 )) -ne 0 ];then
|
||||
[ $(( $flag & 1 )) -ne 0 ] && flag=$(( $flag ^ 1 ))
|
||||
[ $(( $flag & 2 )) -ne 0 ] && flag=$(( $flag ^ 2 ))
|
||||
fi
|
||||
if [ $down_acc = 0 -a $(( $flag & 8 )) -ne 0 ];then
|
||||
flag=$(( $flag ^ 8 ))
|
||||
[ $up_acc -ne 0 ] && flag=$(( $flag | 16 ))
|
||||
fi
|
||||
if [ $up_acc = 0 -a $(( $flag & 16 )) -ne 0 ];then
|
||||
flag=$(( $flag ^ 16 ))
|
||||
[ $down_acc -ne 0 ] && flag=$(( $flag | 8 ))
|
||||
fi
|
||||
|
||||
[ $(( $flag & 1 )) -ne 0 ] && echo "$timestamp $msg" >> $LOGFILE 2> /dev/null
|
||||
[ $(( $flag & 2 )) -ne 0 ] && logger -p "daemon.info" -t "$NAME" "$msg"
|
||||
|
||||
[ $(( $flag & 32 )) = 0 ] && local color="green" || local color="red"
|
||||
[ $(( $flag & 8 )) -ne 0 ] && echo -n "<font color=$color>$timestamp $msg</font>" > $down_state_file 2> /dev/null
|
||||
[ $(( $flag & 16 )) -ne 0 ] && echo -n "<font color=$color>$timestamp $msg</font>" > $up_state_file 2> /dev/null
|
||||
}
|
||||
|
||||
# 清理日志
|
||||
clean_log(){
|
||||
[ $logging = 1 -a -f "$LOGFILE" ] || return
|
||||
[ $(wc -l "$LOGFILE" | awk '{print $1}') -le 800 ] && return
|
||||
_log "清理日志文件"
|
||||
local logdata=$(tail -n 500 "$LOGFILE")
|
||||
echo "$logdata" > $LOGFILE 2> /dev/null
|
||||
unset logdata
|
||||
}
|
||||
|
||||
# 获取接口IP地址
|
||||
get_bind_ip(){
|
||||
network=$(uci get "xlnetacc.general.network" 2> /dev/null)
|
||||
json_cleanup;json_load "$(ubus call network.interface.$network status 2> /dev/null)" >/dev/null 2>&1
|
||||
json_select "ipv4-address" >/dev/null 2>&1;json_select 1 >/dev/null 2>&1
|
||||
json_get_var _bind_ip "address"
|
||||
if [ -z "$_bind_ip" -o "$_bind_ip" = "0.0.0.0" ];then
|
||||
_log "获取网络 $network IP地址失败"
|
||||
return 1
|
||||
else
|
||||
_log "绑定IP地址: $_bind_ip"
|
||||
return 0
|
||||
fi
|
||||
}
|
||||
|
||||
# 生成设备标识
|
||||
gen_device_sign(){
|
||||
local ifname macaddr
|
||||
while :;do
|
||||
ifname=$(uci get "network.$network.ifname" 2> /dev/null)
|
||||
[ "${ifname:0:1}" = @ ] && network="${ifname:1}" || break
|
||||
done
|
||||
[ -z "$ifname" ] && { _log "获取网络 $network 信息出错";return;}
|
||||
json_cleanup;json_load "$(ubus call network.device status {\"name\":\"$ifname\"} 2> /dev/null)" >/dev/null 2>&1
|
||||
json_get_var macaddr "macaddr"
|
||||
[ -z "$macaddr" ] && { _log "获取网络 $network MAC地址出错";return;}
|
||||
macaddr=$(echo -n "$macaddr" | awk '{print toupper($0)}')
|
||||
|
||||
# 计算peerID
|
||||
local fake_peerid=$(awk -F- '{print toupper($5)}' '/proc/sys/kernel/random/uuid')
|
||||
readonly _peerid="${fake_peerid}004V"
|
||||
_log "_peerid is $_peerid" $(( 1 | 4 ))
|
||||
|
||||
# 计算devicesign
|
||||
# sign = div.10?.device_id + md5(sha1(packageName + businessType + md5(a protocolVersion specific GUID)))
|
||||
local fake_device_id=$(echo -n "${macaddr//:/}" | openssl dgst -md5 | awk '{print $2}')
|
||||
local fake_device_sign=$(echo -n "${fake_device_id}${packageName}${businessType}c7f21687eed3cdb400ca11fc2263c998" \
|
||||
| openssl dgst -sha1 | awk '{print $2}')
|
||||
readonly _devicesign="div101.${fake_device_id}"$(echo -n "$fake_device_sign" | openssl dgst -md5 | awk '{print $2}')
|
||||
_log "_devicesign is $_devicesign" $(( 1 | 4 ))
|
||||
}
|
||||
|
||||
# 快鸟帐号通用参数
|
||||
swjsq_json(){
|
||||
let sequence_xl++
|
||||
# 生成POST数据
|
||||
json_init
|
||||
json_add_string protocolVersion "$protocolVersion"
|
||||
json_add_string sequenceNo "$sequence_xl"
|
||||
json_add_string platformVersion '10'
|
||||
json_add_string isCompressed '0'
|
||||
json_add_string appid "$businessType"
|
||||
json_add_string clientVersion "$clientVersion"
|
||||
json_add_string peerID "$_peerid"
|
||||
json_add_string appName "ANDROID-$packageName"
|
||||
json_add_string sdkVersion "${sdkVersion##*.}"
|
||||
json_add_string devicesign "$_devicesign"
|
||||
json_add_string netWorkType 'WIFI'
|
||||
json_add_string providerName 'OTHER'
|
||||
json_add_string deviceModel 'MI'
|
||||
json_add_string deviceName 'Xiaomi Mi'
|
||||
json_add_string OSVersion "7.1.1"
|
||||
}
|
||||
|
||||
# 帐号登录
|
||||
swjsq_login(){
|
||||
swjsq_json
|
||||
if [ -z "$_userid" -o -z "$_loginkey" ];then
|
||||
access_url='https://mobile-login.xunlei.com/login'
|
||||
json_add_string userName "$username"
|
||||
json_add_string passWord "$password"
|
||||
json_add_string verifyKey
|
||||
json_add_string verifyCode
|
||||
json_add_string isMd5Pwd '0'
|
||||
else
|
||||
access_url='https://mobile-login.xunlei.com/loginkey'
|
||||
json_add_string userName "$_userid"
|
||||
json_add_string loginKey "$_loginkey"
|
||||
fi
|
||||
json_close_object
|
||||
|
||||
local ret=$($_http_cmd -A "$agent_xl" -d "$(json_dump)" "$access_url")
|
||||
case $? in
|
||||
0)_log "login is $ret" $(( 1 | 4 ));json_cleanup;json_load "$ret" >/dev/null 2>&1;json_get_var lasterr "errorCode";;
|
||||
2)lasterr=-2;;
|
||||
28)lasterr=-3;;
|
||||
*)lasterr=-1;;
|
||||
esac
|
||||
|
||||
case ${lasterr:=-1} in
|
||||
0)json_get_var _userid "userID";json_get_var _loginkey "loginKey";json_get_var _sessionid "sessionID";_log "_sessionid is $_sessionid" $(( 1 | 4 ));local outmsg="帐号登录成功";_log "$outmsg" $(( 1 | 8 ));;
|
||||
15)_userid=;_loginkey=;;# 身份信息已失效
|
||||
-1)local outmsg="帐号登录失败。迅雷服务器未响应,请稍候";_log "$outmsg";;
|
||||
-2)local outmsg="cURL 参数解析错误,请更新 cURL";_log "$outmsg" $(( 1 | 8 | 32 ));;
|
||||
-3)local outmsg="cURL 网络通信失败,请稍候";_log "$outmsg";;
|
||||
*)local errorDesc;json_get_var errorDesc "errorDesc";local outmsg="帐号登录失败。错误代码: ${lasterr}";[ -n "$errorDesc" ] && outmsg="${outmsg},原因: $errorDesc";_log "$outmsg" $(( 1 | 8 | 32 ));;
|
||||
esac
|
||||
|
||||
[ $lasterr = 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 帐号注销
|
||||
swjsq_logout(){
|
||||
swjsq_json
|
||||
json_add_string userID "$_userid"
|
||||
json_add_string sessionID "$_sessionid"
|
||||
json_close_object
|
||||
|
||||
local ret=$($_http_cmd -A "$agent_xl" -d "$(json_dump)" 'https://mobile-login.xunlei.com/logout')
|
||||
_log "logout is $ret" $(( 1 | 4 ))
|
||||
json_cleanup;json_load "$ret" >/dev/null 2>&1
|
||||
json_get_var lasterr "errorCode"
|
||||
|
||||
case ${lasterr:=-1} in
|
||||
0)_sessionid=;local outmsg="帐号注销成功";_log "$outmsg" $(( 1 | 8 ));;
|
||||
-1)local outmsg="帐号注销失败。迅雷服务器未响应,请稍候";_log "$outmsg";;
|
||||
*)local errorDesc;json_get_var errorDesc "errorDesc";local outmsg="帐号注销失败。错误代码: ${lasterr}";[ -n "$errorDesc" ] && outmsg="${outmsg},原因: $errorDesc";_log "$outmsg" $(( 1 | 8 | 32 ));;
|
||||
esac
|
||||
|
||||
[ $lasterr = 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 获取用户信息
|
||||
swjsq_getuserinfo(){
|
||||
local _vasid vasid_down=14 vasid_up=33 outmsg
|
||||
[ $down_acc -ne 0 ] && _vasid="${_vasid}${vasid_down},";[ $up_acc -ne 0 ] && _vasid="${_vasid}${vasid_up},"
|
||||
swjsq_json
|
||||
json_add_string userID "$_userid"
|
||||
json_add_string sessionID "$_sessionid"
|
||||
json_add_string vasid "$_vasid"
|
||||
json_close_object
|
||||
|
||||
local ret=$($_http_cmd -A "$agent_xl" -d "$(json_dump)" 'https://mobile-login.xunlei.com/getuserinfo')
|
||||
_log "getuserinfo is $ret" $(( 1 | 4 ))
|
||||
json_cleanup;json_load "$ret" >/dev/null 2>&1
|
||||
json_get_var lasterr "errorCode"
|
||||
|
||||
case ${lasterr:=-1} in
|
||||
0)local index=1 can_down=0 vasid isVip isYear expireDate;json_select "vipList" >/dev/null 2>&1
|
||||
while :;do
|
||||
json_select $index >/dev/null 2>&1
|
||||
[ $? -ne 0 ] && break
|
||||
json_get_var vasid "vasid"
|
||||
json_get_var isVip "isVip"
|
||||
json_get_var isYear "isYear"
|
||||
json_get_var expireDate "expireDate"
|
||||
json_select ".." >/dev/null 2>&1
|
||||
let index++
|
||||
case ${vasid:-0} in
|
||||
2)[ $down_acc -ne 0 ] && outmsg="迅雷超级会员" || continue;;
|
||||
$vasid_down)outmsg="迅雷快鸟会员";;
|
||||
$vasid_up)outmsg="上行提速会员";;
|
||||
*)continue;;
|
||||
esac
|
||||
if [ ${isVip:-0} = 1 -o ${isYear:-0} = 1 ];then
|
||||
outmsg="${outmsg}有效。会员到期时间:${expireDate:0:4}-${expireDate:4:2}-${expireDate:6:2}"
|
||||
[ $vasid = $vasid_up ] && _log "$outmsg" $(( 1 | 16 )) || _log "$outmsg" $(( 1 | 8 ))
|
||||
[ $vasid -ne $vasid_up ] && can_down=$(( $can_down | 1 ))
|
||||
else
|
||||
if [ ${#expireDate} -ge 8 ];then
|
||||
outmsg="${outmsg}已到期。会员到期时间:${expireDate:0:4}-${expireDate:4:2}-${expireDate:6:2}"
|
||||
else
|
||||
outmsg="${outmsg}无效"
|
||||
fi
|
||||
[ $vasid = $vasid_up ] && _log "$outmsg" $(( 1 | 16 | 32 )) || _log "$outmsg" $(( 1 | 8 | 32 ))
|
||||
[ $vasid = $vasid_up ] && up_acc=0
|
||||
fi
|
||||
done
|
||||
[ $can_down = 0 ] && down_acc=0;;
|
||||
-1)outmsg="获取迅雷会员信息失败。迅雷服务器未响应,请稍候";_log "$outmsg";;
|
||||
*)local errorDesc;json_get_var errorDesc "errorDesc";outmsg="获取迅雷会员信息失败。错误代码: ${lasterr}";[ -n "$errorDesc" ] && outmsg="${outmsg},原因: $errorDesc";_log "$outmsg" $(( 1 | 8 | 32 ));;
|
||||
esac
|
||||
|
||||
[ $lasterr = 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 登录时间更新
|
||||
swjsq_renewal(){
|
||||
xlnetacc_var 1
|
||||
local limitdate=$(date +%Y%m%d -d "1970.01.01-00:00:$(( $(date +%s) + 30 * 24 * 60 * 60 ))")
|
||||
|
||||
access_url='http://api.ext.swjsq.vip.xunlei.com'
|
||||
local ret=$($_http_cmd -A "$user_agent" "$access_url/renewal?${http_args%&dial_account=*}&limitdate=$limitdate")
|
||||
_log "renewal is $ret" $(( 1 | 4 ))
|
||||
json_cleanup;json_load "$ret" >/dev/null 2>&1
|
||||
json_get_var lasterr "errno"
|
||||
|
||||
case ${lasterr:=-1} in
|
||||
0)local outmsg="更新登录时间成功。帐号登录展期:${limitdate:0:4}-${limitdate:4:2}-${limitdate:6:2}";_log "$outmsg";;
|
||||
-1)local outmsg="更新登录时间失败。迅雷服务器未响应,请稍候";_log "$outmsg";;
|
||||
*)local message;json_get_var message "richmessage";local outmsg="更新登录时间失败。错误代码: ${lasterr}";[ -n "$message" ] && outmsg="${outmsg},原因: $message";_log "$outmsg" $(( 1 | 8 | 32 ));;
|
||||
esac
|
||||
|
||||
[ $lasterr = 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 获取提速入口
|
||||
swjsq_portal(){
|
||||
xlnetacc_var $1
|
||||
|
||||
[ $1 = 1 ] && access_url='http://api.portal.swjsq.vip.xunlei.com:81/v2/queryportal' || \
|
||||
access_url='http://api.upportal.swjsq.vip.xunlei.com/v2/queryportal'
|
||||
local ret=$($_http_cmd -A "$user_agent" "$access_url")
|
||||
_log "portal $1 is $ret" $(( 1 | 4 ))
|
||||
json_cleanup;json_load "$ret" >/dev/null 2>&1
|
||||
json_get_var lasterr "errno"
|
||||
|
||||
case ${lasterr:=-1} in
|
||||
0)local interface_ip interface_port province sp;json_get_var interface_ip "interface_ip";json_get_var interface_port "interface_port";json_get_var province "province_name";json_get_var sp "sp_name"
|
||||
if [ $1 = 1 ];then
|
||||
_portal_down="http://$interface_ip:$interface_port/v2"
|
||||
_log "_portal_down is $_portal_down" $(( 1 | 4 ))
|
||||
else
|
||||
_portal_up="http://$interface_ip:$interface_port/v2"
|
||||
_log "_portal_up is $_portal_up" $(( 1 | 4 ))
|
||||
fi
|
||||
local outmsg="获取${link_cn}提速入口成功";[ -n "$province" -a -n "$sp" ] && outmsg="${outmsg}。运营商:${province}${sp}";_log "$outmsg" $(( 1 | $1 * 8 ));;
|
||||
-1)local outmsg="获取${link_cn}提速入口失败。迅雷服务器未响应,请稍候";_log "$outmsg";;
|
||||
*)local message;json_get_var message "message";local outmsg="获取${link_cn}提速入口失败。错误代码: ${lasterr}";[ -n "$message" ] && outmsg="${outmsg},原因: $message";_log "$outmsg" $(( 1 | $1 * 8 | 32 ));;
|
||||
esac
|
||||
|
||||
[ $lasterr = 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 获取网络带宽信息
|
||||
isp_bandwidth(){
|
||||
xlnetacc_var $1
|
||||
|
||||
local ret=$($_http_cmd -A "$user_agent" "$access_url/bandwidth?${http_args%&dial_account=*}")
|
||||
_log "bandwidth $1 is $ret" $(( 1 | 4 ))
|
||||
json_cleanup;json_load "$ret" >/dev/null 2>&1
|
||||
json_get_var lasterr "errno"
|
||||
|
||||
case ${lasterr:=-1} in
|
||||
# 获取带宽数据
|
||||
0)local can_upgrade bind_dial_account dial_account stream cur_bandwidth max_bandwidth;[ $1 = 1 ] && stream="downstream" || stream="upstream";json_get_var can_upgrade "can_upgrade"
|
||||
json_get_var bind_dial_account "bind_dial_account";json_get_var dial_account "dial_account";json_select;json_select "bandwidth" >/dev/null 2>&1;json_get_var cur_bandwidth "$stream"
|
||||
json_select;json_select "max_bandwidth" >/dev/null 2>&1;json_get_var max_bandwidth "$stream";json_select;cur_bandwidth=$(( ${cur_bandwidth:-0} / 1024 ));max_bandwidth=$(( ${max_bandwidth:-0} / 1024 ))
|
||||
if [ -n "$bind_dial_account" -a "$bind_dial_account" != "$dial_account" ];then
|
||||
local outmsg="绑定宽带账号 $bind_dial_account 与当前宽带账号 $dial_account 不一致,请联系迅雷客服解绑(每月仅一次)";_log "$outmsg" $(( 1 | 8 | 32 ))
|
||||
down_acc=0;up_acc=0
|
||||
elif [ $can_upgrade = 0 ];then
|
||||
local message;json_get_var message "richmessage";[ -z "$message" ] && json_get_var message "message"
|
||||
local outmsg="${link_cn}无法提速";[ -n "$message" ] && outmsg="${outmsg},原因: $message";_log "$outmsg" $(( 1 | $1 * 8 | 32 ))
|
||||
[ $1 = 1 ] && down_acc=0 || up_acc=0
|
||||
elif [ $cur_bandwidth -ge $max_bandwidth ];then
|
||||
local outmsg="${link_cn}无需提速。当前带宽 ${cur_bandwidth}M,超过最大可提升带宽 ${max_bandwidth}M";_log "$outmsg" $(( 1 | $1 * 8 ))
|
||||
[ $1 = 1 ] && down_acc=0 || up_acc=0
|
||||
else
|
||||
if [ -z "$_dial_account" -a -n "$dial_account" ];then
|
||||
_dial_account=$dial_account
|
||||
_log "_dial_account is $_dial_account" $(( 1 | 4 ))
|
||||
fi
|
||||
local outmsg="${link_cn}可以提速。当前带宽 ${cur_bandwidth}M,可提升至 ${max_bandwidth}M";_log "$outmsg" $(( 1 | $1 * 8 ))
|
||||
fi;;
|
||||
# 724 账号存在异常
|
||||
724)lasterr=-2;local outmsg="获取${link_cn}网络带宽信息失败。原因: 您的账号存在异常,请联系迅雷客服反馈";_log "$outmsg" $(( 1 | $1 * 8 | 32 ));;
|
||||
# 3103 线路暂不支持
|
||||
3103)lasterr=0;local province sp;json_get_var province "province_name";json_get_var sp "sp_name";local outmsg="${link_cn}无法提速。原因: ${province}${sp}线路暂不支持";_log "$outmsg" $(( 1 | $1 * 8 | 32 ))
|
||||
[ $1 = 1 ] && down_acc=0 || up_acc=0;;
|
||||
-1)local outmsg="获取${link_cn}网络带宽信息失败。运营商服务器未响应,请稍候";_log "$outmsg";;
|
||||
*)local message;json_get_var message "richmessage";[ -z "$message" ] && json_get_var message "message"
|
||||
local outmsg="获取${link_cn}网络带宽信息失败。错误代码: ${lasterr}";[ -n "$message" ] && outmsg="${outmsg},原因: $message";_log "$outmsg" $(( 1 | $1 * 8 | 32 ));;
|
||||
esac
|
||||
|
||||
[ $lasterr = 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 发送带宽提速信号
|
||||
isp_upgrade(){
|
||||
xlnetacc_var $1
|
||||
|
||||
local ret=$($_http_cmd -A "$user_agent" "$access_url/upgrade?$http_args")
|
||||
_log "upgrade $1 is $ret" $(( 1 | 4 ))
|
||||
json_cleanup;json_load "$ret" >/dev/null 2>&1
|
||||
json_get_var lasterr "errno"
|
||||
|
||||
case ${lasterr:=-1} in
|
||||
0)local bandwidth;json_select "bandwidth" >/dev/null 2>&1;json_get_var bandwidth "downstream";bandwidth=$(( ${bandwidth:-0} / 1024 ))
|
||||
local outmsg="${link_cn}提速成功,带宽已提升到 ${bandwidth}M";_log "$outmsg" $(( 1 | $1 * 8 ));[ $1 = 1 ] && down_acc=2 || up_acc=2;;
|
||||
# 812 已处于提速状态
|
||||
812)lasterr=0;local outmsg="${link_cn}提速成功,当前宽带已处于提速状态";_log "$outmsg" $(( 1 | $1 * 8 ));[ $1 = 1 ] && down_acc=2 || up_acc=2;;
|
||||
# 724 账号存在异常
|
||||
724)lasterr=-2;local outmsg="${link_cn}提速失败。原因: 您的账号存在异常,请联系迅雷客服反馈";_log "$outmsg" $(( 1 | $1 * 8 | 32 ));;
|
||||
-1)local outmsg="${link_cn}提速失败。运营商服务器未响应,请稍候";_log "$outmsg";;
|
||||
*)local message;json_get_var message "richmessage";[ -z "$message" ] && json_get_var message "message"
|
||||
local outmsg="${link_cn}提速失败。错误代码: ${lasterr}";[ -n "$message" ] && outmsg="${outmsg},原因: $message";_log "$outmsg" $(( 1 | $1 * 8 | 32 ));;
|
||||
esac
|
||||
|
||||
[ $lasterr = 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 发送提速心跳信号
|
||||
isp_keepalive(){
|
||||
xlnetacc_var $1
|
||||
|
||||
local ret=$($_http_cmd -A "$user_agent" "$access_url/keepalive?$http_args")
|
||||
_log "keepalive $1 is $ret" $(( 1 | 4 ))
|
||||
json_cleanup;json_load "$ret" >/dev/null 2>&1
|
||||
json_get_var lasterr "errno"
|
||||
|
||||
case ${lasterr:=-1} in
|
||||
0)local outmsg="${link_cn}心跳信号返回正常";_log "$outmsg";;
|
||||
# 513 提速通道不存在
|
||||
513)lasterr=-2;local outmsg="${link_cn}提速超时,提速通道不存在";_log "$outmsg" $(( 1 | $1 * 8 | 32 ));;
|
||||
-1)local outmsg="${link_cn}心跳信号发送失败。运营商服务器未响应,请稍候";_log "$outmsg";;
|
||||
*)local message;json_get_var message "richmessage";[ -z "$message" ] && json_get_var message "message"
|
||||
local outmsg="${link_cn}提速失效。错误代码: ${lasterr}";[ -n "$message" ] && outmsg="${outmsg},原因: $message";_log "$outmsg" $(( 1 | $1 * 8 | 32 ));;
|
||||
esac
|
||||
|
||||
[ $lasterr = 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 发送带宽恢复信号
|
||||
isp_recover(){
|
||||
xlnetacc_var $1
|
||||
|
||||
local ret=$($_http_cmd -A "$user_agent" "$access_url/recover?$http_args")
|
||||
_log "recover $1 is $ret" $(( 1 | 4 ))
|
||||
json_cleanup;json_load "$ret" >/dev/null 2>&1
|
||||
json_get_var lasterr "errno"
|
||||
|
||||
case ${lasterr:=-1} in
|
||||
0)local outmsg="${link_cn}带宽已恢复";_log "$outmsg" $(( 1 | $1 * 8 ));[ $1 = 1 ] && down_acc=1 || up_acc=1;;
|
||||
-1)local outmsg="${link_cn}带宽恢复失败。运营商服务器未响应,请稍候";_log "$outmsg";;
|
||||
*)local message;json_get_var message "richmessage";[ -z "$message" ] && json_get_var message "message"
|
||||
local outmsg="${link_cn}带宽恢复失败。错误代码: ${lasterr}";[ -n "$message" ] && outmsg="${outmsg},原因: $message";_log "$outmsg" $(( 1 | $1 * 8 | 32 ));;
|
||||
esac
|
||||
|
||||
[ $lasterr = 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 查询提速信息,未使用
|
||||
isp_query(){
|
||||
xlnetacc_var $1
|
||||
|
||||
local ret=$($_http_cmd -A "$user_agent" "$access_url/query_try_info?$http_args")
|
||||
_log "query_try_info $1 is $ret" $(( 1 | 4 ))
|
||||
json_cleanup;json_load "$ret" >/dev/null 2>&1
|
||||
json_get_var lasterr "errno"
|
||||
|
||||
[ $lasterr = 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 设置参数变量
|
||||
xlnetacc_var(){
|
||||
if [ $1 = 1 ];then
|
||||
let sequence_down++
|
||||
access_url=$_portal_down
|
||||
http_args="sequence=${sequence_down}&client_type=${client_type_down}-${clientVersion}&client_version=${client_type_down//-/}-${clientVersion}&chanel=umeng-10900011&time_and=$(date +%s)000"
|
||||
user_agent=$agent_down
|
||||
link_cn="下行"
|
||||
else
|
||||
let sequence_up++
|
||||
access_url=$_portal_up
|
||||
http_args="sequence=${sequence_up}&client_type=${client_type_up}-${clientVersion}&client_version=${client_type_up//-/}-${clientVersion}"
|
||||
user_agent=$agent_down
|
||||
link_cn="上行"
|
||||
fi
|
||||
http_args="${http_args}&peerid=${_peerid}&userid=${_userid}&sessionid=${_sessionid}&user_type=1&os=android-7.1.1"
|
||||
[ -n "$_dial_account" ] && http_args="${http_args}&dial_account=${_dial_account}"
|
||||
}
|
||||
|
||||
# 重试循环
|
||||
xlnetacc_retry(){
|
||||
if [ $# -ge 3 ];then
|
||||
if [ $3 -ne 0 ];then
|
||||
[ $2 = 1 -a $down_acc -ne $3 ] && return 0
|
||||
[ $2 = 2 -a $up_acc -ne $3 ] && return 0
|
||||
fi
|
||||
fi
|
||||
local retry=1
|
||||
while :;do
|
||||
lasterr=
|
||||
eval $1 $2 && break # 成功
|
||||
[ $# -ge 4 -a $retry -ge $4 ] && break || let retry++ # 重试超时
|
||||
case $lasterr in
|
||||
-1)sleep 5s;;# 服务器未响应
|
||||
-2)break;;# 严重错误
|
||||
*)sleep 3s;;# 其它错误
|
||||
esac
|
||||
done
|
||||
|
||||
[ ${lasterr:-0} = 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 注销已登录帐号
|
||||
xlnetacc_logout(){
|
||||
[ -z "$_sessionid" ] && return 2
|
||||
[ $# -ge 1 ] && local retry=$1 || local retry=1
|
||||
|
||||
xlnetacc_retry 'isp_recover' 1 2 $retry
|
||||
xlnetacc_retry 'isp_recover' 2 2 $retry
|
||||
xlnetacc_retry 'swjsq_logout' 0 0 $retry
|
||||
[ $down_acc -ne 0 ] && down_acc=1;[ $up_acc -ne 0 ] && up_acc=1
|
||||
_sessionid=;_dial_account=
|
||||
|
||||
[ $lasterr = 0 ] && return 0 || return 1
|
||||
}
|
||||
|
||||
# 中止信号处理
|
||||
sigterm(){
|
||||
_log "trap sigterm, exit" $(( 1 | 4 ))
|
||||
xlnetacc_logout
|
||||
rm -f "$down_state_file" "$up_state_file"
|
||||
exit 0
|
||||
}
|
||||
|
||||
# 初始化
|
||||
xlnetacc_init(){
|
||||
[ "$1" != "--start" ] && return 1
|
||||
|
||||
# 防止重复启动
|
||||
[ -f /var/lock/xlnetacc.lock ] && return 1
|
||||
touch /var/lock/xlnetacc.lock
|
||||
|
||||
# 读取设置
|
||||
readonly NAME=xlnetacc
|
||||
readonly LOGFILE=/var/log/${NAME}.log
|
||||
readonly down_state_file=/var/state/${NAME}_down_state
|
||||
readonly up_state_file=/var/state/${NAME}_up_state
|
||||
down_acc=$(uci_get_by_bool "general" "down_acc" 0)
|
||||
up_acc=$(uci_get_by_bool "general" "up_acc" 0)
|
||||
readonly logging=$(uci_get_by_bool "general" "logging" 1)
|
||||
readonly verbose=$(uci_get_by_bool "general" "verbose" 0)
|
||||
network=$(uci_get_by_name "general" "network" "wan")
|
||||
keepalive=$(uci_get_by_name "general" "keepalive" 10)
|
||||
relogin=$(uci_get_by_name "general" "relogin" 0)
|
||||
readonly username=$(uci_get_by_name "general" "account")
|
||||
readonly password=$(uci_get_by_name "general" "password")
|
||||
local enabled=$(uci_get_by_bool "general" "enabled" 0)
|
||||
([ $enabled = 0 ] || [ $down_acc = 0 -a $up_acc = 0 ] || [ -z "$username" -o -z "$password" -o -z "$network" ]) && return 2
|
||||
([ -z "$keepalive" -o -n "${keepalive//[0-9]/}" ] || [ $keepalive -lt 5 -o $keepalive -gt 60 ]) && keepalive=10
|
||||
readonly keepalive=$(( $keepalive ))
|
||||
([ -z "$relogin" -o -n "${relogin//[0-9]/}" ] || [ $relogin -gt 48 ]) && relogin=0
|
||||
readonly relogin=$(( $relogin * 60 * 60 ))
|
||||
|
||||
[ $logging = 1 ] && [ ! -d /var/log ] && mkdir -p /var/log
|
||||
[ -f "$LOGFILE" ] && _log "------------------------------"
|
||||
_log "迅雷快鸟正在启动..."
|
||||
|
||||
# 检查外部调用工具
|
||||
command -v curl >/dev/null || { _log "cURL 未安装";return 3;}
|
||||
local opensslchk=$(echo -n 'openssl' | openssl dgst -sha1 | awk '{print $2}')
|
||||
[ "$opensslchk" != 'c898fa1e7226427010e329971e82c669f8d8abb4' ] && { _log "openssl-util 未安装或计算错误";return 3;}
|
||||
|
||||
# 捕获中止信号
|
||||
trap 'sigterm' INT # Ctrl-C
|
||||
trap 'sigterm' QUIT # Ctrl-\
|
||||
trap 'sigterm' TERM # kill
|
||||
|
||||
# 生成设备标识
|
||||
gen_device_sign
|
||||
[ ${#_peerid} -ne 16 -o ${#_devicesign} -ne 71 ] && return 4
|
||||
|
||||
clean_log
|
||||
[ -d /var/state ] || mkdir -p /var/state
|
||||
rm -f "$down_state_file" "$up_state_file"
|
||||
return 0
|
||||
}
|
||||
|
||||
# 程序主体
|
||||
xlnetacc_main(){
|
||||
while :;do
|
||||
# 获取外网IP地址
|
||||
xlnetacc_retry 'get_bind_ip'
|
||||
_http_cmd="curl -Lfs -m 5 --interface $_bind_ip"
|
||||
|
||||
# 注销快鸟帐号
|
||||
xlnetacc_logout 3 && sleep 3s
|
||||
|
||||
# 登录快鸟帐号
|
||||
while :;do
|
||||
lasterr=
|
||||
swjsq_login
|
||||
case $lasterr in
|
||||
0)break;;# 登录成功
|
||||
-1)sleep 5s;;# 服务器未响应
|
||||
-2)return 7;;# cURL 参数解析错误
|
||||
-3)sleep 3s;;# cURL 网络通信失败
|
||||
6)sleep 130m;;# 需要输入验证码
|
||||
8)sleep 3m;;# 服务器系统维护
|
||||
15)sleep 1s;;# 身份信息已失效
|
||||
*)return 5;;# 登录失败
|
||||
esac
|
||||
done
|
||||
|
||||
# 获取用户信息
|
||||
xlnetacc_retry 'swjsq_getuserinfo'
|
||||
[ $down_acc = 0 -a $up_acc = 0 ] && break
|
||||
# 登录时间更新
|
||||
xlnetacc_retry 'swjsq_renewal'
|
||||
# 获取提速入口
|
||||
xlnetacc_retry 'swjsq_portal' 1 1
|
||||
xlnetacc_retry 'swjsq_portal' 2 1
|
||||
# 获取带宽信息
|
||||
xlnetacc_retry 'isp_bandwidth' 1 1 10 || { sleep 3m;continue;}
|
||||
xlnetacc_retry 'isp_bandwidth' 2 1 10 || { sleep 3m;continue;}
|
||||
[ $down_acc = 0 -a $up_acc = 0 ] && break
|
||||
# 带宽提速
|
||||
xlnetacc_retry 'isp_upgrade' 1 1 10 || { sleep 3m;continue;}
|
||||
xlnetacc_retry 'isp_upgrade' 2 1 10 || { sleep 3m;continue;}
|
||||
|
||||
# 心跳保持
|
||||
local timer=$(date +%s)
|
||||
while :;do
|
||||
clean_log # 清理日志
|
||||
sleep ${keepalive}m
|
||||
[ $relogin -ne 0 -a $(( $(date +%s) - $timer )) -ge $relogin ] && break # 登录超时
|
||||
xlnetacc_retry 'isp_keepalive' 1 2 5 || break
|
||||
xlnetacc_retry 'isp_keepalive' 2 2 5 || break
|
||||
done
|
||||
done
|
||||
xlnetacc_logout
|
||||
_log "无法提速,迅雷快鸟已停止。"
|
||||
return 6
|
||||
}
|
||||
|
||||
# 程序入口
|
||||
xlnetacc_init "$@" && xlnetacc_main
|
||||
exit $?
|
@ -0,0 +1,11 @@
|
||||
{
|
||||
"luci-app-xlnetacc": {
|
||||
"description": "Grant UCI access for luci-app-xlnetacc",
|
||||
"read": {
|
||||
"uci": [ "xlnetacc" ]
|
||||
},
|
||||
"write": {
|
||||
"uci": [ "xlnetacc" ]
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user