diff options
Diffstat (limited to 'server/notification-providers/matrix.js')
-rw-r--r-- | server/notification-providers/matrix.js | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/server/notification-providers/matrix.js b/server/notification-providers/matrix.js new file mode 100644 index 0000000..805a494 --- /dev/null +++ b/server/notification-providers/matrix.js @@ -0,0 +1,48 @@ +const NotificationProvider = require("./notification-provider"); +const axios = require("axios"); +const Crypto = require("crypto"); +const { log } = require("../../src/util"); + +class Matrix extends NotificationProvider { + name = "matrix"; + + /** + * @inheritdoc + */ + async send(notification, msg, monitorJSON = null, heartbeatJSON = null) { + const okMsg = "Sent Successfully."; + + const size = 20; + const randomString = encodeURIComponent( + Crypto + .randomBytes(size) + .toString("base64") + .slice(0, size) + ); + + log.debug("notification", "Random String: " + randomString); + + const roomId = encodeURIComponent(notification.internalRoomId); + + log.debug("notification", "Matrix Room ID: " + roomId); + + try { + let config = { + headers: { + "Authorization": `Bearer ${notification.accessToken}`, + } + }; + let data = { + "msgtype": "m.text", + "body": msg + }; + + await axios.put(`${notification.homeserverUrl}/_matrix/client/r0/rooms/${roomId}/send/m.room.message/${randomString}`, data, config); + return okMsg; + } catch (error) { + this.throwGeneralAxiosError(error); + } + } +} + +module.exports = Matrix; |