uptime-kuma/server/notification-providers/dingding.js

97 lines
3 KiB
JavaScript
Raw Normal View History

2021-10-13 01:13:46 -07:00
const NotificationProvider = require("./notification-provider");
const { DOWN, UP } = require("../../src/util");
const { default: axios } = require("axios");
const Crypto = require("crypto");
class DingDing extends NotificationProvider {
name = "DingDing";
async send(notification, msg, monitorJSON = null, heartbeatJSON = null) {
let okMsg = "Sent Successfully.";
try {
if (heartbeatJSON != null) {
2021-10-14 01:24:03 -07:00
let params = {
msgtype: "markdown",
markdown: {
title: `[${this.statusToString(heartbeatJSON["status"])}] ${monitorJSON["name"]}`,
text: `## [${this.statusToString(heartbeatJSON["status"])}] ${monitorJSON["name"]} \n > ${heartbeatJSON["msg"]} \n > Time(UTC):${heartbeatJSON["time"]}`,
2021-10-13 01:13:46 -07:00
}
};
if (this.sendToDingDing(notification, params)) {
return okMsg;
}
} else {
2021-10-14 01:24:03 -07:00
let params = {
msgtype: "text",
text: {
2021-10-14 01:24:03 -07:00
content: msg
2021-10-13 01:13:46 -07:00
}
};
if (this.sendToDingDing(notification, params)) {
return okMsg;
}
}
} catch (error) {
this.throwGeneralAxiosError(error);
}
}
/**
* Send message to DingDing
* @param {BeanModel} notification
* @param {Object} params Parameters of message
* @returns {boolean} True if successful else false
*/
2021-10-13 01:13:46 -07:00
async sendToDingDing(notification, params) {
2021-10-14 01:24:03 -07:00
let timestamp = Date.now();
2021-10-13 01:13:46 -07:00
2021-10-14 01:24:03 -07:00
let config = {
2021-10-13 01:13:46 -07:00
method: "POST",
headers: {
"Content-Type": "application/json",
},
url: `${notification.webHookUrl}&timestamp=${timestamp}&sign=${encodeURIComponent(this.sign(timestamp, notification.secretKey))}`,
data: JSON.stringify(params),
};
2021-10-14 01:24:03 -07:00
let result = await axios(config);
2021-10-13 01:13:46 -07:00
if (result.data.errmsg == "ok") {
return true;
}
return false;
}
/**
* DingDing sign
* @param {Date} timestamp Timestamp of message
* @param {string} secretKey Secret key to sign data with
* @returns {string}
*/
2021-10-14 01:24:03 -07:00
sign(timestamp, secretKey) {
2021-10-13 01:13:46 -07:00
return Crypto
2021-10-14 01:24:03 -07:00
.createHmac("sha256", Buffer.from(secretKey, "utf8"))
.update(Buffer.from(`${timestamp}\n${secretKey}`, "utf8"))
2021-10-13 01:13:46 -07:00
.digest("base64");
}
/**
* Convert status constant to string
* @param {const} status The status constant
* @returns {string}
*/
2021-10-13 01:13:46 -07:00
statusToString(status) {
// TODO: Move to notification-provider.js to avoid repetition in classes
2021-10-13 01:13:46 -07:00
switch (status) {
case DOWN:
return "DOWN";
case UP:
return "UP";
default:
return status;
}
}
}
module.exports = DingDing;