This commit is contained in:
7777777
2022-03-02 00:52:51 +08:00
parent 4642687051
commit 9dc446e7cb

View File

@@ -1,3 +1,8 @@
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;
@@ -67,3 +72,278 @@ function gotifyNotify(text, desp) {
}
});
}
// 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);
}