mirror of https://github.com/NobyDa/Script.git
Merge pull request #280 from ztxtop/master
修正无扩展账号数据时获取ck报错及存储key判断错误问题
This commit is contained in:
commit
863c0eb492
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
京东多合一签到脚本
|
京东多合一签到脚本
|
||||||
|
|
||||||
更新时间: 2021.02.27 16:50 v1.94
|
更新时间: 2021.02.28 14:30 v1.95
|
||||||
有效接口: 35+
|
有效接口: 35+
|
||||||
脚本兼容: QuantumultX, Surge, Loon, JSBox, Node.js
|
脚本兼容: QuantumultX, Surge, Loon, JSBox, Node.js
|
||||||
电报频道: @NobyDa
|
电报频道: @NobyDa
|
||||||
|
@ -19,6 +19,8 @@ var Key = ''; //单引号内自行填写您抓取的Cookie
|
||||||
|
|
||||||
var DualKey = ''; //如需双账号签到,此处单引号内填写抓取的"账号2"Cookie, 否则请勿填写
|
var DualKey = ''; //如需双账号签到,此处单引号内填写抓取的"账号2"Cookie, 否则请勿填写
|
||||||
|
|
||||||
|
var OtherKey = ''; //第三账号或以上的Cookie json串数据, 以下样例为第三第四账号:var OtherKey = '[{"cookie":"pt_key=xxxxxx;pt_pin=yyyyyy"},{"cookie":"pt_key=xxxxxx;pt_pin=yyyyyy"}]'
|
||||||
|
|
||||||
/* 注1: 以上选项仅针对于JsBox或Node.js, 如果使用QX,Surge,Loon, 请使用脚本获取Cookie.
|
/* 注1: 以上选项仅针对于JsBox或Node.js, 如果使用QX,Surge,Loon, 请使用脚本获取Cookie.
|
||||||
注2: 双账号用户抓取"账号1"Cookie后, 请勿点击退出账号(可能会导致Cookie失效), 需清除浏览器资料或更换浏览器登录"账号2"抓取.
|
注2: 双账号用户抓取"账号1"Cookie后, 请勿点击退出账号(可能会导致Cookie失效), 需清除浏览器资料或更换浏览器登录"账号2"抓取.
|
||||||
注3: 如果复制的Cookie开头为"Cookie: "请把它删除后填入.
|
注3: 如果复制的Cookie开头为"Cookie: "请把它删除后填入.
|
||||||
|
@ -35,16 +37,15 @@ var DualKey = ''; //如需双账号签到,此处单引号内填写抓取的"账
|
||||||
由于cookie的有效性(经测试网页Cookie有效周期最长31天),如果脚本后续弹出cookie无效的通知,则需要重复上述步骤。
|
由于cookie的有效性(经测试网页Cookie有效周期最长31天),如果脚本后续弹出cookie无效的通知,则需要重复上述步骤。
|
||||||
签到脚本将在每天的凌晨0:05执行, 您可以修改执行时间。 因部分接口京豆限量领取, 建议调整为凌晨签到。
|
签到脚本将在每天的凌晨0:05执行, 您可以修改执行时间。 因部分接口京豆限量领取, 建议调整为凌晨签到。
|
||||||
|
|
||||||
BoxJs订阅地址: https://raw.githubusercontent.com/NobyDa/Script/master/NobyDa_BoxJs.json
|
BoxJs或QX Gallery订阅地址: https://raw.githubusercontent.com/NobyDa/Script/master/NobyDa_BoxJs.json
|
||||||
|
|
||||||
*************************
|
*************************
|
||||||
【 配置双京东账号签到说明 】 :
|
【 配置多京东账号签到说明 】 :
|
||||||
*************************
|
*************************
|
||||||
|
|
||||||
正确配置QX、Surge、Loon后, 并使用此脚本获取"账号1"Cookie成功后, 请勿点击退出账号(可能会导致Cookie失效), 需清除浏览器资料或更换浏览器登录"账号2"获取即可.
|
正确配置QX、Surge、Loon后, 并使用此脚本获取"账号1"Cookie成功后, 请勿点击退出账号(可能会导致Cookie失效), 需清除浏览器资料或更换浏览器登录"账号2"获取即可; 账号3或以上同理.
|
||||||
|
注: 如需清除所有Cookie, 您可开启脚本内"DeleteCookie"选项 (第96行)
|
||||||
|
|
||||||
注: 获取"账号1"或"账号2"的Cookie后, 后续仅可更新该"账号1"或"账号2"的Cookie.
|
|
||||||
如需写入其他账号,您可开启脚本内"DeleteCookie"选项以清除Cookie
|
|
||||||
*************************
|
*************************
|
||||||
【Surge 4.2+ 脚本配置】:
|
【Surge 4.2+ 脚本配置】:
|
||||||
*************************
|
*************************
|
||||||
|
@ -92,7 +93,7 @@ var LogDetails = false; //是否开启响应日志, true则开启
|
||||||
|
|
||||||
var stop = '0'; //自定义延迟签到, 单位毫秒. 默认分批并发无延迟; 该参数接受随机或指定延迟(例: '2000'则表示延迟2秒; '2000-5000'则表示延迟最小2秒,最大5秒内的随机延迟), 如填入延迟则切换顺序签到(耗时较长), Surge用户请注意在SurgeUI界面调整脚本超时; 注: 该参数Node.js或JSbox环境下已配置数据持久化, 留空(var stop = '')即可清除.
|
var stop = '0'; //自定义延迟签到, 单位毫秒. 默认分批并发无延迟; 该参数接受随机或指定延迟(例: '2000'则表示延迟2秒; '2000-5000'则表示延迟最小2秒,最大5秒内的随机延迟), 如填入延迟则切换顺序签到(耗时较长), Surge用户请注意在SurgeUI界面调整脚本超时; 注: 该参数Node.js或JSbox环境下已配置数据持久化, 留空(var stop = '')即可清除.
|
||||||
|
|
||||||
var DeleteCookie = false; //是否清除Cookie, true则开启.
|
var DeleteCookie = false; //是否清除所有Cookie, true则开启.
|
||||||
|
|
||||||
var boxdis = true; //是否开启自动禁用, false则关闭. 脚本运行崩溃时(如VPN断连), 下次运行时将自动禁用相关崩溃接口(仅部分接口启用), 崩溃时可能会误禁用正常接口. (该选项仅适用于QX,Surge,Loon)
|
var boxdis = true; //是否开启自动禁用, false则关闭. 脚本运行崩溃时(如VPN断连), 下次运行时将自动禁用相关崩溃接口(仅部分接口启用), 崩溃时可能会误禁用正常接口. (该选项仅适用于QX,Surge,Loon)
|
||||||
|
|
||||||
|
@ -250,29 +251,19 @@ function notify() {
|
||||||
var four = `【账号总计】: ${beans+Steel}${beans||Steel?`\n`:`获取失败\n`}`
|
var four = `【账号总计】: ${beans+Steel}${beans||Steel?`\n`:`获取失败\n`}`
|
||||||
var five = `【其他总计】: ${Subsidy+Money+Cash}${Subsidy||Money||Cash?`\n`:`获取失败\n`}`
|
var five = `【其他总计】: ${Subsidy+Money+Cash}${Subsidy||Money||Cash?`\n`:`获取失败\n`}`
|
||||||
var DName = merge.TotalBean && merge.TotalBean.nickname ? merge.TotalBean.nickname : "获取失败"
|
var DName = merge.TotalBean && merge.TotalBean.nickname ? merge.TotalBean.nickname : "获取失败"
|
||||||
var Name = add ? DualAccount ? `【签到号一】: ${DName}\n` : `【签到号二】: ${DName}\n` : ""
|
var cnNum = ["零", "一", "二", "三", "四", "五", "六", "七", "八", "九", "十"];
|
||||||
|
var Name = DualKey || OtherKey ? `【签到号${cnNum[DualAccount]||DualAccount}】: ${DName}\n` : ``
|
||||||
const disables = $nobyda.read("JD_DailyBonusDisables")
|
const disables = $nobyda.read("JD_DailyBonusDisables")
|
||||||
const amount = disables ? disables.split(",").length : 0
|
const amount = disables ? disables.split(",").length : 0
|
||||||
const disa = !notify || amount ? `【温馨提示】: 检测到${$nobyda.disable?`上次执行意外崩溃, `:``}已禁用${notify?`${amount}个`:`所有`}接口, 如需开启请前往BoxJs或查看脚本内第99行注释.\n` : ``
|
const disa = !notify || amount ? `【温馨提示】: 检测到${$nobyda.disable?`上次执行意外崩溃, `:``}已禁用${notify?`${amount}个`:`所有`}接口, 如需开启请前往BoxJs或查看脚本内第100行注释.\n` : ``
|
||||||
$nobyda.notify("", "", Name + one + two + three + four + five + disa + notify, {
|
$nobyda.notify("", "", Name + one + two + three + four + five + disa + notify, {
|
||||||
'media-url': $nobyda.headUrl || 'https://cdn.jsdelivr.net/gh/NobyDa/mini@master/Color/jd.png'
|
'media-url': $nobyda.headUrl || 'https://cdn.jsdelivr.net/gh/NobyDa/mini@master/Color/jd.png'
|
||||||
});
|
});
|
||||||
$nobyda.headUrl = null;
|
$nobyda.headUrl = null;
|
||||||
if ($nobyda.isJSBox) {
|
if ($nobyda.isJSBox) {
|
||||||
if (add && DualAccount) {
|
Shortcut = (typeof(Shortcut) == 'undefined' ? '' : Shortcut) + Name + one + two + three + four + five + "\n"
|
||||||
Shortcut = Name + one + two + three + "\n"
|
|
||||||
} else if (!add && DualAccount) {
|
|
||||||
$intents.finish(Name + one + two + three + four + five + notify)
|
|
||||||
} else if (typeof Shortcut != "undefined") {
|
|
||||||
$intents.finish(Shortcut + Name + one + two + three)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (DualAccount) {
|
|
||||||
double();
|
|
||||||
} else {
|
|
||||||
$nobyda.time();
|
|
||||||
$nobyda.done();
|
|
||||||
}
|
}
|
||||||
|
double();
|
||||||
} catch (eor) {
|
} catch (eor) {
|
||||||
$nobyda.notify("通知模块 " + eor.name + "‼️", JSON.stringify(eor), eor.message)
|
$nobyda.notify("通知模块 " + eor.name + "‼️", JSON.stringify(eor), eor.message)
|
||||||
} finally {
|
} finally {
|
||||||
|
@ -282,13 +273,15 @@ function notify() {
|
||||||
}
|
}
|
||||||
|
|
||||||
function ReadCookie() {
|
function ReadCookie() {
|
||||||
DualAccount = true;
|
DualAccount = 1;
|
||||||
const EnvInfo = $nobyda.isJSBox ? "JD_Cookie" : "CookieJD"
|
const EnvInfo = $nobyda.isJSBox ? "JD_Cookie" : "CookieJD"
|
||||||
const EnvInfo2 = $nobyda.isJSBox ? "JD_Cookie2" : "CookieJD2"
|
const EnvInfo2 = $nobyda.isJSBox ? "JD_Cookie2" : "CookieJD2"
|
||||||
|
const EnvInfo3 = $nobyda.isJSBox ? "JD_Cookies" : "CookiesJD"
|
||||||
if (DeleteCookie) {
|
if (DeleteCookie) {
|
||||||
if ($nobyda.read(EnvInfo) || $nobyda.read(EnvInfo2)) {
|
if ($nobyda.read(EnvInfo) || $nobyda.read(EnvInfo2) || ($nobyda.read(EnvInfo3) || '[]') != '[]') {
|
||||||
$nobyda.write("", EnvInfo)
|
$nobyda.write("", EnvInfo)
|
||||||
$nobyda.write("", EnvInfo2)
|
$nobyda.write("", EnvInfo2)
|
||||||
|
$nobyda.write("", EnvInfo3)
|
||||||
$nobyda.notify("京东Cookie清除成功 !", "", '请手动关闭脚本内"DeleteCookie"选项')
|
$nobyda.notify("京东Cookie清除成功 !", "", '请手动关闭脚本内"DeleteCookie"选项')
|
||||||
$nobyda.done()
|
$nobyda.done()
|
||||||
return
|
return
|
||||||
|
@ -300,14 +293,16 @@ function ReadCookie() {
|
||||||
GetCookie()
|
GetCookie()
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if (Key || $nobyda.read(EnvInfo)) {
|
KEY = Key = Key || $nobyda.read(EnvInfo)
|
||||||
|
if (KEY) {
|
||||||
|
DualKey = DualKey || $nobyda.read(EnvInfo2)
|
||||||
|
OtherKey = OtherKey || $nobyda.read(EnvInfo3)
|
||||||
if ($nobyda.isJSBox || $nobyda.isNode) {
|
if ($nobyda.isJSBox || $nobyda.isNode) {
|
||||||
if (Key) $nobyda.write(Key, EnvInfo);
|
if (Key) $nobyda.write(Key, EnvInfo);
|
||||||
if (DualKey) $nobyda.write(DualKey, EnvInfo2);
|
if (DualKey) $nobyda.write(DualKey, EnvInfo2);
|
||||||
|
if (OtherKey) $nobyda.write(OtherKey, EnvInfo3);
|
||||||
if (stop !== '0') $nobyda.write(stop, "JD_DailyBonusDelay");
|
if (stop !== '0') $nobyda.write(stop, "JD_DailyBonusDelay");
|
||||||
}
|
}
|
||||||
add = DualKey || $nobyda.read(EnvInfo2) ? true : false
|
|
||||||
KEY = Key ? Key : $nobyda.read(EnvInfo)
|
|
||||||
out = parseInt($nobyda.read("JD_DailyBonusTimeOut")) || out
|
out = parseInt($nobyda.read("JD_DailyBonusTimeOut")) || out
|
||||||
stop = Wait($nobyda.read("JD_DailyBonusDelay"), true) || Wait(stop, true)
|
stop = Wait($nobyda.read("JD_DailyBonusDelay"), true) || Wait(stop, true)
|
||||||
boxdis = $nobyda.read("JD_Crash_disable") === "false" || $nobyda.isNode || $nobyda.isJSBox ? false : boxdis
|
boxdis = $nobyda.read("JD_Crash_disable") === "false" || $nobyda.isNode || $nobyda.isJSBox ? false : boxdis
|
||||||
|
@ -321,12 +316,29 @@ function ReadCookie() {
|
||||||
}
|
}
|
||||||
|
|
||||||
function double() {
|
function double() {
|
||||||
add = true
|
KEY = '';
|
||||||
DualAccount = false
|
if (DualAccount == 1) {
|
||||||
if (DualKey || $nobyda.read($nobyda.isJSBox ? "JD_Cookie2" : "CookieJD2")) {
|
DualAccount++;
|
||||||
KEY = DualKey ? DualKey : $nobyda.read($nobyda.isJSBox ? "JD_Cookie2" : "CookieJD2")
|
KEY = DualKey
|
||||||
|
}
|
||||||
|
if (!KEY && OtherKey) {
|
||||||
|
DualAccount++;
|
||||||
|
let cks = [];
|
||||||
|
try {
|
||||||
|
cks = JSON.parse(OtherKey);
|
||||||
|
} catch (e) {
|
||||||
|
cks = [];
|
||||||
|
}
|
||||||
|
if (cks.length + 2 >= DualAccount) {
|
||||||
|
KEY = cks[DualAccount - 3].cookie;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (KEY) {
|
||||||
all()
|
all()
|
||||||
} else {
|
} else {
|
||||||
|
if ($nobyda.isJSBox) {
|
||||||
|
$intents.finish(Shortcut)
|
||||||
|
}
|
||||||
$nobyda.time();
|
$nobyda.time();
|
||||||
$nobyda.done();
|
$nobyda.done();
|
||||||
}
|
}
|
||||||
|
@ -2068,36 +2080,49 @@ function Wait(readDelay, ini) {
|
||||||
|
|
||||||
function GetCookie() {
|
function GetCookie() {
|
||||||
try {
|
try {
|
||||||
if ($request.headers && $request.url.match(/api\.m\.jd\.com.*=signBean/)) {
|
if ($request.method != 'OPTIONS' && $request.headers && $request.url !== 'http://www.apple.com/') {
|
||||||
var CV = $request.headers['Cookie']
|
let acObj = {};
|
||||||
if (CV.match(/pt_key=.+?;/) && CV.match(/pt_pin=.+?;/)) {
|
// 提取ck数据
|
||||||
var CookieValue = CV.match(/pt_key=.+?;/)[0] + CV.match(/pt_pin=.+?;/)[0]
|
let CV = ($request.headers['Cookie'] || $request.headers['cookie'] || '').replace(/ /g, '');
|
||||||
var CK1 = $nobyda.read("CookieJD")
|
let ckItems = CV.split(';').filter(s => /^(pt_key|pt_pin)=.+/.test(s)).sort();
|
||||||
var CK2 = $nobyda.read("CookieJD2")
|
if (ckItems.length == 2) {
|
||||||
var AccountOne = CK1 ? CK1.match(/pt_pin=.+?;/) ? CK1.match(/pt_pin=(.+?);/)[1] : null : null
|
acObj.cookie = ckItems.join(';') + ';';
|
||||||
var AccountTwo = CK2 ? CK2.match(/pt_pin=.+?;/) ? CK2.match(/pt_pin=(.+?);/)[1] : null : null
|
acObj.userName = decodeURIComponent(acObj.cookie.match(/pt_pin=(.+?);/)[1]);
|
||||||
var UserName = CookieValue.match(/pt_pin=(.+?);/)[1]
|
}
|
||||||
var DecodeName = decodeURIComponent(UserName)
|
// 无cookie数据进行提示,有ck数据,找到账号位进行存储
|
||||||
if (!AccountOne || UserName == AccountOne) {
|
if (!acObj.cookie) {
|
||||||
var CookieName = " [账号一] ";
|
|
||||||
var CookieKey = "CookieJD";
|
|
||||||
} else if (!AccountTwo || UserName == AccountTwo) {
|
|
||||||
var CookieName = " [账号二] ";
|
|
||||||
var CookieKey = "CookieJD2";
|
|
||||||
} else {
|
|
||||||
$nobyda.notify("更新京东Cookie失败", "非历史写入账号 ‼️", '请开启脚本内"DeleteCookie"以清空Cookie ‼️')
|
|
||||||
return
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$nobyda.notify("写入京东Cookie失败", "", "请查看脚本内说明, 登录网页获取 ‼️")
|
$nobyda.notify("写入京东Cookie失败", "", "请查看脚本内说明, 登录网页获取 ‼️")
|
||||||
return
|
return
|
||||||
}
|
|
||||||
const RA = $nobyda.read(CookieKey);
|
|
||||||
if (RA == CookieValue) {
|
|
||||||
console.log(`\n用户名: ${DecodeName}\n与历史京东${CookieName}Cookie相同, 跳过写入 ⚠️`)
|
|
||||||
} else {
|
} else {
|
||||||
const WT = $nobyda.write(CookieValue, CookieKey);
|
const allCk = [$nobyda.read('CookieJD'), $nobyda.read('CookieJD2')];
|
||||||
$nobyda.notify(`用户名: ${DecodeName}`, ``, `${RA?`更新`:`写入`}京东${CookieName}Cookie${WT?`成功 🎉`:`失败 ‼️`}`)
|
const ocks = $nobyda.read('CookiesJD');
|
||||||
|
let oldCks = [];
|
||||||
|
try {
|
||||||
|
oldCks = (ocks && JSON.parse(ocks)) || [];
|
||||||
|
} catch (e) {
|
||||||
|
console.log(`写入京东Cookie时转换京东扩展账号数据CookiesJD异常,扩展账号信息:\n${ocks}`)
|
||||||
|
oldCks = [];
|
||||||
|
}
|
||||||
|
oldCks.forEach(item => allCk.push(item.cookie));
|
||||||
|
let [status, seatNo] = chooseSeatNo(acObj.cookie, allCk, /pt_pin=(.+?);/);
|
||||||
|
if (status) {
|
||||||
|
if (status > 0) {
|
||||||
|
let WT = '';
|
||||||
|
if (seatNo < 2) {
|
||||||
|
WT = $nobyda.write(acObj.cookie, `CookieJD${seatNo?seatNo+1:''}`);
|
||||||
|
} else {
|
||||||
|
if (oldCks.length <= seatNo - 2) {
|
||||||
|
oldCks.push(acObj);
|
||||||
|
} else {
|
||||||
|
oldCks[seatNo - 2] = acObj;
|
||||||
|
}
|
||||||
|
WT = $nobyda.write(JSON.stringify(oldCks, null, 2), 'CookiesJD');
|
||||||
|
}
|
||||||
|
$nobyda.notify(`用户名: ${acObj.userName}`, ``, `${status==2?`更新`:`写入`}京东 [账号${seatNo+1}] Cookie${WT?`成功 🎉`:`失败 ‼️`}`)
|
||||||
|
} else {
|
||||||
|
console.log(`\n用户名: ${acObj.userName}\n与历史京东 [账号${seatNo+1}] Cookie相同, 跳过写入 ⚠️`)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else if ($request.url === 'http://www.apple.com/') {
|
} else if ($request.url === 'http://www.apple.com/') {
|
||||||
$nobyda.notify("京东签到", "", "类型错误, 手动运行请选择上下文环境为Cron ⚠️");
|
$nobyda.notify("京东签到", "", "类型错误, 手动运行请选择上下文环境为Cron ⚠️");
|
||||||
|
@ -2107,12 +2132,42 @@ function GetCookie() {
|
||||||
} catch (eor) {
|
} catch (eor) {
|
||||||
$nobyda.write("", "CookieJD")
|
$nobyda.write("", "CookieJD")
|
||||||
$nobyda.write("", "CookieJD2")
|
$nobyda.write("", "CookieJD2")
|
||||||
|
$nobyda.write("", "CookiesJD")
|
||||||
$nobyda.notify("写入京东Cookie失败", "", '已尝试清空历史Cookie, 请重试 ⚠️')
|
$nobyda.notify("写入京东Cookie失败", "", '已尝试清空历史Cookie, 请重试 ⚠️')
|
||||||
console.log(`\n写入京东Cookie出现错误 ‼️\n${JSON.stringify(eor)}\n\n${eor}\n\n${JSON.stringify($request.headers)}\n`)
|
console.log(`\n写入京东Cookie出现错误 ‼️\n${JSON.stringify(eor)}\n\n${eor}\n\n${JSON.stringify($request.headers)}\n`)
|
||||||
} finally {
|
} finally {
|
||||||
$nobyda.done()
|
$nobyda.done()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// 获取新ck存放位置
|
||||||
|
function chooseSeatNo(newCk, allCk, reg) {
|
||||||
|
// status-获取操作状态-0:异常、1-新增、2-更新、-1-相同 seatNo-存储位置,默认添加到最后面
|
||||||
|
let [status, seatNo] = [1, allCk.length];
|
||||||
|
try {
|
||||||
|
let newId = ((newCk || '').match(reg) || ['', ''])[1];
|
||||||
|
for (let i = 0, len = allCk.length; i < len; i++) {
|
||||||
|
let oldId = ((allCk[i] || '').match(reg) || ['', ''])[1];
|
||||||
|
if (oldId) {
|
||||||
|
// 账号位数据存在,判断是否为当前账号的数据,不是则跳过,否则设置数据并跳出循环
|
||||||
|
if (oldId == newId) {
|
||||||
|
seatNo = i;
|
||||||
|
status = newCk == allCk[i] ? -1 : 2;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} else if (seatNo == len) {
|
||||||
|
// 旧cookie无效且在初始账号位,先标记新cookie数据存储于此位置
|
||||||
|
seatNo = i;
|
||||||
|
status = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
// 异常时,不操作cookie
|
||||||
|
status = 0;
|
||||||
|
console.log(`\n查询账号存储位置异常 ‼️\n${JSON.stringify(e)}\n\n${e}\n`)
|
||||||
|
}
|
||||||
|
return [status, seatNo];
|
||||||
|
}
|
||||||
|
|
||||||
// Modified from yichahucha
|
// Modified from yichahucha
|
||||||
function nobyda() {
|
function nobyda() {
|
||||||
const start = Date.now()
|
const start = Date.now()
|
||||||
|
@ -2348,4 +2403,4 @@ function nobyda() {
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
ReadCookie();
|
ReadCookie();
|
||||||
|
|
Loading…
Reference in New Issue