|
|
@ -1,8 +1,7 @@
|
|
|
|
const NotificationProvider = require("./notification-provider");
|
|
|
|
const NotificationProvider = require("./notification-provider");
|
|
|
|
const axios = require("axios");
|
|
|
|
const axios = require("axios");
|
|
|
|
const { setting } = require("../util-server");
|
|
|
|
const { setting } = require("../util-server");
|
|
|
|
const { getMonitorRelativeURL } = require("../../src/util");
|
|
|
|
const { getMonitorRelativeURL, UP } = require("../../src/util");
|
|
|
|
const { DOWN, UP } = require("../../src/util");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class GoogleChat extends NotificationProvider {
|
|
|
|
class GoogleChat extends NotificationProvider {
|
|
|
|
name = "GoogleChat";
|
|
|
|
name = "GoogleChat";
|
|
|
@ -16,26 +15,71 @@ class GoogleChat extends NotificationProvider {
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
// Google Chat message formatting: https://developers.google.com/chat/api/guides/message-formats/basic
|
|
|
|
// Google Chat message formatting: https://developers.google.com/chat/api/guides/message-formats/basic
|
|
|
|
|
|
|
|
|
|
|
|
let textMsg = "";
|
|
|
|
let chatHeader = {
|
|
|
|
if (heartbeatJSON && heartbeatJSON.status === UP) {
|
|
|
|
title: "Uptime Kuma Alert",
|
|
|
|
textMsg = "✅ Application is back online\n";
|
|
|
|
};
|
|
|
|
} else if (heartbeatJSON && heartbeatJSON.status === DOWN) {
|
|
|
|
|
|
|
|
textMsg = "🔴 Application went down\n";
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (monitorJSON && monitorJSON.name) {
|
|
|
|
if (monitorJSON && heartbeatJSON) {
|
|
|
|
textMsg += `*${monitorJSON.name}*\n`;
|
|
|
|
chatHeader["title"] =
|
|
|
|
|
|
|
|
heartbeatJSON["status"] === UP
|
|
|
|
|
|
|
|
? `✅ ${monitorJSON["name"]} is back online`
|
|
|
|
|
|
|
|
: `🔴 ${monitorJSON["name"]} went down`;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
textMsg += `${msg}`;
|
|
|
|
// always show msg
|
|
|
|
|
|
|
|
let sectionWidgets = [
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
textParagraph: {
|
|
|
|
|
|
|
|
text: `<b>Message:</b>\n${msg}`,
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// add time if available
|
|
|
|
|
|
|
|
if (heartbeatJSON) {
|
|
|
|
|
|
|
|
sectionWidgets.push({
|
|
|
|
|
|
|
|
textParagraph: {
|
|
|
|
|
|
|
|
text: `<b>Time (${heartbeatJSON["timezone"]}):</b>\n${heartbeatJSON["localDateTime"]}`,
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// add button for monitor link if available
|
|
|
|
const baseURL = await setting("primaryBaseURL");
|
|
|
|
const baseURL = await setting("primaryBaseURL");
|
|
|
|
if (baseURL && monitorJSON) {
|
|
|
|
if (baseURL) {
|
|
|
|
textMsg += `\n${baseURL + getMonitorRelativeURL(monitorJSON.id)}`;
|
|
|
|
const urlPath = monitorJSON ? getMonitorRelativeURL(monitorJSON.id) : "/";
|
|
|
|
|
|
|
|
sectionWidgets.push({
|
|
|
|
|
|
|
|
buttonList: {
|
|
|
|
|
|
|
|
buttons: [
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
text: "Visit Uptime Kuma",
|
|
|
|
|
|
|
|
onClick: {
|
|
|
|
|
|
|
|
openLink: {
|
|
|
|
|
|
|
|
url: baseURL + urlPath,
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
],
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
const data = {
|
|
|
|
let chatSections = [
|
|
|
|
"text": textMsg,
|
|
|
|
{
|
|
|
|
|
|
|
|
widgets: sectionWidgets,
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// construct json data
|
|
|
|
|
|
|
|
let data = {
|
|
|
|
|
|
|
|
cardsV2: [
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
card: {
|
|
|
|
|
|
|
|
header: chatHeader,
|
|
|
|
|
|
|
|
sections: chatSections,
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
],
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
await axios.post(notification.googleChatWebhookURL, data);
|
|
|
|
await axios.post(notification.googleChatWebhookURL, data);
|
|
|
|