mirror of
https://github.com/louislam/uptime-kuma.git
synced 2024-11-27 16:54:04 +00:00
Compare commits
4 commits
d27f0349e5
...
9bf25b9804
Author | SHA1 | Date | |
---|---|---|---|
|
9bf25b9804 | ||
|
8a432ac937 | ||
|
fafa1a78ee | ||
|
c70ec1ea50 |
2 changed files with 79 additions and 19 deletions
|
@ -12,13 +12,16 @@ class WeCom extends NotificationProvider {
|
||||||
const okMsg = "Sent Successfully.";
|
const okMsg = "Sent Successfully.";
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
let WeComUrl =
|
||||||
|
"https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=" +
|
||||||
|
notification.weComBotKey;
|
||||||
let config = {
|
let config = {
|
||||||
headers: {
|
headers: {
|
||||||
"Content-Type": "application/json"
|
"Content-Type": "application/json",
|
||||||
}
|
},
|
||||||
};
|
};
|
||||||
let body = this.composeMessage(heartbeatJSON, msg);
|
let body = this.composeMessage(heartbeatJSON, monitorJSON, msg);
|
||||||
await axios.post(`https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=${notification.weComBotKey}`, body, config);
|
await axios.post(WeComUrl, body, config);
|
||||||
return okMsg;
|
return okMsg;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
this.throwGeneralAxiosError(error);
|
this.throwGeneralAxiosError(error);
|
||||||
|
@ -28,24 +31,77 @@ class WeCom extends NotificationProvider {
|
||||||
/**
|
/**
|
||||||
* Generate the message to send
|
* Generate the message to send
|
||||||
* @param {object} heartbeatJSON Heartbeat details (For Up/Down only)
|
* @param {object} heartbeatJSON Heartbeat details (For Up/Down only)
|
||||||
|
* @param {object} monitorJSON Monitor details
|
||||||
* @param {string} msg General message
|
* @param {string} msg General message
|
||||||
* @returns {object} Message
|
* @returns {object} Message
|
||||||
*/
|
*/
|
||||||
composeMessage(heartbeatJSON, msg) {
|
composeMessage(heartbeatJSON, monitorJSON, msg) {
|
||||||
let title = "UptimeKuma Message";
|
const address = this.extractAddress(monitorJSON);
|
||||||
if (msg != null && heartbeatJSON != null && heartbeatJSON["status"] === UP) {
|
if (heartbeatJSON != null) {
|
||||||
title = "UptimeKuma Monitor Up";
|
const templateCard = {
|
||||||
}
|
card_type: "text_notice",
|
||||||
if (msg != null && heartbeatJSON != null && heartbeatJSON["status"] === DOWN) {
|
main_title: {
|
||||||
title = "UptimeKuma Monitor Down";
|
title: this.statusToString(
|
||||||
|
heartbeatJSON["status"],
|
||||||
|
monitorJSON["name"]
|
||||||
|
),
|
||||||
|
},
|
||||||
|
sub_title_text: heartbeatJSON["msg"],
|
||||||
|
horizontal_content_list: [
|
||||||
|
{
|
||||||
|
keyname: "Timezone",
|
||||||
|
value: heartbeatJSON["timezone"],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
keyname: "Time",
|
||||||
|
value: heartbeatJSON["localDateTime"],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
card_action: {
|
||||||
|
type: 1,
|
||||||
|
url: address
|
||||||
|
? address
|
||||||
|
: "https://github.com/louislam/uptime-kuma", // both card_action and card_action.url are mandatory
|
||||||
|
},
|
||||||
|
};
|
||||||
|
if (address) {
|
||||||
|
templateCard["jump_list"] = [
|
||||||
|
{
|
||||||
|
type: 1,
|
||||||
|
url: address,
|
||||||
|
title: "Monitor URL",
|
||||||
|
},
|
||||||
|
];
|
||||||
|
}
|
||||||
|
return {
|
||||||
|
msgtype: "template_card",
|
||||||
|
template_card: templateCard,
|
||||||
|
};
|
||||||
}
|
}
|
||||||
return {
|
return {
|
||||||
msgtype: "text",
|
msgtype: "text",
|
||||||
text: {
|
text: {
|
||||||
content: title + "\n" + msg
|
content: msg,
|
||||||
}
|
},
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Convert status constant to string
|
||||||
|
* @param {const} status The status constant
|
||||||
|
* @param {string} monitorName Name of monitor
|
||||||
|
* @returns {string} Status
|
||||||
|
*/
|
||||||
|
statusToString(status, monitorName) {
|
||||||
|
switch (status) {
|
||||||
|
case DOWN:
|
||||||
|
return `🔴 [${monitorName}] DOWN`;
|
||||||
|
case UP:
|
||||||
|
return `✅ [${monitorName}] UP`;
|
||||||
|
default:
|
||||||
|
return "Notification";
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports = WeCom;
|
module.exports = WeCom;
|
||||||
|
|
|
@ -220,13 +220,17 @@ module.exports.statusPageSocketHandler = (socket) => {
|
||||||
|
|
||||||
// Delete groups that are not in the list
|
// Delete groups that are not in the list
|
||||||
log.debug("socket", "Delete groups that are not in the list");
|
log.debug("socket", "Delete groups that are not in the list");
|
||||||
const slots = groupIDList.map(() => "?").join(",");
|
if (groupIDList.length === 0) {
|
||||||
|
await R.exec("DELETE FROM `group` WHERE status_page_id = ?", [ statusPage.id ]);
|
||||||
|
} else {
|
||||||
|
const slots = groupIDList.map(() => "?").join(",");
|
||||||
|
|
||||||
const data = [
|
const data = [
|
||||||
...groupIDList,
|
...groupIDList,
|
||||||
statusPage.id
|
statusPage.id
|
||||||
];
|
];
|
||||||
await R.exec(`DELETE FROM \`group\` WHERE id NOT IN (${slots}) AND status_page_id = ?`, data);
|
await R.exec(`DELETE FROM \`group\` WHERE id NOT IN (${slots}) AND status_page_id = ?`, data);
|
||||||
|
}
|
||||||
|
|
||||||
const server = UptimeKumaServer.getInstance();
|
const server = UptimeKumaServer.getInstance();
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue