mirror of
https://github.com/louislam/uptime-kuma.git
synced 2024-10-01 01:25:45 -04:00
a9a1cf1353
- I unified where in file the name of `NotificationProvider.name` is placed - I made sure that all the providers adhere to the signature of `NotificationProvider.send()` - I made sure that all the providers use `okMsg` if returning success messages directly from the function. Here a discussion should be had: Should this be refactored into a constant of `NotificationProvider`? I could imagine that `NotificationProvider.SENDING_SUCCESSFULL` could be a suitable alternative. - I made sure all providers have the URL they `POST`/`GET` to be extraced into a variable. => refactored this way due to Nelsons suggestion
38 lines
999 B
JavaScript
38 lines
999 B
JavaScript
const NotificationProvider = require("./notification-provider");
|
|
const childProcessAsync = require("promisify-child-process");
|
|
|
|
class Apprise extends NotificationProvider {
|
|
name = "apprise";
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
async send(notification, msg, monitorJSON = null, heartbeatJSON = null) {
|
|
const okMsg = "Sent Successfully.";
|
|
|
|
const args = [ "-vv", "-b", msg, notification.appriseURL ];
|
|
if (notification.title) {
|
|
args.push("-t");
|
|
args.push(notification.title);
|
|
}
|
|
const s = await childProcessAsync.spawn("apprise", args, {
|
|
encoding: "utf8",
|
|
});
|
|
|
|
const output = (s.stdout) ? s.stdout.toString() : "ERROR: maybe apprise not found";
|
|
|
|
if (output) {
|
|
|
|
if (! output.includes("ERROR")) {
|
|
return okMsg;
|
|
}
|
|
|
|
throw new Error(output);
|
|
} else {
|
|
return "No output from apprise";
|
|
}
|
|
}
|
|
}
|
|
|
|
module.exports = Apprise;
|