mirror of
https://github.com/lan-tianxiang/clone_scripts.git
synced 2025-07-16 08:53:47 +08:00
760 lines
33 KiB
JavaScript
Executable File
760 lines
33 KiB
JavaScript
Executable File
/*
|
||
京东多合一签到,自用,可N个京东账号
|
||
活动入口:各处的签到汇总
|
||
Node.JS专用
|
||
IOS软件用户请使用 https://raw.githubusercontent.com/NobyDa/Script/master/JD-DailyBonus/JD_DailyBonus.js
|
||
更新时间:2021-6-18
|
||
推送通知默认简洁模式(多账号只发送一次)。如需详细通知,设置环境变量 JD_BEAN_SIGN_NOTIFY_SIMPLE 为false即可(N账号推送N次通知)。
|
||
Modified From github https://github.com/ruicky/jd_sign_bot
|
||
*/
|
||
const canRequest = (url) => {
|
||
const [, , host] = url.split('/')
|
||
|
||
if (
|
||
![
|
||
'oapi.dingtalk.com',
|
||
'cdn.jsdelivr.net',
|
||
'lkyl.dianpusoft.cn',
|
||
'raw.githubusercontent.com',
|
||
'www.fastmock.site',
|
||
'raw.fastgit.org',
|
||
].includes(host) &&
|
||
!/\.jd\.com$/.test(host) &&
|
||
!/\.jingxi\.com/.test(host) &&
|
||
!/\.isvjcloud\.com/.test(host)
|
||
) {
|
||
console.log(host, url)
|
||
throw new Error(`该请求url不合法: ${url}`)
|
||
}
|
||
}
|
||
|
||
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 = () => {}) {
|
||
canRequest(t.url)
|
||
|
||
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 = () => {}) {
|
||
canRequest(t.url)
|
||
|
||
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)
|
||
}
|
||
|
||
const $ = new Env('京东多合一签到');
|
||
const notify = $.isNode() ? require('./sendNotify') : '';
|
||
//Node.js用户请在jdCookie.js处填写京东ck;
|
||
const jdCookieNode = $.isNode() ? require('./jdCookie.js') : '';
|
||
const exec = require('child_process').execSync
|
||
const fs = require('fs')
|
||
const download = require('download');
|
||
let resultPath = "./result.txt";
|
||
let JD_DailyBonusPath = "./JD_DailyBonus.js";
|
||
let outPutUrl = './';
|
||
let NodeSet = 'CookieSet.json';
|
||
let cookiesArr = [], cookie = '', allMessage = '';
|
||
|
||
if ($.isNode()) {
|
||
Object.keys(jdCookieNode).forEach((item) => {
|
||
cookiesArr.push(jdCookieNode[item])
|
||
})
|
||
if (process.env.JD_DEBUG && process.env.JD_DEBUG === 'false') console.log = () => {};
|
||
}
|
||
!(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;
|
||
}
|
||
process.env.JD_BEAN_SIGN_NOTIFY_SIMPLE = process.env.JD_BEAN_SIGN_NOTIFY_SIMPLE ? process.env.JD_BEAN_SIGN_NOTIFY_SIMPLE : 'true';
|
||
await requireConfig();
|
||
// 下载最新代码
|
||
await downFile();
|
||
if (!await fs.existsSync(JD_DailyBonusPath)) {
|
||
console.log(`\nJD_DailyBonus.js 文件不存在,停止执行${$.name}\n`);
|
||
await notify.sendNotify($.name, `本次执行${$.name}失败,JD_DailyBonus.js 文件下载异常,详情请查看日志`)
|
||
return
|
||
}
|
||
const content = await fs.readFileSync(JD_DailyBonusPath, 'utf8')
|
||
for (let i =0; i < cookiesArr.length; i++) {
|
||
cookie = cookiesArr[i];
|
||
if (cookie) {
|
||
$.UserName = decodeURIComponent(cookie.match(/pt_pin=([^; ]+)(?=;?)/) && cookie.match(/pt_pin=([^; ]+)(?=;?)/)[1])
|
||
$.index = i + 1;
|
||
$.nickName = '';
|
||
$.isLogin = true;
|
||
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
|
||
}
|
||
await changeFile(content);
|
||
await execSign();
|
||
}
|
||
}
|
||
//await deleteFile(JD_DailyBonusPath);//删除下载的JD_DailyBonus.js文件
|
||
if ($.isNode() && allMessage && process.env.JD_BEAN_SIGN_NOTIFY_SIMPLE === 'true') {
|
||
$.msg($.name, '', allMessage);
|
||
await notify.sendNotify($.name, allMessage)
|
||
}
|
||
})()
|
||
.catch((e) => $.logErr(e))
|
||
.finally(() => $.done())
|
||
async function execSign() {
|
||
console.log(`\n开始执行 ${$.name} 签到,请稍等...\n`);
|
||
try {
|
||
// if (notify.SCKEY || notify.BARK_PUSH || notify.DD_BOT_TOKEN || (notify.TG_BOT_TOKEN && notify.TG_USER_ID) || notify.IGOT_PUSH_KEY || notify.QQ_SKEY) {
|
||
// await exec(`${process.execPath} ${JD_DailyBonusPath} >> ${resultPath}`);
|
||
// const notifyContent = await fs.readFileSync(resultPath, "utf8");
|
||
// console.log(`👇👇👇👇👇👇👇👇👇👇👇LOG记录👇👇👇👇👇👇👇👇👇👇👇\n${notifyContent}\n👆👆👆👆👆👆👆👆👆LOG记录👆👆👆👆👆👆👆👆👆👆👆`);
|
||
// } else {
|
||
// console.log('没有提供通知推送,则打印脚本执行日志')
|
||
// await exec(`${process.execPath} ${JD_DailyBonusPath}`, { stdio: "inherit" });
|
||
// }
|
||
await exec(`${process.execPath} ${JD_DailyBonusPath} >> ${resultPath}`);
|
||
const notifyContent = await fs.readFileSync(resultPath, "utf8");
|
||
console.error(`👇👇👇👇👇👇👇👇👇👇👇签到详情👇👇👇👇👇👇👇👇👇👇👇\n${notifyContent}\n👆👆👆👆👆👆👆👆👆签到详情👆👆👆👆👆👆👆👆👆👆👆`);
|
||
// await exec("node JD_DailyBonus.js", { stdio: "inherit" });
|
||
// console.log('执行完毕', new Date(new Date().getTime() + 8 * 3600000).toLocaleDateString())
|
||
//发送通知
|
||
let BarkContent = '';
|
||
if (fs.existsSync(resultPath)) {
|
||
const barkContentStart = notifyContent.indexOf('【签到概览】')
|
||
const barkContentEnd = notifyContent.length;
|
||
if (process.env.JD_BEAN_SIGN_STOP_NOTIFY !== 'true') {
|
||
if (process.env.JD_BEAN_SIGN_NOTIFY_SIMPLE === 'true') {
|
||
if (barkContentStart > -1 && barkContentEnd > -1) {
|
||
BarkContent = notifyContent.substring(barkContentStart, barkContentEnd);
|
||
}
|
||
BarkContent = BarkContent.split('\n\n')[0];
|
||
} else {
|
||
if (barkContentStart > -1 && barkContentEnd > -1) {
|
||
BarkContent = notifyContent.substring(barkContentStart, barkContentEnd);
|
||
}
|
||
}
|
||
}
|
||
}
|
||
//不管哪个时区,这里得到的都是北京时间的时间戳;
|
||
const UTC8 = new Date().getTime() + new Date().getTimezoneOffset()*60000 + 28800000;
|
||
$.beanSignTime = new Date(UTC8).toLocaleString('zh', {hour12: false});
|
||
//console.log(`脚本执行完毕时间:${$.beanSignTime}`)
|
||
if (BarkContent) {
|
||
allMessage += `【京东号 ${$.index}】: ${$.nickName || $.UserName}\n【签到时间】: ${$.beanSignTime}\n${BarkContent}${$.index !== cookiesArr.length ? '\n\n' : ''}`;
|
||
if (!process.env.JD_BEAN_SIGN_NOTIFY_SIMPLE || (process.env.JD_BEAN_SIGN_NOTIFY_SIMPLE && process.env.JD_BEAN_SIGN_NOTIFY_SIMPLE !== 'true')) {
|
||
await notify.sendNotify(`${$.name} - 账号${$.index} - ${$.nickName || $.UserName}`, `【签到号 ${$.index}】: ${$.nickName || $.UserName}\n【签到时间】: ${$.beanSignTime}\n${BarkContent}`);
|
||
}
|
||
}
|
||
//运行完成后,删除下载的文件
|
||
await deleteFile(resultPath);//删除result.txt
|
||
console.log(`\n\n*****************${new Date(new Date().getTime()).toLocaleString('zh', {hour12: false})} 京东账号${$.index} ${$.nickName || $.UserName} ${$.name}完成*******************\n\n`);
|
||
} catch (e) {
|
||
console.log("京东签到脚本执行异常:" + e);
|
||
}
|
||
}
|
||
async function downFile () {
|
||
let url = '';
|
||
await downloadUrl();
|
||
if ($.body) {
|
||
url = 'https://raw.fastgit.org/NobyDa/Script/master/JD-DailyBonus/JD_DailyBonus.js';
|
||
} else {
|
||
url = 'https://cdn.jsdelivr.net/gh/NobyDa/Script@master/JD-DailyBonus/JD_DailyBonus.js';
|
||
}
|
||
try {
|
||
const options = { }
|
||
if (process.env.TG_PROXY_HOST && process.env.TG_PROXY_PORT) {
|
||
const tunnel = require("tunnel");
|
||
const agent = {
|
||
https: tunnel.httpsOverHttp({
|
||
proxy: {
|
||
host: process.env.TG_PROXY_HOST,
|
||
port: process.env.TG_PROXY_PORT * 1
|
||
}
|
||
})
|
||
}
|
||
Object.assign(options, { agent })
|
||
}
|
||
await download(url, outPutUrl, options);
|
||
console.log(`JD_DailyBonus.js文件下载完毕\n\n`);
|
||
} catch (e) {
|
||
console.log("JD_DailyBonus.js 文件下载异常:" + e);
|
||
}
|
||
}
|
||
|
||
async function changeFile (content) {
|
||
console.log(`开始替换变量`)
|
||
let newContent = content.replace(/var Key = '.*'/, `var Key = '${cookie}'`);
|
||
newContent = newContent.replace(/const NodeSet = 'CookieSet.json'/, `const NodeSet = '${NodeSet}'`)
|
||
if (process.env.JD_BEAN_STOP && process.env.JD_BEAN_STOP !== '0') {
|
||
newContent = newContent.replace(/var stop = '0'/, `var stop = '${process.env.JD_BEAN_STOP}'`);
|
||
}
|
||
const zone = new Date().getTimezoneOffset();
|
||
if (zone === 0) {
|
||
//此处针对UTC-0时区用户做的
|
||
newContent = newContent.replace(/tm\s=.*/, `tm = new Date(new Date().toLocaleDateString()).getTime() - 28800000;`);
|
||
}
|
||
try {
|
||
await fs.writeFileSync(JD_DailyBonusPath, newContent, 'utf8');
|
||
console.log('替换变量完毕');
|
||
} catch (e) {
|
||
console.log("京东签到写入文件异常:" + e);
|
||
}
|
||
}
|
||
async function deleteFile(path) {
|
||
// 查看文件result.txt是否存在,如果存在,先删除
|
||
const fileExists = await fs.existsSync(path);
|
||
// console.log('fileExists', fileExists);
|
||
if (fileExists) {
|
||
const unlinkRes = await fs.unlinkSync(path);
|
||
// console.log('unlinkRes', unlinkRes)
|
||
}
|
||
}
|
||
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")
|
||
},
|
||
"timeout": 10000
|
||
}
|
||
$.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 downloadUrl(url = 'https://raw.githubusercontent.com/NobyDa/Script/master/JD-DailyBonus/JD_DailyBonus.js') {
|
||
return new Promise(resolve => {
|
||
const options = { url, "timeout": 10000 };
|
||
if ($.isNode() && process.env.TG_PROXY_HOST && process.env.TG_PROXY_PORT) {
|
||
const tunnel = require("tunnel");
|
||
const agent = {
|
||
https: tunnel.httpsOverHttp({
|
||
proxy: {
|
||
host: process.env.TG_PROXY_HOST,
|
||
port: process.env.TG_PROXY_PORT * 1
|
||
}
|
||
})
|
||
}
|
||
Object.assign(options, { agent })
|
||
}
|
||
$.get(options, async (err, resp, data) => {
|
||
try {
|
||
if (err) {
|
||
// console.log(`${JSON.stringify(err)}`)
|
||
console.log(`检测到您当前网络环境不能访问外网,将使用jsdelivr CDN下载JD_DailyBonus.js文件`);
|
||
await $.http.get({url: `https://purge.jsdelivr.net/gh/NobyDa/Script@master/JD-DailyBonus/JD_DailyBonus.js`, timeout: 10000}).then((resp) => {
|
||
if (resp.statusCode === 200) {
|
||
let { body } = resp;
|
||
body = JSON.parse(body);
|
||
if (body['success']) {
|
||
console.log(`JD_DailyBonus.js文件 CDN刷新成功`)
|
||
} else {
|
||
console.log(`JD_DailyBonus.js文件 CDN刷新失败`)
|
||
}
|
||
}
|
||
});
|
||
} else {
|
||
$.body = data;
|
||
}
|
||
} catch (e) {
|
||
$.logErr(e, resp)
|
||
} finally {
|
||
resolve();
|
||
}
|
||
})
|
||
})
|
||
}
|
||
function requireConfig() {
|
||
return new Promise(resolve => {
|
||
// const file = 'jd_bean_sign.js';
|
||
// fs.access(file, fs.constants.W_OK, (err) => {
|
||
// resultPath = err ? '/tmp/result.txt' : resultPath;
|
||
// JD_DailyBonusPath = err ? '/tmp/JD_DailyBonus.js' : JD_DailyBonusPath;
|
||
// outPutUrl = err ? '/tmp/' : outPutUrl;
|
||
// NodeSet = err ? '/tmp/CookieSet.json' : NodeSet;
|
||
// resolve()
|
||
// });
|
||
//判断是否是云函数环境。原函数根目录目录没有可写入权限,文件只能放到根目录下虚拟的/temp/文件夹(具有可写入权限)
|
||
resultPath = process.env.TENCENTCLOUD_RUNENV === 'SCF' ? '/tmp/result.txt' : resultPath;
|
||
JD_DailyBonusPath = process.env.TENCENTCLOUD_RUNENV === 'SCF' ? '/tmp/JD_DailyBonus.js' : JD_DailyBonusPath;
|
||
outPutUrl = process.env.TENCENTCLOUD_RUNENV === 'SCF' ? '/tmp/' : outPutUrl;
|
||
NodeSet = process.env.TENCENTCLOUD_RUNENV === 'SCF' ? '/tmp/CookieSet.json' : NodeSet;
|
||
resolve()
|
||
})
|
||
}
|
||
function timeFormat(time) {
|
||
let date;
|
||
if (time) {
|
||
date = new Date(time)
|
||
} else {
|
||
date = new Date();
|
||
}
|
||
return date.getFullYear() + '-' + ((date.getMonth() + 1) >= 10 ? (date.getMonth() + 1) : '0' + (date.getMonth() + 1)) + '-' + (date.getDate() >= 10 ? date.getDate() : '0' + date.getDate());
|
||
}
|
||
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)} |