diff options
Diffstat (limited to 'server/notification-providers/pushover.js')
-rw-r--r-- | server/notification-providers/pushover.js | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/server/notification-providers/pushover.js b/server/notification-providers/pushover.js new file mode 100644 index 0000000..8422b64 --- /dev/null +++ b/server/notification-providers/pushover.js @@ -0,0 +1,58 @@ +const { getMonitorRelativeURL } = require("../../src/util"); +const { setting } = require("../util-server"); + +const NotificationProvider = require("./notification-provider"); +const axios = require("axios"); + +class Pushover extends NotificationProvider { + name = "pushover"; + + /** + * @inheritdoc + */ + async send(notification, msg, monitorJSON = null, heartbeatJSON = null) { + const okMsg = "Sent Successfully."; + const url = "https://api.pushover.net/1/messages.json"; + + let data = { + "message": msg, + "user": notification.pushoveruserkey, + "token": notification.pushoverapptoken, + "sound": notification.pushoversounds, + "priority": notification.pushoverpriority, + "title": notification.pushovertitle, + "retry": "30", + "expire": "3600", + "html": 1, + }; + + const baseURL = await setting("primaryBaseURL"); + if (baseURL && monitorJSON) { + data["url"] = baseURL + getMonitorRelativeURL(monitorJSON.id); + data["url_title"] = "Link to Monitor"; + } + + if (notification.pushoverdevice) { + data.device = notification.pushoverdevice; + } + if (notification.pushoverttl) { + data.ttl = notification.pushoverttl; + } + + try { + if (heartbeatJSON == null) { + await axios.post(url, data); + return okMsg; + } else { + data.message += `\n<b>Time (${heartbeatJSON["timezone"]})</b>:${heartbeatJSON["localDateTime"]}`; + await axios.post(url, data); + return okMsg; + } + } catch (error) { + this.throwGeneralAxiosError(error); + } + + } +} + +module.exports = Pushover; |