jd_scripts/sendNotify.js

631 lines
26 KiB
JavaScript
Raw Normal View History

2020-12-20 13:56:36 +08:00
/*
2021-01-16 17:10:19 +08:00
* @Author: LXK9301 https://github.com/LXK9301
2020-12-20 13:56:36 +08:00
* @Date: 2020-08-19 16:12:40
2021-01-16 17:10:19 +08:00
* @Last Modified by: LXK9301
2021-01-07 12:54:35 +08:00
* @Last Modified time: 2021-1-7 17:52:54
2020-12-20 13:56:36 +08:00
*/
2020-11-10 09:29:58 +08:00
const querystring = require("querystring");
const $ = new Env();
// =======================================微信server酱通知设置区域===========================================
//此处填你申请的SCKEY.
2021-01-16 17:10:19 +08:00
//(环境变量名 PUSH_KEY)
2020-11-10 09:29:58 +08:00
let SCKEY = '';
2020-12-21 13:30:03 +08:00
// =======================================QQ酷推通知设置区域===========================================
//此处填你申请的SKEY(具体详见文档 https://cp.xuthus.cc/)
2021-01-16 17:10:19 +08:00
//(环境变量名 QQ_SKEY)
2020-12-21 15:02:09 +08:00
let QQ_SKEY = '';
2021-01-10 17:24:08 +08:00
//此处填写私聊或群组推送,默认私聊(send[私聊]、group[群聊]、wx[个微]、ww[企微]、email[邮件])
2020-12-21 15:02:09 +08:00
let QQ_MODE = 'send';
2020-12-21 13:30:03 +08:00
2020-11-10 09:29:58 +08:00
// =======================================Bark App通知设置区域===========================================
//此处填你BarkAPP的信息(IP/设备码例如https://api.day.app/XXXXXXXX)
let BARK_PUSH = '';
//BARK app推送铃声,铃声列表去APP查看复制填写
let BARK_SOUND = '';
// =======================================telegram机器人通知设置区域===========================================
//此处填你telegram bot 的Token例如1077xxx4424:AAFjv0FcqxxxxxxgEMGfi22B4yh15R5uw
2021-01-16 17:10:19 +08:00
//(环境变量名 TG_BOT_TOKEN)
2020-11-10 09:29:58 +08:00
let TG_BOT_TOKEN = '';
//此处填你接收通知消息的telegram用户的id例如129xxx206
2021-01-16 17:10:19 +08:00
//(环境变量名 TG_USER_ID)
2020-11-10 09:29:58 +08:00
let TG_USER_ID = '';
// =======================================钉钉机器人通知设置区域===========================================
//此处填你钉钉 bot 的webhook例如5a544165465465645d0f31dca676e7bd07415asdasd
2021-01-16 17:10:19 +08:00
//(环境变量名 DD_BOT_TOKEN)
2020-11-10 09:29:58 +08:00
let DD_BOT_TOKEN = '';
//密钥机器人安全设置页面加签一栏下面显示的SEC开头的字符串
let DD_BOT_SECRET = '';
2020-12-22 20:35:43 +08:00
// =======================================企业微信机器人通知设置区域===========================================
2020-12-23 13:48:23 +08:00
//此处填你企业微信机器人的 webhook(详见文档 https://work.weixin.qq.com/api/doc/90000/90136/91770)例如693a91f6-7xxx-4bc4-97a0-0ec2sifa5aaa
2021-01-16 17:10:19 +08:00
//(环境变量名 QYWX_KEY)
2020-12-22 20:35:43 +08:00
let QYWX_KEY = '';
// =======================================企业微信应用消息通知设置区域===========================================
2021-01-16 17:10:19 +08:00
//此处填你企业微信应用消息的 值(详见文档 https://work.weixin.qq.com/api/doc/90000/90135/90236)依次填上corpid的值,corpsecret的值,touser的值,agentid的值素材库图片id见https://github.com/LXK9301/jd_scripts/issues/519) 注意用,号隔开例如wwcff56746d9adwers,B-791548lnzXBE6_BWfxdf3kSTMJr9vFEPKAbh6WERQ,mingcheng,1000001,2COXgjH2UIfERF2zxrtUOKgQ9XklUqMdGSWLBoW_lSDAdafat
//增加一个选择推送消息类型用图文消息直接填写素材库图片id的值用卡片消息就填写0(就是数字零)
2021-01-16 17:10:19 +08:00
//(环境变量名 QYWX_AM)
let QYWX_AM = '';
2020-11-10 09:29:58 +08:00
// =======================================iGot聚合推送通知设置区域===========================================
//此处填您iGot的信息(推送key例如https://push.hellyw.com/XXXXXXXX)
let IGOT_PUSH_KEY = '';
2020-12-21 15:25:54 +08:00
// =======================================push+设置区域=======================================
//官方文档https://pushplus.hxtrip.com/
//PUSH_PLUS_TOKEN微信扫码登录后一对一推送或一对多推送下面的token(您的Token)不提供PUSH_PLUS_USER则默认为一对一推送
//PUSH_PLUS_USER 一对多推送的“群组编码”(一对多推送下面->您的群组(如无则新建)->群组编码,如果您是创建群组人。也需点击“查看二维码”扫描绑定,否则不能接受群组消息推送)
2020-12-21 15:25:54 +08:00
let PUSH_PLUS_TOKEN = '';
let PUSH_PLUS_USER = '';
//==========================云端环境变量的判断与接收=========================
2020-11-10 09:29:58 +08:00
if (process.env.PUSH_KEY) {
SCKEY = process.env.PUSH_KEY;
}
2020-12-21 13:30:03 +08:00
if (process.env.QQ_SKEY) {
2020-12-21 15:02:09 +08:00
QQ_SKEY = process.env.QQ_SKEY;
}
if (process.env.QQ_MODE) {
QQ_MODE = process.env.QQ_MODE;
2020-12-21 13:30:03 +08:00
}
2020-11-10 09:29:58 +08:00
if (process.env.BARK_PUSH) {
if(process.env.BARK_PUSH.indexOf('https') > -1 || process.env.BARK_PUSH.indexOf('http') > -1) {
//兼容BARK自建用户
BARK_PUSH = process.env.BARK_PUSH
} else {
BARK_PUSH = `https://api.day.app/${process.env.BARK_PUSH}`
}
if (process.env.BARK_SOUND) {
BARK_SOUND = process.env.BARK_SOUND
}
} else {
if(BARK_PUSH && BARK_PUSH.indexOf('https') === -1 && BARK_PUSH.indexOf('http') === -1) {
//兼容BARK本地用户只填写设备码的情况
BARK_PUSH = `https://api.day.app/${BARK_PUSH}`
}
}
if (process.env.TG_BOT_TOKEN) {
TG_BOT_TOKEN = process.env.TG_BOT_TOKEN;
}
if (process.env.TG_USER_ID) {
TG_USER_ID = process.env.TG_USER_ID;
}
if (process.env.DD_BOT_TOKEN) {
DD_BOT_TOKEN = process.env.DD_BOT_TOKEN;
if (process.env.DD_BOT_SECRET) {
DD_BOT_SECRET = process.env.DD_BOT_SECRET;
}
}
2020-12-22 20:35:43 +08:00
if (process.env.QYWX_KEY) {
QYWX_KEY = process.env.QYWX_KEY;
}
if (process.env.QYWX_AM) {
QYWX_AM = process.env.QYWX_AM;
}
2020-11-10 09:29:58 +08:00
if (process.env.IGOT_PUSH_KEY) {
IGOT_PUSH_KEY = process.env.IGOT_PUSH_KEY
}
2020-12-21 15:25:54 +08:00
if (process.env.PUSH_PLUS_TOKEN) {
PUSH_PLUS_TOKEN = process.env.PUSH_PLUS_TOKEN;
}
if (process.env.PUSH_PLUS_USER) {
PUSH_PLUS_USER = process.env.PUSH_PLUS_USER;
}
//==========================云端环境变量的判断与接收=========================
2020-12-21 15:25:54 +08:00
2020-11-10 09:29:58 +08:00
async function sendNotify(text, desp, params = {}) {
//提供7种通知
2021-01-16 17:10:19 +08:00
desp += `\n本脚本开源免费使用 Byhttps://github.com/LXK9301/jd_scripts`;
2021-01-05 17:39:33 +08:00
await Promise.all([
serverNotify(text, desp),//微信server酱
pushPlusNotify(text, desp)//pushplus(推送加)
])
//由于上述两种微信通知需点击进去才能查看到详情故text(标题内容)携带了账号序号以及昵称信息,方便不点击也可知道是哪个京东哪个活动
2020-11-10 14:51:34 +08:00
text = text.match(/.*?(?=\s?-)/g) ? text.match(/.*?(?=\s?-)/g)[0] : text;
2021-01-05 17:39:33 +08:00
await Promise.all([
BarkNotify(text, desp, params),//iOS Bark APP
tgBotNotify(text, desp),//telegram 机器人
ddBotNotify(text, desp),//钉钉机器人
qywxBotNotify(text, desp), //企业微信机器人
qywxamNotify(text, desp), //企业微信应用消息推送
iGotNotify(text, desp, params),//iGot
CoolPush(text, desp)//QQ酷推
])
2020-11-10 09:29:58 +08:00
}
function serverNotify(text, desp, timeout = 2100) {
2020-11-10 09:29:58 +08:00
return new Promise(resolve => {
if (SCKEY) {
//微信server酱推送通知一个\n不会换行需要两个\n才能换行故做此替换
desp = desp.replace(/[\n\r]/g, '\n\n');
const options = {
url: `https://sc.ftqq.com/${SCKEY}.send`,
body: `text=${text}&desp=${desp}`,
headers: {
'Content-Type': 'application/x-www-form-urlencoded'
}
}
setTimeout(() => {
$.post(options, (err, resp, data) => {
try {
if (err) {
2020-12-21 15:02:09 +08:00
console.log('发送通知调用API失败\n')
console.log(err);
} else {
data = JSON.parse(data);
if (data.errno === 0) {
2020-12-21 15:02:09 +08:00
console.log('server酱发送通知消息成功\n')
} else if (data.errno === 1024) {
2020-12-22 01:21:29 +08:00
// 一分钟内发送相同的内容会触发
console.log(`server酱发送通知消息异常: ${data.errmsg}\n`)
} else {
console.log(`server酱发送通知消息异常\n${JSON.stringify(data)}`)
}
2020-11-10 09:29:58 +08:00
}
} catch (e) {
$.logErr(e, resp);
} finally {
resolve(data);
2020-11-10 09:29:58 +08:00
}
})
}, timeout)
2020-11-10 09:29:58 +08:00
} else {
2020-12-21 15:02:09 +08:00
console.log('您未提供server酱的SCKEY取消微信推送消息通知\n');
2020-11-10 09:29:58 +08:00
resolve()
}
})
}
2020-12-21 13:30:03 +08:00
function CoolPush(text, desp) {
return new Promise(resolve => {
2020-12-21 15:02:09 +08:00
if (QQ_SKEY) {
2021-01-10 17:24:08 +08:00
let options = {
2020-12-21 15:02:09 +08:00
url: `https://push.xuthus.cc/${QQ_MODE}/${QQ_SKEY}`,
2020-12-21 13:30:03 +08:00
headers: {
2020-12-21 15:02:09 +08:00
'Content-Type': 'application/json'
2020-12-21 13:30:03 +08:00
}
}
2021-01-10 17:24:08 +08:00
switch (QQ_MODE) {
case "email":
options.json = {
"t": text,
"c": desp,
};
break;
default:
options.body = `${text}\n\n${desp}`;
}
let pushMode = function(t) {
switch (t){
case "send":
return "个人";
case "group":
return "QQ群";
case "wx":
return "微信";
case "ww":
return "企业微信";
case "email":
return "邮件";
default:
return "未知方式"
}
}
2020-12-21 13:30:03 +08:00
$.post(options, (err, resp, data) => {
try {
if (err) {
2021-01-10 17:24:08 +08:00
console.log(`发送${pushMode(QQ_MODE)}通知调用API失败\n`)
2020-12-21 13:30:03 +08:00
console.log(err);
} else {
data = JSON.parse(data);
if (data.code === 200) {
2021-01-10 17:24:08 +08:00
console.log(`酷推发送${pushMode(QQ_MODE)}通知消息成功\n`)
2020-12-21 13:30:03 +08:00
} else if (data.code === 400) {
2021-01-10 17:24:08 +08:00
console.log(`QQ酷推(Cool Push)发送${pushMode(QQ_MODE)}推送失败:${data.msg}\n`)
}else{
console.log(`酷推推送异常: ${data.msg}`);
2020-12-21 13:30:03 +08:00
}
}
} catch (e) {
$.logErr(e, resp);
} finally {
resolve(data);
}
})
} else {
2020-12-21 15:02:09 +08:00
console.log('您未提供酷推的SKEY取消QQ推送消息通知\n');
2020-12-21 13:30:03 +08:00
resolve()
}
})
}
2020-11-10 09:29:58 +08:00
function BarkNotify(text, desp, params={}) {
return new Promise(resolve => {
if (BARK_PUSH) {
const options = {
2020-11-10 14:51:34 +08:00
url: `${BARK_PUSH}/${encodeURIComponent(text)}/${encodeURIComponent(desp)}?sound=${BARK_SOUND}&${querystring.stringify(params)}`,
2020-11-10 09:29:58 +08:00
headers: {
'Content-Type': 'application/x-www-form-urlencoded'
}
}
$.get(options, (err, resp, data) => {
try {
if (err) {
2020-12-21 15:02:09 +08:00
console.log('Bark APP发送通知调用API失败\n')
2020-11-10 09:29:58 +08:00
console.log(err);
} else {
data = JSON.parse(data);
if (data.code === 200) {
2020-12-21 15:02:09 +08:00
console.log('Bark APP发送通知消息成功\n')
2020-11-10 09:29:58 +08:00
} else {
2020-12-21 15:02:09 +08:00
console.log(`${data.message}\n`);
2020-11-10 09:29:58 +08:00
}
}
} catch (e) {
$.logErr(e, resp);
} finally {
resolve();
}
})
} else {
2020-12-21 15:02:09 +08:00
console.log('您未提供Bark的APP推送BARK_PUSH取消Bark推送消息通知\n');
2020-11-10 09:29:58 +08:00
resolve()
}
})
}
function tgBotNotify(text, desp) {
return new Promise(resolve => {
if (TG_BOT_TOKEN && TG_USER_ID) {
const options = {
url: `https://api.telegram.org/bot${TG_BOT_TOKEN}/sendMessage`,
2020-11-10 14:51:34 +08:00
body: `chat_id=${TG_USER_ID}&text=${text}\n\n${desp}&disable_web_page_preview=true`,
2020-11-10 09:29:58 +08:00
headers: {
'Content-Type': 'application/x-www-form-urlencoded'
}
}
if (process.env.TG_PROXY_HOST && process.env.TG_PROXY_PORT) {
const tunnel = require("tunnel");
2020-11-10 09:29:58 +08:00
const agent = {
https: tunnel.httpsOverHttp({
proxy: {
host: process.env.TG_PROXY_HOST,
port: process.env.TG_PROXY_PORT * 1
}
})
}
Object.assign(options, { agent })
}
$.post(options, (err, resp, data) => {
try {
if (err) {
2020-12-21 15:02:09 +08:00
console.log('telegram发送通知消息失败\n')
2020-11-10 09:29:58 +08:00
console.log(err);
} else {
data = JSON.parse(data);
if (data.ok) {
2020-12-21 15:02:09 +08:00
console.log('Telegram发送通知消息完成。\n')
2020-11-10 09:29:58 +08:00
} else if (data.error_code === 400) {
2020-12-21 15:02:09 +08:00
console.log('请主动给bot发送一条消息并检查接收用户ID是否正确。\n')
2020-11-10 09:29:58 +08:00
} else if (data.error_code === 401){
2020-12-21 15:02:09 +08:00
console.log('Telegram bot token 填写错误。\n')
2020-11-10 09:29:58 +08:00
}
}
} catch (e) {
$.logErr(e, resp);
} finally {
resolve(data);
}
})
} else {
2020-12-21 15:02:09 +08:00
console.log('您未提供telegram机器人推送所需的TG_BOT_TOKEN和TG_USER_ID取消telegram推送消息通知\n');
2020-11-10 09:29:58 +08:00
resolve()
}
})
}
function ddBotNotify(text, desp) {
return new Promise(resolve => {
const options = {
url: `https://oapi.dingtalk.com/robot/send?access_token=${DD_BOT_TOKEN}`,
json: {
"msgtype": "text",
"text": {
2020-11-10 14:51:34 +08:00
"content": ` ${text}\n\n${desp}`
2020-11-10 09:29:58 +08:00
}
},
headers: {
'Content-Type': 'application/json'
}
}
if (DD_BOT_TOKEN && DD_BOT_SECRET) {
const crypto = require('crypto');
const dateNow = Date.now();
const hmac = crypto.createHmac('sha256', DD_BOT_SECRET);
hmac.update(`${dateNow}\n${DD_BOT_SECRET}`);
const result = encodeURIComponent(hmac.digest('base64'));
options.url = `${options.url}&timestamp=${dateNow}&sign=${result}`;
$.post(options, (err, resp, data) => {
try {
if (err) {
2020-12-21 15:02:09 +08:00
console.log('钉钉发送通知消息失败!!\n')
2020-11-10 09:29:58 +08:00
console.log(err);
} else {
data = JSON.parse(data);
if (data.errcode === 0) {
2020-12-21 15:02:09 +08:00
console.log('钉钉发送通知消息完成。\n')
2020-11-10 09:29:58 +08:00
} else {
2020-12-21 15:02:09 +08:00
console.log(`${data.errmsg}\n`)
2020-11-10 09:29:58 +08:00
}
}
} catch (e) {
$.logErr(e, resp);
} finally {
resolve(data);
}
})
} else if (DD_BOT_TOKEN) {
$.post(options, (err, resp, data) => {
try {
if (err) {
2020-12-21 15:02:09 +08:00
console.log('钉钉发送通知消息失败!!\n')
2020-11-10 09:29:58 +08:00
console.log(err);
} else {
data = JSON.parse(data);
if (data.errcode === 0) {
2020-12-21 15:02:09 +08:00
console.log('钉钉发送通知消息完成。\n')
2020-11-10 09:29:58 +08:00
} else {
2020-12-21 15:02:09 +08:00
console.log(`${data.errmsg}\n`)
2020-11-10 09:29:58 +08:00
}
}
} catch (e) {
$.logErr(e, resp);
} finally {
resolve(data);
}
})
} else {
2020-12-21 15:02:09 +08:00
console.log('您未提供钉钉机器人推送所需的DD_BOT_TOKEN或者DD_BOT_SECRET取消钉钉推送消息通知\n');
2020-11-10 09:29:58 +08:00
resolve()
}
})
}
2020-12-22 20:35:43 +08:00
function qywxBotNotify(text, desp) {
return new Promise(resolve => {
const options = {
url: `https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=${QYWX_KEY}`,
json: {
msgtype: 'text',
text: {
content: ` ${text}\n\n${desp}`,
},
},
headers: {
'Content-Type': 'application/json',
},
};
if (QYWX_KEY) {
$.post(options, (err, resp, data) => {
try {
if (err) {
console.log('企业微信发送通知消息失败!!\n');
console.log(err);
} else {
data = JSON.parse(data);
if (data.errcode === 0) {
console.log('企业微信发送通知消息完成。\n');
} else {
console.log(`${data.errmsg}\n`);
}
}
} catch (e) {
$.logErr(e, resp);
} finally {
resolve(data);
}
});
} else {
console.log('您未提供企业微信机器人推送所需的QYWX_KEY取消企业微信推送消息通知\n');
resolve();
}
});
}
function qywxamNotify(text, desp) {
return new Promise(resolve => {
if (QYWX_AM) {
var QYWX_AM_AY = QYWX_AM.split(',');
const options_accesstoken = {
url: `https://qyapi.weixin.qq.com/cgi-bin/gettoken`,
json: {
corpid:`${QYWX_AM_AY[0]}`,
corpsecret:`${QYWX_AM_AY[1]}`,
},
headers: {
'Content-Type': 'application/json',
},
};
$.post(options_accesstoken, (err, resp, data) => {
html=desp.replace(/\n/g,"<br/>")
var json = JSON.parse(data);
accesstoken = json.access_token;
const options_textcard = {
url: `https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=${accesstoken}`,
json: {
touser:`${QYWX_AM_AY[2]}`,
agentid:`${QYWX_AM_AY[3]}`,
msgtype: 'textcard',
textcard: {
title: `${text}`,
description: `${desp}`,
url: '127.0.0.1',
btntxt: '更多'
},
safe:'0',
},
headers: {
'Content-Type': 'application/json',
},
};
const options_mpnews = {
url: `https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=${accesstoken}`,
json: {
touser:`${QYWX_AM_AY[2]}`,
agentid:`${QYWX_AM_AY[3]}`,
msgtype: 'mpnews',
mpnews: {
articles: [
{
title: `${text}`,
thumb_media_id: `${QYWX_AM_AY[4]}`,
author : `智能助手` ,
content_source_url: ``,
content : `${html}`,
digest: `${desp}`
}
]
},
safe:'0',
},
headers: {
'Content-Type': 'application/json',
},
};
$.post((QYWX_AM_AY[4]==0)?options_textcard:options_mpnews, (err, resp, data) => {
try {
if (err) {
console.log('企业微信应用消息发送通知消息失败!!\n');
console.log(err);
} else {
data = JSON.parse(data);
if (data.errcode === 0) {
console.log('企业微信应用消息发送通知消息完成。\n');
} else {
console.log(`${data.errmsg}\n`);
}
}
} catch (e) {
$.logErr(e, resp);
} finally {
resolve(data);
}
});
});
} else {
console.log('您未提供企业微信应用消息推送所需的QYWX_AM取消企业微信应用消息推送消息通知\n');
resolve();
}
});
}
2020-11-10 09:29:58 +08:00
function iGotNotify(text, desp, params={}){
return new Promise(resolve => {
if (IGOT_PUSH_KEY) {
// 校验传入的IGOT_PUSH_KEY是否有效
const IGOT_PUSH_KEY_REGX = new RegExp("^[a-zA-Z0-9]{24}$")
if(!IGOT_PUSH_KEY_REGX.test(IGOT_PUSH_KEY)) {
2020-12-21 15:02:09 +08:00
console.log('您所提供的IGOT_PUSH_KEY无效\n')
2020-11-10 09:29:58 +08:00
resolve()
return
2020-11-10 14:51:34 +08:00
}
2020-11-10 09:29:58 +08:00
const options = {
url: `https://push.hellyw.com/${IGOT_PUSH_KEY.toLowerCase()}`,
2020-11-10 14:51:34 +08:00
body: `title=${text}&content=${desp}&${querystring.stringify(params)}`,
2020-11-10 09:29:58 +08:00
headers: {
'Content-Type': 'application/x-www-form-urlencoded'
}
}
$.post(options, (err, resp, data) => {
try {
if (err) {
2020-12-21 15:02:09 +08:00
console.log('发送通知调用API失败\n')
2020-11-10 09:29:58 +08:00
console.log(err);
} else {
if(typeof data === 'string') data = JSON.parse(data);
if (data.ret === 0) {
2020-12-21 15:02:09 +08:00
console.log('iGot发送通知消息成功\n')
2020-11-10 09:29:58 +08:00
} else {
2020-12-21 15:02:09 +08:00
console.log(`iGot发送通知消息失败${data.errMsg}\n`)
2020-11-10 09:29:58 +08:00
}
}
} catch (e) {
$.logErr(e, resp);
} finally {
resolve(data);
}
})
} else {
2020-12-21 15:02:09 +08:00
console.log('您未提供iGot的推送IGOT_PUSH_KEY取消iGot推送消息通知\n');
2020-11-10 09:29:58 +08:00
resolve()
}
})
}
2020-12-21 15:25:54 +08:00
function pushPlusNotify(text, desp) {
return new Promise(resolve => {
if (PUSH_PLUS_TOKEN) {
desp = desp.replace(/[\n\r]/g, '<br>'); // 默认为html, 不支持plaintext
const body = {
token: `${PUSH_PLUS_TOKEN}`,
title: `${text}`,
content:`${desp}`,
topic: `${PUSH_PLUS_USER}`
};
2020-12-21 15:25:54 +08:00
const options = {
url: `https://pushplus.hxtrip.com/send`,
body: JSON.stringify(body),
2020-12-21 15:25:54 +08:00
headers: {
'Content-Type': ' application/json'
2020-12-21 15:25:54 +08:00
}
}
$.post(options, (err, resp, data) => {
try {
if (err) {
console.log(`push+发送${PUSH_PLUS_USER ? '一对多' : '一对一'}通知消息失败!!\n`)
2020-12-21 15:25:54 +08:00
console.log(err);
} else {
data = JSON.parse(data);
if (data.code === 200) {
console.log(`push+发送${PUSH_PLUS_USER ? '一对多' : '一对一'}通知消息完成。\n`)
2020-12-21 15:25:54 +08:00
} else {
console.log(`push+发送${PUSH_PLUS_USER ? '一对多' : '一对一'}通知消息失败:${data.msg}\n`)
2020-12-21 15:25:54 +08:00
}
}
} catch (e) {
$.logErr(e, resp);
} finally {
resolve(data);
}
})
} else {
console.log('您未提供push+推送所需的PUSH_PLUS_TOKEN取消push+推送消息通知\n');
2020-12-21 15:25:54 +08:00
resolve()
}
})
}
2020-11-10 09:29:58 +08:00
module.exports = {
2021-01-07 12:54:35 +08:00
sendNotify,
BARK_PUSH
2020-12-21 15:02:09 +08:00
}
2020-11-10 09:29:58 +08:00
// prettier-ignore
2020-12-21 13:30:03 +08:00
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"]="applicat