mirror of
https://github.com/shufflewzc/faker2.git
synced 2025-04-23 10:58:44 +08:00
Merge branch 'shufflewzc:main' into main
This commit is contained in:
commit
87b907b77d
531
jd_CkSeq.js
Normal file
531
jd_CkSeq.js
Normal file
@ -0,0 +1,531 @@
|
|||||||
|
/*
|
||||||
|
cron "0 0 * * *" jd_CheckCkSeq.js, tag:CK顺序调试工具by-ccwav
|
||||||
|
*/
|
||||||
|
const $ = new Env("CK顺序调试工具");
|
||||||
|
const {
|
||||||
|
getEnvs
|
||||||
|
} = require('./ql');
|
||||||
|
const notify = $.isNode() ? require('./sendNotify') : '';
|
||||||
|
const jdCookieNode = $.isNode() ? require("./jdCookie.js") : "";
|
||||||
|
let cookiesArr = [];
|
||||||
|
if ($.isNode()) {
|
||||||
|
Object.keys(jdCookieNode).forEach((item) => {
|
||||||
|
cookiesArr.push(jdCookieNode[item])
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
let arrCkPtPin = [];
|
||||||
|
let arrEnvPtPin = [];
|
||||||
|
let arrEnvStatus = [];
|
||||||
|
let arrEnvOnebyOne = [];
|
||||||
|
let strCk = "";
|
||||||
|
let strNoFoundCk = "";
|
||||||
|
let strMessage = "";
|
||||||
|
|
||||||
|
const fs = require('fs');
|
||||||
|
let TempCKUid = [];
|
||||||
|
let strUidFile = '/ql/scripts/CK_WxPusherUid.json';
|
||||||
|
let UidFileexists = fs.existsSync(strUidFile);
|
||||||
|
if (UidFileexists) {
|
||||||
|
console.log("检测到一对一Uid文件WxPusherUid.json,载入...");
|
||||||
|
TempCKUid = fs.readFileSync(strUidFile, 'utf-8');
|
||||||
|
if (TempCKUid) {
|
||||||
|
TempCKUid = TempCKUid.toString();
|
||||||
|
TempCKUid = JSON.parse(TempCKUid);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
!(async() => {
|
||||||
|
|
||||||
|
const envs = await getEnvs();
|
||||||
|
for (let i = 0; i < envs.length; i++) {
|
||||||
|
if (envs[i].value) {
|
||||||
|
var tempptpin = decodeURIComponent(envs[i].value.match(/pt_pin=([^; ]+)(?=;?)/) && envs[i].value.match(/pt_pin=([^; ]+)(?=;?)/)[1]);
|
||||||
|
arrEnvPtPin.push(tempptpin);
|
||||||
|
arrEnvStatus.push(envs[i].status);
|
||||||
|
var struuid=getuuid(envs[i].remarks,tempptpin)
|
||||||
|
arrEnvOnebyOne.push(struuid);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (let i = 0; i < cookiesArr.length; i++) {
|
||||||
|
if (cookiesArr[i]) {
|
||||||
|
cookie = cookiesArr[i];
|
||||||
|
var tempptpin = decodeURIComponent(cookie.match(/pt_pin=([^; ]+)(?=;?)/) && cookie.match(/pt_pin=([^; ]+)(?=;?)/)[1]);
|
||||||
|
var intSeq = inArray(tempptpin, arrEnvPtPin);
|
||||||
|
if (intSeq != -1) {
|
||||||
|
intSeq += 1;
|
||||||
|
arrCkPtPin.push(tempptpin);
|
||||||
|
strCk += "【"+intSeq + "】" + tempptpin ;
|
||||||
|
if (arrEnvOnebyOne[i]) {
|
||||||
|
strCk += "(账号已启用一对一推送)"
|
||||||
|
}
|
||||||
|
strCk +="\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (let i = 0; i < arrEnvPtPin.length; i++) {
|
||||||
|
var tempptpin = arrEnvPtPin[i];
|
||||||
|
var intSeq = inArray(tempptpin, arrCkPtPin);
|
||||||
|
if (intSeq == -1) {
|
||||||
|
strNoFoundCk += "【"+(i + 1) + "】" + tempptpin;
|
||||||
|
if (arrEnvStatus[i] == 1) {
|
||||||
|
strNoFoundCk += "(状态已禁用)"
|
||||||
|
}
|
||||||
|
if (arrEnvOnebyOne[i]) {
|
||||||
|
strNoFoundCk += "(账号已启用一对一推送)"
|
||||||
|
}
|
||||||
|
strNoFoundCk +="\n";
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (strNoFoundCk) {
|
||||||
|
console.log("没有出现在今日CK队列中的账号: \n" + strNoFoundCk);
|
||||||
|
strMessage+="没有出现在今日CK队列中的账号: \n" + strNoFoundCk;
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log("\n今日执行任务的账号顺序: \n" + strCk);
|
||||||
|
strMessage+="\n今日执行任务的账号顺序: \n" + strCk;
|
||||||
|
|
||||||
|
if ($.isNode()) {
|
||||||
|
await notify.sendNotify(`${$.name}`, strMessage);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
})()
|
||||||
|
.catch((e) => $.logErr(e))
|
||||||
|
.finally(() => $.done());
|
||||||
|
|
||||||
|
function inArray(search, array) {
|
||||||
|
var lnSeq = -1;
|
||||||
|
for (var i in array) {
|
||||||
|
if (array[i] == search) {
|
||||||
|
lnSeq = i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return parseInt(lnSeq);
|
||||||
|
}
|
||||||
|
|
||||||
|
function getuuid(strRemark, PtPin) {
|
||||||
|
var strTempuuid = "";
|
||||||
|
if (strRemark) {
|
||||||
|
var Tempindex = strRemark.indexOf("@@");
|
||||||
|
if (Tempindex != -1) {
|
||||||
|
//console.log(PtPin + ": 检测到NVJDC的一对一格式,瑞思拜~!");
|
||||||
|
var TempRemarkList = strRemark.split("@@");
|
||||||
|
for (let j = 1; j < TempRemarkList.length; j++) {
|
||||||
|
if (TempRemarkList[j]) {
|
||||||
|
if (TempRemarkList[j].length > 4) {
|
||||||
|
if (TempRemarkList[j].substring(0, 4) == "UID_") {
|
||||||
|
strTempuuid = TempRemarkList[j];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!strTempuuid && TempCKUid) {
|
||||||
|
//console.log("正在从CK_WxPusherUid文件中检索资料...");
|
||||||
|
for (let j = 0; j < TempCKUid.length; j++) {
|
||||||
|
if (PtPin == decodeURIComponent(TempCKUid[j].pt_pin)) {
|
||||||
|
strTempuuid = TempCKUid[j].Uid;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return strTempuuid;
|
||||||
|
}
|
||||||
|
|
||||||
|
// prettier-ignore
|
||||||
|
function Env(t, e) {
|
||||||
|
"undefined" != typeof process && JSON.stringify(process.env).indexOf("GITHUB") > -1 && process.exit(0);
|
||||||
|
class s {
|
||||||
|
constructor(t) {
|
||||||
|
this.env = t
|
||||||
|
}
|
||||||
|
send(t, e = "GET") {
|
||||||
|
t = "string" == typeof t ? {
|
||||||
|
url: t
|
||||||
|
}
|
||||||
|
: t;
|
||||||
|
let s = this.get;
|
||||||
|
return "POST" === e && (s = this.post),
|
||||||
|
new Promise((e, i) => {
|
||||||
|
s.call(this, t, (t, s, r) => {
|
||||||
|
t ? i(t) : e(s)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
get(t) {
|
||||||
|
return this.send.call(this.env, t)
|
||||||
|
}
|
||||||
|
post(t) {
|
||||||
|
return this.send.call(this.env, t, "POST")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return new class {
|
||||||
|
constructor(t, e) {
|
||||||
|
this.name = t,
|
||||||
|
this.http = new s(this),
|
||||||
|
this.data = null,
|
||||||
|
this.dataFile = "box.dat",
|
||||||
|
this.logs = [],
|
||||||
|
this.isMute = !1,
|
||||||
|
this.isNeedRewrite = !1,
|
||||||
|
this.logSeparator = "\n",
|
||||||
|
this.startTime = (new Date).getTime(),
|
||||||
|
Object.assign(this, e),
|
||||||
|
this.log("", `🔔${this.name}, 开始!`)
|
||||||
|
}
|
||||||
|
isNode() {
|
||||||
|
return "undefined" != typeof module && !!module.exports
|
||||||
|
}
|
||||||
|
isQuanX() {
|
||||||
|
return "undefined" != typeof $task
|
||||||
|
}
|
||||||
|
isSurge() {
|
||||||
|
return "undefined" != typeof $httpClient && "undefined" == typeof $loon
|
||||||
|
}
|
||||||
|
isLoon() {
|
||||||
|
return "undefined" != typeof $loon
|
||||||
|
}
|
||||||
|
toObj(t, e = null) {
|
||||||
|
try {
|
||||||
|
return JSON.parse(t)
|
||||||
|
} catch {
|
||||||
|
return e
|
||||||
|
}
|
||||||
|
}
|
||||||
|
toStr(t, e = null) {
|
||||||
|
try {
|
||||||
|
return JSON.stringify(t)
|
||||||
|
} catch {
|
||||||
|
return e
|
||||||
|
}
|
||||||
|
}
|
||||||
|
getjson(t, e) {
|
||||||
|
let s = e;
|
||||||
|
const i = this.getdata(t);
|
||||||
|
if (i)
|
||||||
|
try {
|
||||||
|
s = JSON.parse(this.getdata(t))
|
||||||
|
} catch {}
|
||||||
|
return s
|
||||||
|
}
|
||||||
|
setjson(t, e) {
|
||||||
|
try {
|
||||||
|
return this.setdata(JSON.stringify(t), e)
|
||||||
|
} catch {
|
||||||
|
return !1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
getScript(t) {
|
||||||
|
return new Promise(e => {
|
||||||
|
this.get({
|
||||||
|
url: t
|
||||||
|
}, (t, s, i) => e(i))
|
||||||
|
})
|
||||||
|
}
|
||||||
|
runScript(t, e) {
|
||||||
|
return new Promise(s => {
|
||||||
|
let i = this.getdata("@chavy_boxjs_userCfgs.httpapi");
|
||||||
|
i = i ? i.replace(/\n/g, "").trim() : i;
|
||||||
|
let r = this.getdata("@chavy_boxjs_userCfgs.httpapi_timeout");
|
||||||
|
r = r ? 1 * r : 20,
|
||||||
|
r = e && e.timeout ? e.timeout : r;
|
||||||
|
const[o, h] = i.split("@"),
|
||||||
|
n = {
|
||||||
|
url: `http://${h}/v1/scripting/evaluate`,
|
||||||
|
body: {
|
||||||
|
script_text: t,
|
||||||
|
mock_type: "cron",
|
||||||
|
timeout: r
|
||||||
|
},
|
||||||
|
headers: {
|
||||||
|
"X-Key": o,
|
||||||
|
Accept: "*/*"
|
||||||
|
}
|
||||||
|
};
|
||||||
|
this.post(n, (t, e, i) => s(i))
|
||||||
|
}).catch(t => this.logErr(t))
|
||||||
|
}
|
||||||
|
loaddata() {
|
||||||
|
if (!this.isNode())
|
||||||
|
return {}; {
|
||||||
|
this.fs = this.fs ? this.fs : require("fs"),
|
||||||
|
this.path = this.path ? this.path : require("path");
|
||||||
|
const t = this.path.resolve(this.dataFile),
|
||||||
|
e = this.path.resolve(process.cwd(), this.dataFile),
|
||||||
|
s = this.fs.existsSync(t),
|
||||||
|
i = !s && this.fs.existsSync(e);
|
||||||
|
if (!s && !i)
|
||||||
|
return {}; {
|
||||||
|
const i = s ? t : e;
|
||||||
|
try {
|
||||||
|
return JSON.parse(this.fs.readFileSync(i))
|
||||||
|
} catch (t) {
|
||||||
|
return {}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
writedata() {
|
||||||
|
if (this.isNode()) {
|
||||||
|
this.fs = this.fs ? this.fs : require("fs"),
|
||||||
|
this.path = this.path ? this.path : require("path");
|
||||||
|
const t = this.path.resolve(this.dataFile),
|
||||||
|
e = this.path.resolve(process.cwd(), this.dataFile),
|
||||||
|
s = this.fs.existsSync(t),
|
||||||
|
i = !s && this.fs.existsSync(e),
|
||||||
|
r = JSON.stringify(this.data);
|
||||||
|
s ? this.fs.writeFileSync(t, r) : i ? this.fs.writeFileSync(e, r) : this.fs.writeFileSync(t, r)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
lodash_get(t, e, s) {
|
||||||
|
const i = e.replace(/\[(\d+)\]/g, ".$1").split(".");
|
||||||
|
let r = t;
|
||||||
|
for (const t of i)
|
||||||
|
if (r = Object(r)[t], void 0 === r)
|
||||||
|
return s;
|
||||||
|
return r
|
||||||
|
}
|
||||||
|
lodash_set(t, e, s) {
|
||||||
|
return Object(t) !== t ? t : (Array.isArray(e) || (e = e.toString().match(/[^.[\]]+/g) || []), e.slice(0, -1).reduce((t, s, i) => Object(t[s]) === t[s] ? t[s] : t[s] = Math.abs(e[i + 1]) >> 0 == +e[i + 1] ? [] : {}, t)[e[e.length - 1]] = s, t)
|
||||||
|
}
|
||||||
|
getdata(t) {
|
||||||
|
let e = this.getval(t);
|
||||||
|
if (/^@/.test(t)) {
|
||||||
|
const[, s, i] = /^@(.*?)\.(.*?)$/.exec(t),
|
||||||
|
r = s ? this.getval(s) : "";
|
||||||
|
if (r)
|
||||||
|
try {
|
||||||
|
const t = JSON.parse(r);
|
||||||
|
e = t ? this.lodash_get(t, i, "") : e
|
||||||
|
} catch (t) {
|
||||||
|
e = ""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return e
|
||||||
|
}
|
||||||
|
setdata(t, e) {
|
||||||
|
let s = !1;
|
||||||
|
if (/^@/.test(e)) {
|
||||||
|
const[, i, r] = /^@(.*?)\.(.*?)$/.exec(e),
|
||||||
|
o = this.getval(i),
|
||||||
|
h = i ? "null" === o ? null : o || "{}" : "{}";
|
||||||
|
try {
|
||||||
|
const e = JSON.parse(h);
|
||||||
|
this.lodash_set(e, r, t),
|
||||||
|
s = this.setval(JSON.stringify(e), i)
|
||||||
|
} catch (e) {
|
||||||
|
const o = {};
|
||||||
|
this.lodash_set(o, r, t),
|
||||||
|
s = this.setval(JSON.stringify(o), i)
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
s = this.setval(t, e);
|
||||||
|
return s
|
||||||
|
}
|
||||||
|
getval(t) {
|
||||||
|
return this.isSurge() || this.isLoon() ? $persistentStore.read(t) : this.isQuanX() ? $prefs.valueForKey(t) : this.isNode() ? (this.data = this.loaddata(), this.data[t]) : this.data && this.data[t] || null
|
||||||
|
}
|
||||||
|
setval(t, e) {
|
||||||
|
return this.isSurge() || this.isLoon() ? $persistentStore.write(t, e) : this.isQuanX() ? $prefs.setValueForKey(t, e) : this.isNode() ? (this.data = this.loaddata(), this.data[e] = t, this.writedata(), !0) : this.data && this.data[e] || null
|
||||||
|
}
|
||||||
|
initGotEnv(t) {
|
||||||
|
this.got = this.got ? this.got : require("got"),
|
||||||
|
this.cktough = this.cktough ? this.cktough : require("tough-cookie"),
|
||||||
|
this.ckjar = this.ckjar ? this.ckjar : new this.cktough.CookieJar,
|
||||||
|
t && (t.headers = t.headers ? t.headers : {}, void 0 === t.headers.Cookie && void 0 === t.cookieJar && (t.cookieJar = this.ckjar))
|
||||||
|
}
|
||||||
|
get(t, e = (() => {})) {
|
||||||
|
t.headers && (delete t.headers["Content-Type"], delete t.headers["Content-Length"]),
|
||||||
|
this.isSurge() || this.isLoon() ? (this.isSurge() && this.isNeedRewrite && (t.headers = t.headers || {}, Object.assign(t.headers, {
|
||||||
|
"X-Surge-Skip-Scripting": !1
|
||||||
|
})), $httpClient.get(t, (t, s, i) => {
|
||||||
|
!t && s && (s.body = i, s.statusCode = s.status),
|
||||||
|
e(t, s, i)
|
||||||
|
})) : this.isQuanX() ? (this.isNeedRewrite && (t.opts = t.opts || {}, Object.assign(t.opts, {
|
||||||
|
hints: !1
|
||||||
|
})), $task.fetch(t).then(t => {
|
||||||
|
const {
|
||||||
|
statusCode: s,
|
||||||
|
statusCode: i,
|
||||||
|
headers: r,
|
||||||
|
body: o
|
||||||
|
} = t;
|
||||||
|
e(null, {
|
||||||
|
status: s,
|
||||||
|
statusCode: i,
|
||||||
|
headers: r,
|
||||||
|
body: o
|
||||||
|
}, o)
|
||||||
|
}, t => e(t))) : this.isNode() && (this.initGotEnv(t), this.got(t).on("redirect", (t, e) => {
|
||||||
|
try {
|
||||||
|
if (t.headers["set-cookie"]) {
|
||||||
|
const s = t.headers["set-cookie"].map(this.cktough.Cookie.parse).toString();
|
||||||
|
s && this.ckjar.setCookieSync(s, null),
|
||||||
|
e.cookieJar = this.ckjar
|
||||||
|
}
|
||||||
|
} catch (t) {
|
||||||
|
this.logErr(t)
|
||||||
|
}
|
||||||
|
}).then(t => {
|
||||||
|
const {
|
||||||
|
statusCode: s,
|
||||||
|
statusCode: i,
|
||||||
|
headers: r,
|
||||||
|
body: o
|
||||||
|
} = t;
|
||||||
|
e(null, {
|
||||||
|
status: s,
|
||||||
|
statusCode: i,
|
||||||
|
headers: r,
|
||||||
|
body: o
|
||||||
|
}, o)
|
||||||
|
}, t => {
|
||||||
|
const {
|
||||||
|
message: s,
|
||||||
|
response: i
|
||||||
|
} = t;
|
||||||
|
e(s, i, i && i.body)
|
||||||
|
}))
|
||||||
|
}
|
||||||
|
post(t, e = (() => {})) {
|
||||||
|
if (t.body && t.headers && !t.headers["Content-Type"] && (t.headers["Content-Type"] = "application/x-www-form-urlencoded"), t.headers && delete t.headers["Content-Length"], this.isSurge() || this.isLoon())
|
||||||
|
this.isSurge() && this.isNeedRewrite && (t.headers = t.headers || {}, Object.assign(t.headers, {
|
||||||
|
"X-Surge-Skip-Scripting": !1
|
||||||
|
})), $httpClient.post(t, (t, s, i) => {
|
||||||
|
!t && s && (s.body = i, s.statusCode = s.status),
|
||||||
|
e(t, s, i)
|
||||||
|
});
|
||||||
|
else if (this.isQuanX())
|
||||||
|
t.method = "POST", this.isNeedRewrite && (t.opts = t.opts || {}, Object.assign(t.opts, {
|
||||||
|
hints: !1
|
||||||
|
})), $task.fetch(t).then(t => {
|
||||||
|
const {
|
||||||
|
statusCode: s,
|
||||||
|
statusCode: i,
|
||||||
|
headers: r,
|
||||||
|
body: o
|
||||||
|
} = t;
|
||||||
|
e(null, {
|
||||||
|
status: s,
|
||||||
|
statusCode: i,
|
||||||
|
headers: r,
|
||||||
|
body: o
|
||||||
|
}, o)
|
||||||
|
}, t => e(t));
|
||||||
|
else if (this.isNode()) {
|
||||||
|
this.initGotEnv(t);
|
||||||
|
const {
|
||||||
|
url: s,
|
||||||
|
...i
|
||||||
|
} = t;
|
||||||
|
this.got.post(s, i).then(t => {
|
||||||
|
const {
|
||||||
|
statusCode: s,
|
||||||
|
statusCode: i,
|
||||||
|
headers: r,
|
||||||
|
body: o
|
||||||
|
} = t;
|
||||||
|
e(null, {
|
||||||
|
status: s,
|
||||||
|
statusCode: i,
|
||||||
|
headers: r,
|
||||||
|
body: o
|
||||||
|
}, o)
|
||||||
|
}, t => {
|
||||||
|
const {
|
||||||
|
message: s,
|
||||||
|
response: i
|
||||||
|
} = t;
|
||||||
|
e(s, i, i && i.body)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
time(t, e = null) {
|
||||||
|
const s = e ? new Date(e) : new Date;
|
||||||
|
let i = {
|
||||||
|
"M+": s.getMonth() + 1,
|
||||||
|
"d+": s.getDate(),
|
||||||
|
"H+": s.getHours(),
|
||||||
|
"m+": s.getMinutes(),
|
||||||
|
"s+": s.getSeconds(),
|
||||||
|
"q+": Math.floor((s.getMonth() + 3) / 3),
|
||||||
|
S: s.getMilliseconds()
|
||||||
|
};
|
||||||
|
/(y+)/.test(t) && (t = t.replace(RegExp.$1, (s.getFullYear() + "").substr(4 - RegExp.$1.length)));
|
||||||
|
for (let e in i)
|
||||||
|
new RegExp("(" + e + ")").test(t) && (t = t.replace(RegExp.$1, 1 == RegExp.$1.length ? i[e] : ("00" + i[e]).substr(("" + i[e]).length)));
|
||||||
|
return t
|
||||||
|
}
|
||||||
|
msg(e = t, s = "", i = "", r) {
|
||||||
|
const o = t => {
|
||||||
|
if (!t)
|
||||||
|
return t;
|
||||||
|
if ("string" == typeof t)
|
||||||
|
return this.isLoon() ? t : this.isQuanX() ? {
|
||||||
|
"open-url": t
|
||||||
|
}
|
||||||
|
: this.isSurge() ? {
|
||||||
|
url: t
|
||||||
|
}
|
||||||
|
: void 0;
|
||||||
|
if ("object" == typeof t) {
|
||||||
|
if (this.isLoon()) {
|
||||||
|
let e = t.openUrl || t.url || t["open-url"],
|
||||||
|
s = t.mediaUrl || t["media-url"];
|
||||||
|
return {
|
||||||
|
openUrl: e,
|
||||||
|
mediaUrl: s
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (this.isQuanX()) {
|
||||||
|
let e = t["open-url"] || t.url || t.openUrl,
|
||||||
|
s = t["media-url"] || t.mediaUrl;
|
||||||
|
return {
|
||||||
|
"open-url": e,
|
||||||
|
"media-url": s
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (this.isSurge()) {
|
||||||
|
let e = t.url || t.openUrl || t["open-url"];
|
||||||
|
return {
|
||||||
|
url: e
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
if (this.isMute || (this.isSurge() || this.isLoon() ? $notification.post(e, s, i, o(r)) : this.isQuanX() && $notify(e, s, i, o(r))), !this.isMuteLog) {
|
||||||
|
let t = ["", "==============📣系统通知📣=============="];
|
||||||
|
t.push(e),
|
||||||
|
s && t.push(s),
|
||||||
|
i && t.push(i),
|
||||||
|
console.log(t.join("\n")),
|
||||||
|
this.logs = this.logs.concat(t)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
log(...t) {
|
||||||
|
t.length > 0 && (this.logs = [...this.logs, ...t]),
|
||||||
|
console.log(t.join(this.logSeparator))
|
||||||
|
}
|
||||||
|
logErr(t, e) {
|
||||||
|
const s = !this.isSurge() && !this.isQuanX() && !this.isLoon();
|
||||||
|
s ? this.log("", `❗️${this.name}, 错误!`, t.stack) : this.log("", `❗️${this.name}, 错误!`, t)
|
||||||
|
}
|
||||||
|
wait(t) {
|
||||||
|
return new Promise(e => setTimeout(e, t))
|
||||||
|
}
|
||||||
|
done(t = {}) {
|
||||||
|
const e = (new Date).getTime(),
|
||||||
|
s = (e - this.startTime) / 1e3;
|
||||||
|
this.log("", `🔔${this.name}, 结束! 🕛 ${s} 秒`),
|
||||||
|
this.log(),
|
||||||
|
(this.isSurge() || this.isQuanX() || this.isLoon()) && $done(t)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
(t, e)
|
||||||
|
}
|
2349
jd_bean_sign.js
2349
jd_bean_sign.js
File diff suppressed because one or more lines are too long
273
jd_jrmx.py
Normal file
273
jd_jrmx.py
Normal file
@ -0,0 +1,273 @@
|
|||||||
|
# -*- coding:utf-8 -*-
|
||||||
|
#依赖管理-Python3-添加依赖PyExecJS
|
||||||
|
#依赖安装:进入容器执行:pip3 install PyExecJS
|
||||||
|
#想拿券的cookie环境变量JDJR_COOKIE,格式就是普通的cookie格式(pt_key=xxx;pt_pin=xxx)
|
||||||
|
#活动每天早上10点开始截止到这个月28号,建议corn 5 0 10 * * *
|
||||||
|
|
||||||
|
"""
|
||||||
|
cron: 5 0 10 * * *
|
||||||
|
new Env('京东金融分享助力');
|
||||||
|
"""
|
||||||
|
|
||||||
|
import execjs
|
||||||
|
import requests
|
||||||
|
import json
|
||||||
|
import time
|
||||||
|
import os
|
||||||
|
import re
|
||||||
|
import sys
|
||||||
|
import random
|
||||||
|
import string
|
||||||
|
import urllib
|
||||||
|
from urllib.parse import quote
|
||||||
|
|
||||||
|
|
||||||
|
#以下部分参考Curtin的脚本:https://github.com/curtinlv/JD-Script
|
||||||
|
|
||||||
|
|
||||||
|
def randomuserAgent():
|
||||||
|
global uuid,addressid,iosVer,iosV,clientVersion,iPhone,ADID,area,lng,lat
|
||||||
|
|
||||||
|
uuid=''.join(random.sample(['a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z','0','1','2','3','4','5','6','7','8','9','a','b','c','z'], 40))
|
||||||
|
addressid = ''.join(random.sample('1234567898647', 10))
|
||||||
|
iosVer = ''.join(random.sample(["15.1.1","14.5.1", "14.4", "14.3", "14.2", "14.1", "14.0.1"], 1))
|
||||||
|
iosV = iosVer.replace('.', '_')
|
||||||
|
clientVersion=''.join(random.sample(["10.3.0", "10.2.7", "10.2.4"], 1))
|
||||||
|
iPhone = ''.join(random.sample(["8", "9", "10", "11", "12", "13"], 1))
|
||||||
|
ADID = ''.join(random.sample('0987654321ABCDEF', 8)) + '-' + ''.join(random.sample('0987654321ABCDEF', 4)) + '-' + ''.join(random.sample('0987654321ABCDEF', 4)) + '-' + ''.join(random.sample('0987654321ABCDEF', 4)) + '-' + ''.join(random.sample('0987654321ABCDEF', 12))
|
||||||
|
|
||||||
|
|
||||||
|
area=''.join(random.sample('0123456789', 2)) + '_' + ''.join(random.sample('0123456789', 4)) + '_' + ''.join(random.sample('0123456789', 5)) + '_' + ''.join(random.sample('0123456789', 4))
|
||||||
|
lng='119.31991256596'+str(random.randint(100,999))
|
||||||
|
lat='26.1187118976'+str(random.randint(100,999))
|
||||||
|
|
||||||
|
|
||||||
|
UserAgent=''
|
||||||
|
if not UserAgent:
|
||||||
|
return f'jdapp;iPhone;10.0.4;{iosVer};{uuid};network/wifi;ADID/{ADID};model/iPhone{iPhone},1;addressid/{addressid};appBuild/167707;jdSupportDarkMode/0;Mozilla/5.0 (iPhone; CPU iPhone OS {iosV} like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/null;supportJDSHWK/1'
|
||||||
|
else:
|
||||||
|
return UserAgent
|
||||||
|
|
||||||
|
#以上部分参考Curtin的脚本:https://github.com/curtinlv/JD-Script
|
||||||
|
|
||||||
|
|
||||||
|
def printf(text):
|
||||||
|
print(text+'\n')
|
||||||
|
sys.stdout.flush()
|
||||||
|
|
||||||
|
|
||||||
|
def load_send():
|
||||||
|
global send
|
||||||
|
cur_path = os.path.abspath(os.path.dirname(__file__))
|
||||||
|
sys.path.append(cur_path)
|
||||||
|
if os.path.exists(cur_path + "/sendNotify.py"):
|
||||||
|
try:
|
||||||
|
from sendNotify import send
|
||||||
|
except:
|
||||||
|
send=False
|
||||||
|
printf("加载通知服务失败~")
|
||||||
|
else:
|
||||||
|
send=False
|
||||||
|
printf("加载通知服务失败~")
|
||||||
|
load_send()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
def get_remarkinfo():
|
||||||
|
url='http://127.0.0.1:5600/api/envs'
|
||||||
|
try:
|
||||||
|
with open('/ql/config/auth.json', 'r') as f:
|
||||||
|
token=json.loads(f.read())['token']
|
||||||
|
headers={
|
||||||
|
'Accept':'application/json',
|
||||||
|
'authorization':'Bearer '+token,
|
||||||
|
}
|
||||||
|
response=requests.get(url=url,headers=headers)
|
||||||
|
|
||||||
|
for i in range(len(json.loads(response.text)['data'])):
|
||||||
|
if json.loads(response.text)['data'][i]['name']=='JD_COOKIE':
|
||||||
|
try:
|
||||||
|
if json.loads(response.text)['data'][i]['remarks'].find('@@')==-1:
|
||||||
|
remarkinfos[json.loads(response.text)['data'][i]['value'].split(';')[1].replace('pt_pin=','')]=json.loads(response.text)['data'][i]['remarks'].replace('remark=','')
|
||||||
|
else:
|
||||||
|
remarkinfos[json.loads(response.text)['data'][i]['value'].split(';')[1].replace('pt_pin=','')]=json.loads(response.text)['data'][i]['remarks'].split("@@")[0].replace('remark=','').replace(';','')
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
except:
|
||||||
|
printf('读取auth.json文件出错,跳过获取备注')
|
||||||
|
|
||||||
|
|
||||||
|
def JDSignValidator(url):
|
||||||
|
with open('JDJRSignValidator.js', 'r', encoding='utf-8') as f:
|
||||||
|
jstext = f.read()
|
||||||
|
ctx = execjs.compile(jstext)
|
||||||
|
result = ctx.call('getBody', url)
|
||||||
|
fp=result['fp']
|
||||||
|
a=result['a']
|
||||||
|
d=result['d']
|
||||||
|
return fp,a,d
|
||||||
|
|
||||||
|
|
||||||
|
def geteid(a,d):
|
||||||
|
url=f'https://gia.jd.com/fcf.html?a={a}'
|
||||||
|
data=f'&d={d}'
|
||||||
|
headers={
|
||||||
|
'Host':'gia.jd.com',
|
||||||
|
'Content-Type':'application/x-www-form-urlencoded;charset=UTF-8',
|
||||||
|
'Origin':'https://jrmkt.jd.com',
|
||||||
|
'Accept-Encoding':'gzip, deflate, br',
|
||||||
|
'Connection':'keep-alive',
|
||||||
|
'Accept':'*/*',
|
||||||
|
'User-Agent':UserAgent,
|
||||||
|
'Referer':'https://jrmkt.jd.com/',
|
||||||
|
'Content-Length':'376',
|
||||||
|
'Accept-Language':'zh-CN,zh-Hans;q=0.9',
|
||||||
|
}
|
||||||
|
response=requests.post(url=url,headers=headers,data=data)
|
||||||
|
return response.text
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
def gettoken():
|
||||||
|
url='https://gia.jd.com/m.html'
|
||||||
|
headers={'User-Agent':UserAgent}
|
||||||
|
response=requests.get(url=url,headers=headers)
|
||||||
|
return response.text.split(';')[0].replace('var jd_risk_token_id = \'','').replace('\'','')
|
||||||
|
|
||||||
|
|
||||||
|
def getsharetasklist(ck,eid,fp,token):
|
||||||
|
url='https://ms.jr.jd.com/gw/generic/bt/h5/m/getShareTaskList'
|
||||||
|
data='reqData='+quote('{"extMap":{"eid":"%s","fp":"%s","sdkToken":"","token":"%s","appType":"1","pageUrl":"https://btfront.jd.com/release/shareCouponRedemption/helpList/?channelId=17&channelName=pdy&jrcontainer=h5&jrlogin=true&jrcloseweb=false"},"channelId":"17","bizGroup":18}'%(eid,fp,token))
|
||||||
|
headers={
|
||||||
|
'Host':'ms.jr.jd.com',
|
||||||
|
'Content-Type':'application/x-www-form-urlencoded',
|
||||||
|
'Origin':'https://btfront.jd.com',
|
||||||
|
'Accept-Encoding':'gzip, deflate, br',
|
||||||
|
'Cookie':ck,
|
||||||
|
'Connection':'keep-alive',
|
||||||
|
'Accept':'application/json, text/plain, */*',
|
||||||
|
'User-Agent':UserAgent,
|
||||||
|
'Referer':'https://btfront.jd.com/',
|
||||||
|
'Content-Length':str(len(data)),
|
||||||
|
'Accept-Language':'zh-CN,zh-Hans;q=0.9'
|
||||||
|
}
|
||||||
|
try:
|
||||||
|
response=requests.post(url=url,headers=headers,data=data)
|
||||||
|
for i in range(len(json.loads(response.text)['resultData']['data'])):
|
||||||
|
if json.loads(response.text)['resultData']['data'][i]['couponBigWord']=='12' and json.loads(response.text)['resultData']['data'][i]['couponSmallWord']=='期':
|
||||||
|
printf('12期免息券活动id:'+str(json.loads(response.text)['resultData']['data'][i]['activityId']))
|
||||||
|
return json.loads(response.text)['resultData']['data'][i]['activityId']
|
||||||
|
break
|
||||||
|
except:
|
||||||
|
printf('获取任务信息出错,程序即将退出!')
|
||||||
|
os._exit(0)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
def obtainsharetask(ck,eid,fp,token,activityid):
|
||||||
|
url='https://ms.jr.jd.com/gw/generic/bt/h5/m/obtainShareTask'
|
||||||
|
data='reqData='+quote('{"extMap":{"eid":"%s","fp":"%s","sdkToken":"","token":"%s","appType":"1","pageUrl":"https://btfront.jd.com/release/shareCouponRedemption/helpList/?channelId=17&channelName=pdy&jrcontainer=h5&jrlogin=true&jrcloseweb=false"},"activityId":%s}'%(eid,fp,token,activityid))
|
||||||
|
headers={
|
||||||
|
'Host':'ms.jr.jd.com',
|
||||||
|
'Content-Type':'application/x-www-form-urlencoded',
|
||||||
|
'Origin':'https://btfront.jd.com',
|
||||||
|
'Accept-Encoding':'gzip, deflate, br',
|
||||||
|
'Cookie':ck,
|
||||||
|
'Connection':'keep-alive',
|
||||||
|
'Accept':'application/json, text/plain, */*',
|
||||||
|
'User-Agent':UserAgent,
|
||||||
|
'Referer':'https://btfront.jd.com/',
|
||||||
|
'Content-Length':str(len(data)),
|
||||||
|
'Accept-Language':'zh-CN,zh-Hans;q=0.9'
|
||||||
|
}
|
||||||
|
try:
|
||||||
|
response=requests.post(url=url,headers=headers,data=data)
|
||||||
|
printf('obtainActivityId:'+json.loads(response.text)['resultData']['data']['obtainActivityId'])
|
||||||
|
printf('inviteCode:'+json.loads(response.text)['resultData']['data']['inviteCode'])
|
||||||
|
return json.loads(response.text)['resultData']['data']['obtainActivityId']+'@'+json.loads(response.text)['resultData']['data']['inviteCode']
|
||||||
|
except:
|
||||||
|
printf('开启任务出错,程序即将退出!')
|
||||||
|
os._exit(0)
|
||||||
|
|
||||||
|
|
||||||
|
def assist(ck,eid,fp,token,obtainActivityid,invitecode):
|
||||||
|
url='https://ms.jr.jd.com/gw/generic/bt/h5/m/helpFriend'
|
||||||
|
data='reqData='+quote('{"extMap":{"eid":"%s","fp":"%s","sdkToken":"","token":"%s","appType":"10","pageUrl":"https://btfront.jd.com/release/shareCouponRedemption/sharePage/?obtainActivityId=%s&channelId=17&channelName=pdy&jrcontainer=h5&jrcloseweb=false&jrlogin=true&inviteCode=%s"},"obtainActivityId":"%s","inviteCode":"%s"}'%(eid,fp,token,obtainActivityid,invitecode,obtainActivityid,invitecode))
|
||||||
|
headers={
|
||||||
|
'Host':'ms.jr.jd.com',
|
||||||
|
'Content-Type':'application/x-www-form-urlencoded',
|
||||||
|
'Origin':'https://btfront.jd.com',
|
||||||
|
'Accept-Encoding':'gzip, deflate, br',
|
||||||
|
'Cookie':ck,
|
||||||
|
'Connection':'keep-alive',
|
||||||
|
'Accept':'application/json, text/plain, */*',
|
||||||
|
'User-Agent':UserAgent,
|
||||||
|
'Referer':'https://btfront.jd.com/',
|
||||||
|
'Content-Length':str(len(data)),
|
||||||
|
'Accept-Language':'zh-CN,zh-Hans;q=0.9'
|
||||||
|
}
|
||||||
|
try:
|
||||||
|
response=requests.post(url=url,headers=headers,data=data)
|
||||||
|
if response.text.find('本次助力活动已完成')!=-1:
|
||||||
|
send('京东白条12期免息优惠券助力完成','去京东金融-白条-我的-我的优惠券看看吧')
|
||||||
|
printf('助力完成,程序即将退出!')
|
||||||
|
os._exit(0)
|
||||||
|
else:
|
||||||
|
if json.loads(response.text)['resultData']['result']['code']=='0000':
|
||||||
|
printf('助力成功')
|
||||||
|
elif json.loads(response.text)['resultData']['result']['code']=='M1003':
|
||||||
|
printf('该用户未开启白条,助力失败!')
|
||||||
|
elif json.loads(response.text)['resultData']['result']['code']=='U0002':
|
||||||
|
printf('该用户白条账户异常,助力失败!')
|
||||||
|
elif json.loads(response.text)['resultData']['result']['code']=='E0004':
|
||||||
|
printf('该活动仅限受邀用户参与,助力失败!')
|
||||||
|
else:
|
||||||
|
print(response.text)
|
||||||
|
except:
|
||||||
|
try:
|
||||||
|
print(response.text)
|
||||||
|
except:
|
||||||
|
printf('助力出错,可能是cookie过期了')
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
remarkinfos={}
|
||||||
|
get_remarkinfo()
|
||||||
|
|
||||||
|
|
||||||
|
jdjrcookie=os.environ["JDJR_COOKIE"]
|
||||||
|
|
||||||
|
UserAgent=randomuserAgent()
|
||||||
|
info=JDSignValidator('https://jrmfp.jr.jd.com/')
|
||||||
|
eid=json.loads(geteid(info[1],info[2]).split('_*')[1])['eid']
|
||||||
|
fp=info[0]
|
||||||
|
token=gettoken()
|
||||||
|
activityid=getsharetasklist(jdjrcookie,eid,fp,token)
|
||||||
|
inviteinfo=obtainsharetask(jdjrcookie,eid,fp,token,activityid)
|
||||||
|
|
||||||
|
|
||||||
|
try:
|
||||||
|
cks = os.environ["JD_COOKIE"].split("&")
|
||||||
|
except:
|
||||||
|
f = open("/jd/config/config.sh", "r", encoding='utf-8')
|
||||||
|
cks = re.findall(r'Cookie[0-9]*="(pt_key=.*?;pt_pin=.*?;)"', f.read())
|
||||||
|
f.close()
|
||||||
|
for ck in cks:
|
||||||
|
ptpin = re.findall(r"pt_pin=(.*?);", ck)[0]
|
||||||
|
try:
|
||||||
|
if remarkinfos[ptpin]!='':
|
||||||
|
printf("--账号:" + remarkinfos[ptpin] + "--")
|
||||||
|
username=remarkinfos[ptpin]
|
||||||
|
else:
|
||||||
|
printf("--无备注账号:" + urllib.parse.unquote(ptpin) + "--")
|
||||||
|
username=urllib.parse.unquote(ptpin)
|
||||||
|
except:
|
||||||
|
printf("--账号:" + urllib.parse.unquote(ptpin) + "--")
|
||||||
|
username=urllib.parse.unquote(ptpin)
|
||||||
|
UserAgent=randomuserAgent()
|
||||||
|
info=JDSignValidator('https://jrmfp.jr.jd.com/')
|
||||||
|
eid=json.loads(geteid(info[1],info[2]).split('_*')[1])['eid']
|
||||||
|
fp=info[0]
|
||||||
|
token=gettoken()
|
||||||
|
assist(ck,eid,fp,token,inviteinfo.split('@')[0],inviteinfo.split('@')[1])
|
529
jd_jxlhb.js
Normal file
529
jd_jxlhb.js
Normal file
File diff suppressed because one or more lines are too long
18
jd_m_sign.js
18
jd_m_sign.js
@ -6,7 +6,7 @@
|
|||||||
===========================
|
===========================
|
||||||
[task_local]
|
[task_local]
|
||||||
#京东通天塔--签到
|
#京东通天塔--签到
|
||||||
3 0 * * * jd_m_sign.js, tag=京东通天塔--签到, img-url=https://raw.githubusercontent.com/Orz-3/mini/master/Color/jd.png, enabled=true
|
3 1,11 * * * jd_m_sign.js, tag=京东通天塔--签到, img-url=https://raw.githubusercontent.com/Orz-3/mini/master/Color/jd.png, enabled=true
|
||||||
*/
|
*/
|
||||||
|
|
||||||
const $ = new Env('京东通天塔--签到');
|
const $ = new Env('京东通天塔--签到');
|
||||||
@ -64,14 +64,18 @@ async function jdsign() {
|
|||||||
try {
|
try {
|
||||||
console.log(`签到开始........`)
|
console.log(`签到开始........`)
|
||||||
await getInfo("https://pro.m.jd.com/mall/active/3S28janPLYmtFxypu37AYAGgivfp/index.html");//拍拍二手签到
|
await getInfo("https://pro.m.jd.com/mall/active/3S28janPLYmtFxypu37AYAGgivfp/index.html");//拍拍二手签到
|
||||||
await $.wait(1000)
|
await $.wait(2000)
|
||||||
await getInfo("https://pro.m.jd.com/mall/active/4QjXVcRyTcRaLPaU6z2e3Sw1QzWE/index.html");//全城购签到
|
|
||||||
await $.wait(1000)
|
|
||||||
await getInfo("https://prodev.m.jd.com/mall/active/3MFSkPGCDZrP2WPKBRZdiKm9AZ7D/index.html");//同城签到
|
|
||||||
await $.wait(1000)
|
|
||||||
await getInfo("https://pro.m.jd.com/mall/active/kPM3Xedz1PBiGQjY4ZYGmeVvrts/index.html");//陪伴
|
await getInfo("https://pro.m.jd.com/mall/active/kPM3Xedz1PBiGQjY4ZYGmeVvrts/index.html");//陪伴
|
||||||
await $.wait(1000)
|
await $.wait(2000)
|
||||||
await getInfo("https://pro.m.jd.com/mall/active/3SC6rw5iBg66qrXPGmZMqFDwcyXi/index.html");//京东图书
|
await getInfo("https://pro.m.jd.com/mall/active/3SC6rw5iBg66qrXPGmZMqFDwcyXi/index.html");//京东图书
|
||||||
|
await $.wait(2000)
|
||||||
|
await getInfo("https://prodev.m.jd.com/mall/active/412SRRXnKE1Q4Y6uJRWVT6XhyseG/index.html");//京东服装
|
||||||
|
// await getInfo("https://pro.m.jd.com/mall/active/ZrH7gGAcEkY2gH8wXqyAPoQgk6t/index.html");//箱包签到
|
||||||
|
// await $.wait(1000)
|
||||||
|
// await getInfo("https://pro.m.jd.com/mall/active/4RXyb1W4Y986LJW8ToqMK14BdTD/index.html");//鞋靴馆签到
|
||||||
|
|
||||||
|
// await $.wait(1000)
|
||||||
|
// await getInfo("https://pro.m.jd.com/mall/active/3joSPpr7RgdHMbcuqoRQ8HbcPo9U/index.html");//生活特权签到
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
$.logErr(e)
|
$.logErr(e)
|
||||||
}
|
}
|
||||||
|
56
jd_nzmh.js
56
jd_nzmh.js
@ -1,22 +1,35 @@
|
|||||||
/*
|
/*
|
||||||
#女装盲盒抽京豆任务,自行加入一下环境变量
|
女装盲盒
|
||||||
export jd_nzmhurl="https://anmp.jd.com/babelDiy/Zeus/2x36jyruNVDWxUiAiGAgHRrkqVX2/index.html"
|
活动时间:2021-3-1至2021-3-31
|
||||||
|
活动地址:https://anmp.jd.com/babelDiy/Zeus/3z12ngsd27UR1KfRqdMrMSSg3uxg/index.html
|
||||||
|
活动入口:京东app-女装馆-赢京豆
|
||||||
|
已支持IOS双京东账号,Node.js支持N个京东账号
|
||||||
|
脚本兼容: QuantumultX, Surge, Loon, JSBox, Node.js
|
||||||
|
============Quantumultx===============
|
||||||
|
[task_local]
|
||||||
|
#女装盲盒
|
||||||
|
35 1,23 * * * https://raw.githubusercontent.com/Aaron-lv/sync/jd_scripts/jd_nzmh.js, tag=女装盲盒, img-url=https://raw.githubusercontent.com/Orz-3/mini/master/Color/jd.png, enabled=true
|
||||||
|
|
||||||
cron 35 1,23 * * *
|
================Loon==============
|
||||||
|
[Script]
|
||||||
|
cron "35 1,23 * * *" script-path=https://raw.githubusercontent.com/Aaron-lv/sync/jd_scripts/jd_nzmh.js,tag=女装盲盒
|
||||||
|
|
||||||
|
===============Surge=================
|
||||||
|
女装盲盒 = type=cron,cronexp="35 1,23 * * *",wake-system=1,timeout=3600,script-path=https://raw.githubusercontent.com/Aaron-lv/sync/jd_scripts/jd_nzmh.js
|
||||||
|
|
||||||
|
============小火箭=========
|
||||||
|
女装盲盒 = type=cron,script-path=https://raw.githubusercontent.com/Aaron-lv/sync/jd_scripts/jd_nzmh.js, cronexpr="35 1,23 * * *", timeout=3600, enable=true
|
||||||
*/
|
*/
|
||||||
|
|
||||||
const $ = new Env('女装盲盒抽京豆');
|
const $ = new Env('女装盲盒抽京豆');
|
||||||
const notify = $.isNode() ? require('./sendNotify') : '';
|
const notify = $.isNode() ? require('./sendNotify') : '';
|
||||||
const jdCookieNode = $.isNode() ? require('./jdCookie.js') : '';
|
const jdCookieNode = $.isNode() ? require('./jdCookie.js') : '';
|
||||||
//Node.js用户请在jdCookie.js处填写京东ck;
|
//Node.js用户请在jdCookie.js处填写京东ck;
|
||||||
//IOS等用户直接用NobyDa的jd cookie
|
//IOS等用户直接用NobyDa的jd cookie
|
||||||
let cookiesArr = [], cookie = '', message = '', allMessage = '';
|
let cookiesArr = [], cookie = '', message;
|
||||||
let jd_nzmhurl = 'https://anmp.jd.com/babelDiy/Zeus/3ZHWXfEDpu5GyX1BgCEN3qQwrC4K/index.html';
|
|
||||||
if ($.isNode()) {
|
if ($.isNode()) {
|
||||||
Object.keys(jdCookieNode).forEach((item) => {
|
Object.keys(jdCookieNode).forEach((item) => {
|
||||||
cookiesArr.push(jdCookieNode[item])
|
cookiesArr.push(jdCookieNode[item])
|
||||||
})
|
})
|
||||||
if (process.env.jd_nzmhurl) jd_nzmhurl = process.env.jd_nzmhurl
|
|
||||||
if (process.env.JD_DEBUG && process.env.JD_DEBUG === 'false') console.log = () => {};
|
if (process.env.JD_DEBUG && process.env.JD_DEBUG === 'false') console.log = () => {};
|
||||||
} else {
|
} else {
|
||||||
cookiesArr = [$.getdata('CookieJD'), $.getdata('CookieJD2'), ...jsonParse($.getdata('CookiesJD') || "[]").map(item => item.cookie)].filter(item => !!item);
|
cookiesArr = [$.getdata('CookieJD'), $.getdata('CookieJD2'), ...jsonParse($.getdata('CookiesJD') || "[]").map(item => item.cookie)].filter(item => !!item);
|
||||||
@ -26,11 +39,9 @@ if ($.isNode()) {
|
|||||||
$.msg($.name, '【提示】请先获取京东账号一cookie\n直接使用NobyDa的京东签到获取', 'https://bean.m.jd.com/', {"open-url": "https://bean.m.jd.com/"});
|
$.msg($.name, '【提示】请先获取京东账号一cookie\n直接使用NobyDa的京东签到获取', 'https://bean.m.jd.com/', {"open-url": "https://bean.m.jd.com/"});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (!jd_nzmhurl) {
|
console.log('女装盲盒\n' +
|
||||||
$.log(`暂时没有女装盲盒,改日再来~`);
|
'活动时间:2021-3-1至2021-3-31\n' +
|
||||||
return;
|
'活动地址:https://anmp.jd.com/babelDiy/Zeus/3z12ngsd27UR1KfRqdMrMSSg3uxg/index.html');
|
||||||
}
|
|
||||||
console.log(`新的女装盲盒已经准备好: ${jd_nzmhurl},准备开始薅豆`);
|
|
||||||
for (let i = 0; i < cookiesArr.length; i++) {
|
for (let i = 0; i < cookiesArr.length; i++) {
|
||||||
if (cookiesArr[i]) {
|
if (cookiesArr[i]) {
|
||||||
cookie = cookiesArr[i];
|
cookie = cookiesArr[i];
|
||||||
@ -50,16 +61,12 @@ if ($.isNode()) {
|
|||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
await jdMh(jd_nzmhurl)
|
await jdMh('https://anmp.jd.com/babelDiy/Zeus/3z12ngsd27UR1KfRqdMrMSSg3uxg/index.html')
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
$.logErr(e)
|
$.logErr(e)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (allMessage) {
|
|
||||||
if ($.isNode()) await notify.sendNotify(`${$.name}`, `${allMessage}`);
|
|
||||||
$.msg($.name, '', allMessage);
|
|
||||||
}
|
|
||||||
})()
|
})()
|
||||||
.catch((e) => {
|
.catch((e) => {
|
||||||
$.log('', `❌ ${$.name}, 失败! 原因: ${e}!`, '')
|
$.log('', `❌ ${$.name}, 失败! 原因: ${e}!`, '')
|
||||||
@ -88,7 +95,6 @@ function showMsg() {
|
|||||||
return new Promise(resolve => {
|
return new Promise(resolve => {
|
||||||
if ($.beans) {
|
if ($.beans) {
|
||||||
message += `本次运行获得${$.beans}京豆`
|
message += `本次运行获得${$.beans}京豆`
|
||||||
allMessage += `京东账号${$.index}${$.nickName}获得${$.beans}京豆\n`
|
|
||||||
$.msg($.name, '', `京东账号${$.index}${$.nickName}\n${message}`);
|
$.msg($.name, '', `京东账号${$.index}${$.nickName}\n${message}`);
|
||||||
}
|
}
|
||||||
resolve()
|
resolve()
|
||||||
@ -96,7 +102,7 @@ function showMsg() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function getInfo(url) {
|
function getInfo(url) {
|
||||||
console.log(`\n女装盲盒url:${url}\n`)
|
console.log(`url:${url}`)
|
||||||
return new Promise(resolve => {
|
return new Promise(resolve => {
|
||||||
$.get({
|
$.get({
|
||||||
url,
|
url,
|
||||||
@ -153,9 +159,13 @@ function doTask(taskId) {
|
|||||||
console.log(`${$.name} API请求失败,请检查网路重试`)
|
console.log(`${$.name} API请求失败,请检查网路重试`)
|
||||||
} else {
|
} else {
|
||||||
data = JSON.parse(data.match(/query\((.*)\n/)[1])
|
data = JSON.parse(data.match(/query\((.*)\n/)[1])
|
||||||
if (data.data.complete_task_list.includes(taskId)) {
|
if (data.errcode === 8004) {
|
||||||
console.log(`任务完成成功,当前幸运值${data.data.curbless}`)
|
console.log(`任务完成失败,无效任务ID`)
|
||||||
$.userInfo.bless = data.data.curbless
|
} else {
|
||||||
|
if (data.data.complete_task_list.includes(taskId)) {
|
||||||
|
console.log(`任务完成成功,当前幸运值${data.data.curbless}`)
|
||||||
|
$.userInfo.bless = data.data.curbless
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
@ -205,7 +215,7 @@ function taskUrl(function_id, body = '') {
|
|||||||
'Content-Type': 'application/json;charset=utf-8',
|
'Content-Type': 'application/json;charset=utf-8',
|
||||||
'Origin': 'wq.jd.com',
|
'Origin': 'wq.jd.com',
|
||||||
'User-Agent': 'JD4iPhone/167490 (iPhone; iOS 14.2; Scale/3.00)',
|
'User-Agent': 'JD4iPhone/167490 (iPhone; iOS 14.2; Scale/3.00)',
|
||||||
'Referer': `${jd_nzmhurl}?wxAppName=jd`,
|
'Referer': `https://anmp.jd.com/babelDiy/Zeus/xKACpgVjVJM7zPKbd5AGCij5yV9/index.html?wxAppName=jd`,
|
||||||
'Cookie': cookie
|
'Cookie': cookie
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
14
jd_pet.js
14
jd_pet.js
@ -57,6 +57,16 @@ if ($.isNode() && process.env.CC_NOHELPAFTER8) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
let WP_APP_TOKEN_ONE = "";
|
||||||
|
if ($.isNode()) {
|
||||||
|
if (process.env.WP_APP_TOKEN_ONE) {
|
||||||
|
WP_APP_TOKEN_ONE = process.env.WP_APP_TOKEN_ONE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(WP_APP_TOKEN_ONE)
|
||||||
|
console.log(`检测到已配置Wxpusher的Token,启用一对一推送...`);
|
||||||
|
else
|
||||||
|
console.log(`检测到未配置Wxpusher的Token,禁用一对一推送...`);
|
||||||
|
|
||||||
console.log(`共${cookiesArr.length}个京东账号\n`);
|
console.log(`共${cookiesArr.length}个京东账号\n`);
|
||||||
|
|
||||||
@ -166,6 +176,9 @@ async function jdPet() {
|
|||||||
if ($.isNode()) {
|
if ($.isNode()) {
|
||||||
await notify.sendNotify(`${$.name} - 账号${$.index} - ${$.nickName || $.UserName}奖品已可领取`, `京东账号${$.index} ${$.nickName || $.UserName}\n${$.petInfo.goodsInfo.goodsName}已可领取`);
|
await notify.sendNotify(`${$.name} - 账号${$.index} - ${$.nickName || $.UserName}奖品已可领取`, `京东账号${$.index} ${$.nickName || $.UserName}\n${$.petInfo.goodsInfo.goodsName}已可领取`);
|
||||||
}
|
}
|
||||||
|
if ($.isNode() && WP_APP_TOKEN_ONE) {
|
||||||
|
await notify.sendNotifybyWxPucher($.name, `【提醒⏰】${$.petInfo.goodsInfo.goodsName}已可领取\n【领取步骤】京东->我的->东东萌宠兑换京东红包,可以用于京东app的任意商品.`, `${$.UserName}`);
|
||||||
|
}
|
||||||
return
|
return
|
||||||
} else if ($.petInfo.petStatus === 6) {
|
} else if ($.petInfo.petStatus === 6) {
|
||||||
await slaveHelp(); //已领取红包,但未领养新的,也能继续助力好友
|
await slaveHelp(); //已领取红包,但未领养新的,也能继续助力好友
|
||||||
@ -174,6 +187,7 @@ async function jdPet() {
|
|||||||
if ($.isNode()) {
|
if ($.isNode()) {
|
||||||
await notify.sendNotify(`${$.name} - 账号${$.index} - ${$.nickName || $.UserName}奖品已可领取`, `京东账号${$.index} ${$.nickName || $.UserName}\n已领取红包,但未继续领养新的物品`);
|
await notify.sendNotify(`${$.name} - 账号${$.index} - ${$.nickName || $.UserName}奖品已可领取`, `京东账号${$.index} ${$.nickName || $.UserName}\n已领取红包,但未继续领养新的物品`);
|
||||||
}
|
}
|
||||||
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
//console.log(`\n【京东账号${$.index}(${$.UserName})的${$.name}好友互助码】${$.petInfo.shareCode}\n`);
|
//console.log(`\n【京东账号${$.index}(${$.UserName})的${$.name}好友互助码】${$.petInfo.shareCode}\n`);
|
||||||
|
953
jd_petrw.js
Normal file
953
jd_petrw.js
Normal file
@ -0,0 +1,953 @@
|
|||||||
|
/*
|
||||||
|
东东萌宠 更新地址: jd_pet.js
|
||||||
|
更新时间:2021-05-21
|
||||||
|
活动入口:京东APP我的-更多工具-东东萌宠
|
||||||
|
已支持IOS多京东账号,Node.js支持N个京东账号
|
||||||
|
脚本兼容: QuantumultX, Surge, Loon, JSBox, Node.js
|
||||||
|
|
||||||
|
互助码shareCode请先手动运行脚本查看打印可看到
|
||||||
|
一天只能帮助5个人。多出的助力码无效
|
||||||
|
|
||||||
|
=================================Quantumultx=========================
|
||||||
|
[task_local]
|
||||||
|
#东东萌宠
|
||||||
|
15 6-18/6 * * * jd_pet.js, tag=东东萌宠, img-url=https://raw.githubusercontent.com/58xinian/icon/master/jdmc.png, enabled=true
|
||||||
|
|
||||||
|
=================================Loon===================================
|
||||||
|
[Script]
|
||||||
|
cron "15 6-18/6 * * *" script-path=jd_pet.js,tag=东东萌宠
|
||||||
|
|
||||||
|
===================================Surge================================
|
||||||
|
东东萌宠 = type=cron,cronexp="15 6-18/6 * * *",wake-system=1,timeout=3600,script-path=jd_pet.js
|
||||||
|
|
||||||
|
====================================小火箭=============================
|
||||||
|
东东萌宠 = type=cron,script-path=jd_pet.js, cronexpr="15 6-18/6 * * *", timeout=3600, enable=true
|
||||||
|
|
||||||
|
*/
|
||||||
|
const $ = new Env('东东萌宠任务');
|
||||||
|
let cookiesArr = [], cookie = '', jdPetShareArr = [], isBox = false, allMessage = '';
|
||||||
|
let message = '', subTitle = '', option = {};
|
||||||
|
let jdNotify = false; //是否关闭通知,false打开通知推送,true关闭通知推送
|
||||||
|
const JD_API_HOST = 'https://api.m.jd.com/client.action';
|
||||||
|
let goodsUrl = '', taskInfoKey = [];
|
||||||
|
let notify = $.isNode() ? require('./sendNotify') : '';
|
||||||
|
const jdCookieNode = $.isNode() ? require('./jdCookie.js') : '';
|
||||||
|
let newShareCodes = [];
|
||||||
|
let NoNeedCodes = [];
|
||||||
|
let lnrun = 0;
|
||||||
|
if ($.isNode()) {
|
||||||
|
Object.keys(jdCookieNode).forEach((item) => {
|
||||||
|
if (jdCookieNode[item]) {
|
||||||
|
cookiesArr.push(jdCookieNode[item])
|
||||||
|
}
|
||||||
|
})
|
||||||
|
if (process.env.JD_DEBUG && process.env.JD_DEBUG === 'false')
|
||||||
|
console.log = () => {};
|
||||||
|
} else {
|
||||||
|
cookiesArr = [$.getdata('CookieJD'), $.getdata('CookieJD2'), ...jsonParse($.getdata('CookiesJD') || "[]").map(item => item.cookie)].filter(item => !!item);
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log(`共${cookiesArr.length}个京东账号\n`);
|
||||||
|
|
||||||
|
!(async() => {
|
||||||
|
if (!cookiesArr[0]) {
|
||||||
|
$.msg($.name, '【提示】请先获取京东账号一cookie\n直接使用NobyDa的京东签到获取', 'https://bean.m.jd.com/bean/signIndex.action', {
|
||||||
|
"open-url": "https://bean.m.jd.com/bean/signIndex.action"
|
||||||
|
});
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
for (let i = 0; i < cookiesArr.length; i++) {
|
||||||
|
if (cookiesArr[i]) {
|
||||||
|
cookie = cookiesArr[i];
|
||||||
|
$.UserName = decodeURIComponent(cookie.match(/pt_pin=([^; ]+)(?=;?)/) && cookie.match(/pt_pin=([^; ]+)(?=;?)/)[1]);
|
||||||
|
$.index = i + 1;
|
||||||
|
$.isLogin = true;
|
||||||
|
$.nickName = '';
|
||||||
|
await TotalBean();
|
||||||
|
console.log(`开始【京东账号${$.index}】${$.nickName || $.UserName}\n`);
|
||||||
|
if (!$.isLogin) {
|
||||||
|
$.msg($.name, `【提示】cookie已失效`, `京东账号${$.index} ${$.nickName || $.UserName}\n请重新登录获取\nhttps://bean.m.jd.com/bean/signIndex.action`, {
|
||||||
|
"open-url": "https://bean.m.jd.com/bean/signIndex.action"
|
||||||
|
});
|
||||||
|
|
||||||
|
if ($.isNode()) {
|
||||||
|
await notify.sendNotify(`${$.name}cookie已失效 - ${$.UserName}`, `京东账号${$.index} ${$.UserName}\n请重新登录获取cookie`);
|
||||||
|
}
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
message = '';
|
||||||
|
subTitle = '';
|
||||||
|
goodsUrl = '';
|
||||||
|
taskInfoKey = [];
|
||||||
|
option = {};
|
||||||
|
lnrun++;
|
||||||
|
await jdPet();
|
||||||
|
if (lnrun == 3) {
|
||||||
|
console.log(`\n【访问接口次数达到3次,休息一分钟.....】\n`);
|
||||||
|
await $.wait(60 * 1000);
|
||||||
|
lnrun = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ($.isNode() && allMessage && $.ctrTemp) {
|
||||||
|
await notify.sendNotify(`${$.name}`, `${allMessage}`)
|
||||||
|
}
|
||||||
|
})()
|
||||||
|
.catch((e) => {
|
||||||
|
$.log('', `❌ ${$.name}, 失败! 原因: ${e}!`, '')
|
||||||
|
})
|
||||||
|
.finally(() => {
|
||||||
|
$.done();
|
||||||
|
})
|
||||||
|
async function jdPet() {
|
||||||
|
try {
|
||||||
|
//查询jd宠物信息
|
||||||
|
const initPetTownRes = await request('initPetTown');
|
||||||
|
message = `【京东账号${$.index}】${$.nickName || $.UserName}\n`;
|
||||||
|
if (initPetTownRes.code === '0' && initPetTownRes.resultCode === '0' && initPetTownRes.message === 'success') {
|
||||||
|
$.petInfo = initPetTownRes.result;
|
||||||
|
if ($.petInfo.userStatus === 0) {
|
||||||
|
$.log($.name, '', `【提示】京东账号${$.index}${$.nickName || $.UserName}\n萌宠活动未开启\n请手动去京东APP开启活动\n入口:我的->游戏与互动->查看更多开启`);
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if (!$.petInfo.goodsInfo) {
|
||||||
|
$.msg($.name, '', `【提示】京东账号${$.index}${$.nickName || $.UserName}\n暂未选购新的商品`, {
|
||||||
|
"open-url": "openapp.jdmoble://"
|
||||||
|
});
|
||||||
|
if ($.isNode())
|
||||||
|
await notify.sendNotify(`${$.name} - ${$.index} - ${$.nickName || $.UserName}`, `【提示】京东账号${$.index}${$.nickName || $.UserName}\n暂未选购新的商品`);
|
||||||
|
return
|
||||||
|
}
|
||||||
|
goodsUrl = $.petInfo.goodsInfo && $.petInfo.goodsInfo.goodsUrl;
|
||||||
|
// option['media-url'] = goodsUrl;
|
||||||
|
// console.log(`初始化萌宠信息完成: ${JSON.stringify(petInfo)}`);
|
||||||
|
if ($.petInfo.petStatus === 5) {
|
||||||
|
option['open-url'] = "openApp.jdMobile://";
|
||||||
|
$.msg($.name, ``, `【京东账号${$.index}】${$.nickName || $.UserName}\n【提醒⏰】${$.petInfo.goodsInfo.goodsName}已可领取\n请去京东APP或微信小程序查看\n点击弹窗即达`, option);
|
||||||
|
if ($.isNode()) {
|
||||||
|
await notify.sendNotify(`${$.name} - 账号${$.index} - ${$.nickName || $.UserName}奖品已可领取`, `京东账号${$.index} ${$.nickName || $.UserName}\n${$.petInfo.goodsInfo.goodsName}已可领取`);
|
||||||
|
}
|
||||||
|
return
|
||||||
|
} else if ($.petInfo.petStatus === 6) {
|
||||||
|
option['open-url'] = "openApp.jdMobile://";
|
||||||
|
$.msg($.name, ``, `【京东账号${$.index}】${$.nickName || $.UserName}\n【提醒⏰】已领取红包,但未继续领养新的物品\n请去京东APP或微信小程序查看\n点击弹窗即达`, option);
|
||||||
|
if ($.isNode()) {
|
||||||
|
await notify.sendNotify(`${$.name} - 账号${$.index} - ${$.nickName || $.UserName}奖品已可领取`, `京东账号${$.index} ${$.nickName || $.UserName}\n已领取红包,但未继续领养新的物品`);
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
//console.log(`\n【京东账号${$.index}(${$.UserName})的${$.name}好友互助码】${$.petInfo.shareCode}\n`);
|
||||||
|
await taskInit();
|
||||||
|
if ($.taskInit.resultCode === '9999' || !$.taskInit.result) {
|
||||||
|
console.log('初始化任务异常, 请稍后再试');
|
||||||
|
return
|
||||||
|
}
|
||||||
|
$.taskInfo = $.taskInit.result;
|
||||||
|
|
||||||
|
await petSport(); //遛弯
|
||||||
|
await masterHelpInit(); //获取助力的信息
|
||||||
|
await doTask(); //做日常任务
|
||||||
|
await feedPetsAgain(); //再次投食
|
||||||
|
await energyCollect(); //收集好感度
|
||||||
|
//await showMsg();
|
||||||
|
|
||||||
|
} else if (initPetTownRes.code === '0') {
|
||||||
|
console.log(`初始化萌宠失败: ${initPetTownRes.message}`);
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
$.logErr(e)
|
||||||
|
const errMsg = `京东账号${$.index} ${$.nickName || $.UserName}\n任务执行异常,请检查执行日志 ‼️‼️`;
|
||||||
|
if ($.isNode())
|
||||||
|
await notify.sendNotify(`${$.name}`, errMsg);
|
||||||
|
$.msg($.name, '', `${errMsg}`)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 收取所有好感度
|
||||||
|
async function energyCollect() {
|
||||||
|
console.log('开始收取任务奖励好感度');
|
||||||
|
let function_id = arguments.callee.name.toString();
|
||||||
|
const response = await request(function_id);
|
||||||
|
// console.log(`收取任务奖励好感度完成:${JSON.stringify(response)}`);
|
||||||
|
if (response.resultCode === '0') {
|
||||||
|
message += `【第${response.result.medalNum + 1}块勋章完成进度】${response.result.medalPercent}%,还需收集${response.result.needCollectEnergy}好感\n`;
|
||||||
|
message += `【已获得勋章】${response.result.medalNum}块,还需收集${response.result.needCollectMedalNum}块即可兑换奖品“${$.petInfo.goodsInfo.goodsName}”\n`;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//再次投食
|
||||||
|
async function feedPetsAgain() {
|
||||||
|
const response = await request('initPetTown'); //再次初始化萌宠
|
||||||
|
if (response.code === '0' && response.resultCode === '0' && response.message === 'success') {
|
||||||
|
$.petInfo = response.result;
|
||||||
|
let foodAmount = $.petInfo.foodAmount; //剩余狗粮
|
||||||
|
if (foodAmount - 100 >= 10) {
|
||||||
|
for (let i = 0; i < parseInt((foodAmount - 100) / 10); i++) {
|
||||||
|
const feedPetRes = await request('feedPets');
|
||||||
|
await $.wait(5 * 1000);
|
||||||
|
console.log(`投食feedPetRes`);
|
||||||
|
if (feedPetRes.resultCode == 0 && feedPetRes.code == 0) {
|
||||||
|
console.log('投食成功')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
const response2 = await request('initPetTown');
|
||||||
|
$.petInfo = response2.result;
|
||||||
|
subTitle = $.petInfo.goodsInfo.goodsName;
|
||||||
|
// message += `【与爱宠相识】${$.petInfo.meetDays}天\n`;
|
||||||
|
// message += `【剩余狗粮】${$.petInfo.foodAmount}g\n`;
|
||||||
|
} else {
|
||||||
|
console.log("目前剩余狗粮:【" + foodAmount + "】g,不再继续投食,保留部分狗粮用于完成第二天任务");
|
||||||
|
subTitle = $.petInfo.goodsInfo && $.petInfo.goodsInfo.goodsName;
|
||||||
|
// message += `【与爱宠相识】${$.petInfo.meetDays}天\n`;
|
||||||
|
// message += `【剩余狗粮】${$.petInfo.foodAmount}g\n`;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
console.log(`初始化萌宠失败: ${JSON.stringify($.petInfo)}`);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async function doTask() {
|
||||||
|
const {
|
||||||
|
signInit,
|
||||||
|
threeMealInit,
|
||||||
|
firstFeedInit,
|
||||||
|
feedReachInit,
|
||||||
|
inviteFriendsInit,
|
||||||
|
browseShopsInit,
|
||||||
|
taskList
|
||||||
|
} = $.taskInfo;
|
||||||
|
for (let item of taskList) {
|
||||||
|
if ($.taskInfo[item].finished) {
|
||||||
|
console.log(`任务 ${item} 已完成`)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//每日签到
|
||||||
|
if (signInit && !signInit.finished) {
|
||||||
|
await signInitFun();
|
||||||
|
}
|
||||||
|
// 首次喂食
|
||||||
|
if (firstFeedInit && !firstFeedInit.finished) {
|
||||||
|
await firstFeedInitFun();
|
||||||
|
}
|
||||||
|
// 三餐
|
||||||
|
if (threeMealInit && !threeMealInit.finished) {
|
||||||
|
if (threeMealInit.timeRange === -1) {
|
||||||
|
console.log(`未到三餐时间`);
|
||||||
|
} else {
|
||||||
|
await threeMealInitFun();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (browseShopsInit && !browseShopsInit.finished) {
|
||||||
|
await browseShopsInitFun();
|
||||||
|
}
|
||||||
|
let browseSingleShopInitList = [];
|
||||||
|
taskList.map((item) => {
|
||||||
|
if (item.indexOf('browseSingleShopInit') > -1) {
|
||||||
|
browseSingleShopInitList.push(item);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
// 去逛逛好货会场
|
||||||
|
for (let item of browseSingleShopInitList) {
|
||||||
|
const browseSingleShopInitTask = $.taskInfo[item];
|
||||||
|
if (browseSingleShopInitTask && !browseSingleShopInitTask.finished) {
|
||||||
|
await browseSingleShopInit(browseSingleShopInitTask);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (inviteFriendsInit && !inviteFriendsInit.finished) {
|
||||||
|
await inviteFriendsInitFun();
|
||||||
|
}
|
||||||
|
// 投食10次
|
||||||
|
if (feedReachInit && !feedReachInit.finished) {
|
||||||
|
lnrun++;
|
||||||
|
await feedReachInitFun();
|
||||||
|
if (lnrun == 5) {
|
||||||
|
console.log(`\n【访问接口次数达到5次,休息半分钟.....】\n`);
|
||||||
|
await $.wait(30 * 1000);
|
||||||
|
lnrun = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// 好友助力信息
|
||||||
|
async function masterHelpInit() {
|
||||||
|
let res = await request(arguments.callee.name.toString());
|
||||||
|
// console.log(`助力信息: ${JSON.stringify(res)}`);
|
||||||
|
if (res.code === '0' && res.resultCode === '0') {
|
||||||
|
if (res.result.masterHelpPeoples && res.result.masterHelpPeoples.length >= 5) {
|
||||||
|
if (!res.result.addedBonusFlag) {
|
||||||
|
console.log("开始领取额外奖励");
|
||||||
|
let getHelpAddedBonusResult = await request('getHelpAddedBonus');
|
||||||
|
if (getHelpAddedBonusResult.resultCode === '0') {
|
||||||
|
message += `【额外奖励${getHelpAddedBonusResult.result.reward}领取】${getHelpAddedBonusResult.message}\n`;
|
||||||
|
}
|
||||||
|
console.log(`领取30g额外奖励结果:【${getHelpAddedBonusResult.message}】`);
|
||||||
|
} else {
|
||||||
|
console.log("已经领取过5好友助力额外奖励");
|
||||||
|
message += `【额外奖励】已领取\n`;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
console.log("助力好友未达到5个")
|
||||||
|
message += `【额外奖励】领取失败,原因:给您助力的人未达5个\n`;
|
||||||
|
}
|
||||||
|
if (res.result.masterHelpPeoples && res.result.masterHelpPeoples.length > 0) {
|
||||||
|
console.log('帮您助力的好友的名单开始')
|
||||||
|
let str = '';
|
||||||
|
res.result.masterHelpPeoples.map((item, index) => {
|
||||||
|
if (index === (res.result.masterHelpPeoples.length - 1)) {
|
||||||
|
str += item.nickName || "匿名用户";
|
||||||
|
} else {
|
||||||
|
str += (item.nickName || "匿名用户") + ',';
|
||||||
|
}
|
||||||
|
})
|
||||||
|
message += `【助力您的好友】${str}\n`;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// 遛狗, 每天次数上限10次, 随机给狗粮, 每次遛狗结束需调用getSportReward领取奖励, 才能进行下一次遛狗
|
||||||
|
async function petSport() {
|
||||||
|
console.log('开始遛弯');
|
||||||
|
let times = 1
|
||||||
|
const code = 0
|
||||||
|
let resultCode = 0
|
||||||
|
do {
|
||||||
|
let response = await request(arguments.callee.name.toString())
|
||||||
|
console.log(`第${times}次遛狗完成: ${JSON.stringify(response)}`);
|
||||||
|
resultCode = response.resultCode;
|
||||||
|
if (resultCode == 0) {
|
||||||
|
let sportRevardResult = await request('getSportReward');
|
||||||
|
console.log(`领取遛狗奖励完成: ${JSON.stringify(sportRevardResult)}`);
|
||||||
|
} else if (resultCode == 1013) {
|
||||||
|
let sportRevardResult = await request('getSportReward', {"version":1});
|
||||||
|
console.log(`领取遛狗奖励完成: ${JSON.stringify(sportRevardResult)}`);
|
||||||
|
if (sportRevardResult.resultCode == 0) resultCode = 0
|
||||||
|
}
|
||||||
|
times++;
|
||||||
|
} while (resultCode == 0 && code == 0)
|
||||||
|
if (times > 1) {
|
||||||
|
// message += '【十次遛狗】已完成\n';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// 初始化任务, 可查询任务完成情况
|
||||||
|
async function taskInit() {
|
||||||
|
console.log('开始任务初始化');
|
||||||
|
$.taskInit = await request(arguments.callee.name.toString(), {
|
||||||
|
"version": 1
|
||||||
|
});
|
||||||
|
}
|
||||||
|
// 每日签到, 每天一次
|
||||||
|
async function signInitFun() {
|
||||||
|
console.log('准备每日签到');
|
||||||
|
const response = await request("getSignReward");
|
||||||
|
console.log(`每日签到结果: ${JSON.stringify(response)}`);
|
||||||
|
if (response.code === '0' && response.resultCode === '0') {
|
||||||
|
console.log(`【每日签到成功】奖励${response.result.signReward}g狗粮\n`);
|
||||||
|
// message += `【每日签到成功】奖励${response.result.signReward}g狗粮\n`;
|
||||||
|
} else {
|
||||||
|
console.log(`【每日签到】${response.message}\n`);
|
||||||
|
// message += `【每日签到】${response.message}\n`;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 三餐签到, 每天三段签到时间
|
||||||
|
async function threeMealInitFun() {
|
||||||
|
console.log('准备三餐签到');
|
||||||
|
const response = await request("getThreeMealReward");
|
||||||
|
console.log(`三餐签到结果: ${JSON.stringify(response)}`);
|
||||||
|
if (response.code === '0' && response.resultCode === '0') {
|
||||||
|
console.log(`【定时领狗粮】获得${response.result.threeMealReward}g\n`);
|
||||||
|
// message += `【定时领狗粮】获得${response.result.threeMealReward}g\n`;
|
||||||
|
} else {
|
||||||
|
console.log(`【定时领狗粮】${response.message}\n`);
|
||||||
|
// message += `【定时领狗粮】${response.message}\n`;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 浏览指定店铺 任务
|
||||||
|
async function browseSingleShopInit(item) {
|
||||||
|
console.log(`开始做 ${item.title} 任务, ${item.desc}`);
|
||||||
|
const body = {
|
||||||
|
"index": item['index'],
|
||||||
|
"version": 1,
|
||||||
|
"type": 1
|
||||||
|
};
|
||||||
|
const body2 = {
|
||||||
|
"index": item['index'],
|
||||||
|
"version": 1,
|
||||||
|
"type": 2
|
||||||
|
};
|
||||||
|
const response = await request("getSingleShopReward", body);
|
||||||
|
// console.log(`点击进去response::${JSON.stringify(response)}`);
|
||||||
|
if (response.code === '0' && response.resultCode === '0') {
|
||||||
|
const response2 = await request("getSingleShopReward", body2);
|
||||||
|
// console.log(`浏览完毕领取奖励:response2::${JSON.stringify(response2)}`);
|
||||||
|
if (response2.code === '0' && response2.resultCode === '0') {
|
||||||
|
console.log(`【浏览指定店铺】获取${response2.result.reward}g\n`);
|
||||||
|
// message += `【浏览指定店铺】获取${response2.result.reward}g\n`;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 浏览店铺任务, 任务可能为多个? 目前只有一个
|
||||||
|
async function browseShopsInitFun() {
|
||||||
|
console.log('开始浏览店铺任务');
|
||||||
|
let times = 0;
|
||||||
|
let resultCode = 0;
|
||||||
|
let code = 0;
|
||||||
|
do {
|
||||||
|
let response = await request("getBrowseShopsReward");
|
||||||
|
console.log(`第${times}次浏览店铺结果: ${JSON.stringify(response)}`);
|
||||||
|
code = response.code;
|
||||||
|
resultCode = response.resultCode;
|
||||||
|
times++;
|
||||||
|
} while (resultCode == 0 && code == 0 && times < 5)
|
||||||
|
console.log('浏览店铺任务结束');
|
||||||
|
}
|
||||||
|
// 首次投食 任务
|
||||||
|
function firstFeedInitFun() {
|
||||||
|
console.log('首次投食任务合并到10次喂食任务中\n');
|
||||||
|
}
|
||||||
|
|
||||||
|
// 邀请新用户
|
||||||
|
async function inviteFriendsInitFun() {
|
||||||
|
console.log('邀请新用户功能未实现');
|
||||||
|
if ($.taskInfo.inviteFriendsInit.status == 1 && $.taskInfo.inviteFriendsInit.inviteFriendsNum > 0) {
|
||||||
|
// 如果有邀请过新用户,自动领取60gg奖励
|
||||||
|
const res = await request('getInviteFriendsReward');
|
||||||
|
if (res.code == 0 && res.resultCode == 0) {
|
||||||
|
console.log(`领取邀请新用户奖励成功,获得狗粮现有狗粮${$.taskInfo.inviteFriendsInit.reward}g,${res.result.foodAmount}g`);
|
||||||
|
message += `【邀请新用户】获取狗粮${$.taskInfo.inviteFriendsInit.reward}g\n`;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 投食10次 任务
|
||||||
|
*/
|
||||||
|
async function feedReachInitFun() {
|
||||||
|
console.log('投食任务开始...');
|
||||||
|
let finishedTimes = $.taskInfo.feedReachInit.hadFeedAmount / 10; //已经喂养了几次
|
||||||
|
let needFeedTimes = 10 - finishedTimes; //还需要几次
|
||||||
|
let tryTimes = 10; //尝试次数
|
||||||
|
do {
|
||||||
|
console.log(`还需要投食${needFeedTimes}次`);
|
||||||
|
const response = await request('feedPets');
|
||||||
|
await $.wait(5 * 1000);
|
||||||
|
console.log(`本次投食结果: ${JSON.stringify(response)}`);
|
||||||
|
if (response.resultCode == 0 && response.code == 0) {
|
||||||
|
needFeedTimes--;
|
||||||
|
}
|
||||||
|
if (response.resultCode == 3003 && response.code == 0) {
|
||||||
|
console.log('剩余狗粮不足, 投食结束');
|
||||||
|
needFeedTimes = 0;
|
||||||
|
}
|
||||||
|
tryTimes--;
|
||||||
|
} while (needFeedTimes > 0 && tryTimes > 0)
|
||||||
|
console.log('投食任务结束...\n');
|
||||||
|
}
|
||||||
|
async function showMsg() {
|
||||||
|
if ($.isNode() && process.env.PET_NOTIFY_CONTROL) {
|
||||||
|
$.ctrTemp = `${process.env.PET_NOTIFY_CONTROL}` === 'false';
|
||||||
|
} else if ($.getdata('jdPetNotify')) {
|
||||||
|
$.ctrTemp = $.getdata('jdPetNotify') === 'false';
|
||||||
|
} else {
|
||||||
|
$.ctrTemp = `${jdNotify}` === 'false';
|
||||||
|
}
|
||||||
|
// jdNotify = `${notify.petNotifyControl}` === 'false' && `${jdNotify}` === 'false' && $.getdata('jdPetNotify') === 'false';
|
||||||
|
if ($.ctrTemp) {
|
||||||
|
$.msg($.name, subTitle, message, option);
|
||||||
|
if ($.isNode()) {
|
||||||
|
allMessage += `${subTitle}\n${message}${$.index !== cookiesArr.length ? '\n\n' : ''}`
|
||||||
|
// await notify.sendNotify(`${$.name} - 账号${$.index} - ${$.nickName || $.UserName}`, `${subTitle}\n${message}`);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
$.log(`\n${message}\n`);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function TotalBean() {
|
||||||
|
return new Promise(async resolve => {
|
||||||
|
const options = {
|
||||||
|
"url": `https://wq.jd.com/user/info/QueryJDUserInfo?sceneval=2`,
|
||||||
|
"headers": {
|
||||||
|
"Accept": "application/json,text/plain, */*",
|
||||||
|
"Content-Type": "application/x-www-form-urlencoded",
|
||||||
|
"Accept-Encoding": "gzip, deflate, br",
|
||||||
|
"Accept-Language": "zh-cn",
|
||||||
|
"Connection": "keep-alive",
|
||||||
|
"Cookie": cookie,
|
||||||
|
"Referer": "https://wqs.jd.com/my/jingdou/my.shtml?sceneval=2",
|
||||||
|
"User-Agent": $.isNode() ? (process.env.JD_USER_AGENT ? process.env.JD_USER_AGENT : (require('./USER_AGENTS').USER_AGENT)) : ($.getdata('JDUA') ? $.getdata('JDUA') : "jdapp;iPhone;9.4.4;14.3;network/4g;Mozilla/5.0 (iPhone; CPU iPhone OS 14_3 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148;supportJDSHWK/1")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$.post(options, (err, resp, data) => {
|
||||||
|
try {
|
||||||
|
if (err) {
|
||||||
|
console.log(`${JSON.stringify(err)}`)
|
||||||
|
console.log(`${$.name} API请求失败,请检查网路重试`)
|
||||||
|
} else {
|
||||||
|
if (data) {
|
||||||
|
data = JSON.parse(data);
|
||||||
|
if (data['retcode'] === 13) {
|
||||||
|
$.isLogin = false; //cookie过期
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if (data['retcode'] === 0 && data.base && data.base.nickname) {
|
||||||
|
$.nickName = data.base.nickname;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
console.log(`京东服务器返回空数据`)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
$.logErr(e)
|
||||||
|
}
|
||||||
|
finally {
|
||||||
|
resolve();
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
// 请求
|
||||||
|
async function request(function_id, body = {}) {
|
||||||
|
await $.wait(5 * 1000); //歇口气儿, 不然会报操作频繁
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
$.post(taskUrl(function_id, body), (err, resp, data) => {
|
||||||
|
try {
|
||||||
|
if (err) {
|
||||||
|
console.log('\n东东萌宠: API查询请求失败 ‼️‼️');
|
||||||
|
console.log(JSON.stringify(err));
|
||||||
|
$.logErr(err);
|
||||||
|
} else {
|
||||||
|
data = JSON.parse(data);
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
$.logErr(e, resp);
|
||||||
|
}
|
||||||
|
finally {
|
||||||
|
resolve(data)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
// function taskUrl(function_id, body = {}) {
|
||||||
|
// return {
|
||||||
|
// url: `${JD_API_HOST}?functionId=${function_id}&appid=wh5&loginWQBiz=pet-town&body=${escape(JSON.stringify(body))}`,
|
||||||
|
// headers: {
|
||||||
|
// Cookie: cookie,
|
||||||
|
// UserAgent: $.isNode() ? (process.env.JD_USER_AGENT ? process.env.JD_USER_AGENT : (require('./USER_AGENTS').USER_AGENT)) : ($.getdata('JDUA') ? $.getdata('JDUA') : "jdapp;iPhone;9.4.4;14.3;network/4g;Mozilla/5.0 (iPhone; CPU iPhone OS 14_3 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148;supportJDSHWK/1"),
|
||||||
|
// }
|
||||||
|
// };
|
||||||
|
// }
|
||||||
|
function taskUrl(function_id, body = {}) {
|
||||||
|
body["version"] = 2;
|
||||||
|
body["channel"] = 'app';
|
||||||
|
return {
|
||||||
|
url: `${JD_API_HOST}?functionId=${function_id}`,
|
||||||
|
body: `body=${encodeURIComponent(JSON.stringify(body))}&appid=wh5&loginWQBiz=pet-town&clientVersion=9.0.4`,
|
||||||
|
headers: {
|
||||||
|
'Cookie': cookie,
|
||||||
|
'User-Agent': $.isNode() ? (process.env.JD_USER_AGENT ? process.env.JD_USER_AGENT : (require('./USER_AGENTS').USER_AGENT)) : ($.getdata('JDUA') ? $.getdata('JDUA') : "jdapp;iPhone;9.4.4;14.3;network/4g;Mozilla/5.0 (iPhone; CPU iPhone OS 14_3 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148;supportJDSHWK/1"),
|
||||||
|
'Host': 'api.m.jd.com',
|
||||||
|
'Content-Type': 'application/x-www-form-urlencoded',
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
function jsonParse(str) {
|
||||||
|
if (typeof str == "string") {
|
||||||
|
try {
|
||||||
|
return JSON.parse(str);
|
||||||
|
} catch (e) {
|
||||||
|
console.log(e);
|
||||||
|
$.msg($.name, '', '请勿随意在BoxJs输入框修改内容\n建议通过脚本去获取cookie')
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// prettier-ignore
|
||||||
|
function Env(t, e) {
|
||||||
|
"undefined" != typeof process && JSON.stringify(process.env).indexOf("GITHUB") > -1 && process.exit(0);
|
||||||
|
class s {
|
||||||
|
constructor(t) {
|
||||||
|
this.env = t
|
||||||
|
}
|
||||||
|
send(t, e = "GET") {
|
||||||
|
t = "string" == typeof t ? {
|
||||||
|
url: t
|
||||||
|
}
|
||||||
|
: t;
|
||||||
|
let s = this.get;
|
||||||
|
return "POST" === e && (s = this.post),
|
||||||
|
new Promise((e, i) => {
|
||||||
|
s.call(this, t, (t, s, r) => {
|
||||||
|
t ? i(t) : e(s)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
get(t) {
|
||||||
|
return this.send.call(this.env, t)
|
||||||
|
}
|
||||||
|
post(t) {
|
||||||
|
return this.send.call(this.env, t, "POST")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return new class {
|
||||||
|
constructor(t, e) {
|
||||||
|
this.name = t,
|
||||||
|
this.http = new s(this),
|
||||||
|
this.data = null,
|
||||||
|
this.dataFile = "box.dat",
|
||||||
|
this.logs = [],
|
||||||
|
this.isMute = !1,
|
||||||
|
this.isNeedRewrite = !1,
|
||||||
|
this.logSeparator = "\n",
|
||||||
|
this.startTime = (new Date).getTime(),
|
||||||
|
Object.assign(this, e),
|
||||||
|
this.log("", `🔔${this.name}, 开始!`)
|
||||||
|
}
|
||||||
|
isNode() {
|
||||||
|
return "undefined" != typeof module && !!module.exports
|
||||||
|
}
|
||||||
|
isQuanX() {
|
||||||
|
return "undefined" != typeof $task
|
||||||
|
}
|
||||||
|
isSurge() {
|
||||||
|
return "undefined" != typeof $httpClient && "undefined" == typeof $loon
|
||||||
|
}
|
||||||
|
isLoon() {
|
||||||
|
return "undefined" != typeof $loon
|
||||||
|
}
|
||||||
|
toObj(t, e = null) {
|
||||||
|
try {
|
||||||
|
return JSON.parse(t)
|
||||||
|
} catch {
|
||||||
|
return e
|
||||||
|
}
|
||||||
|
}
|
||||||
|
toStr(t, e = null) {
|
||||||
|
try {
|
||||||
|
return JSON.stringify(t)
|
||||||
|
} catch {
|
||||||
|
return e
|
||||||
|
}
|
||||||
|
}
|
||||||
|
getjson(t, e) {
|
||||||
|
let s = e;
|
||||||
|
const i = this.getdata(t);
|
||||||
|
if (i)
|
||||||
|
try {
|
||||||
|
s = JSON.parse(this.getdata(t))
|
||||||
|
} catch {}
|
||||||
|
return s
|
||||||
|
}
|
||||||
|
setjson(t, e) {
|
||||||
|
try {
|
||||||
|
return this.setdata(JSON.stringify(t), e)
|
||||||
|
} catch {
|
||||||
|
return !1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
getScript(t) {
|
||||||
|
return new Promise(e => {
|
||||||
|
this.get({
|
||||||
|
url: t
|
||||||
|
}, (t, s, i) => e(i))
|
||||||
|
})
|
||||||
|
}
|
||||||
|
runScript(t, e) {
|
||||||
|
return new Promise(s => {
|
||||||
|
let i = this.getdata("@chavy_boxjs_userCfgs.httpapi");
|
||||||
|
i = i ? i.replace(/\n/g, "").trim() : i;
|
||||||
|
let r = this.getdata("@chavy_boxjs_userCfgs.httpapi_timeout");
|
||||||
|
r = r ? 1 * r : 20,
|
||||||
|
r = e && e.timeout ? e.timeout : r;
|
||||||
|
const[o, h] = i.split("@"),
|
||||||
|
n = {
|
||||||
|
url: `http://${h}/v1/scripting/evaluate`,
|
||||||
|
body: {
|
||||||
|
script_text: t,
|
||||||
|
mock_type: "cron",
|
||||||
|
timeout: r
|
||||||
|
},
|
||||||
|
headers: {
|
||||||
|
"X-Key": o,
|
||||||
|
Accept: "*/*"
|
||||||
|
}
|
||||||
|
};
|
||||||
|
this.post(n, (t, e, i) => s(i))
|
||||||
|
}).catch(t => this.logErr(t))
|
||||||
|
}
|
||||||
|
loaddata() {
|
||||||
|
if (!this.isNode())
|
||||||
|
return {}; {
|
||||||
|
this.fs = this.fs ? this.fs : require("fs"),
|
||||||
|
this.path = this.path ? this.path : require("path");
|
||||||
|
const t = this.path.resolve(this.dataFile),
|
||||||
|
e = this.path.resolve(process.cwd(), this.dataFile),
|
||||||
|
s = this.fs.existsSync(t),
|
||||||
|
i = !s && this.fs.existsSync(e);
|
||||||
|
if (!s && !i)
|
||||||
|
return {}; {
|
||||||
|
const i = s ? t : e;
|
||||||
|
try {
|
||||||
|
return JSON.parse(this.fs.readFileSync(i))
|
||||||
|
} catch (t) {
|
||||||
|
return {}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
writedata() {
|
||||||
|
if (this.isNode()) {
|
||||||
|
this.fs = this.fs ? this.fs : require("fs"),
|
||||||
|
this.path = this.path ? this.path : require("path");
|
||||||
|
const t = this.path.resolve(this.dataFile),
|
||||||
|
e = this.path.resolve(process.cwd(), this.dataFile),
|
||||||
|
s = this.fs.existsSync(t),
|
||||||
|
i = !s && this.fs.existsSync(e),
|
||||||
|
r = JSON.stringify(this.data);
|
||||||
|
s ? this.fs.writeFileSync(t, r) : i ? this.fs.writeFileSync(e, r) : this.fs.writeFileSync(t, r)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
lodash_get(t, e, s) {
|
||||||
|
const i = e.replace(/\[(\d+)\]/g, ".$1").split(".");
|
||||||
|
let r = t;
|
||||||
|
for (const t of i)
|
||||||
|
if (r = Object(r)[t], void 0 === r)
|
||||||
|
return s;
|
||||||
|
return r
|
||||||
|
}
|
||||||
|
lodash_set(t, e, s) {
|
||||||
|
return Object(t) !== t ? t : (Array.isArray(e) || (e = e.toString().match(/[^.[\]]+/g) || []), e.slice(0, -1).reduce((t, s, i) => Object(t[s]) === t[s] ? t[s] : t[s] = Math.abs(e[i + 1]) >> 0 == +e[i + 1] ? [] : {}, t)[e[e.length - 1]] = s, t)
|
||||||
|
}
|
||||||
|
getdata(t) {
|
||||||
|
let e = this.getval(t);
|
||||||
|
if (/^@/.test(t)) {
|
||||||
|
const[, s, i] = /^@(.*?)\.(.*?)$/.exec(t),
|
||||||
|
r = s ? this.getval(s) : "";
|
||||||
|
if (r)
|
||||||
|
try {
|
||||||
|
const t = JSON.parse(r);
|
||||||
|
e = t ? this.lodash_get(t, i, "") : e
|
||||||
|
} catch (t) {
|
||||||
|
e = ""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return e
|
||||||
|
}
|
||||||
|
setdata(t, e) {
|
||||||
|
let s = !1;
|
||||||
|
if (/^@/.test(e)) {
|
||||||
|
const[, i, r] = /^@(.*?)\.(.*?)$/.exec(e),
|
||||||
|
o = this.getval(i),
|
||||||
|
h = i ? "null" === o ? null : o || "{}" : "{}";
|
||||||
|
try {
|
||||||
|
const e = JSON.parse(h);
|
||||||
|
this.lodash_set(e, r, t),
|
||||||
|
s = this.setval(JSON.stringify(e), i)
|
||||||
|
} catch (e) {
|
||||||
|
const o = {};
|
||||||
|
this.lodash_set(o, r, t),
|
||||||
|
s = this.setval(JSON.stringify(o), i)
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
s = this.setval(t, e);
|
||||||
|
return s
|
||||||
|
}
|
||||||
|
getval(t) {
|
||||||
|
return this.isSurge() || this.isLoon() ? $persistentStore.read(t) : this.isQuanX() ? $prefs.valueForKey(t) : this.isNode() ? (this.data = this.loaddata(), this.data[t]) : this.data && this.data[t] || null
|
||||||
|
}
|
||||||
|
setval(t, e) {
|
||||||
|
return this.isSurge() || this.isLoon() ? $persistentStore.write(t, e) : this.isQuanX() ? $prefs.setValueForKey(t, e) : this.isNode() ? (this.data = this.loaddata(), this.data[e] = t, this.writedata(), !0) : this.data && this.data[e] || null
|
||||||
|
}
|
||||||
|
initGotEnv(t) {
|
||||||
|
this.got = this.got ? this.got : require("got"),
|
||||||
|
this.cktough = this.cktough ? this.cktough : require("tough-cookie"),
|
||||||
|
this.ckjar = this.ckjar ? this.ckjar : new this.cktough.CookieJar,
|
||||||
|
t && (t.headers = t.headers ? t.headers : {}, void 0 === t.headers.Cookie && void 0 === t.cookieJar && (t.cookieJar = this.ckjar))
|
||||||
|
}
|
||||||
|
get(t, e = (() => {})) {
|
||||||
|
t.headers && (delete t.headers["Content-Type"], delete t.headers["Content-Length"]),
|
||||||
|
this.isSurge() || this.isLoon() ? (this.isSurge() && this.isNeedRewrite && (t.headers = t.headers || {}, Object.assign(t.headers, {
|
||||||
|
"X-Surge-Skip-Scripting": !1
|
||||||
|
})), $httpClient.get(t, (t, s, i) => {
|
||||||
|
!t && s && (s.body = i, s.statusCode = s.status),
|
||||||
|
e(t, s, i)
|
||||||
|
})) : this.isQuanX() ? (this.isNeedRewrite && (t.opts = t.opts || {}, Object.assign(t.opts, {
|
||||||
|
hints: !1
|
||||||
|
})), $task.fetch(t).then(t => {
|
||||||
|
const {
|
||||||
|
statusCode: s,
|
||||||
|
statusCode: i,
|
||||||
|
headers: r,
|
||||||
|
body: o
|
||||||
|
} = t;
|
||||||
|
e(null, {
|
||||||
|
status: s,
|
||||||
|
statusCode: i,
|
||||||
|
headers: r,
|
||||||
|
body: o
|
||||||
|
}, o)
|
||||||
|
}, t => e(t))) : this.isNode() && (this.initGotEnv(t), this.got(t).on("redirect", (t, e) => {
|
||||||
|
try {
|
||||||
|
if (t.headers["set-cookie"]) {
|
||||||
|
const s = t.headers["set-cookie"].map(this.cktough.Cookie.parse).toString();
|
||||||
|
s && this.ckjar.setCookieSync(s, null),
|
||||||
|
e.cookieJar = this.ckjar
|
||||||
|
}
|
||||||
|
} catch (t) {
|
||||||
|
this.logErr(t)
|
||||||
|
}
|
||||||
|
}).then(t => {
|
||||||
|
const {
|
||||||
|
statusCode: s,
|
||||||
|
statusCode: i,
|
||||||
|
headers: r,
|
||||||
|
body: o
|
||||||
|
} = t;
|
||||||
|
e(null, {
|
||||||
|
status: s,
|
||||||
|
statusCode: i,
|
||||||
|
headers: r,
|
||||||
|
body: o
|
||||||
|
}, o)
|
||||||
|
}, t => {
|
||||||
|
const {
|
||||||
|
message: s,
|
||||||
|
response: i
|
||||||
|
} = t;
|
||||||
|
e(s, i, i && i.body)
|
||||||
|
}))
|
||||||
|
}
|
||||||
|
post(t, e = (() => {})) {
|
||||||
|
if (t.body && t.headers && !t.headers["Content-Type"] && (t.headers["Content-Type"] = "application/x-www-form-urlencoded"), t.headers && delete t.headers["Content-Length"], this.isSurge() || this.isLoon())
|
||||||
|
this.isSurge() && this.isNeedRewrite && (t.headers = t.headers || {}, Object.assign(t.headers, {
|
||||||
|
"X-Surge-Skip-Scripting": !1
|
||||||
|
})), $httpClient.post(t, (t, s, i) => {
|
||||||
|
!t && s && (s.body = i, s.statusCode = s.status),
|
||||||
|
e(t, s, i)
|
||||||
|
});
|
||||||
|
else if (this.isQuanX())
|
||||||
|
t.method = "POST", this.isNeedRewrite && (t.opts = t.opts || {}, Object.assign(t.opts, {
|
||||||
|
hints: !1
|
||||||
|
})), $task.fetch(t).then(t => {
|
||||||
|
const {
|
||||||
|
statusCode: s,
|
||||||
|
statusCode: i,
|
||||||
|
headers: r,
|
||||||
|
body: o
|
||||||
|
} = t;
|
||||||
|
e(null, {
|
||||||
|
status: s,
|
||||||
|
statusCode: i,
|
||||||
|
headers: r,
|
||||||
|
body: o
|
||||||
|
}, o)
|
||||||
|
}, t => e(t));
|
||||||
|
else if (this.isNode()) {
|
||||||
|
this.initGotEnv(t);
|
||||||
|
const {
|
||||||
|
url: s,
|
||||||
|
...i
|
||||||
|
} = t;
|
||||||
|
this.got.post(s, i).then(t => {
|
||||||
|
const {
|
||||||
|
statusCode: s,
|
||||||
|
statusCode: i,
|
||||||
|
headers: r,
|
||||||
|
body: o
|
||||||
|
} = t;
|
||||||
|
e(null, {
|
||||||
|
status: s,
|
||||||
|
statusCode: i,
|
||||||
|
headers: r,
|
||||||
|
body: o
|
||||||
|
}, o)
|
||||||
|
}, t => {
|
||||||
|
const {
|
||||||
|
message: s,
|
||||||
|
response: i
|
||||||
|
} = t;
|
||||||
|
e(s, i, i && i.body)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
time(t, e = null) {
|
||||||
|
const s = e ? new Date(e) : new Date;
|
||||||
|
let i = {
|
||||||
|
"M+": s.getMonth() + 1,
|
||||||
|
"d+": s.getDate(),
|
||||||
|
"H+": s.getHours(),
|
||||||
|
"m+": s.getMinutes(),
|
||||||
|
"s+": s.getSeconds(),
|
||||||
|
"q+": Math.floor((s.getMonth() + 3) / 3),
|
||||||
|
S: s.getMilliseconds()
|
||||||
|
};
|
||||||
|
/(y+)/.test(t) && (t = t.replace(RegExp.$1, (s.getFullYear() + "").substr(4 - RegExp.$1.length)));
|
||||||
|
for (let e in i)
|
||||||
|
new RegExp("(" + e + ")").test(t) && (t = t.replace(RegExp.$1, 1 == RegExp.$1.length ? i[e] : ("00" + i[e]).substr(("" + i[e]).length)));
|
||||||
|
return t
|
||||||
|
}
|
||||||
|
msg(e = t, s = "", i = "", r) {
|
||||||
|
const o = t => {
|
||||||
|
if (!t)
|
||||||
|
return t;
|
||||||
|
if ("string" == typeof t)
|
||||||
|
return this.isLoon() ? t : this.isQuanX() ? {
|
||||||
|
"open-url": t
|
||||||
|
}
|
||||||
|
: this.isSurge() ? {
|
||||||
|
url: t
|
||||||
|
}
|
||||||
|
: void 0;
|
||||||
|
if ("object" == typeof t) {
|
||||||
|
if (this.isLoon()) {
|
||||||
|
let e = t.openUrl || t.url || t["open-url"],
|
||||||
|
s = t.mediaUrl || t["media-url"];
|
||||||
|
return {
|
||||||
|
openUrl: e,
|
||||||
|
mediaUrl: s
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (this.isQuanX()) {
|
||||||
|
let e = t["open-url"] || t.url || t.openUrl,
|
||||||
|
s = t["media-url"] || t.mediaUrl;
|
||||||
|
return {
|
||||||
|
"open-url": e,
|
||||||
|
"media-url": s
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (this.isSurge()) {
|
||||||
|
let e = t.url || t.openUrl || t["open-url"];
|
||||||
|
return {
|
||||||
|
url: e
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
if (this.isMute || (this.isSurge() || this.isLoon() ? $notification.post(e, s, i, o(r)) : this.isQuanX() && $notify(e, s, i, o(r))), !this.isMuteLog) {
|
||||||
|
let t = ["", "==============📣系统通知📣=============="];
|
||||||
|
t.push(e),
|
||||||
|
s && t.push(s),
|
||||||
|
i && t.push(i),
|
||||||
|
console.log(t.join("\n")),
|
||||||
|
this.logs = this.logs.concat(t)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
log(...t) {
|
||||||
|
t.length > 0 && (this.logs = [...this.logs, ...t]),
|
||||||
|
console.log(t.join(this.logSeparator))
|
||||||
|
}
|
||||||
|
logErr(t, e) {
|
||||||
|
const s = !this.isSurge() && !this.isQuanX() && !this.isLoon();
|
||||||
|
s ? this.log("", `❗️${this.name}, 错误!`, t.stack) : this.log("", `❗️${this.name}, 错误!`, t)
|
||||||
|
}
|
||||||
|
wait(t) {
|
||||||
|
return new Promise(e => setTimeout(e, t))
|
||||||
|
}
|
||||||
|
done(t = {}) {
|
||||||
|
const e = (new Date).getTime(),
|
||||||
|
s = (e - this.startTime) / 1e3;
|
||||||
|
this.log("", `🔔${this.name}, 结束! 🕛 ${s} 秒`),
|
||||||
|
this.log(),
|
||||||
|
(this.isSurge() || this.isQuanX() || this.isLoon()) && $done(t)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
(t, e)
|
||||||
|
}
|
46
jd_tyt.js
46
jd_tyt.js
@ -1,13 +1,11 @@
|
|||||||
/*
|
/*
|
||||||
入口 极速版 赚金币 推一推
|
旁白
|
||||||
助力前三
|
|
||||||
|
|
||||||
[task_local]
|
[task_local]
|
||||||
#搞基大神-推一推
|
#快速推一推
|
||||||
3 1 * * * http://47.101.146.160/scripts/jd_tyt.js, tag=搞基大神-推一推, img-url=https://raw.githubusercontent.com/Orz-3/mini/master/Color/jd.png, enabled=true
|
0 1 * * * jd_tyt.js, tag=推一推, img-url=
|
||||||
*/
|
*/
|
||||||
|
|
||||||
const $ = new Env('推一推');//助力前三个可助力的账号
|
const $ = new Env('极速版-推推赚大钱');//助力前八个可助力的账号不满意去57行改即可
|
||||||
const notify = $.isNode() ? require('./sendNotify') : '';
|
const notify = $.isNode() ? require('./sendNotify') : '';
|
||||||
//Node.js用户请在jdCookie.js处填写京东ck;
|
//Node.js用户请在jdCookie.js处填写京东ck;
|
||||||
const jdCookieNode = $.isNode() ? require('./jdCookie.js') : '';
|
const jdCookieNode = $.isNode() ? require('./jdCookie.js') : '';
|
||||||
@ -15,9 +13,7 @@ const JD_API_HOST = 'https://api.m.jd.com';
|
|||||||
//IOS等用户直接用NobyDa的jd cookie
|
//IOS等用户直接用NobyDa的jd cookie
|
||||||
let cookiesArr = [], cookie = '', message;
|
let cookiesArr = [], cookie = '', message;
|
||||||
let status = ''
|
let status = ''
|
||||||
|
|
||||||
let inviteCodes = []
|
let inviteCodes = []
|
||||||
|
|
||||||
if ($.isNode()) {
|
if ($.isNode()) {
|
||||||
Object.keys(jdCookieNode).forEach((item) => {
|
Object.keys(jdCookieNode).forEach((item) => {
|
||||||
cookiesArr.push(jdCookieNode[item])
|
cookiesArr.push(jdCookieNode[item])
|
||||||
@ -32,7 +28,6 @@ if ($.isNode()) {
|
|||||||
$.msg($.name, '【提示】请先获取京东账号一cookie\n直接使用NobyDa的京东签到获取', 'https://bean.m.jd.com/bean/signIndex.action', { "open-url": "https://bean.m.jd.com/bean/signIndex.action" });
|
$.msg($.name, '【提示】请先获取京东账号一cookie\n直接使用NobyDa的京东签到获取', 'https://bean.m.jd.com/bean/signIndex.action', { "open-url": "https://bean.m.jd.com/bean/signIndex.action" });
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (let i = 0; i < cookiesArr.length; i++) {
|
for (let i = 0; i < cookiesArr.length; i++) {
|
||||||
if (cookiesArr[i]) {
|
if (cookiesArr[i]) {
|
||||||
cookie = cookiesArr[i];
|
cookie = cookiesArr[i];
|
||||||
@ -52,17 +47,15 @@ if ($.isNode()) {
|
|||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
console.log('\n入口 狗东极速版 赚金币 推一推\n');
|
console.log('\n入口→极速版→赚金币→推推赚大钱\n');
|
||||||
console.log('\n本脚本无任何内置助力\n如果你发现有那么就是别人二改加的\n一切与本人无关\n');
|
|
||||||
await info()
|
await info()
|
||||||
await coinDozerBackFlow()
|
await coinDozerBackFlow()
|
||||||
await getCoinDozerInfo()
|
await getCoinDozerInfo()
|
||||||
console.log('\n注意助力前三个可助力的账号\n');
|
console.log('\n助力前八个可助力的账号不满意去57行改即可\n');
|
||||||
if (inviteCodes.length >= 3) {
|
if (inviteCodes.length >= 7) {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log('\n#######开始助力前三个可助力的账号#######\n');
|
console.log('\n#######开始助力前三个可助力的账号#######\n');
|
||||||
cookiesArr.sort(function () {
|
cookiesArr.sort(function () {
|
||||||
return .5 - Math.random();
|
return .5 - Math.random();
|
||||||
@ -96,24 +89,19 @@ if ($.isNode()) {
|
|||||||
.finally(() => {
|
.finally(() => {
|
||||||
$.done();
|
$.done();
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
function info() {
|
function info() {
|
||||||
return new Promise((resolve) => {
|
return new Promise((resolve) => {
|
||||||
|
|
||||||
const nm = {
|
const nm = {
|
||||||
url: `${JD_API_HOST}`,
|
url: `https://api.m.jd.com/?_t=1646094718628`,
|
||||||
body: `functionId=initiateCoinDozer&body={"actId":"d5a8c7198ee54de093d2adb04089d3ec","channel":"coin_dozer","antiToken":"","referer":"-1","frontendInitStatus":"s"}&appid=megatron&client=ios&clientVersion=14.3&t=1636014459632&networkType=4g&eid=&fp=-1&frontendInitStatus=s&uuid=8888&osVersion=14.3&d_brand=&d_model=&agent=-1&pageClickKey=-1&screen=400*700&platform=3&lang=zh_CN`,
|
body: `functionId=initiateCoinDozer&body={"actId":"49f40d2f40b3470e8d6c39aa4866c7ff","channel":"coin_dozer","antiToken":"","referer":"-1","frontendInitStatus":"s"}&appid=megatron&client=ios&clientVersion=14.3&t=1636014459632&networkType=4g&eid=&fp=-1&frontendInitStatus=s&uuid=8888&osVersion=14.3&d_brand=&d_model=&agent=-1&pageClickKey=-1&screen=400*700&platform=3&lang=zh_CN`,
|
||||||
headers: {
|
headers: {
|
||||||
|
|
||||||
"Cookie": cookie,
|
"Cookie": cookie,
|
||||||
"Origin": "https://pushgold.jd.com",
|
"Origin": "https://pushgold.jd.com",
|
||||||
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4430.212 Safari/537.36",
|
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4430.212 Safari/537.36",
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$.post(nm, async (err, resp, data) => {
|
$.post(nm, async (err, resp, data) => {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
if (err) {
|
if (err) {
|
||||||
console.log(`${JSON.stringify(err)}`)
|
console.log(`${JSON.stringify(err)}`)
|
||||||
@ -149,7 +137,7 @@ function coinDozerBackFlow() {
|
|||||||
|
|
||||||
const nm = {
|
const nm = {
|
||||||
url: `${JD_API_HOST}`,
|
url: `${JD_API_HOST}`,
|
||||||
body: `functionId=coinDozerBackFlow&body={"actId":"d5a8c7198ee54de093d2adb04089d3ec","channel":"coin_dozer","antiToken":"","referer":"-1","frontendInitStatus":"s"}&appid=megatron&client=ios&clientVersion=14.3&t=1636015617899&networkType=4g&eid=&fp=-1&frontendInitStatus=s&uuid=8888&osVersion=14.3&d_brand=&d_model=&agent=-1&pageClickKey=-1&screen=400*700&platform=3&lang=zh_CN`,
|
body: `functionId=coinDozerBackFlow&body={"actId":"49f40d2f40b3470e8d6c39aa4866c7ff","channel":"coin_dozer","antiToken":"","referer":"-1","frontendInitStatus":"s"}&appid=megatron&client=ios&clientVersion=14.3&t=1636015617899&networkType=4g&eid=&fp=-1&frontendInitStatus=s&uuid=8888&osVersion=14.3&d_brand=&d_model=&agent=-1&pageClickKey=-1&screen=400*700&platform=3&lang=zh_CN`,
|
||||||
headers: {
|
headers: {
|
||||||
|
|
||||||
"Cookie": cookie,
|
"Cookie": cookie,
|
||||||
@ -190,7 +178,7 @@ function helpCoinDozer(packetId) {
|
|||||||
return new Promise((resolve) => {
|
return new Promise((resolve) => {
|
||||||
const nm = {
|
const nm = {
|
||||||
url: `${JD_API_HOST}`,
|
url: `${JD_API_HOST}`,
|
||||||
body: `functionId=helpCoinDozer&appid=station-soa-h5&client=H5&clientVersion=1.0.0&t=1636015855103&body={"actId":"d5a8c7198ee54de093d2adb04089d3ec","channel":"coin_dozer","antiToken":"","referer":"-1","frontendInitStatus":"s","packetId":"${packetId}"}&_ste=1&_stk=appid,body,client,clientVersion,functionId,t&h5st=20211104165055104;9806356985655163;10005;tk01wd1ed1d5f30nBDriGzaeVZZ9vuiX+cBzRLExSEzpfTriRD0nxU6BbRIOcSQvnfh74uInjSeb6i+VHpnHrBJdVwzs;017f330f7a84896d31a8d6017a1504dc16be8001273aaea9a04a8d04aad033d9`,
|
body: `functionId=helpCoinDozer&appid=station-soa-h5&client=H5&clientVersion=1.0.0&t=1636015855103&body={"actId":"49f40d2f40b3470e8d6c39aa4866c7ff","channel":"coin_dozer","antiToken":"","referer":"-1","frontendInitStatus":"s","packetId":"${packetId}"}&_ste=1&_stk=appid,body,client,clientVersion,functionId,t&h5st=20211104165055104;9806356985655163;10005;tk01wd1ed1d5f30nBDriGzaeVZZ9vuiX+cBzRLExSEzpfTriRD0nxU6BbRIOcSQvnfh74uInjSeb6i+VHpnHrBJdVwzs;017f330f7a84896d31a8d6017a1504dc16be8001273aaea9a04a8d04aad033d9`,
|
||||||
headers: {
|
headers: {
|
||||||
|
|
||||||
"Cookie": cookie,
|
"Cookie": cookie,
|
||||||
@ -226,13 +214,11 @@ function helpCoinDozer(packetId) {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function help(packetId) {
|
function help(packetId) {
|
||||||
return new Promise((resolve) => {
|
return new Promise((resolve) => {
|
||||||
const nm = {
|
const nm = {
|
||||||
url: `${JD_API_HOST}`,
|
url: `${JD_API_HOST}`,
|
||||||
body: `functionId=helpCoinDozer&appid=station-soa-h5&client=H5&clientVersion=1.0.0&t=1623120183787&body={"actId":"d5a8c7198ee54de093d2adb04089d3ec","channel":"coin_dozer","antiToken":"","referer":"-1","frontendInitStatus":"s","packetId":"${packetId}","helperStatus":"0"}&_ste=1&_stk=appid,body,client,clientVersion,functionId,t&h5st=20210608104303790;8489907903583162;10005;tk01w89681aa9a8nZDdIanIyWnVuWFLK4gnqY+05WKcPY3NWU2dcfa73B7PBM7ufJEN0U+4MyHW5N2mT/RNMq72ycJxH;7e6b956f1a8a71b269a0038bbb4abd24bcfb834a88910818cf1bdfc55b7b96e5`,
|
body: `functionId=helpCoinDozer&appid=station-soa-h5&client=H5&clientVersion=1.0.0&t=1623120183787&body={"actId":"49f40d2f40b3470e8d6c39aa4866c7ff","channel":"coin_dozer","antiToken":"","referer":"-1","frontendInitStatus":"s","packetId":"${packetId}","helperStatus":"0"}&_ste=1&_stk=appid,body,client,clientVersion,functionId,t&h5st=20210608104303790;8489907903583162;10005;tk01w89681aa9a8nZDdIanIyWnVuWFLK4gnqY+05WKcPY3NWU2dcfa73B7PBM7ufJEN0U+4MyHW5N2mT/RNMq72ycJxH;7e6b956f1a8a71b269a0038bbb4abd24bcfb834a88910818cf1bdfc55b7b96e5`,
|
||||||
headers: {
|
headers: {
|
||||||
|
|
||||||
"Cookie": cookie,
|
"Cookie": cookie,
|
||||||
@ -263,10 +249,8 @@ function help(packetId) {
|
|||||||
if (data.msg.indexOf("完成") != -1) {
|
if (data.msg.indexOf("完成") != -1) {
|
||||||
$.ok = true
|
$.ok = true
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
$.logErr(e, resp)
|
$.logErr(e, resp)
|
||||||
} finally {
|
} finally {
|
||||||
@ -281,13 +265,11 @@ function getCoinDozerInfo() {
|
|||||||
|
|
||||||
const nm = {
|
const nm = {
|
||||||
url: `${JD_API_HOST}`,
|
url: `${JD_API_HOST}`,
|
||||||
body: `functionId=getCoinDozerInfo&body={"actId":"d5a8c7198ee54de093d2adb04089d3ec","channel":"coin_dozer","antiToken":"","referer":"-1","frontendInitStatus":"s"}&appid=megatron&client=ios&clientVersion=14.3&t=1636015858295&networkType=4g&eid=&fp=-1&frontendInitStatus=s&uuid=8888&osVersion=14.3&d_brand=&d_model=&agent=-1&pageClickKey=-1&screen=400*700&platform=3&lang=zh_CN`,
|
body: `functionId=getCoinDozerInfo&body={"actId":"49f40d2f40b3470e8d6c39aa4866c7ff","channel":"coin_dozer","antiToken":"","referer":"-1","frontendInitStatus":"s"}&appid=megatron&client=ios&clientVersion=14.3&t=1636015858295&networkType=4g&eid=&fp=-1&frontendInitStatus=s&uuid=8888&osVersion=14.3&d_brand=&d_model=&agent=-1&pageClickKey=-1&screen=400*700&platform=3&lang=zh_CN`,
|
||||||
headers: {
|
headers: {
|
||||||
|
|
||||||
"Cookie": cookie,
|
"Cookie": cookie,
|
||||||
"Origin": "https://pushgold.jd.com",
|
"Origin": "https://pushgold.jd.com",
|
||||||
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4430.212 Safari/537.36",
|
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4430.212 Safari/537.36",
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$.post(nm, async (err, resp, data) => {
|
$.post(nm, async (err, resp, data) => {
|
||||||
@ -300,7 +282,7 @@ function getCoinDozerInfo() {
|
|||||||
if (safeGet(data)) {
|
if (safeGet(data)) {
|
||||||
data = JSON.parse(data);
|
data = JSON.parse(data);
|
||||||
if (data.success == true && data?.data?.sponsorActivityInfo?.packetId) {
|
if (data.success == true && data?.data?.sponsorActivityInfo?.packetId) {
|
||||||
console.log('叼毛:' + data.data.sponsorActivityInfo.initiatorNickname)
|
console.log('CK:' + data.data.sponsorActivityInfo.initiatorNickname)
|
||||||
console.log('邀请码:' + data.data.sponsorActivityInfo.packetId)
|
console.log('邀请码:' + data.data.sponsorActivityInfo.packetId)
|
||||||
console.log('推出:' + data.data.sponsorActivityInfo.dismantledAmount)
|
console.log('推出:' + data.data.sponsorActivityInfo.dismantledAmount)
|
||||||
if (data.data && data.data.sponsorActivityInfo.packetId) {
|
if (data.data && data.data.sponsorActivityInfo.packetId) {
|
||||||
|
@ -14,7 +14,7 @@ const querystring = require('querystring');
|
|||||||
const exec = require('child_process').exec;
|
const exec = require('child_process').exec;
|
||||||
const $ = new Env();
|
const $ = new Env();
|
||||||
const timeout = 15000; //超时时间(单位毫秒)
|
const timeout = 15000; //超时时间(单位毫秒)
|
||||||
console.log("加载sendNotify,当前版本: 20220217");
|
console.log("加载sendNotify,当前版本: 20220302");
|
||||||
// =======================================go-cqhttp通知设置区域===========================================
|
// =======================================go-cqhttp通知设置区域===========================================
|
||||||
//gobot_url 填写请求地址http://127.0.0.1/send_private_msg
|
//gobot_url 填写请求地址http://127.0.0.1/send_private_msg
|
||||||
//gobot_token 填写在go-cqhttp文件设置的访问密钥
|
//gobot_token 填写在go-cqhttp文件设置的访问密钥
|
||||||
@ -1587,7 +1587,7 @@ function getQLinfo(strCK, intcreated, strTimestamp, strRemark) {
|
|||||||
var strCheckCK = strCK.match(/pt_key=([^; ]+)(?=;?)/) && strCK.match(/pt_key=([^; ]+)(?=;?)/)[1];
|
var strCheckCK = strCK.match(/pt_key=([^; ]+)(?=;?)/) && strCK.match(/pt_key=([^; ]+)(?=;?)/)[1];
|
||||||
var strPtPin = decodeURIComponent(strCK.match(/pt_pin=([^; ]+)(?=;?)/) && strCK.match(/pt_pin=([^; ]+)(?=;?)/)[1]);
|
var strPtPin = decodeURIComponent(strCK.match(/pt_pin=([^; ]+)(?=;?)/) && strCK.match(/pt_pin=([^; ]+)(?=;?)/)[1]);
|
||||||
var strReturn = "";
|
var strReturn = "";
|
||||||
if (strCheckCK.substring(0, 4) == "AAJh") {
|
if (strCheckCK.substring(0, 3) == "AAJ") {
|
||||||
var DateCreated = new Date(intcreated);
|
var DateCreated = new Date(intcreated);
|
||||||
var DateTimestamp = new Date(strTimestamp);
|
var DateTimestamp = new Date(strTimestamp);
|
||||||
var DateToday = new Date();
|
var DateToday = new Date();
|
||||||
|
Loading…
Reference in New Issue
Block a user