349 lines
14 KiB
JavaScript
349 lines
14 KiB
JavaScript
const querystring = require('querystring');
|
||
const exec = require('child_process').exec;
|
||
const $ = new Env();
|
||
const timeout = 15000; //超时时间(单位毫秒)
|
||
|
||
let GOTIFY_URL = 'https://pushplus.mcraft.cn';
|
||
let GOTIFY_TOKEN = 'jdprotoken213';
|
||
let GOTIFY_PRIORITY = 0;
|
||
|
||
sendNotify('mytitle', 'despLine1\nSecond Line');
|
||
|
||
/**
|
||
* sendNotify 推送通知功能
|
||
* @param text 通知头
|
||
* @param desp 通知体
|
||
* @param params 某些推送通知方式点击弹窗可跳转, 例:{ url: 'https://abc.com' }
|
||
* @param author 作者仓库等信息 例:`本通知 By:https://github.com/whyour/qinglong`
|
||
* @returns {Promise<unknown>}
|
||
*/
|
||
async function sendNotify(
|
||
text,
|
||
desp,
|
||
params = {},
|
||
author = '\n\n本通知 By:https://github.com/whyour/qinglong',
|
||
) {
|
||
//提供6种通知
|
||
desp += author; //增加作者信息,防止被贩卖等
|
||
/*
|
||
await Promise.all([
|
||
pushPlusNotify(text, desp), //pushplus(推送加)
|
||
]);*/
|
||
//由于上述两种微信通知需点击进去才能查看到详情,故text(标题内容)携带了账号序号以及昵称信息,方便不点击也可知道是哪个京东哪个活动
|
||
text = text.match(/.*?(?=\s?-)/g) ? text.match(/.*?(?=\s?-)/g)[0] : text;
|
||
await Promise.all([
|
||
gotifyNotify(text, desp), //gotify
|
||
]);
|
||
}
|
||
|
||
function gotifyNotify(text, desp) {
|
||
return new Promise((resolve) => {
|
||
if (GOTIFY_URL && GOTIFY_TOKEN) {
|
||
const options = {
|
||
url: `${GOTIFY_URL}/message?token=${GOTIFY_TOKEN}`,
|
||
body: `title=${encodeURIComponent(text)}&message=${encodeURIComponent(
|
||
desp,
|
||
)}&priority=${GOTIFY_PRIORITY}`,
|
||
headers: {
|
||
'Content-Type': 'application/x-www-form-urlencoded',
|
||
},
|
||
};
|
||
$.post(options, (err, resp, data) => {
|
||
try {
|
||
if (err) {
|
||
console.log('gotify发送通知调用API失败!!\n');
|
||
console.log(err);
|
||
} else {
|
||
data = JSON.parse(data);
|
||
if (data.id) {
|
||
console.log('gotify发送通知消息成功🎉\n');
|
||
} else {
|
||
console.log(`${data.message}\n`);
|
||
}
|
||
}
|
||
} catch (e) {
|
||
$.logErr(e, resp);
|
||
} finally {
|
||
resolve();
|
||
}
|
||
});
|
||
} else {
|
||
resolve();
|
||
}
|
||
});
|
||
}
|
||
|
||
|
||
// prettier-ignore
|
||
function Env(t, s) {
|
||
return new(class {
|
||
constructor(t, s) {
|
||
(this.name = t),
|
||
(this.data = null),
|
||
(this.dataFile = 'box.dat'),
|
||
(this.logs = []),
|
||
(this.logSeparator = '\n'),
|
||
(this.startTime = new Date().getTime()),
|
||
Object.assign(this, s),
|
||
this.log('', `\ud83d\udd14${this.name}, \u5f00\u59cb!`);
|
||
}
|
||
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;
|
||
}
|
||
getScript(t) {
|
||
return new Promise((s) => {
|
||
$.get({
|
||
url: t
|
||
}, (t, e, i) => s(i));
|
||
});
|
||
}
|
||
runScript(t, s) {
|
||
return new Promise((e) => {
|
||
let i = this.getdata('@chavy_boxjs_userCfgs.httpapi');
|
||
i = i ? i.replace(/\n/g, '').trim() : i;
|
||
let o = this.getdata('@chavy_boxjs_userCfgs.httpapi_timeout');
|
||
(o = o ? 1 * o : 20),
|
||
(o = s && s.timeout ? s.timeout : o);
|
||
const[h, a] = i.split('@'),
|
||
r = {
|
||
url: `http://${a}/v1/scripting/evaluate`,
|
||
body: {
|
||
script_text: t,
|
||
mock_type: 'cron',
|
||
timeout: o
|
||
},
|
||
headers: {
|
||
'X-Key': h,
|
||
Accept: '*/*'
|
||
},
|
||
};
|
||
$.post(r, (t, s, i) => e(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),
|
||
s = this.path.resolve(process.cwd(), this.dataFile),
|
||
e = this.fs.existsSync(t),
|
||
i = !e && this.fs.existsSync(s);
|
||
if (!e && !i)
|
||
return {}; {
|
||
const i = e ? t : s;
|
||
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),
|
||
s = this.path.resolve(process.cwd(), this.dataFile),
|
||
e = this.fs.existsSync(t),
|
||
i = !e && this.fs.existsSync(s),
|
||
o = JSON.stringify(this.data);
|
||
e ? this.fs.writeFileSync(t, o) : i ? this.fs.writeFileSync(s, o) : this.fs.writeFileSync(t, o);
|
||
}
|
||
}
|
||
lodash_get(t, s, e) {
|
||
const i = s.replace(/\[(\d+)\]/g, '.$1').split('.');
|
||
let o = t;
|
||
for (const t of i)
|
||
if (((o = Object(o)[t]), void 0 === o))
|
||
return e;
|
||
return o;
|
||
}
|
||
lodash_set(t, s, e) {
|
||
return Object(t) !== t ? t : (Array.isArray(s) || (s = s.toString().match(/[^.[\]]+/g) || []), (s.slice(0, -1).reduce((t, e, i) => (Object(t[e]) === t[e] ? t[e] : (t[e] = Math.abs(s[i + 1]) >> 0 == +s[i + 1] ? [] : {})), t)[s[s.length - 1]] = e), t);
|
||
}
|
||
getdata(t) {
|
||
let s = this.getval(t);
|
||
if (/^@/.test(t)) {
|
||
const[, e, i] = /^@(.*?)\.(.*?)$/.exec(t),
|
||
o = e ? this.getval(e) : '';
|
||
if (o)
|
||
try {
|
||
const t = JSON.parse(o);
|
||
s = t ? this.lodash_get(t, i, '') : s;
|
||
} catch (t) {
|
||
s = '';
|
||
}
|
||
}
|
||
return s;
|
||
}
|
||
setdata(t, s) {
|
||
let e = !1;
|
||
if (/^@/.test(s)) {
|
||
const[, i, o] = /^@(.*?)\.(.*?)$/.exec(s),
|
||
h = this.getval(i),
|
||
a = i ? ('null' === h ? null : h || '{}') : '{}';
|
||
try {
|
||
const s = JSON.parse(a);
|
||
this.lodash_set(s, o, t),
|
||
(e = this.setval(JSON.stringify(s), i));
|
||
} catch (s) {
|
||
const h = {};
|
||
this.lodash_set(h, o, t),
|
||
(e = this.setval(JSON.stringify(h), i));
|
||
}
|
||
} else
|
||
e = $.setval(t, s);
|
||
return e;
|
||
}
|
||
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, s) {
|
||
return this.isSurge() || this.isLoon() ? $persistentStore.write(t, s) : this.isQuanX() ? $prefs.setValueForKey(t, s) : this.isNode() ? ((this.data = this.loaddata()), (this.data[s] = t), this.writedata(), !0) : (this.data && this.data[s]) || 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, s = () => {}) {
|
||
t.headers && (delete t.headers['Content-Type'], delete t.headers['Content-Length']),
|
||
this.isSurge() || this.isLoon() ? $httpClient.get(t, (t, e, i) => {
|
||
!t && e && ((e.body = i), (e.statusCode = e.status)),
|
||
s(t, e, i);
|
||
}) : this.isQuanX() ? $task.fetch(t).then((t) => {
|
||
const {
|
||
statusCode: e,
|
||
statusCode: i,
|
||
headers: o,
|
||
body: h
|
||
} = t;
|
||
s(null, {
|
||
status: e,
|
||
statusCode: i,
|
||
headers: o,
|
||
body: h
|
||
}, h);
|
||
}, (t) => s(t)) : this.isNode() && (this.initGotEnv(t), this.got(t).on('redirect', (t, s) => {
|
||
try {
|
||
const e = t.headers['set-cookie'].map(this.cktough.Cookie.parse).toString();
|
||
this.ckjar.setCookieSync(e, null),
|
||
(s.cookieJar = this.ckjar);
|
||
} catch (t) {
|
||
this.logErr(t);
|
||
}
|
||
}).then((t) => {
|
||
const {
|
||
statusCode: e,
|
||
statusCode: i,
|
||
headers: o,
|
||
body: h
|
||
} = t;
|
||
s(null, {
|
||
status: e,
|
||
statusCode: i,
|
||
headers: o,
|
||
body: h
|
||
}, h);
|
||
}, (t) => s(t)));
|
||
}
|
||
post(t, s = () => {}) {
|
||
if ((t.body && t.headers && !t.headers['Content-Type'] && (t.headers['Content-Type'] = 'application/x-www-form-urlencoded'), delete t.headers['Content-Length'], this.isSurge() || this.isLoon()))
|
||
$httpClient.post(t, (t, e, i) => {
|
||
!t && e && ((e.body = i), (e.statusCode = e.status)),
|
||
s(t, e, i);
|
||
});
|
||
else if (this.isQuanX())
|
||
(t.method = 'POST'), $task.fetch(t).then((t) => {
|
||
const {
|
||
statusCode: e,
|
||
statusCode: i,
|
||
headers: o,
|
||
body: h
|
||
} = t;
|
||
s(null, {
|
||
status: e,
|
||
statusCode: i,
|
||
headers: o,
|
||
body: h
|
||
}, h);
|
||
}, (t) => s(t));
|
||
else if (this.isNode()) {
|
||
this.initGotEnv(t);
|
||
const {
|
||
url: e,
|
||
...i
|
||
} = t;
|
||
this.got.post(e, i).then((t) => {
|
||
const {
|
||
statusCode: e,
|
||
statusCode: i,
|
||
headers: o,
|
||
body: h
|
||
} = t;
|
||
s(null, {
|
||
status: e,
|
||
statusCode: i,
|
||
headers: o,
|
||
body: h
|
||
}, h);
|
||
}, (t) => s(t));
|
||
}
|
||
}
|
||
time(t) {
|
||
let s = {
|
||
'M+': new Date().getMonth() + 1,
|
||
'd+': new Date().getDate(),
|
||
'H+': new Date().getHours(),
|
||
'm+': new Date().getMinutes(),
|
||
's+': new Date().getSeconds(),
|
||
'q+': Math.floor((new Date().getMonth() + 3) / 3),
|
||
S: new Date().getMilliseconds(),
|
||
};
|
||
/(y+)/.test(t) && (t = t.replace(RegExp.$1, (new Date().getFullYear() + '').substr(4 - RegExp.$1.length)));
|
||
for (let e in s)
|
||
new RegExp('(' + e + ')').test(t) && (t = t.replace(RegExp.$1, 1 == RegExp.$1.length ? s[e] : ('00' + s[e]).substr(('' + s[e]).length)));
|
||
return t;
|
||
}
|
||
msg(s = t, e = '', i = '', o) {
|
||
const h = (t) => !t || (!this.isLoon() && this.isSurge()) ? t : 'string' == typeof t ? this.isLoon() ? t : this.isQuanX() ? {
|
||
'open-url': t
|
||
}
|
||
: void 0 : 'object' == typeof t && (t['open-url'] || t['media-url']) ? this.isLoon() ? t['open-url'] : this.isQuanX() ? t : void 0 : void 0;
|
||
$.isMute || (this.isSurge() || this.isLoon() ? $notification.post(s, e, i, h(o)) : this.isQuanX() && $notify(s, e, i, h(o))),
|
||
this.logs.push('', '==============\ud83d\udce3\u7cfb\u7edf\u901a\u77e5\ud83d\udce3=============='),
|
||
this.logs.push(s),
|
||
e && this.logs.push(e),
|
||
i && this.logs.push(i);
|
||
}
|
||
log(...t) {
|
||
t.length > 0 ? (this.logs = [...this.logs, ...t]) : console.log(this.logs.join(this.logSeparator));
|
||
}
|
||
logErr(t, s) {
|
||
const e = !this.isSurge() && !this.isQuanX() && !this.isLoon();
|
||
e ? $.log('', `\u2757\ufe0f${this.name}, \u9519\u8bef!`, t.stack) : $.log('', `\u2757\ufe0f${this.name}, \u9519\u8bef!`, t);
|
||
}
|
||
wait(t) {
|
||
return new Promise((s) => setTimeout(s, t));
|
||
}
|
||
done(t = {}) {
|
||
const s = new Date().getTime(),
|
||
e = (s - this.startTime) / 1e3;
|
||
this.log('', `\ud83d\udd14${this.name}, \u7ed3\u675f! \ud83d\udd5b ${e} \u79d2`),
|
||
this.log(),
|
||
(this.isSurge() || this.isQuanX() || this.isLoon()) && $done(t);
|
||
}
|
||
})(t, s);
|
||
} |