From 95dfd326ad0022c3bc8f7f946fbd22ac6f9fbba5 Mon Sep 17 00:00:00 2001 From: lean Date: Fri, 22 Jan 2021 11:27:27 +0800 Subject: [PATCH] luci-app-jd-dailybonus: bump version --- package/lean/luci-app-jd-dailybonus/Makefile | 4 +- .../luasrc/controller/jd-dailybonus.lua | 134 +++++--- .../luasrc/model/cbi/jd-dailybonus/client.lua | 111 +++--- .../view/jd-dailybonus/cookie_tools.htm | 20 +- .../view/jd-dailybonus/update_service.htm | 316 +++++++++++++----- .../po/zh-cn/jd-dailybonus.po | 111 ------ .../root/etc/config/jd-dailybonus | 19 +- .../usr/share/jd-dailybonus/JD_DailyBonus.js | 123 +------ .../usr/share/jd-dailybonus/jd_cookie.lua | 168 ++++++++++ .../root/usr/share/jd-dailybonus/newapp.sh | 89 ++--- .../root/usr/share/jd-dailybonus/requests.lua | 303 +++++++++++++++++ .../root/www/jd-dailybonus/JDCookie.zip | Bin 20108 -> 0 bytes .../root/www/jd-dailybonus/qrcode.min.js | 1 + 13 files changed, 922 insertions(+), 477 deletions(-) delete mode 100644 package/lean/luci-app-jd-dailybonus/po/zh-cn/jd-dailybonus.po create mode 100644 package/lean/luci-app-jd-dailybonus/root/usr/share/jd-dailybonus/jd_cookie.lua create mode 100644 package/lean/luci-app-jd-dailybonus/root/usr/share/jd-dailybonus/requests.lua delete mode 100644 package/lean/luci-app-jd-dailybonus/root/www/jd-dailybonus/JDCookie.zip create mode 100644 package/lean/luci-app-jd-dailybonus/root/www/jd-dailybonus/qrcode.min.js diff --git a/package/lean/luci-app-jd-dailybonus/Makefile b/package/lean/luci-app-jd-dailybonus/Makefile index 3fe61a796..d4a67e644 100644 --- a/package/lean/luci-app-jd-dailybonus/Makefile +++ b/package/lean/luci-app-jd-dailybonus/Makefile @@ -7,8 +7,8 @@ include $(TOPDIR)/rules.mk PKG_NAME:=luci-app-jd-dailybonus LUCI_PKGARCH:=all -PKG_VERSION:=0.8.9 -PKG_RELEASE:=20201230 +PKG_VERSION:=1.0.0 +PKG_RELEASE:=1 include $(INCLUDE_DIR)/package.mk diff --git a/package/lean/luci-app-jd-dailybonus/luasrc/controller/jd-dailybonus.lua b/package/lean/luci-app-jd-dailybonus/luasrc/controller/jd-dailybonus.lua index 38914fe75..f284836d3 100644 --- a/package/lean/luci-app-jd-dailybonus/luasrc/controller/jd-dailybonus.lua +++ b/package/lean/luci-app-jd-dailybonus/luasrc/controller/jd-dailybonus.lua @@ -1,82 +1,112 @@ -- Copyright (C) 2020 jerrykuku -- Licensed to the public under the GNU General Public License v3. -module("luci.controller.jd-dailybonus", package.seeall) -function index() - if not nixio.fs.access("/etc/config/jd-dailybonus") then - return +module('luci.controller.jd-dailybonus', package.seeall) +package.path = package.path .. ';/usr/share/jd-dailybonus/?.lua' +function index() + if not nixio.fs.access('/etc/config/jd-dailybonus') then + return end - entry({"admin", "services", "jd-dailybonus"}, alias("admin", "services", "jd-dailybonus", "client"), _("JD-DailyBonus"), 10).dependent = true -- 首页 - entry({"admin", "services", "jd-dailybonus", "client"}, cbi("jd-dailybonus/client"),_("Client"), 10).leaf = true -- 基本设置 - entry({"admin", "services", "jd-dailybonus", "log"},form("jd-dailybonus/log"),_("Log"), 30).leaf = true -- 日志页面 - entry({"admin", "services", "jd-dailybonus", "script"},form("jd-dailybonus/script"),_("Script"), 20).leaf = true -- 直接配置脚本 - entry({"admin", "services", "jd-dailybonus", "run"}, call("run")) -- 执行程序 - entry({"admin", "services", "jd-dailybonus", "update"}, call("update")) -- 执行更新 - entry({"admin", "services", "jd-dailybonus", "check_update"}, call("check_update")) -- 检查更新 + entry({'admin', 'services', 'jd-dailybonus'}, alias('admin', 'services', 'jd-dailybonus', 'client'), _('京东签到服务'), 10).dependent = true -- 首页 + entry({'admin', 'services', 'jd-dailybonus', 'client'}, cbi('jd-dailybonus/client', {hidesavebtn = true, hideresetbtn = true}), _('客户端'), 10).leaf = true -- 基本设置 + entry({'admin', 'services', 'jd-dailybonus', 'log'}, form('jd-dailybonus/log'), _('日志'), 30).leaf = true -- 日志页面 + entry({'admin', 'services', 'jd-dailybonus', 'script'}, form('jd-dailybonus/script'), _('脚本查看'), 20).leaf = true -- 直接配置脚本 + entry({'admin', 'services', 'jd-dailybonus', 'run'}, call('run')) -- 执行程序 + entry({'admin', 'services', 'jd-dailybonus', 'update'}, call('update')) -- 执行更新 + entry({'admin', 'services', 'jd-dailybonus', 'check_update'}, call('check_update')) -- 检查更新 + entry({'admin', 'services', 'jd-dailybonus', 'qrcode'}, call('qrcode')) -- 获取二维码 + entry({'admin', 'services', 'jd-dailybonus', 'check_login'}, call('check_login')) -- 获取二维码 end - +-- 写入配置 +function write_json(file, content) + local json = require 'luci.jsonc' + local f = assert(io.open(file, 'w')) + f:write(json.stringify(content, 1)) + f:close() +end -- 执行程序 - function run() local e = {} local uci = luci.model.uci.cursor() - local cookie = luci.http.formvalue("cookies") - local cookie2 = luci.http.formvalue("cookies2") - local auto_update = luci.http.formvalue("auto_update") - local auto_update_time = luci.http.formvalue("auto_update_time") - local auto_run = luci.http.formvalue("auto_run") - local auto_run_time = luci.http.formvalue("auto_run_time") - local stop = luci.http.formvalue("stop") - local serverchan = luci.http.formvalue("serverchan") - local failed = luci.http.formvalue("failed") - local name = "" - uci:foreach("vssr", "global", function(s) name = s[".name"] end) + local data = luci.http.formvalue() - if cookie ~= " " then - uci:set("jd-dailybonus", '@global[0]', 'auto_update', auto_update) - uci:set("jd-dailybonus", '@global[0]', 'auto_update_time', auto_update_time) - uci:set("jd-dailybonus", '@global[0]', 'auto_run', auto_run) - uci:set("jd-dailybonus", '@global[0]', 'auto_run_time', auto_run_time) - uci:set("jd-dailybonus", '@global[0]', 'stop', stop) - uci:set("jd-dailybonus", '@global[0]', 'cookie', cookie) - uci:set("jd-dailybonus", '@global[0]', 'cookie2', cookie2) - uci:set("jd-dailybonus", '@global[0]', 'serverchan', serverchan) - uci:set("jd-dailybonus", '@global[0]', 'failed', failed) - uci:save("jd-dailybonus") - uci:commit("jd-dailybonus") - luci.sys.call("/usr/share/jd-dailybonus/newapp.sh -r") - luci.sys.call("/usr/share/jd-dailybonus/newapp.sh -a") - e.error = 0 - else - e.error = 1 - end + data.auto_run = data.auto_run ~= nil and data.auto_run or 0 + data.auto_update = data.auto_update ~= nil and data.auto_update or 0 + uci:tset('jd-dailybonus', '@global[0]', data) + uci:commit('jd-dailybonus') + local json_data = { + CookieJD = data.cookie, + CookieJD2 = data.cookie2:len() == 0 and nil or data.cookie2, + JD_DailyBonusDelay = data.stop, + JD_DailyBonusTimeOut = data.out + } + write_json('/root/CookieSet.json', json_data) + write_json('/www/CookieSet.json', json_data) + luci.sys.call('/usr/share/jd-dailybonus/newapp.sh -r') + luci.sys.call('/usr/share/jd-dailybonus/newapp.sh -a') + e.error = 0 - luci.http.prepare_content("application/json") + luci.http.prepare_content('application/json') luci.http.write_json(e) - end --检查更新 function check_update() - local jd = "jd-dailybonus" + local jd = 'jd-dailybonus' local e = {} - local new_version = luci.sys.exec("/usr/share/jd-dailybonus/newapp.sh -n") + local new_version = luci.sys.exec('/usr/share/jd-dailybonus/newapp.sh -n') e.new_version = new_version e.error = 0 - luci.http.prepare_content("application/json") + luci.http.prepare_content('application/json') luci.http.write_json(e) end --执行更新 function update() - local jd = "jd-dailybonus" + local jd = 'jd-dailybonus' local e = {} local uci = luci.model.uci.cursor() - local version = luci.http.formvalue("version") + local version = luci.http.formvalue('version') --下载脚本 - local code = luci.sys.exec("/usr/share/jd-dailybonus/newapp.sh -u") + local code = luci.sys.exec('/usr/share/jd-dailybonus/newapp.sh -u') e.error = code - luci.http.prepare_content("application/json") + luci.http.prepare_content('application/json') luci.http.write_json(e) -end \ No newline at end of file +end + +--获取二维码 +function qrcode() + local jd_cookie = require 'jd_cookie' + local e = {} + e.error = 0 + e.data = jd_cookie.get_qrcode() + luci.http.prepare_content('application/json') + luci.http.write_json(e) +end + +--检测登录 +function check_login() + local jd_cookie = require 'jd_cookie' + local uci = luci.model.uci.cursor() + local data = luci.http.formvalue() + local id = data.id + local e = jd_cookie.checkLogin(data.check_url, data.cookies) + if e.error == 0 then + local cookieStr = 'pt_key=' .. e.cookie.pt_key .. ';pt_pin=' .. e.cookie.pt_pin .. ';' + uci:set('jd-dailybonus', '@global[0]', id, cookieStr) + local json_data = { + CookieJD = uci:get('jd-dailybonus', '@global[0]', 'cookie'), + CookieJD2 = uci:get('jd-dailybonus', '@global[0]', 'cookie2'), + JD_DailyBonusDelay = uci:get('jd-dailybonus', '@global[0]', 'stop'), + JD_DailyBonusTimeOut = uci:get('jd-dailybonus', '@global[0]', 'out') + } + write_json('/root/CookieSet.json', json_data) + write_json('/www/CookieSet.json', json_data) + uci:commit('jd-dailybonus') + e.cstr = cookieStr + end + + luci.http.prepare_content('application/json') + luci.http.write_json(e) +end diff --git a/package/lean/luci-app-jd-dailybonus/luasrc/model/cbi/jd-dailybonus/client.lua b/package/lean/luci-app-jd-dailybonus/luasrc/model/cbi/jd-dailybonus/client.lua index 72a252472..0bc0737ec 100644 --- a/package/lean/luci-app-jd-dailybonus/luasrc/model/cbi/jd-dailybonus/client.lua +++ b/package/lean/luci-app-jd-dailybonus/luasrc/model/cbi/jd-dailybonus/client.lua @@ -1,75 +1,100 @@ -local jd = "jd-dailybonus" +local jd = 'jd-dailybonus' local uci = luci.model.uci.cursor() -local sys = require "luci.sys" +local sys = require 'luci.sys' m = Map(jd) -- [[ 基本设置 ]]-- -s = m:section(TypedSection, "global", - translate("Base Config")) +s = m:section(TypedSection, 'global', translate('基本设置')) s.anonymous = true -o = s:option(DummyValue, "", "") +o = s:option(DummyValue, '', '') o.rawhtml = true -o.template = "jd-dailybonus/cookie_tools" +o.template = 'jd-dailybonus/cookie_tools' -o = s:option(ListValue, "remote_url", translate("Source Update Url")) -o:value("https://cdn.jsdelivr.net/gh/NobyDa/Script/JD-DailyBonus/JD_DailyBonus.js", translate("GitHub")) -o:value("https://gitee.com/jerrykuku/staff/raw/master/JD_DailyBonus.js", translate("Gitee")) -o.default = "nil" -o.rmempty = false -o.description = translate('当GitHub源无法更新时,可以选择使用国内Gitee源') - -o = s:option(Value, "cookie", translate("First Cookie")) +o = s:option(Value, 'cookie', translate('第一账号Cookie')) o.rmempty = false -o = s:option(Value, "cookie2", translate("Second Cookie")) +o = s:option(Value, 'cookie2', translate('第二账号Cookie')) o.rmempty = true -o.description = translate('双账号用户抓取"账号1"Cookie后, 请勿点击退出账号(可能会导致Cookie失效), 需清除浏览器资料或更换浏览器登录"账号2"抓取.') -o = s:option(Value, "stop", translate("Execute Delay")) +o = s:option(Value, 'stop', translate('延迟签到')) o.rmempty = false o.default = 0 o.datatype = integer -o.description = translate("自定义延迟签到,单位毫秒. 默认分批并发无延迟. (延迟作用于每个签到接口, 如填入延迟则切换顺序签到. ) ") +o.description = translate('自定义延迟签到,单位毫秒. 默认分批并发无延迟. (延迟作用于每个签到接口, 如填入延迟则切换顺序签到. ) ') -o = s:option(ListValue, "serverurl", translate("ServerURL")) -o:value("scu", translate("SCU")) -o:value("sct", translate("SCT")) -o.default = "scu" +o = s:option(Value, 'out', translate('接口超时')) +o.rmempty = false +o.default = 0 +o.datatype = integer +o.description = translate('接口超时退出,单位毫秒 用于可能发生的网络不稳定, 0则关闭.') + +-- server chan +o = s:option(ListValue, 'serverurl', translate('Server酱的推送接口地址')) +o:value('scu', translate('SCU')) +o:value('sct', translate('SCT')) +o.default = 'scu' o.rmempty = false o.description = translate('选择Server酱的推送接口') -o = s:option(Value, "serverchan", translate("ServerChan SCKEY")) +o = s:option(Value, 'serverchan', translate('Server酱 SCKEY')) o.rmempty = true -o.description = translate("微信推送,基于Server酱服务,请自行登录 http://sc.ftqq.com/ 绑定并获取 SCKEY (仅在自动签到时推送)") +o.description = translate('微信推送,基于Server酱服务,请自行登录 http://sc.ftqq.com/ 绑定并获取 SCKEY。') -o = s:option(Flag, "failed", translate("Failed Push")) +-- telegram + +o = s:option(Value, 'tg_token', translate('Telegram Bot Token')) +o.rmempty = true +o.description = translate('首先在Telegram上搜索BotFather机器人,创建一个属于自己的通知机器人,并获取Token。') + +o = s:option(Value, 'tg_userid', translate('Telegram UserID')) +o.rmempty = true +o.description = translate('在Telegram上搜索getuserIDbot机器人,获取UserID。') + +--Auto Run Script Service + +o = s:option(Flag, 'auto_run', translate('自动签到')) o.rmempty = false -o.description = translate("仅当cookie失效时推送") -o = s:option(Flag, "auto_update", translate("Auto Update")) -o.rmempty = false -o.description = translate("Auto Update Script Service") - -o =s:option(ListValue, "auto_update_time", translate("Update time (every day)")) -for t = 0, 23 do o:value(t, t .. ":01") end +o = s:option(ListValue, 'auto_run_time_h', translate('每天签到时间(小时)')) +for t = 0, 23 do + o:value(t, t) +end o.default = 1 o.rmempty = true -o:depends("auto_update", "1") - -o = s:option(Flag, "auto_run", translate("Auto Run")) -o.rmempty = false -o.description = translate("Auto Run Script Service") - -o =s:option(ListValue, "auto_run_time", translate("Run time (every day)")) -for t = 0, 23 do o:value(t, t .. ":05") end +o:depends('auto_run', '1') +o = s:option(ListValue, 'auto_run_time_m', translate('每天签到时间(分钟)')) +for t = 0, 59 do + o:value(t, t) +end o.default = 1 o.rmempty = true -o:depends("auto_run", "1") +o:depends('auto_run', '1') -o = s:option(DummyValue, "", "") +-- Auto Update Script Service + +o = s:option(Flag, 'auto_update', translate('自动更新')) +o.rmempty = false + +o = s:option(ListValue, 'auto_update_time', translate('每天更新时间')) +for t = 0, 23 do + o:value(t, t .. ':01') +end +o.default = 1 +o.rmempty = true +o:depends('auto_update', '1') + +o = s:option(ListValue, 'remote_url', translate('更新源地址')) +o:value('https://raw.githubusercontent.com/NobyDa/Script/master/JD-DailyBonus/JD_DailyBonus.js', translate('GitHub')) +o:value('https://gitee.com/jerrykuku/staff/raw/master/JD_DailyBonus.js', translate('Gitee')) +o.default = 'nil' +o.rmempty = false +o.description = translate('当GitHub源无法更新时,可以选择使用国内Gitee源') + +o = s:option(DummyValue, '', '') o.rawhtml = true o.version = sys.exec('uci get jd-dailybonus.@global[0].version') -o.template = "jd-dailybonus/update_service" +o.template = 'jd-dailybonus/update_service' + return m diff --git a/package/lean/luci-app-jd-dailybonus/luasrc/view/jd-dailybonus/cookie_tools.htm b/package/lean/luci-app-jd-dailybonus/luasrc/view/jd-dailybonus/cookie_tools.htm index a88d8248b..bb00927d8 100644 --- a/package/lean/luci-app-jd-dailybonus/luasrc/view/jd-dailybonus/cookie_tools.htm +++ b/package/lean/luci-app-jd-dailybonus/luasrc/view/jd-dailybonus/cookie_tools.htm @@ -1,25 +1,13 @@ <%+cbi/valueheader%> - +
- + +
帮助 - <%= translate("Click to download the JDCookie.zip,unzip it,and use load Unpacked extensions to install.link:[chrome://extensions/]")%> -
-
- -<%+cbi/valuefooter%> -<%+cbi/valueheader%> - - -
- -
-
- 帮助 - <%= translate("Sign in ,then click JDCookie button.you will copy JD cookies, paste the cookie below.")%> + <%= translate("点击上面按钮使用京东手机app扫码获取Cookie")%>
diff --git a/package/lean/luci-app-jd-dailybonus/luasrc/view/jd-dailybonus/update_service.htm b/package/lean/luci-app-jd-dailybonus/luasrc/view/jd-dailybonus/update_service.htm index 947f9d505..6ef9b0ff9 100644 --- a/package/lean/luci-app-jd-dailybonus/luasrc/view/jd-dailybonus/update_service.htm +++ b/package/lean/luci-app-jd-dailybonus/luasrc/view/jd-dailybonus/update_service.htm @@ -1,5 +1,9 @@ <%+cbi/valueheader%> + + - +
"> + value="<%= translate("保存Cookie,并马上进行签到") %>">
-<%+cbi/valuefooter%> -<%+cbi/valueheader%> - -
-
- v<%=self.version%> -
- -
<%+cbi/valuefooter%> <%+cbi/valueheader%> - +
"> - + value="<%= translate("手动检查脚本更新,当前版本:v")..self.version %>">
<%+cbi/valuefooter%> + + diff --git a/package/lean/luci-app-jd-dailybonus/po/zh-cn/jd-dailybonus.po b/package/lean/luci-app-jd-dailybonus/po/zh-cn/jd-dailybonus.po deleted file mode 100644 index 22daa12df..000000000 --- a/package/lean/luci-app-jd-dailybonus/po/zh-cn/jd-dailybonus.po +++ /dev/null @@ -1,111 +0,0 @@ -msgid "" -msgstr "Content-Type: text/plain; charset=UTF-8\n" - -msgid "JD-DailyBonus" -msgstr "京东签到服务" - -msgid "Enable" -msgstr "启用" - -msgid "Disable" -msgstr "停用" - -msgid "Log" -msgstr "日志" - -msgid "Script" -msgstr "脚本" - -msgid "Base Config" -msgstr "基本设置" - -msgid "Cookie Tools" -msgstr "Cookie 工具" - -msgid "JDCookie Tools" -msgstr "获取京东cookie扩展工具" - -msgid "Source Update Url" -msgstr "更新源地址" - -msgid "First Cookie" -msgstr "主账号Cookie" - -msgid "Second Cookie" -msgstr "第二账号Cookie" - -msgid "Click to download the JDCookie.zip,unzip it,and use load Unpacked extensions to install.link:[chrome://extensions/]")" -msgstr "点击上面的按钮安装下载JDCookie.zip(获取京东cookie扩展工具),解压后在[chrome://extensions/]中使用加载已解压的扩展程序进行安装。 " - -msgid "JD Url" -msgstr "京东链接" - -msgid "Sign in ,then click JDCookie button.you will copy JD cookies, paste the cookie below." -msgstr "登录后点击JDCookie 扩展工具复制cookie,然后粘贴到下面输入框中。(请使用F12调试工具,进入模拟手机浏览器模式)" - -msgid "Auto Update Script Service" -msgstr "自动更新脚本服务" - -msgid "Update time (every day)" -msgstr "更新时间 (每天)" - -msgid "Update Script" -msgstr "更新脚本" - -msgid "Execute Delay" -msgstr "延迟签到" - -msgid "ServerChan SCKEY" -msgstr "Server酱 SCKEY" - -msgid "ServerURL" -msgstr "Server酱的推送接口地址" - -msgid "SCT" -msgstr "测试版推送接口地址" - -msgid "SCU" -msgstr "原版推送接口地址" - -msgid "Failed Push" -msgstr "失效时推送" - -msgid "Auto Run" -msgstr "自动签到" - -msgid "Run" -msgstr "执行" - -msgid "Auto Run Script Service" -msgstr "自动签到服务" - -msgid "Run time (every day)" -msgstr "签到时间 (每天)" - -msgid "Save Cookies And Run Service" -msgstr "保存Cookie并签到" - -msgid "Sign in info" -msgstr "签到信息" - -msgid "Service is running,Please do not refresh!" -msgstr "服务正在执行中,请勿刷新!" - -msgid "Updating script,please wait ..." -msgstr "正在更新脚本,请稍候 ..." - -msgid "Is currently the latest version" -msgstr "当前已是最新版本。" - -msgid "There is a new version, click to update" -msgstr "有新的版本,请点击更新" - -msgid "Checking the New Version ..." -msgstr "正在检查是否存在新的版本 ..." - -msgid "Check Script Version" -msgstr "手动检查脚本更新" - -msgid "Current Script Version" -msgstr "当前脚本版本" - diff --git a/package/lean/luci-app-jd-dailybonus/root/etc/config/jd-dailybonus b/package/lean/luci-app-jd-dailybonus/root/etc/config/jd-dailybonus index 14a038cb7..8002200ac 100644 --- a/package/lean/luci-app-jd-dailybonus/root/etc/config/jd-dailybonus +++ b/package/lean/luci-app-jd-dailybonus/root/etc/config/jd-dailybonus @@ -1,9 +1,14 @@ config global - option version '1.87' - option auto_run_time '1' - option auto_run '1' - option auto_update_time '1' + option version '1.90' + option out '0' + option stop '100' + option serverchan '' + option remote_url 'https://raw.githubusercontent.com/NobyDa/Script/master/JD-DailyBonus/JD_DailyBonus.js' + option serverurl 'scu' option auto_update '1' - option stop '0' - option failed '0' - option remote_url 'https://cdn.jsdelivr.net/gh/NobyDa/Script/JD-DailyBonus/JD_DailyBonus.js' \ No newline at end of file + option auto_update_time '23' + option auto_run '1' + option auto_run_time '0' + option auto_run_time_m '1' + option auto_run_time_h '1' + option cookie '' \ No newline at end of file diff --git a/package/lean/luci-app-jd-dailybonus/root/usr/share/jd-dailybonus/JD_DailyBonus.js b/package/lean/luci-app-jd-dailybonus/root/usr/share/jd-dailybonus/JD_DailyBonus.js index c6d411f1f..467ff87d1 100644 --- a/package/lean/luci-app-jd-dailybonus/root/usr/share/jd-dailybonus/JD_DailyBonus.js +++ b/package/lean/luci-app-jd-dailybonus/root/usr/share/jd-dailybonus/JD_DailyBonus.js @@ -2,7 +2,7 @@ 京东多合一签到脚本 -更新时间: 2020.12.25 17:50 v1.89 +更新时间: 2021.01.07 17:00 v1.90 有效接口: 40+ 脚本兼容: QuantumultX, Surge, Loon, JSBox, Node.js 电报频道: @NobyDa @@ -13,7 +13,7 @@ 【 JSbox, Node.js 说明 】 : ************************* -开启抓包app后, Safari浏览器登录 https://bean.m.jd.com 点击签到并且出现签到日历后, 返回抓包app搜索关键字 functionId=signBean 复制请求头Cookie填入以下Key处的单引号内即可 */ +开启抓包app后, Safari浏览器登录 https://bean.m.jd.com/bean/signIndex.action 点击签到并且出现签到日历后, 返回抓包app搜索关键字 functionId=signBean 复制请求头Cookie填入以下Key处的单引号内即可 */ var Key = ''; //单引号内自行填写您抓取的Cookie @@ -30,7 +30,7 @@ var DualKey = ''; //如需双账号签到,此处单引号内填写抓取的"账 【 QX, Surge, Loon 说明 】 : ************************* -初次使用时, app配置文件添加脚本配置,并启用Mitm后, Safari浏览器打开登录 https://bean.m.jd.com ,点击签到并且出现签到日历后, 如果通知获得cookie成功, 则可以使用此签到脚本。 注: 请勿在京东APP内获取!!! +初次使用时, app配置文件添加脚本配置,并启用Mitm后, Safari浏览器打开登录 https://bean.m.jd.com/bean/signIndex.action ,点击签到并且出现签到日历后, 如果通知获得cookie成功, 则可以使用此签到脚本。 注: 请勿在京东APP内获取!!! 由于cookie的有效性(经测试网页Cookie有效周期最长31天),如果脚本后续弹出cookie无效的通知,则需要重复上述步骤。 签到脚本将在每天的凌晨0:05执行, 您可以修改执行时间。 因部分接口京豆限量领取, 建议调整为凌晨签到。 @@ -108,14 +108,12 @@ async function all() { case 0: await Promise.all([ JingDongBean(stop), //京东京豆 - JDTakeaLook(stop), //京东发现-看一看 JingDongStore(stop), //京东超市 JingDongWebcasts(stop), //京东直播 JingRongBean(stop), //金融简单赚钱 JingRongSteel(stop), //金融钢镚 JingDongTurn(stop), //京东转盘 JDFlashSale(stop), //京东闪购 - JDOverseas(stop), //京东国际 JingDongCash(stop), //京东现金红包 JDMagicCube(stop, 2), //京东小魔方 JingDongSubsidy(stop), //京东金贴 @@ -131,15 +129,13 @@ async function all() { JingRongDoll(stop, 'JRFiveDoll', '京东金融-签伍', '1D06AA3B0F') ]); await Promise.all([ - JDUserSignPre(stop, 'JDClothing', '京东商城-服饰', '4RBT3H9jmgYg1k2kBnHF8NAHm7m8'), //京东服饰 - JDUserSignPre(stop, 'JDUnderwear', '京东商城-内衣', '4PgpL1xqPSW1sVXCJ3xopDbB1f69'), //京东内衣馆 JDUserSignPre(stop, 'JDShoes', '京东商城-鞋靴', '4RXyb1W4Y986LJW8ToqMK14BdTD'), //京东鞋靴 JDUserSignPre(stop, 'JDCalendar', '京东日历-翻牌', '36V2Qw59VPNsuLxY84vCFtxFzrFs'), //京东日历翻牌 JDUserSignPre(stop, 'JDChild', '京东商城-童装', '3Af6mZNcf5m795T8dtDVfDwWVNhJ'), //京东童装馆 JDUserSignPre(stop, 'JDBaby', '京东商城-母婴', '3BbAVGQPDd6vTyHYjmAutXrKAos6'), //京东母婴馆 JDUserSignPre(stop, 'JD3C', '京东商城-数码', '4SWjnZSCTHPYjE5T7j35rxxuMTb6'), //京东数码电器馆 - JDUserSignPre(stop, 'JDSubsidy', '京东晚市-补贴', 'xK148m4kWj5hBcTPuJUNNXH3AkJ'), //京东晚市补贴金 - JDUserSignPre(stop, 'JDDrug', '京东商城-医药', '3tqTG5sF1xCUyC6vgEF5CLCxGn7w'), //京东医药馆 + // JDUserSignPre(stop, 'JDSubsidy', '京东晚市-补贴', 'xK148m4kWj5hBcTPuJUNNXH3AkJ'), //京东晚市补贴金 + // JDUserSignPre(stop, 'JDDrug', '京东商城-医药', '3tqTG5sF1xCUyC6vgEF5CLCxGn7w'), //京东医药馆 JDUserSignPre(stop, 'JDWomen', '京东商城-女装', 'DpSh7ma8JV7QAxSE2gJNro8Q2h9'), //京东女装馆 JDUserSignPre(stop, 'JDFineWine', '京东商城-酒饮', 'zGwAUzL3pVGjptBBGeYfpKjYdtX'), //京东酒饮馆 JDUserSignPre(stop, 'JDBook', '京东商城-图书', '3SC6rw5iBg66qrXPGmZMqFDwcyXi'), //京东图书 @@ -147,15 +143,17 @@ async function all() { JingRongDoll(stop, 'XJDouble', '金融现金-双签', 'F68B2C3E71', '', '', '', 'xianjin') //京东金融 现金双签 ]); await Promise.all([ + JDUserSignPre(stop, 'JDClothing', '京东商城-服饰', '4RBT3H9jmgYg1k2kBnHF8NAHm7m8'), //京东服饰 + JDUserSignPre(stop, 'JDUnderwear', '京东商城-内衣', '4PgpL1xqPSW1sVXCJ3xopDbB1f69'), //京东内衣馆 JDUserSignPre(stop, 'JDSuitcase', '京东商城-箱包', 'ZrH7gGAcEkY2gH8wXqyAPoQgk6t'), //京东箱包馆 JDUserSignPre(stop, 'JDSchool', '京东商城-校园', '4812pn2PAcUyfNdWr7Cvpww5MCyW'), //京东校园 JDUserSignPre(stop, 'JDHealth', '京东商城-健康', 'w2oeK5yLdHqHvwef7SMMy4PL8LF'), //京东健康 - JDUserSignPre(stop, 'JDPet', '京东商城-宠物', '37ta5sh5ocrMZF3Fz5UMJbTsL42'), //京东宠物馆 - JDUserSignPre(stop, 'JDShand', '京东拍拍-二手', '3S28janPLYmtFxypu37AYAGgivfp'), //京东拍拍二手 + // JDUserSignPre(stop, 'JDPet', '京东商城-宠物', '37ta5sh5ocrMZF3Fz5UMJbTsL42'), //京东宠物馆 + // JDUserSignPre(stop, 'JDShand', '京东拍拍-二手', '3S28janPLYmtFxypu37AYAGgivfp'), //京东拍拍二手 JDUserSignPre(stop, 'JDClean', '京东商城-清洁', '2Tjm6ay1ZbZ3v7UbriTj6kHy9dn6'), //京东清洁馆 JDUserSignPre(stop, 'JDCare', '京东商城-个护', 'NJ1kd1PJWhwvhtim73VPsD1HwY3'), //京东个人护理馆 JDUserSignPre(stop, 'JDJewels', '京东商城-珠宝', 'zHUHpTHNTaztSRfNBFNVZscyFZU'), //京东珠宝馆 - JDUserSignPre(stop, 'JDClocks', '京东商城-钟表', '2BcJPCVVzMEtMUynXkPscCSsx68W'), //京东钟表馆 + // JDUserSignPre(stop, 'JDClocks', '京东商城-钟表', '2BcJPCVVzMEtMUynXkPscCSsx68W'), //京东钟表馆 JDUserSignPre(stop, 'JDMakeup', '京东商城-美妆', '2smCxzLNuam5L14zNJHYu43ovbAP'), //京东美妆馆 JDUserSignPre(stop, 'JDVege', '京东商城-菜场', 'Wcu2LVCFMkBP3HraRvb7pgSpt64') //京东菜场 ]); @@ -164,14 +162,12 @@ async function all() { break; default: await JingDongBean(stop); //京东京豆 - await JDTakeaLook(stop); //京东发现-看一看 await JingDongStore(stop); //京东超市 await JingDongWebcasts(stop); //京东直播 await JingRongBean(stop); //金融简单赚钱 await JingRongSteel(stop); //金融钢镚 await JingDongTurn(stop); //京东转盘 await JDFlashSale(stop); //京东闪购 - await JDOverseas(stop); //京东国际 await JingDongCash(stop); //京东现金红包 await JDMagicCube(stop, 2); //京东小魔方 await JingDongGetCash(stop); //京东领现金 @@ -197,13 +193,13 @@ async function all() { await JDUserSignPre(stop, 'JDChild', '京东商城-童装', '3Af6mZNcf5m795T8dtDVfDwWVNhJ'); //京东童装馆 await JDUserSignPre(stop, 'JDBaby', '京东商城-母婴', '3BbAVGQPDd6vTyHYjmAutXrKAos6'); //京东母婴馆 await JDUserSignPre(stop, 'JD3C', '京东商城-数码', '4SWjnZSCTHPYjE5T7j35rxxuMTb6'); //京东数码电器馆 - await JDUserSignPre(stop, 'JDSubsidy', '京东晚市-补贴', 'xK148m4kWj5hBcTPuJUNNXH3AkJ'); //京东晚市补贴金 - await JDUserSignPre(stop, 'JDClocks', '京东商城-钟表', '2BcJPCVVzMEtMUynXkPscCSsx68W'); //京东钟表馆 - await JDUserSignPre(stop, 'JDDrug', '京东商城-医药', '3tqTG5sF1xCUyC6vgEF5CLCxGn7w'); //京东医药馆 + // await JDUserSignPre(stop, 'JDSubsidy', '京东晚市-补贴', 'xK148m4kWj5hBcTPuJUNNXH3AkJ'); //京东晚市补贴金 + // await JDUserSignPre(stop, 'JDClocks', '京东商城-钟表', '2BcJPCVVzMEtMUynXkPscCSsx68W'); //京东钟表馆 + // await JDUserSignPre(stop, 'JDDrug', '京东商城-医药', '3tqTG5sF1xCUyC6vgEF5CLCxGn7w'); //京东医药馆 await JDUserSignPre(stop, 'JDWomen', '京东商城-女装', 'DpSh7ma8JV7QAxSE2gJNro8Q2h9'); //京东女装馆 - await JDUserSignPre(stop, 'JDPet', '京东商城-宠物', '37ta5sh5ocrMZF3Fz5UMJbTsL42'); //京东宠物馆 + // await JDUserSignPre(stop, 'JDPet', '京东商城-宠物', '37ta5sh5ocrMZF3Fz5UMJbTsL42'); //京东宠物馆 await JDUserSignPre(stop, 'JDBook', '京东商城-图书', '3SC6rw5iBg66qrXPGmZMqFDwcyXi'); //京东图书 - await JDUserSignPre(stop, 'JDShand', '京东拍拍-二手', '3S28janPLYmtFxypu37AYAGgivfp'); //京东拍拍二手 + // await JDUserSignPre(stop, 'JDShand', '京东拍拍-二手', '3S28janPLYmtFxypu37AYAGgivfp'); //京东拍拍二手 await JDUserSignPre(stop, 'JDMakeup', '京东商城-美妆', '2smCxzLNuam5L14zNJHYu43ovbAP'); //京东美妆馆 await JDUserSignPre(stop, 'JDFineWine', '京东商城-酒饮', 'zGwAUzL3pVGjptBBGeYfpKjYdtX'); //京东酒饮馆 await JDUserSignPre(stop, 'JDVege', '京东商城-菜场', 'Wcu2LVCFMkBP3HraRvb7pgSpt64'); //京东菜场 @@ -1700,56 +1696,6 @@ function JingRongDoll(s, key, title, code, type, num, award, belong) { }); } -function JDOverseas(s) { - merge.Overseas = {}; - return new Promise(resolve => { - if (disable("Overseas")) return resolve() - setTimeout(() => { - const OverseasUrl = { - url: 'https://api.m.jd.com/client.action?functionId=checkin', - headers: { - Cookie: KEY - }, - body: "body=%7B%7D&build=167237&client=apple&clientVersion=9.0.0&openudid=1fce88cd05c42fe2b054e846f11bdf33f016d676&partner=apple&scope=11&sign=e27f8b904040a0e3c99b87fc27e09c87&st=1591730990449&sv=101" - }; - $nobyda.post(OverseasUrl, function(error, response, data) { - try { - if (error) { - throw new Error(error) - } else { - const Details = LogDetails ? "response:\n" + data : ''; - if (data.match(/\"type\":\d+?,/)) { - console.log("\n" + "京东商城-国际签到成功 " + Details) - merge.Overseas.success = 1 - if (data.match(/\"jdBeanAmount\":[1-9]+/)) { - merge.Overseas.bean = data.match(/\"jdBeanAmount\":(\d+)/)[1] - merge.Overseas.notify = "京东商城-国际: 成功, 明细: " + merge.Overseas.bean + "京豆 🐶" - } else { - merge.Overseas.notify = "京东商城-国际: 成功, 明细: 无京豆 🐶" - } - } else { - console.log("\n" + "京东商城-国际签到失败 " + Details) - merge.Overseas.fail = 1 - if (data.match(/(\"code\":\"13\"|重复签到)/)) { - merge.Overseas.notify = "京东商城-国际: 失败, 原因: 已签过 ⚠️" - } else if (data.match(/\"code\":\"(-1|3)\"/)) { - merge.Overseas.notify = "京东商城-国际: 失败, 原因: Cookie失效‼️" - } else { - merge.Overseas.notify = "京东商城-国际: 失败, 原因: 未知 ⚠️" - } - } - } - } catch (eor) { - $nobyda.AnError("京东商城-国际", "Overseas", eor, response, data) - } finally { - resolve() - } - }) - }, s) - if (out) setTimeout(resolve, out + s) - }); -} - function JingDongGetCash(s) { merge.JDGetCash = {}; return new Promise(resolve => { @@ -1834,45 +1780,6 @@ function JingDongWebcasts(s) { }); } -function JDTakeaLook(s) { - merge.TakeaLook = {}; - return new Promise(resolve => { - if (disable("TakeaLook")) return resolve() - setTimeout(() => { - $nobyda.get({ - url: 'https://api.m.jd.com/client.action?functionId=discTaskList&body=%7B%22bizType%22%3A1%2C%22referPageId%22%3A%22discRecommend%22%7D&client=apple&clientVersion=9.1.6&openudid=1fce88cd05c42fe2b054e846f11bdf33f016d676&sign=17061147fe8e0eb10edfe8d9968b6d66&st=1601138337675&sv=102', - headers: { - Cookie: KEY - } - }, (error, response, data) => { - try { - if (error) throw new Error(error); - const cc = JSON.parse(data); - const Details = LogDetails ? "response:\n" + data : ''; - const tm = parseInt((Date.now() + 28800000) / 86400000) * 86400000 - 28800000 - if (data.match(/签到成功/) && !data.match(tm)) { - console.log(`\n京东发现-看看签到成功 ${Details}`) - const aw = data.match(/\"签到成功,获得(\d+)京豆\"/) - merge.TakeaLook.success = 1 - merge.TakeaLook.bean = aw ? aw[1] : 0 - merge.TakeaLook.notify = `京东发现-看看: 成功, 明细: ${merge.TakeaLook.bean||`无`}京豆 🐶` - } else { - console.log(`\n京东发现-看看签到失败 ${Details}`) - const tp = data.match(tm) ? `已签过` : cc.busiCode == 2001 ? `Cookie失效` : `${cc.message||`未知`}` - merge.TakeaLook.notify = `京东发现-看看: 失败, 原因: ${tp}${cc.busiCode==2001?`‼️`:` ⚠️`}` - merge.TakeaLook.fail = 1 - } - } catch (eor) { - $nobyda.AnError("京东发现-看看", "TakeaLook", eor, response, data) - } finally { - resolve() - } - }) - }, s) - if (out) setTimeout(resolve, out + s) - }); -} - function JingDongStore(s) { merge.JDGStore = {}; return new Promise(resolve => { diff --git a/package/lean/luci-app-jd-dailybonus/root/usr/share/jd-dailybonus/jd_cookie.lua b/package/lean/luci-app-jd-dailybonus/root/usr/share/jd-dailybonus/jd_cookie.lua new file mode 100644 index 000000000..a1ddffac1 --- /dev/null +++ b/package/lean/luci-app-jd-dailybonus/root/usr/share/jd-dailybonus/jd_cookie.lua @@ -0,0 +1,168 @@ +-- Copyright (C) 2021 jerrykuku +-- Licensed to the public under the GNU General Public License v3. + +local uci = require 'luci.model.uci'.cursor() +local config = 'jd-dailybonus' +package.path = package.path .. ';/usr/share/jd-dailybonus/?.lua' +local requests = require 'requests' +local socket = require 'socket' +local tinsert = table.insert +local ssub, slen, schar, sbyte, sformat, sgsub = string.sub, string.len, string.char, string.byte, string.format, string.gsub +local User_Agent = 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.111 Safari/537.36' +local Host = 'plogin.m.jd.com' +local jd_cookie = {} + +--打印table +function print_r(t) + local print_r_cache = {} + local function sub_print_r(t, indent) + if (print_r_cache[tostring(t)]) then + print(indent .. '*' .. tostring(t)) + else + print_r_cache[tostring(t)] = true + if (type(t) == 'table') then + for pos, val in pairs(t) do + if (type(val) == 'table') then + print(indent .. '[' .. pos .. '] => ' .. tostring(t) .. ' {') + sub_print_r(val, indent .. string.rep(' ', string.len(pos) + 8)) + print(indent .. string.rep(' ', string.len(pos) + 6) .. '}') + elseif (type(val) == 'string') then + print(indent .. '[' .. pos .. '] => "' .. val .. '"') + else + print(indent .. '[' .. pos .. '] => ' .. tostring(val)) + end + end + else + print(indent .. tostring(t)) + end + end + end + if (type(t) == 'table') then + print(tostring(t) .. ' {') + sub_print_r(t, ' ') + print('}') + else + sub_print_r(t, ' ') + end + print() +end + +-- 分割字符串 +local function split(full, sep) + full = full:gsub('%z', '') -- 这里不是很清楚 有时候结尾带个\0 + local off, result = 1, {} + while true do + local nStart, nEnd = full:find(sep, off) + if not nEnd then + local res = ssub(full, off, slen(full)) + if #res > 0 then -- 过滤掉 \0 + tinsert(result, res) + end + break + else + tinsert(result, ssub(full, off, nStart - 1)) + off = nEnd + 1 + end + end + return result +end + +--获取unix时间戳 +function jd_cookie.timestamp() + return math.floor(socket.gettime() * 1000) +end + +--延时函数 +function sleep(n) + os.execute('sleep ' .. n) +end + +--解析cookie +function praseSetCookies(rcookie) + local tbl = {} + for k, v in rcookie:gmatch('([^;%s]+)=([^;]+)') do + tbl[k] = v + end + return tbl +end + +--获取二维码链接和检测URL +function jd_cookie.get_qrcode() + local timeStamp = jd_cookie.timestamp() + local url = + 'https://plogin.m.jd.com/cgi-bin/mm/new_login_entrance?lang=chs&appid=300&returnurl=https://wq.jd.com/passport/LoginRedirect?state=' .. + timeStamp .. '&returnurl=https://home.m.jd.com/myJd/newhome.action?sceneval=2&ufc=&/myJd/home.action&source=wq_passport' + local xformHeaders = { + ['Content-Type'] = 'application/x-www-form-urlencoded', + ['Connection'] = 'Keep-Alive', + ['Accept'] = 'application/json, text/plain, */*', + ['Accept-Language'] = 'zh-cn', + ['Referer'] = 'https://plogin.m.jd.com/login/login?appid=300&returnurl=https://wq.jd.com/passport/LoginRedirect?state=' .. + timeStamp .. '&returnurl=https://home.m.jd.com/myJd/newhome.action?sceneval=2&ufc=&/myJd/home.action&source=wq_passport', + ['User-Agent'] = User_Agent, + ['Host'] = Host + } + local response = requests.get {url, headers = xformHeaders} + local s_token = response.json().s_token + local dat = split(string.gsub(response.headers['set-cookie'], ' DOMAIN=.plogin.m.jd.com', ''), ';') + local cookies = string.gsub(dat[1] .. dat[4] .. dat[6] .. dat[8], ',', ';') .. ';' + + local timeStamp = jd_cookie.timestamp() + local url = 'https://plogin.m.jd.com/cgi-bin/m/tmauthreflogurl?s_token=' .. s_token .. '&v=' .. timeStamp .. '&remember=true' + local xformHeaders = { + ['Content-Type'] = 'application/x-www-form-urlencoded', + ['Connection'] = 'Keep-Alive', + ['Accept'] = 'application/json, text/plain, */*', + ['Accept-Language'] = 'zh-cn', + ['Referer'] = 'https://plogin.m.jd.com/login/login?appid=300&returnurl=https://wq.jd.com/passport/LoginRedirect?state=' .. + timeStamp .. '&returnurl=https://home.m.jd.com/myJd/newhome.action?sceneval=2&ufc=&/myJd/home.action&source=wq_passport', + ['User-Agent'] = User_Agent, + ['Host'] = Host + } + local response = requests.post {url, cookies = cookies, headers = xformHeaders} + local json_body, error = response.json() + local token = json_body['token'] + local ou_state = json_body['ou_state'] + local okl_token = praseSetCookies(response.headers['set-cookie']).okl_token + local return_json = { + qrcode_url = 'https://plogin.m.jd.com/cgi-bin/m/tmauth?appid=300&client_type=m&token=' .. token, + check_url = 'https://plogin.m.jd.com/cgi-bin/m/tmauthchecktoken?&token=' .. token .. '&ou_state=' .. ou_state .. '&okl_token=' .. okl_token, + cookies = cookies + } + return return_json +end + +--检测扫码状态 并返回cookie +function jd_cookie.checkLogin(url, cookies) + local xformHeaders = { + ['Content-Type'] = 'application/x-www-form-urlencoded', + ['Connection'] = 'Keep-Alive', + ['Accept'] = 'application/json, text/plain, */*', + ['Accept-Language'] = 'zh-cn', + ['Referer'] = 'https://plogin.m.jd.com/login/login?appid=300&returnurl=https://wqlogin2.jd.com/passport/LoginRedirect?state=', + ['User-Agent'] = User_Agent, + ['Host'] = Host + } + local data = + 'lang=chs&appid=300&source=wq_passport&returnurl=https://wqlogin2.jd.com/passport/LoginRedirect?state=1100399130787&returnurl=//home.m.jd.com/myJd/newhome.action?sceneval=2&ufc=&/myJd/home.action' + local response = requests.post {url, data = data, cookies = cookies, headers = xformHeaders} + --local cookie = jd_cookie.praseSetCookies(response.headers['set-cookie']) + local json = response.json() + local return_json = {} + if json.errcode == 0 then + local ucookie = praseSetCookies(response.headers['set-cookie']) + return_json = { + error = 0, + cookie = ucookie + } + else + return_json = { + error = json.errcode, + msg = json.message + } + end + + return return_json +end + +return jd_cookie diff --git a/package/lean/luci-app-jd-dailybonus/root/usr/share/jd-dailybonus/newapp.sh b/package/lean/luci-app-jd-dailybonus/root/usr/share/jd-dailybonus/newapp.sh index 938461c03..c91e838b4 100755 --- a/package/lean/luci-app-jd-dailybonus/root/usr/share/jd-dailybonus/newapp.sh +++ b/package/lean/luci-app-jd-dailybonus/root/usr/share/jd-dailybonus/newapp.sh @@ -49,78 +49,58 @@ cancel() { exit 1 } -fill_cookie() { - cookie1=$(uci_get_by_type global cookie) - if [ ! "$cookie1" = "" ]; then - varb="var Key = '$cookie1';" - a=$(sed -n '/var Key =/=' $JD_SCRIPT) - b=$((a-1)) - sed -i "${a}d" $JD_SCRIPT - sed -i "${b}a ${varb}" $JD_SCRIPT - fi - - cookie2=$(uci_get_by_type global cookie2) - if [ ! "$cookie2" = "" ]; then - varb2="var DualKey = '$cookie2';" - aa=$(sed -n '/var DualKey =/=' $JD_SCRIPT) - bb=$((aa-1)) - sed -i "${aa}d" $JD_SCRIPT - sed -i "${bb}a ${varb2}" $JD_SCRIPT - fi - - stop=$(uci_get_by_type global stop) - if [ ! "$stop" = "" ]; then - varb3="var stop = $stop;" - sed -i "s/^var stop =.*/$varb3/g" $JD_SCRIPT - fi -} - add_cron() { sed -i '/jd-dailybonus/d' $CRON_FILE - [ $(uci_get_by_type global auto_run 0) -eq 1 ] && echo '5 '$(uci_get_by_type global auto_run_time)' * * * sleep '$(expr $(head -n 128 /dev/urandom | tr -dc "0123456789" | head -c4) % 180)'s; /usr/share/jd-dailybonus/newapp.sh -w' >>$CRON_FILE + [ $(uci_get_by_type global auto_run 0) -eq 1 ] && echo $(uci_get_by_type global auto_run_time_m)' '$(uci_get_by_type global auto_run_time_h)' * * * /usr/share/jd-dailybonus/newapp.sh -w' >>$CRON_FILE [ $(uci_get_by_type global auto_update 0) -eq 1 ] && echo '1 '$(uci_get_by_type global auto_update_time)' * * * /usr/share/jd-dailybonus/newapp.sh -u' >>$CRON_FILE crontab $CRON_FILE + /etc/init.d/cron restart } # Run Script -serverchan() { - sckey=$(uci_get_by_type global serverchan) - failed=$(uci_get_by_type global failed) - desc=$(cat /www/JD_DailyBonus.htm | grep -E '签到号|签到概览|签到奖励|其他奖励|账号总计|其他总计' | sed 's/$/&\n/g') - serverurlflag=$(uci_get_by_type global serverurl) - serverurl=https://sc.ftqq.com/ - if [ "$serverurlflag" = "sct" ]; then - serverurl=https://sctapi.ftqq.com/ - fi - if [ $failed -eq 1 ]; then - grep "Cookie失效" /www/JD_DailyBonus.htm > /dev/null - if [ $? -eq 0 ]; then - title="$(date '+%Y年%m月%d日') 京东签到 Cookie 失效" - wget-ssl -q --output-document=/dev/null --post-data="text=$title~&desp=$desc" $serverurl$sckey.send - fi +notify() { + grep "Cookie失效" /www/JD_DailyBonus.htm >/dev/null + if [ $? -eq 0 ]; then + title="$(date '+%Y年%m月%d日') 京东签到 Cookie 失效" else title="$(date '+%Y年%m月%d日') 京东签到" + fi + desc=$(cat /www/JD_DailyBonus.htm | grep -E '签到号|签到概览|签到奖励|其他奖励|账号总计|其他总计' | sed 's/$/&\n/g') + #serverchan + sckey=$(uci_get_by_type global serverchan) + if [ ! -z $sckey ]; then + serverurlflag=$(uci_get_by_type global serverurl) + serverurl=https://sc.ftqq.com/ + if [ "$serverurlflag" = "sct" ]; then + serverurl=https://sctapi.ftqq.com/ + fi wget-ssl -q --output-document=/dev/null --post-data="text=$title~&desp=$desc" $serverurl$sckey.send fi + #telegram + TG_BOT_TOKEN=$(uci_get_by_type global tg_token) + TG_USER_ID=$(uci_get_by_type global tg_userid) + API_URL="https://api.telegram.org/bot${TG_BOT_TOKEN}/sendMessage" + if [ ! -z $TG_BOT_TOKEN ] && [ ! -z $TG_USER_ID ]; then + text="*$title* + +\`\`\` +"$desc" +==================================== +本消息来自京东签到插件 jd-dailybonus +\`\`\`" + wget-ssl -q --output-document=/dev/null --post-data="chat_id=$TG_USER_ID&text=$text&parse_mode=markdownv2" $API_URL + fi } run() { - fill_cookie echo -e $(date '+%Y-%m-%d %H:%M:%S %A') >$LOG_HTM 2>/dev/null - [ ! -f "/usr/bin/node" ] && echo -e "未安装node.js,请安装后再试!\nNode.js is not installed, please try again after installation!">>$LOG_HTM && exit 1 - node $JD_SCRIPT >>$LOG_HTM 2>/dev/null -} - -back_run() { - run - sleep 1s - serverchan + [ ! -f "/usr/bin/node" ] && echo -e "未安装node.js,请安装后再试!\nNode.js is not installed, please try again after installation!" >>$LOG_HTM && exit 1 + node $JD_SCRIPT >>$LOG_HTM 2>/dev/null && notify & } save() { - fill_cookie add_cron } @@ -156,7 +136,6 @@ update() { fi remote_ver=$(get_ver $TEMP_SCRIPT) cp -r $TEMP_SCRIPT $JD_SCRIPT - fill_cookie uci set jd-dailybonus.@global[0].version=$remote_ver uci commit jd-dailybonus cancel "0" @@ -169,7 +148,7 @@ while getopts ":alnruswh" arg; do exit 0 ;; l) - serverchan + notify exit 0 ;; n) @@ -189,7 +168,7 @@ while getopts ":alnruswh" arg; do exit 0 ;; w) - back_run + run exit 0 ;; h) diff --git a/package/lean/luci-app-jd-dailybonus/root/usr/share/jd-dailybonus/requests.lua b/package/lean/luci-app-jd-dailybonus/root/usr/share/jd-dailybonus/requests.lua new file mode 100644 index 000000000..c2fc4d702 --- /dev/null +++ b/package/lean/luci-app-jd-dailybonus/root/usr/share/jd-dailybonus/requests.lua @@ -0,0 +1,303 @@ +-- Lua Requests library for http ease + +local http_socket = require('socket.http') +local https_socket = require('ssl.https') +local url_parser = require('socket.url') +local ltn12 = require('ltn12') +local json = require('cjson.safe') +local md5sum = require('md5') -- TODO: Make modular? +local mime = require('mime') + +local requests = { + _DESCRIPTION = 'Http requests made simpler', + http_socket = http_socket, + https_socket = https_socket +} + +local _requests = {} + +--User facing function the make a request use Digest Authentication +--TODO: Determine what else should live in authentication +function requests.HTTPDigestAuth(user, password) + return { _type = 'digest', user = user, password = password} +end + +--User facing function the make a request use Basic Authentication +--TODO: Determine what else should live in authentication +function requests.HTTPBasicAuth(user, password) + return { _type = 'basic', user = user, password = password} +end + +function requests.post(url, args) + return requests.request("POST", url, args) +end + +function requests.get(url, args) + return requests.request("GET", url, args) +end + +function requests.delete(url, args) + return requests.request("DELETE", url, args) +end + +function requests.patch(url, args) + return requests.request("PATCH", url, args) +end + +function requests.put(url, args) + return requests.request("PUT", url, args) +end + +function requests.options(url, args) + return requests.request("OPTIONS", url, args) +end + +function requests.head(url, args) + return requests.request("HEAD", url, args) +end + +function requests.trace(url, args) + return requests.request("TRACE", url, args) +end + +--Sets up all the data for a request and makes the request +function requests.request(method, url, args) + local request + + if type(url) == "table" then + request = url + if not request.url and request[1] then + request.url = table.remove(request, 1) + end + else + request = args or {} + request.url = url + end + + request.method = method + _requests.parse_args(request) + + -- TODO: Find a better way to do this + if request.auth and request.auth._type == 'digest' then + local response = _requests.make_request(request) + return _requests.use_digest(response, request) + else + return _requests.make_request(request) + end +end + +--Makes a request +function _requests.make_request(request) + local response_body = {} + local full_request = { + method = request.method, + url = request.url, + headers = request.headers, + sink = ltn12.sink.table(response_body), + redirect = request.allow_redirects, + proxy = request.proxy + } + if request.data then + full_request.source = ltn12.source.string(request.data) + end + + local response = {} + local ok + local socket = string.find(full_request.url, '^https:') and not request.proxy and https_socket or http_socket + + ok, response.status_code, response.headers, response.status = socket.request(full_request) + + assert(ok, 'error in '..request.method..' request: '..response.status_code) + response.text = table.concat(response_body) + response.json = function () return json.decode(response.text) end + + return response +end + +--Parses through all the possible arguments for a request +function _requests.parse_args(request) + _requests.check_url(request) + _requests.check_data(request) + _requests.create_header(request) + _requests.check_timeout(request.timeout) + _requests.check_redirect(request.allow_redirects) +end + +--Format the the url based on the params argument +function _requests.format_params(url, params) -- TODO: Clean + if not params or next(params) == nil then return url end + + url = url..'?' + for key, value in pairs(params) do + if tostring(value) then + url = url..tostring(key)..'=' + + if type(value) == 'table' then + local val_string = '' + + for _, val in ipairs(value) do + val_string = val_string..tostring(val)..',' + end + + url = url..val_string:sub(0, -2) + else + url = url..tostring(value) + end + + url = url..'&' + end + end + + return url:sub(0, -2) +end + +--Check that there is a URL given and append to it if params are passed in. +function _requests.check_url(request) + assert(request.url, 'No url specified for request') + request.url = _requests.format_params(request.url, request.params) +end + +-- Add to the HTTP header +function _requests.create_header(request) + request.headers = request.headers or {} + if request.data then + request.headers['Content-Length'] = request.data:len() + end + + if request.cookies then + if request.headers.cookie then + request.headers.cookie = request.headers.cookie..'; '..request.cookies + else + request.headers.cookie = request.cookies + end + end + + if request.auth then + _requests.add_auth_headers(request) + end +end + +--Makes sure that the data is in a format that can be sent +function _requests.check_data(request) + if type(request.data) == "table" then + request.data = json.encode(request.data) + elseif request.data then + request.data = tostring(request.data) + end +end + +--Set the timeout +function _requests.check_timeout(timeout) + http_socket.TIMEOUT = timeout or 5 + https_socket.TIMEOUT = timeout or 5 +end + +--Checks is allow_redirects parameter is set correctly +function _requests.check_redirect(allow_redirects) + if allow_redirects and type(allow_redirects) ~= "boolean" then + error("allow_redirects expects a boolean value. received type = "..type(allow_redirects)) + end +end + +--Create the Authorization header for Basic Auth +function _requests.basic_auth_header(request) + local encoded = mime.b64(request.auth.user..':'..request.auth.password) + request.headers.Authorization = 'Basic '..encoded +end + +-- Create digest authorization string for request header TODO: Could be better, but it should work +function _requests.digest_create_header_string(auth) + local authorization = 'Digest username="'..auth.user..'", realm="'..auth.realm..'", nonce="'..auth.nonce + authorization = authorization..'", uri="'..auth.uri..'", qop='..auth.qop..', nc='..auth.nc + authorization = authorization..', cnonce="'..auth.cnonce..'", response="'..auth.response..'"' + + if auth.opaque then + authorization = authorization..', opaque="'..auth.opaque..'"' + end + + return authorization +end + +--MD5 hash all parameters +local function md5_hash(...) + return md5sum.sumhexa(table.concat({...}, ":")) +end + +-- Creates response hash TODO: Add functionality +function _requests.digest_hash_response(auth_table) + return md5_hash( + md5_hash(auth_table.user, auth_table.realm, auth_table.password), + auth_table.nonce, + auth_table.nc, + auth_table.cnonce, + auth_table.qop, + md5_hash(auth_table.method, auth_table.uri) + ) +end + +-- Add digest authentication to the request header +function _requests.digest_auth_header(request) + if not request.auth.nonce then return end + + request.auth.cnonce = request.auth.cnonce or string.format("%08x", os.time()) + + request.auth.nc_count = request.auth.nc_count or 0 + request.auth.nc_count = request.auth.nc_count + 1 + + request.auth.nc = string.format("%08x", request.auth.nc_count) + + local url = url_parser.parse(request.url) + request.auth.uri = url_parser.build{path = url.path, query = url.query} + request.auth.method = request.method + request.auth.qop = 'auth' + + request.auth.response = _requests.digest_hash_response(request.auth) + + request.headers.Authorization = _requests.digest_create_header_string(request.auth) +end + +--Checks the resonse code and adds additional headers for Digest Auth +-- TODO: Rename this +function _requests.use_digest(response, request) + if response.status_code == 401 then + _requests.parse_digest_response_header(response,request) + _requests.create_header(request) + response = _requests.make_request(request) + response.auth = request.auth + response.cookies = request.headers.cookie + return response + else + response.auth = request.auth + response.cookies = request.headers.cookie + return response + end +end + +--Parse the first response from the host to make the Authorization header +function _requests.parse_digest_response_header(response, request) + for key, value in response.headers['www-authenticate']:gmatch('(%w+)="(%S+)"') do + request.auth[key] = value + end + + if request.headers.cookie then + request.headers.cookie = request.headers.cookie..'; '..response.headers['set-cookie'] + else + request.headers.cookie = response.headers['set-cookie'] + end + + request.auth.nc_count = 0 +end + +-- Call the correct authentication header function +function _requests.add_auth_headers(request) + local auth_func = { + basic = _requests.basic_auth_header, + digest = _requests.digest_auth_header + } + + auth_func[request.auth._type](request) +end + +--Return public functions +requests._private = _requests +return requests diff --git a/package/lean/luci-app-jd-dailybonus/root/www/jd-dailybonus/JDCookie.zip b/package/lean/luci-app-jd-dailybonus/root/www/jd-dailybonus/JDCookie.zip deleted file mode 100644 index 54bcf0cd5cbf8c89b0b335508eb1f17ff0c753c5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 20108 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 diff --git a/package/lean/luci-app-jd-dailybonus/root/www/jd-dailybonus/qrcode.min.js b/package/lean/luci-app-jd-dailybonus/root/www/jd-dailybonus/qrcode.min.js new file mode 100644 index 000000000..993e88f39 --- /dev/null +++ b/package/lean/luci-app-jd-dailybonus/root/www/jd-dailybonus/qrcode.min.js @@ -0,0 +1 @@ +var QRCode;!function(){function a(a){this.mode=c.MODE_8BIT_BYTE,this.data=a,this.parsedData=[];for(var b=[],d=0,e=this.data.length;e>d;d++){var f=this.data.charCodeAt(d);f>65536?(b[0]=240|(1835008&f)>>>18,b[1]=128|(258048&f)>>>12,b[2]=128|(4032&f)>>>6,b[3]=128|63&f):f>2048?(b[0]=224|(61440&f)>>>12,b[1]=128|(4032&f)>>>6,b[2]=128|63&f):f>128?(b[0]=192|(1984&f)>>>6,b[1]=128|63&f):b[0]=f,this.parsedData=this.parsedData.concat(b)}this.parsedData.length!=this.data.length&&(this.parsedData.unshift(191),this.parsedData.unshift(187),this.parsedData.unshift(239))}function b(a,b){this.typeNumber=a,this.errorCorrectLevel=b,this.modules=null,this.moduleCount=0,this.dataCache=null,this.dataList=[]}function i(a,b){if(void 0==a.length)throw new Error(a.length+"/"+b);for(var c=0;c=f;f++){var h=0;switch(b){case d.L:h=l[f][0];break;case d.M:h=l[f][1];break;case d.Q:h=l[f][2];break;case d.H:h=l[f][3]}if(h>=e)break;c++}if(c>l.length)throw new Error("Too long data");return c}function s(a){var b=encodeURI(a).toString().replace(/\%[0-9a-fA-F]{2}/g,"a");return b.length+(b.length!=a?3:0)}a.prototype={getLength:function(){return this.parsedData.length},write:function(a){for(var b=0,c=this.parsedData.length;c>b;b++)a.put(this.parsedData[b],8)}},b.prototype={addData:function(b){var c=new a(b);this.dataList.push(c),this.dataCache=null},isDark:function(a,b){if(0>a||this.moduleCount<=a||0>b||this.moduleCount<=b)throw new Error(a+","+b);return this.modules[a][b]},getModuleCount:function(){return this.moduleCount},make:function(){this.makeImpl(!1,this.getBestMaskPattern())},makeImpl:function(a,c){this.moduleCount=4*this.typeNumber+17,this.modules=new Array(this.moduleCount);for(var d=0;d=7&&this.setupTypeNumber(a),null==this.dataCache&&(this.dataCache=b.createData(this.typeNumber,this.errorCorrectLevel,this.dataList)),this.mapData(this.dataCache,c)},setupPositionProbePattern:function(a,b){for(var c=-1;7>=c;c++)if(!(-1>=a+c||this.moduleCount<=a+c))for(var d=-1;7>=d;d++)-1>=b+d||this.moduleCount<=b+d||(this.modules[a+c][b+d]=c>=0&&6>=c&&(0==d||6==d)||d>=0&&6>=d&&(0==c||6==c)||c>=2&&4>=c&&d>=2&&4>=d?!0:!1)},getBestMaskPattern:function(){for(var a=0,b=0,c=0;8>c;c++){this.makeImpl(!0,c);var d=f.getLostPoint(this);(0==c||a>d)&&(a=d,b=c)}return b},createMovieClip:function(a,b,c){var d=a.createEmptyMovieClip(b,c),e=1;this.make();for(var f=0;f=g;g++)for(var h=-2;2>=h;h++)this.modules[d+g][e+h]=-2==g||2==g||-2==h||2==h||0==g&&0==h?!0:!1}},setupTypeNumber:function(a){for(var b=f.getBCHTypeNumber(this.typeNumber),c=0;18>c;c++){var d=!a&&1==(1&b>>c);this.modules[Math.floor(c/3)][c%3+this.moduleCount-8-3]=d}for(var c=0;18>c;c++){var d=!a&&1==(1&b>>c);this.modules[c%3+this.moduleCount-8-3][Math.floor(c/3)]=d}},setupTypeInfo:function(a,b){for(var c=this.errorCorrectLevel<<3|b,d=f.getBCHTypeInfo(c),e=0;15>e;e++){var g=!a&&1==(1&d>>e);6>e?this.modules[e][8]=g:8>e?this.modules[e+1][8]=g:this.modules[this.moduleCount-15+e][8]=g}for(var e=0;15>e;e++){var g=!a&&1==(1&d>>e);8>e?this.modules[8][this.moduleCount-e-1]=g:9>e?this.modules[8][15-e-1+1]=g:this.modules[8][15-e-1]=g}this.modules[this.moduleCount-8][8]=!a},mapData:function(a,b){for(var c=-1,d=this.moduleCount-1,e=7,g=0,h=this.moduleCount-1;h>0;h-=2)for(6==h&&h--;;){for(var i=0;2>i;i++)if(null==this.modules[d][h-i]){var j=!1;g>>e));var k=f.getMask(b,d,h-i);k&&(j=!j),this.modules[d][h-i]=j,e--,-1==e&&(g++,e=7)}if(d+=c,0>d||this.moduleCount<=d){d-=c,c=-c;break}}}},b.PAD0=236,b.PAD1=17,b.createData=function(a,c,d){for(var e=j.getRSBlocks(a,c),g=new k,h=0;h8*l)throw new Error("code length overflow. ("+g.getLengthInBits()+">"+8*l+")");for(g.getLengthInBits()+4<=8*l&&g.put(0,4);0!=g.getLengthInBits()%8;)g.putBit(!1);for(;;){if(g.getLengthInBits()>=8*l)break;if(g.put(b.PAD0,8),g.getLengthInBits()>=8*l)break;g.put(b.PAD1,8)}return b.createBytes(g,e)},b.createBytes=function(a,b){for(var c=0,d=0,e=0,g=new Array(b.length),h=new Array(b.length),j=0;j=0?p.get(q):0}}for(var r=0,m=0;mm;m++)for(var j=0;jm;m++)for(var j=0;j=0;)b^=f.G15<=0;)b^=f.G18<>>=1;return b},getPatternPosition:function(a){return f.PATTERN_POSITION_TABLE[a-1]},getMask:function(a,b,c){switch(a){case e.PATTERN000:return 0==(b+c)%2;case e.PATTERN001:return 0==b%2;case e.PATTERN010:return 0==c%3;case e.PATTERN011:return 0==(b+c)%3;case e.PATTERN100:return 0==(Math.floor(b/2)+Math.floor(c/3))%2;case e.PATTERN101:return 0==b*c%2+b*c%3;case e.PATTERN110:return 0==(b*c%2+b*c%3)%2;case e.PATTERN111:return 0==(b*c%3+(b+c)%2)%2;default:throw new Error("bad maskPattern:"+a)}},getErrorCorrectPolynomial:function(a){for(var b=new i([1],0),c=0;a>c;c++)b=b.multiply(new i([1,g.gexp(c)],0));return b},getLengthInBits:function(a,b){if(b>=1&&10>b)switch(a){case c.MODE_NUMBER:return 10;case c.MODE_ALPHA_NUM:return 9;case c.MODE_8BIT_BYTE:return 8;case c.MODE_KANJI:return 8;default:throw new Error("mode:"+a)}else if(27>b)switch(a){case c.MODE_NUMBER:return 12;case c.MODE_ALPHA_NUM:return 11;case c.MODE_8BIT_BYTE:return 16;case c.MODE_KANJI:return 10;default:throw new Error("mode:"+a)}else{if(!(41>b))throw new Error("type:"+b);switch(a){case c.MODE_NUMBER:return 14;case c.MODE_ALPHA_NUM:return 13;case c.MODE_8BIT_BYTE:return 16;case c.MODE_KANJI:return 12;default:throw new Error("mode:"+a)}}},getLostPoint:function(a){for(var b=a.getModuleCount(),c=0,d=0;b>d;d++)for(var e=0;b>e;e++){for(var f=0,g=a.isDark(d,e),h=-1;1>=h;h++)if(!(0>d+h||d+h>=b))for(var i=-1;1>=i;i++)0>e+i||e+i>=b||(0!=h||0!=i)&&g==a.isDark(d+h,e+i)&&f++;f>5&&(c+=3+f-5)}for(var d=0;b-1>d;d++)for(var e=0;b-1>e;e++){var j=0;a.isDark(d,e)&&j++,a.isDark(d+1,e)&&j++,a.isDark(d,e+1)&&j++,a.isDark(d+1,e+1)&&j++,(0==j||4==j)&&(c+=3)}for(var d=0;b>d;d++)for(var e=0;b-6>e;e++)a.isDark(d,e)&&!a.isDark(d,e+1)&&a.isDark(d,e+2)&&a.isDark(d,e+3)&&a.isDark(d,e+4)&&!a.isDark(d,e+5)&&a.isDark(d,e+6)&&(c+=40);for(var e=0;b>e;e++)for(var d=0;b-6>d;d++)a.isDark(d,e)&&!a.isDark(d+1,e)&&a.isDark(d+2,e)&&a.isDark(d+3,e)&&a.isDark(d+4,e)&&!a.isDark(d+5,e)&&a.isDark(d+6,e)&&(c+=40);for(var k=0,e=0;b>e;e++)for(var d=0;b>d;d++)a.isDark(d,e)&&k++;var l=Math.abs(100*k/b/b-50)/5;return c+=10*l}},g={glog:function(a){if(1>a)throw new Error("glog("+a+")");return g.LOG_TABLE[a]},gexp:function(a){for(;0>a;)a+=255;for(;a>=256;)a-=255;return g.EXP_TABLE[a]},EXP_TABLE:new Array(256),LOG_TABLE:new Array(256)},h=0;8>h;h++)g.EXP_TABLE[h]=1<h;h++)g.EXP_TABLE[h]=g.EXP_TABLE[h-4]^g.EXP_TABLE[h-5]^g.EXP_TABLE[h-6]^g.EXP_TABLE[h-8];for(var h=0;255>h;h++)g.LOG_TABLE[g.EXP_TABLE[h]]=h;i.prototype={get:function(a){return this.num[a]},getLength:function(){return this.num.length},multiply:function(a){for(var b=new Array(this.getLength()+a.getLength()-1),c=0;cf;f++)for(var g=c[3*f+0],h=c[3*f+1],i=c[3*f+2],k=0;g>k;k++)e.push(new j(h,i));return e},j.getRsBlockTable=function(a,b){switch(b){case d.L:return j.RS_BLOCK_TABLE[4*(a-1)+0];case d.M:return j.RS_BLOCK_TABLE[4*(a-1)+1];case d.Q:return j.RS_BLOCK_TABLE[4*(a-1)+2];case d.H:return j.RS_BLOCK_TABLE[4*(a-1)+3];default:return void 0}},k.prototype={get:function(a){var b=Math.floor(a/8);return 1==(1&this.buffer[b]>>>7-a%8)},put:function(a,b){for(var c=0;b>c;c++)this.putBit(1==(1&a>>>b-c-1))},getLengthInBits:function(){return this.length},putBit:function(a){var b=Math.floor(this.length/8);this.buffer.length<=b&&this.buffer.push(0),a&&(this.buffer[b]|=128>>>this.length%8),this.length++}};var l=[[17,14,11,7],[32,26,20,14],[53,42,32,24],[78,62,46,34],[106,84,60,44],[134,106,74,58],[154,122,86,64],[192,152,108,84],[230,180,130,98],[271,213,151,119],[321,251,177,137],[367,287,203,155],[425,331,241,177],[458,362,258,194],[520,412,292,220],[586,450,322,250],[644,504,364,280],[718,560,394,310],[792,624,442,338],[858,666,482,382],[929,711,509,403],[1003,779,565,439],[1091,857,611,461],[1171,911,661,511],[1273,997,715,535],[1367,1059,751,593],[1465,1125,805,625],[1528,1190,868,658],[1628,1264,908,698],[1732,1370,982,742],[1840,1452,1030,790],[1952,1538,1112,842],[2068,1628,1168,898],[2188,1722,1228,958],[2303,1809,1283,983],[2431,1911,1351,1051],[2563,1989,1423,1093],[2699,2099,1499,1139],[2809,2213,1579,1219],[2953,2331,1663,1273]],o=function(){var a=function(a,b){this._el=a,this._htOption=b};return a.prototype.draw=function(a){function g(a,b){var c=document.createElementNS("http://www.w3.org/2000/svg",a);for(var d in b)b.hasOwnProperty(d)&&c.setAttribute(d,b[d]);return c}var b=this._htOption,c=this._el,d=a.getModuleCount();Math.floor(b.width/d),Math.floor(b.height/d),this.clear();var h=g("svg",{viewBox:"0 0 "+String(d)+" "+String(d),width:"100%",height:"100%",fill:b.colorLight});h.setAttributeNS("http://www.w3.org/2000/xmlns/","xmlns:xlink","http://www.w3.org/1999/xlink"),c.appendChild(h),h.appendChild(g("rect",{fill:b.colorDark,width:"1",height:"1",id:"template"}));for(var i=0;d>i;i++)for(var j=0;d>j;j++)if(a.isDark(i,j)){var k=g("use",{x:String(i),y:String(j)});k.setAttributeNS("http://www.w3.org/1999/xlink","href","#template"),h.appendChild(k)}},a.prototype.clear=function(){for(;this._el.hasChildNodes();)this._el.removeChild(this._el.lastChild)},a}(),p="svg"===document.documentElement.tagName.toLowerCase(),q=p?o:m()?function(){function a(){this._elImage.src=this._elCanvas.toDataURL("image/png"),this._elImage.style.display="block",this._elCanvas.style.display="none"}function d(a,b){var c=this;if(c._fFail=b,c._fSuccess=a,null===c._bSupportDataURI){var d=document.createElement("img"),e=function(){c._bSupportDataURI=!1,c._fFail&&_fFail.call(c)},f=function(){c._bSupportDataURI=!0,c._fSuccess&&c._fSuccess.call(c)};return d.onabort=e,d.onerror=e,d.onload=f,d.src="",void 0}c._bSupportDataURI===!0&&c._fSuccess?c._fSuccess.call(c):c._bSupportDataURI===!1&&c._fFail&&c._fFail.call(c)}if(this._android&&this._android<=2.1){var b=1/window.devicePixelRatio,c=CanvasRenderingContext2D.prototype.drawImage;CanvasRenderingContext2D.prototype.drawImage=function(a,d,e,f,g,h,i,j){if("nodeName"in a&&/img/i.test(a.nodeName))for(var l=arguments.length-1;l>=1;l--)arguments[l]=arguments[l]*b;else"undefined"==typeof j&&(arguments[1]*=b,arguments[2]*=b,arguments[3]*=b,arguments[4]*=b);c.apply(this,arguments)}}var e=function(a,b){this._bIsPainted=!1,this._android=n(),this._htOption=b,this._elCanvas=document.createElement("canvas"),this._elCanvas.width=b.width,this._elCanvas.height=b.height,a.appendChild(this._elCanvas),this._el=a,this._oContext=this._elCanvas.getContext("2d"),this._bIsPainted=!1,this._elImage=document.createElement("img"),this._elImage.style.display="none",this._el.appendChild(this._elImage),this._bSupportDataURI=null};return e.prototype.draw=function(a){var b=this._elImage,c=this._oContext,d=this._htOption,e=a.getModuleCount(),f=d.width/e,g=d.height/e,h=Math.round(f),i=Math.round(g);b.style.display="none",this.clear();for(var j=0;e>j;j++)for(var k=0;e>k;k++){var l=a.isDark(j,k),m=k*f,n=j*g;c.strokeStyle=l?d.colorDark:d.colorLight,c.lineWidth=1,c.fillStyle=l?d.colorDark:d.colorLight,c.fillRect(m,n,f,g),c.strokeRect(Math.floor(m)+.5,Math.floor(n)+.5,h,i),c.strokeRect(Math.ceil(m)-.5,Math.ceil(n)-.5,h,i)}this._bIsPainted=!0},e.prototype.makeImage=function(){this._bIsPainted&&d.call(this,a)},e.prototype.isPainted=function(){return this._bIsPainted},e.prototype.clear=function(){this._oContext.clearRect(0,0,this._elCanvas.width,this._elCanvas.height),this._bIsPainted=!1},e.prototype.round=function(a){return a?Math.floor(1e3*a)/1e3:a},e}():function(){var a=function(a,b){this._el=a,this._htOption=b};return a.prototype.draw=function(a){for(var b=this._htOption,c=this._el,d=a.getModuleCount(),e=Math.floor(b.width/d),f=Math.floor(b.height/d),g=[''],h=0;d>h;h++){g.push("");for(var i=0;d>i;i++)g.push('');g.push("")}g.push("
"),c.innerHTML=g.join("");var j=c.childNodes[0],k=(b.width-j.offsetWidth)/2,l=(b.height-j.offsetHeight)/2;k>0&&l>0&&(j.style.margin=l+"px "+k+"px")},a.prototype.clear=function(){this._el.innerHTML=""},a}();QRCode=function(a,b){if(this._htOption={width:256,height:256,typeNumber:4,colorDark:"#000000",colorLight:"#ffffff",correctLevel:d.H},"string"==typeof b&&(b={text:b}),b)for(var c in b)this._htOption[c]=b[c];"string"==typeof a&&(a=document.getElementById(a)),this._android=n(),this._el=a,this._oQRCode=null,this._oDrawing=new q(this._el,this._htOption),this._htOption.text&&this.makeCode(this._htOption.text)},QRCode.prototype.makeCode=function(a){this._oQRCode=new b(r(a,this._htOption.correctLevel),this._htOption.correctLevel),this._oQRCode.addData(a),this._oQRCode.make(),this._el.title=a,this._oDrawing.draw(this._oQRCode),this.makeImage()},QRCode.prototype.makeImage=function(){"function"==typeof this._oDrawing.makeImage&&(!this._android||this._android>=3)&&this._oDrawing.makeImage()},QRCode.prototype.clear=function(){this._oDrawing.clear()},QRCode.CorrectLevel=d}(); \ No newline at end of file