summaryrefslogtreecommitdiffstats
path: root/server/notification-providers/matrix.js
diff options
context:
space:
mode:
Diffstat (limited to 'server/notification-providers/matrix.js')
-rw-r--r--server/notification-providers/matrix.js48
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;