mirror of
https://github.com/louislam/uptime-kuma.git
synced 2024-12-18 20:24:36 -05:00
push notificationMessage to card header and add action button to dashboard
This commit is contained in:
parent
7756070c57
commit
5b87da94b3
@ -1,6 +1,7 @@
|
|||||||
const NotificationProvider = require("./notification-provider");
|
const NotificationProvider = require("./notification-provider");
|
||||||
const axios = require("axios");
|
const axios = require("axios");
|
||||||
const { DOWN, UP } = require("../../src/util");
|
const { setting } = require("../util-server");
|
||||||
|
const { DOWN, UP, getMonitorRelativeURL } = require("../../src/util");
|
||||||
|
|
||||||
class Teams extends NotificationProvider {
|
class Teams extends NotificationProvider {
|
||||||
name = "teams";
|
name = "teams";
|
||||||
@ -13,9 +14,9 @@ class Teams extends NotificationProvider {
|
|||||||
*/
|
*/
|
||||||
_statusMessageFactory = (status, monitorName) => {
|
_statusMessageFactory = (status, monitorName) => {
|
||||||
if (status === DOWN) {
|
if (status === DOWN) {
|
||||||
return `🔴 Application [${monitorName}] went down`;
|
return `🔴 [${monitorName}] went down`;
|
||||||
} else if (status === UP) {
|
} else if (status === UP) {
|
||||||
return `✅ Application [${monitorName}] is back online`;
|
return `✅ [${monitorName}] is back online`;
|
||||||
}
|
}
|
||||||
return "Notification";
|
return "Notification";
|
||||||
};
|
};
|
||||||
@ -35,27 +36,14 @@ class Teams extends NotificationProvider {
|
|||||||
return "emphasis";
|
return "emphasis";
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
|
||||||
* Format an URL in the markdown format
|
|
||||||
* @param {string} url An absolute URL
|
|
||||||
* @param {string} linkName Optional name of the link
|
|
||||||
* @returns {string} The URL formatted as markdown link
|
|
||||||
*/
|
|
||||||
_formatAsMarkdownLink = (url, linkName) => {
|
|
||||||
if (linkName) {
|
|
||||||
return `[${linkName}](${url})`;
|
|
||||||
} else {
|
|
||||||
return `[${url}](${url})`;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Generate payload for notification
|
* Generate payload for notification
|
||||||
* @param {object} args Method arguments
|
* @param {object} args Method arguments
|
||||||
* @param {const} args.status The status of the monitor
|
* @param {const} args.status The status of the monitor
|
||||||
* @param {string} args.monitorMessage Message to send
|
* @param {string} args.monitorMessage Message to send
|
||||||
* @param {string} args.monitorName Name of monitor affected
|
* @param {string} args.monitorName Name of the monitor affected
|
||||||
* @param {string} args.monitorUrl URL of monitor affected
|
* @param {string} args.monitorUrl URL of the monitor affected
|
||||||
|
* @param {string} args.dashboardUrl URL of the dashboard affected
|
||||||
* @returns {object} Notification payload
|
* @returns {object} Notification payload
|
||||||
*/
|
*/
|
||||||
_notificationPayloadFactory = ({
|
_notificationPayloadFactory = ({
|
||||||
@ -63,6 +51,7 @@ class Teams extends NotificationProvider {
|
|||||||
monitorMessage,
|
monitorMessage,
|
||||||
monitorName,
|
monitorName,
|
||||||
monitorUrl,
|
monitorUrl,
|
||||||
|
dashboardUrl,
|
||||||
}) => {
|
}) => {
|
||||||
const notificationMessage = this._statusMessageFactory(
|
const notificationMessage = this._statusMessageFactory(
|
||||||
status,
|
status,
|
||||||
@ -88,11 +77,14 @@ class Teams extends NotificationProvider {
|
|||||||
if (monitorUrl && monitorUrl !== "https://") {
|
if (monitorUrl && monitorUrl !== "https://") {
|
||||||
facts.push({
|
facts.push({
|
||||||
title: "URL",
|
title: "URL",
|
||||||
value: this._formatAsMarkdownLink(monitorUrl),
|
// format URL as markdown syntax, to be clickable
|
||||||
|
value: `[${monitorUrl}](${monitorUrl})`,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
return {
|
const headerMessage = `**${notificationMessage}**`;
|
||||||
|
|
||||||
|
const payload = {
|
||||||
"type": "message",
|
"type": "message",
|
||||||
"attachments": [
|
"attachments": [
|
||||||
{
|
{
|
||||||
@ -129,9 +121,17 @@ class Teams extends NotificationProvider {
|
|||||||
"items": [
|
"items": [
|
||||||
{
|
{
|
||||||
"type": "TextBlock",
|
"type": "TextBlock",
|
||||||
"size": "Large",
|
"size": "Medium",
|
||||||
"weight": "Bolder",
|
"weight": "Bolder",
|
||||||
"text": "**Uptime Kuma Alert**"
|
"text": headerMessage,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "TextBlock",
|
||||||
|
"size": "Small",
|
||||||
|
"weight": "Default",
|
||||||
|
"text": "Uptime Kuma Alert",
|
||||||
|
"isSubtle": true,
|
||||||
|
"spacing": "None"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
@ -139,15 +139,9 @@ class Teams extends NotificationProvider {
|
|||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"type": "TextBlock",
|
|
||||||
"weight": "Bolder",
|
|
||||||
"text": notificationMessage,
|
|
||||||
"separator": true,
|
|
||||||
"wrap": true
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"type": "FactSet",
|
"type": "FactSet",
|
||||||
|
"separator": true,
|
||||||
"facts": facts
|
"facts": facts
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
@ -157,6 +151,23 @@ class Teams extends NotificationProvider {
|
|||||||
}
|
}
|
||||||
]
|
]
|
||||||
};
|
};
|
||||||
|
|
||||||
|
if (dashboardUrl) {
|
||||||
|
payload.attachments.forEach(element => {
|
||||||
|
element.content.push({
|
||||||
|
"type": "ActionSet",
|
||||||
|
"actions": [
|
||||||
|
{
|
||||||
|
"type": "Action.OpenUrl",
|
||||||
|
"title": "Visit Uptime Kuma",
|
||||||
|
"url": dashboardUrl
|
||||||
|
}
|
||||||
|
]
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
return payload;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -195,26 +206,33 @@ class Teams extends NotificationProvider {
|
|||||||
return okMsg;
|
return okMsg;
|
||||||
}
|
}
|
||||||
|
|
||||||
let url;
|
let monitorUrl;
|
||||||
|
|
||||||
switch (monitorJSON["type"]) {
|
switch (monitorJSON["type"]) {
|
||||||
case "http":
|
case "http":
|
||||||
case "keywork":
|
case "keywork":
|
||||||
url = monitorJSON["url"];
|
monitorUrl = monitorJSON["url"];
|
||||||
break;
|
break;
|
||||||
case "docker":
|
case "docker":
|
||||||
url = monitorJSON["docker_host"];
|
monitorUrl = monitorJSON["docker_host"];
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
url = monitorJSON["hostname"];
|
monitorUrl = monitorJSON["hostname"];
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const baseURL = await setting("primaryBaseURL");
|
||||||
|
let dashboardUrl;
|
||||||
|
if (baseURL) {
|
||||||
|
dashboardUrl = baseURL + getMonitorRelativeURL(monitorJSON.id);
|
||||||
|
}
|
||||||
|
|
||||||
const payload = this._notificationPayloadFactory({
|
const payload = this._notificationPayloadFactory({
|
||||||
monitorMessage: heartbeatJSON.msg,
|
monitorMessage: heartbeatJSON.msg,
|
||||||
monitorName: monitorJSON.name,
|
monitorName: monitorJSON.name,
|
||||||
monitorUrl: url,
|
monitorUrl: monitorUrl,
|
||||||
status: heartbeatJSON.status,
|
status: heartbeatJSON.status,
|
||||||
|
dashboardUrl: dashboardUrl,
|
||||||
});
|
});
|
||||||
|
|
||||||
await this._sendNotification(notification.webhookUrl, payload);
|
await this._sendNotification(notification.webhookUrl, payload);
|
||||||
|
Loading…
Reference in New Issue
Block a user