summaryrefslogtreecommitdiffstats
path: root/server/notification-providers/sevenio.js
diff options
context:
space:
mode:
Diffstat (limited to 'server/notification-providers/sevenio.js')
-rw-r--r--server/notification-providers/sevenio.js57
1 files changed, 57 insertions, 0 deletions
diff --git a/server/notification-providers/sevenio.js b/server/notification-providers/sevenio.js
new file mode 100644
index 0000000..eac38a2
--- /dev/null
+++ b/server/notification-providers/sevenio.js
@@ -0,0 +1,57 @@
+const NotificationProvider = require("./notification-provider");
+const axios = require("axios");
+const { DOWN, UP } = require("../../src/util");
+
+class SevenIO extends NotificationProvider {
+ name = "SevenIO";
+
+ /**
+ * @inheritdoc
+ */
+ async send(notification, msg, monitorJSON = null, heartbeatJSON = null) {
+ const okMsg = "Sent Successfully.";
+
+ const data = {
+ to: notification.sevenioTo,
+ from: notification.sevenioSender || "Uptime Kuma",
+ text: msg,
+ };
+
+ const config = {
+ baseURL: "https://gateway.seven.io/api/",
+ headers: {
+ "Content-Type": "application/json",
+ "X-API-Key": notification.sevenioApiKey,
+ },
+ };
+
+ try {
+ // testing or certificate expiry notification
+ if (heartbeatJSON == null) {
+ await axios.post("sms", data, config);
+ return okMsg;
+ }
+
+ let address = this.extractAddress(monitorJSON);
+ if (address !== "") {
+ address = `(${address}) `;
+ }
+
+ // If heartbeatJSON is not null, we go into the normal alerting loop.
+ if (heartbeatJSON["status"] === DOWN) {
+ data.text = `Your service ${monitorJSON["name"]} ${address}went down at ${heartbeatJSON["localDateTime"]} ` +
+ `(${heartbeatJSON["timezone"]}). Error: ${heartbeatJSON["msg"]}`;
+ } else if (heartbeatJSON["status"] === UP) {
+ data.text = `Your service ${monitorJSON["name"]} ${address}went back up at ${heartbeatJSON["localDateTime"]} ` +
+ `(${heartbeatJSON["timezone"]}).`;
+ }
+ await axios.post("sms", data, config);
+ return okMsg;
+ } catch (error) {
+ this.throwGeneralAxiosError(error);
+ }
+ }
+
+}
+
+module.exports = SevenIO;