summaryrefslogtreecommitdiffstats
path: root/server/notification-providers/webhook.js
diff options
context:
space:
mode:
authorDaniel Baumann <daniel@debian.org>2024-11-26 09:28:28 +0100
committerDaniel Baumann <daniel@debian.org>2024-11-26 12:25:58 +0100
commita1882b67c41fe9901a0cd8059b5cc78a5beadec0 (patch)
tree2a24507c67aa99a15416707b2f7e645142230ed8 /server/notification-providers/webhook.js
parentInitial commit. (diff)
downloaduptime-kuma-upstream.tar.xz
uptime-kuma-upstream.zip
Adding upstream version 2.0.0~beta.0+dfsg.upstream/2.0.0_beta.0+dfsgupstream
Signed-off-by: Daniel Baumann <daniel@debian.org>
Diffstat (limited to 'server/notification-providers/webhook.js')
-rw-r--r--server/notification-providers/webhook.js66
1 files changed, 66 insertions, 0 deletions
diff --git a/server/notification-providers/webhook.js b/server/notification-providers/webhook.js
new file mode 100644
index 0000000..986986d
--- /dev/null
+++ b/server/notification-providers/webhook.js
@@ -0,0 +1,66 @@
+const NotificationProvider = require("./notification-provider");
+const axios = require("axios");
+const FormData = require("form-data");
+const { Liquid } = require("liquidjs");
+
+class Webhook extends NotificationProvider {
+ name = "webhook";
+
+ /**
+ * @inheritdoc
+ */
+ async send(notification, msg, monitorJSON = null, heartbeatJSON = null) {
+ const okMsg = "Sent Successfully.";
+
+ try {
+ let data = {
+ heartbeat: heartbeatJSON,
+ monitor: monitorJSON,
+ msg,
+ };
+ let config = {
+ headers: {}
+ };
+
+ if (notification.webhookContentType === "form-data") {
+ const formData = new FormData();
+ formData.append("data", JSON.stringify(data));
+ config.headers = formData.getHeaders();
+ data = formData;
+ } else if (notification.webhookContentType === "custom") {
+ // Initialize LiquidJS and parse the custom Body Template
+ const engine = new Liquid();
+ const tpl = engine.parse(notification.webhookCustomBody);
+
+ // Insert templated values into Body
+ data = await engine.render(tpl,
+ {
+ msg,
+ heartbeatJSON,
+ monitorJSON
+ });
+ }
+
+ if (notification.webhookAdditionalHeaders) {
+ try {
+ config.headers = {
+ ...config.headers,
+ ...JSON.parse(notification.webhookAdditionalHeaders)
+ };
+ } catch (err) {
+ throw "Additional Headers is not a valid JSON";
+ }
+ }
+
+ await axios.post(notification.webhookURL, data, config);
+ return okMsg;
+
+ } catch (error) {
+ this.throwGeneralAxiosError(error);
+ }
+
+ }
+
+}
+
+module.exports = Webhook;