Skip to content

Commit

Permalink
made sure that the address extraction is extracted into its own method
Browse files Browse the repository at this point in the history
  • Loading branch information
CommanderStorm authored Jun 13, 2024
1 parent bd95ccd commit c9132ad
Show file tree
Hide file tree
Showing 7 changed files with 37 additions and 103 deletions.
22 changes: 1 addition & 21 deletions server/notification-providers/discord.js
Original file line number Diff line number Diff line change
Expand Up @@ -33,26 +33,6 @@ class Discord extends NotificationProvider {
return okMsg;
}

let address;

switch (monitorJSON["type"]) {
case "ping":
address = monitorJSON["hostname"];
break;
case "port":
case "dns":
case "gamedig":
case "steam":
address = monitorJSON["hostname"];
if (monitorJSON["port"]) {
address += ":" + monitorJSON["port"];
}
break;
default:
address = monitorJSON["url"];
break;
}

// If heartbeatJSON is not null, we go into the normal alerting loop.
if (heartbeatJSON["status"] === DOWN) {
let discorddowndata = {
Expand Down Expand Up @@ -105,7 +85,7 @@ class Discord extends NotificationProvider {
},
{
name: monitorJSON["type"] === "push" ? "Service Type" : "Service URL",
value: monitorJSON["type"] === "push" ? "Heartbeat" : address,
value: this.extractAdress(monitorJSON),
},
{
name: `Time (${heartbeatJSON["timezone"]})`,
Expand Down
31 changes: 31 additions & 0 deletions server/notification-providers/notification-provider.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,37 @@ class NotificationProvider {
throw new Error("Have to override Notification.send(...)");
}

/**
* Extracts the address from a monitor JSON object based on its type.
*
* @param {?object} monitorJSON Monitor details (For Up/Down only)
* @returns {string} The extracted address based on the monitor type.
*/
extractAdress(monitorJSON){
if (!monitorJSON) {
return ""
}
switch (monitorJSON["type"]) {
case "push":
return "Heartbeat";
case "ping":
return monitorJSON["hostname"];
case "port":
case "dns":
case "gamedig":
case "steam":
if (monitorJSON["port"]) {
return monitorJSON["hostname"] + ":" + monitorJSON["port"];
}
return monitorJSON["hostname"]
default:
if (![ "https://", "http://", "" ].includes(monitorJSON["url"])) {
return monitorJSON["url"];
}
return "";
}
}

/**
* Throws an error
* @param {any} error The error to throw
Expand Down
23 changes: 1 addition & 22 deletions server/notification-providers/sevenio.js
Original file line number Diff line number Diff line change
Expand Up @@ -32,28 +32,7 @@ class SevenIO extends NotificationProvider {
return okMsg;
}

let address = "";

switch (monitorJSON["type"]) {
case "ping":
address = monitorJSON["hostname"];
break;
case "port":
case "dns":
case "gamedig":
case "steam":
address = monitorJSON["hostname"];
if (monitorJSON["port"]) {
address += ":" + monitorJSON["port"];
}
break;
default:
if (![ "https://", "http://", "" ].includes(monitorJSON["url"])) {
address = monitorJSON["url"];
}
break;
}

let address = extractAdress(monitorJSON);
if (address !== "") {
address = `(${address}) `;
}
Expand Down
7 changes: 1 addition & 6 deletions server/notification-providers/smtp.js
Original file line number Diff line number Diff line change
Expand Up @@ -93,12 +93,7 @@ class SMTP extends NotificationProvider {

if (monitorJSON !== null) {
monitorName = monitorJSON["name"];

if (monitorJSON["type"] === "http" || monitorJSON["type"] === "keyword" || monitorJSON["type"] === "json-query") {
monitorHostnameOrURL = monitorJSON["url"];
} else {
monitorHostnameOrURL = monitorJSON["hostname"];
}
monitorHostnameOrURL = this.extractAdress(monitorJSON);
}

let serviceStatus = "⚠️ Test";
Expand Down
20 changes: 1 addition & 19 deletions server/notification-providers/squadcast.js
Original file line number Diff line number Diff line change
Expand Up @@ -34,25 +34,7 @@ class Squadcast extends NotificationProvider {
data.status = "resolve";
}

let address;
switch (monitorJSON["type"]) {
case "ping":
address = monitorJSON["hostname"];
break;
case "port":
case "dns":
case "steam":
address = monitorJSON["hostname"];
if (monitorJSON["port"]) {
address += ":" + monitorJSON["port"];
}
break;
default:
address = monitorJSON["url"];
break;
}

data.tags["AlertAddress"] = address;
data.tags["AlertAddress"] = this.extractAdress(monitorJSON);

monitorJSON["tags"].forEach(tag => {
data.tags[tag["name"]] = {
Expand Down
17 changes: 1 addition & 16 deletions server/notification-providers/teams.js
Original file line number Diff line number Diff line change
Expand Up @@ -216,21 +216,6 @@ class Teams extends NotificationProvider {
return okMsg;
}

let monitorUrl;

switch (monitorJSON["type"]) {
case "http":
case "keywork":
monitorUrl = monitorJSON["url"];
break;
case "docker":
monitorUrl = monitorJSON["docker_host"];
break;
default:
monitorUrl = monitorJSON["hostname"];
break;
}

const baseURL = await setting("primaryBaseURL");
let dashboardUrl;
if (baseURL) {
Expand All @@ -240,7 +225,7 @@ class Teams extends NotificationProvider {
const payload = this._notificationPayloadFactory({
heartbeatJSON: heartbeatJSON,
monitorName: monitorJSON.name,
monitorUrl: monitorUrl,
monitorUrl: this.extractAdress(monitorJSON),
dashboardUrl: dashboardUrl,
});

Expand Down
20 changes: 1 addition & 19 deletions server/notification-providers/zoho-cliq.js
Original file line number Diff line number Diff line change
Expand Up @@ -82,25 +82,7 @@ class ZohoCliq extends NotificationProvider {
return okMsg;
}

let address;

switch (monitorJSON["type"]) {
case "ping":
address = monitorJSON["hostname"];
break;
case "port":
case "dns":
case "gamedig":
case "steam":
address = monitorJSON["hostname"];
if (monitorJSON["port"]) {
address += ":" + monitorJSON["port"];
}
break;
default:
address = monitorJSON["url"];
break;
}


const payload = this._notificationPayloadFactory({
monitorMessage: heartbeatJSON.msg,
Expand Down

0 comments on commit c9132ad

Please sign in to comment.