forked from smlie-cyber/faker2
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
shufflewzc
committed
Jul 12, 2021
1 parent
8a9c147
commit 13b9b8d
Showing
1 changed file
with
242 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,242 @@ | ||
/* | ||
天天优惠大乐透 | ||
活动入口-领券-券后9.9 | ||
脚本兼容: QuantumultX, Surge, Loon, JSBox, Node.js | ||
============Quantumultx=============== | ||
[task_local] | ||
15 6 * * * jd_DrawEntrance.js, tag=天天优惠大乐透, enabled=true | ||
================Loon============== | ||
[Script] | ||
cron "15 6 * * *" script-path=jd_DrawEntrance.js,tag=天天优惠大乐透 | ||
===============Surge================= | ||
天天优惠大乐透 = type=cron,cronexp="15 6 * * *",wake-system=1,timeout=3600,script-path=jd_DrawEntrance.js | ||
============小火箭========= | ||
天天优惠大乐透 = type=cron,script-path=jd_DrawEntrance.js, cronexpr="15 6 * * *", timeout=3600, enable=true | ||
*/ | ||
const $ = new Env('天天优惠大乐透'); | ||
const notify = $.isNode() ? require('./sendNotify') : ''; | ||
//Node.js用户请在jdCookie.js处填写京东ck; | ||
const jdCookieNode = $.isNode() ? require('./jdCookie.js') : ''; | ||
let jdNotify = false;//是否关闭通知,false打开通知推送,true关闭通知推送 | ||
//IOS等用户直接用NobyDa的jd cookie | ||
let cookiesArr = [], cookie = '', message = ''; | ||
if ($.isNode()) { | ||
Object.keys(jdCookieNode).forEach((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); | ||
} | ||
const JD_API_HOST = 'https://api.m.jd.com/api'; | ||
!(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 = ''; | ||
// message = ''; //不重置信息内容 | ||
await TotalBean(); | ||
console.log(`\n******开始【京东账号${$.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 | ||
} | ||
$.ADID = getUUID('xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx', 1); | ||
$.UUID = getUUID('xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'); | ||
$.noChance = false; | ||
await extend(); | ||
for (let x = 0; x < 3; x++) { | ||
if ($.noChance) { | ||
continue | ||
} | ||
$.log("\n尝试抽奖") | ||
await doLuckDrawEntrance(); | ||
await $.wait(1000 * 1) | ||
} | ||
} | ||
} | ||
if (message !== "") { | ||
if ($.isNode()) { | ||
await notify.sendNotify($.name,message) | ||
}else{ | ||
$.msg($.name,'',message) | ||
} | ||
} | ||
})() | ||
.catch((e) => { | ||
$.log('', `❌ ${$.name}, 失败! 原因: ${e}!`, '') | ||
}) | ||
.finally(() => { | ||
$.done(); | ||
}) | ||
function extend() { | ||
return new Promise(resolve => { | ||
$.post(taskUrl("getLuckyDrawResourceConfig", {"platformType":"1"}), async (err, resp, data) => { | ||
try { | ||
if (err) { | ||
console.log(err) | ||
console.log(`${$.name} API请求失败,请检查网路重试`) | ||
} else { | ||
if (safeGet(data)) { | ||
data = JSON.parse(data); | ||
$.extend=data.result.luckyDrawConfig.extend | ||
} | ||
} | ||
} catch (e) { | ||
$.logErr(e, resp) | ||
} finally { | ||
resolve(data); | ||
} | ||
}) | ||
}) | ||
} | ||
function doLuckDrawEntrance() { | ||
let body = {"platformType":"1","extend":$.extend} | ||
return new Promise(resolve => { | ||
$.post(taskUrl("doLuckDrawEntrance", body), async (err, resp, data) => { | ||
try { | ||
if (err) { | ||
console.log(`${JSON.stringify(err)}`) | ||
console.log(`${$.name} API请求失败,请检查网路重试`) | ||
} else { | ||
if (safeGet(data)) { | ||
data = JSON.parse(data); | ||
if (data.success && "luckyDrawData" in data.result) { | ||
if (data.result.luckyDrawData.checkWinOrNot) {//调整判断的顺序 | ||
switch (data.result.luckyDrawData.couponType) { | ||
case '2': | ||
console.log(` 成功领取优惠券:${data.result.luckyDrawData.discount}\n ${data.result.luckyDrawData.quotaDesc},${data.result.luckyDrawData.prizeName}`) | ||
break; | ||
case '0': | ||
console.log(` 成功领取无门槛红包:${data.result.luckyDrawData.quota}`) | ||
//message += `\n【京东账号${$.index}】${$.nickName || $.UserName} \n 成功领取无门槛红包:${data.result.luckyDrawData.quota}`//增加通知内容 | ||
break; | ||
default: | ||
console.log(JSON.stringify(data))//这边把对象已文本形式输出,避免对象中的属性有数组形式造成不完全打印 | ||
break; | ||
} | ||
} else { | ||
$.noChance = true; | ||
console.log("已经没有次数了"); | ||
} | ||
} | ||
|
||
} | ||
} | ||
} catch (e) { | ||
$.logErr(e, resp) | ||
} finally { | ||
resolve(data); | ||
} | ||
}) | ||
}) | ||
} | ||
|
||
function taskUrl(function_id, body = {}) { | ||
return { | ||
url: `${JD_API_HOST}?functionId=${function_id}&body=${escape(JSON.stringify(body))}&appid=XPMSGC2019&client=m&clientVersion=1.0.0&area=19_1601_3633_63252&geo=[object Object]&uuid=${$.UUID}`, | ||
headers: { | ||
"Cookie": cookie, | ||
"Host": "api.m.jd.com", | ||
"Origin": "https://h5.m.jd.com", | ||
"Content-Length": "0", | ||
"Connection": "keep-alive", | ||
"Accept": "application/json, text/plain, */*", | ||
"User-Agent": `jdapp;iPhone;9.5.0;13.5;${$.UUID};network/wifi;ADID/${$.ADID};supportApplePay/0;hasUPPay/0;hasOCPay/0;model/iPhone11,6;addressid/138222502;supportBestPay/0;appBuild/167638;jdSupportDarkMode/0;Mozilla/5.0 (iPhone; CPU iPhone OS 13_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148;supportJDSHWK/1`, | ||
"Accept-Language": "zh-cn", | ||
"Referer": "https://h5.m.jd.com/babelDiy/Zeus/yj8mbcm6roENn7qhNdhiekyeqtd/index.html", | ||
"Accept-Encoding": "gzip, deflate, br", | ||
"Content-Type": "text/plain", | ||
} | ||
} | ||
} | ||
function getUUID(format = 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx', UpperCase = 0) { | ||
return format.replace(/[xy]/g, function (c) { | ||
var r = Math.random() * 16 | 0, v = c == 'x' ? r : (r & 0x3 | 0x8); | ||
if (UpperCase) { | ||
uuid = v.toString(36).toUpperCase(); | ||
} else { | ||
uuid = v.toString(36) | ||
} | ||
return uuid; | ||
}); | ||
} | ||
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": `jdapp;iPhone;9.5.0;13.5;${$.UUID};network/wifi;ADID/${$.ADID};supportApplePay/0;hasUPPay/0;hasOCPay/0;model/iPhone11,6;addressid/138222502;supportBestPay/0;appBuild/167638;jdSupportDarkMode/0;Mozilla/5.0 (iPhone; CPU iPhone OS 13_5 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) { | ||
$.nickName = (data['base'] && data['base'].nickname) || $.UserName; | ||
} else { | ||
$.nickName = $.UserName | ||
} | ||
} else { | ||
console.log(`京东服务器返回空数据`) | ||
} | ||
} | ||
} catch (e) { | ||
$.logErr(e, resp) | ||
} finally { | ||
resolve(); | ||
} | ||
}) | ||
}) | ||
} | ||
function safeGet(data) { | ||
try { | ||
if (typeof JSON.parse(data) == "object") { | ||
return true; | ||
} | ||
} catch (e) { | ||
console.log(e); | ||
console.log(`京东服务器访问数据为空,请检查自身设备网络情况`); | ||
return false; | ||
} | ||
} | ||
function jsonParse(str) { | ||
if (typeof str == "string") { | ||
try { | ||
return JSON.parse(str); | ||
} catch (e) { | ||
console.log(e); | ||
$.msg($.name, '', '不要在BoxJS手动复制粘贴修改cookie') | ||
return []; | ||
} | ||
} | ||
} | ||
// prettier-ignore | ||
function Env(t, e) { 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) } |