Browse Source

Format touched files with eslint

deefdragon/Template-Engine
Jeffrey Koehler 3 years ago
parent
commit
3b15a1a7a1
  1. 106
      server/notification.js
  2. 2
      server/server.js
  3. 25
      src/components/NotificationDialog.vue

106
server/notification.js

@ -1,5 +1,5 @@
const { R } = require("redbean-node"); const { R } = require("redbean-node");
const { Liquid } = require( 'liquidjs'); const { Liquid } = require( "liquidjs");
const { UP } = require("../src/util"); const { UP } = require("../src/util");
const dayjs = require("dayjs"); const dayjs = require("dayjs");
@ -28,9 +28,8 @@ const Feishu = require("./notification-providers/feishu");
const AliyunSms = require("./notification-providers/aliyun-sms"); const AliyunSms = require("./notification-providers/aliyun-sms");
const DingDing = require("./notification-providers/dingding"); const DingDing = require("./notification-providers/dingding");
const MinimalDetailTemplate = "{{monitor.name}}: {{monitor.health}}";
const MinimalDetailTemplate = "{{monitor.name}}: {{monitor.health}}" const LowDetailTemplate = "[{{monitor.name}}] [{{monitor.health}}] {{heartbeat.msg}}";
const LowDetailTemplate = "[{{monitor.name}}] [{{monitor.health}}] {{heartbeat.msg}}"
const MediumDetailTemplate = `Monitor: {{monitor.name}} const MediumDetailTemplate = `Monitor: {{monitor.name}}
Health: {{monitor.health}} Health: {{monitor.health}}
Address: {{monitor.url}} Address: {{monitor.url}}
@ -45,7 +44,7 @@ Address: {{monitor.url}}
Your {{monitor.type}} monitor is unexpectedly down. Your {{monitor.type}} monitor is unexpectedly down.
{%- endif %} {%- endif %}
Time: {{heartbeat.time}} Time: {{heartbeat.time}}
Uptime Message: {{heartbeat.msg}}` Uptime Message: {{heartbeat.msg}}`;
const FullDetailTemplate = `Monitor: {{monitor.name}} const FullDetailTemplate = `Monitor: {{monitor.name}}
Health: {{monitor.health}} Health: {{monitor.health}}
@ -70,11 +69,11 @@ Tags
{%- if tag.value and tag.value != "" -%} {%- if tag.value and tag.value != "" -%}
: {{tag.value}} : {{tag.value}}
{%- endif %} {%- endif %}
{% endfor -%}` {% endfor -%}`;
class Notification { class Notification {
static generateTestHeartbeat(){ static generateTestHeartbeat() {
return { return {
monitorID: 5, monitorID: 5,
status: 1, status: 1,
@ -85,7 +84,8 @@ class Notification {
duration: 8, duration: 8,
}; };
} }
static generateTestMonitor(){
static generateTestMonitor() {
return { return {
id: 5, id: 5,
name: "Test Notification Monitor", name: "Test Notification Monitor",
@ -110,10 +110,17 @@ class Notification {
dns_resolve_server: "1.1.1.1", dns_resolve_server: "1.1.1.1",
dns_last_result: null, dns_last_result: null,
pushToken: null, pushToken: null,
notificationIDList:{"1":true,"5":true}, notificationIDList: { "1": true,
tags: [{"id":21,"monitor_id":16,"tag_id":2,"value":"","name":"Internal","color":"#059669"}], "5": true },
tags: [{ "id": 21,
"monitor_id": 16,
"tag_id": 2,
"value": "",
"name": "Internal",
"color": "#059669" }],
}; };
} }
providerList = {}; providerList = {};
static init() { static init() {
@ -158,7 +165,6 @@ class Notification {
} }
} }
/** /**
* *
* @param notification : BeanModel * @param notification : BeanModel
@ -170,74 +176,76 @@ class Notification {
*/ */
static async send(notification, msg, monitorJSON, heartbeatJSON) { static async send(notification, msg, monitorJSON, heartbeatJSON) {
if (this.providerList[notification.type]) { if (this.providerList[notification.type]) {
try {
monitorJSON.health = ((heartbeatJSON.status == 1) !== monitorJSON.upsideDown) ? "✅ Healthy": "❌ Unhealthy"
let parseData = {
// I actually dont think that it is necessary to put the notification in the data sent to the template.
// notification: notification,
monitor: monitorJSON,
heartbeat: heartbeatJSON,
}
let template = this.getTemplateFromNotification(notification)
console.log(`Template: (${template})`)
let message = await engine.parseAndRender(template, parseData)
return this.providerList[notification.type].send(notification, message, monitorJSON, heartbeatJSON); monitorJSON.health = ((heartbeatJSON.status == 1) !== monitorJSON.upsideDown) ? "✅ Healthy" : "❌ Unhealthy";
} catch (e) {
throw e let parseData = {
} // I actually dont think that it is necessary to put the notification in the data sent to the template.
// notification: notification,
monitor: monitorJSON,
heartbeat: heartbeatJSON,
};
let template = this.getTemplateFromNotification(notification);
console.log(`Template: (${template})`);
let message = await engine.parseAndRender(template, parseData);
return this.providerList[notification.type].send(notification, message, monitorJSON, heartbeatJSON);
//Removed try-catch here. I am not sure what the default should be in the case of a broken template.
//switch to manually building the message?
//the problem is that it would still need to send a message after the template fails of if it failed to send completely..
//im not sure if that is the desired result on a template fail.
} else { } else {
throw new Error("Notification type is not supported"); throw new Error("Notification type is not supported");
} }
} }
static getTemplateFromNotification(notification){ static getTemplateFromNotification(notification) {
let template = notification.template let template = notification.template;
let detail = notification.detail let detail = notification.detail;
console.log(`Detail: (${detail}) Template: (${template})`) console.log(`Detail: (${detail}) Template: (${template})`);
switch (detail) { switch (detail) {
case "Minimal Detail": case "Minimal Detail":
return MinimalDetailTemplate return MinimalDetailTemplate;
case "Low Detail": case "Low Detail":
return LowDetailTemplate return LowDetailTemplate;
case "Medium Detail": case "Medium Detail":
return MediumDetailTemplate return MediumDetailTemplate;
case "Full Detail": case "Full Detail":
return FullDetailTemplate return FullDetailTemplate;
case "Custom Template": case "Custom Template":
if (template) { if (template) {
return template return template;
} }
//returns low in the case of a template being empty string or undefined. //returns low in the case of a template being empty string or undefined.
} }
return LowDetailTemplate return LowDetailTemplate;
} }
static async save(notification, notificationID, userID) { static async save(notification, notificationID, userID) {
let bean let bean;
if (notificationID) { if (notificationID) {
bean = await R.findOne("notification", " id = ? AND user_id = ? ", [ bean = await R.findOne("notification", " id = ? AND user_id = ? ", [
notificationID, notificationID,
userID, userID,
]) ]);
if (! bean) { if (! bean) {
throw new Error("notification not found") throw new Error("notification not found");
} }
} else { } else {
bean = R.dispense("notification") bean = R.dispense("notification");
} }
bean.name = notification.name; bean.name = notification.name;
bean.user_id = userID; bean.user_id = userID;
bean.config = JSON.stringify(notification); bean.config = JSON.stringify(notification);
bean.is_default = notification.isDefault || false; bean.is_default = notification.isDefault || false;
await R.store(bean) await R.store(bean);
if (notification.applyExisting) { if (notification.applyExisting) {
await applyNotificationEveryMonitor(bean.id, userID); await applyNotificationEveryMonitor(bean.id, userID);
@ -250,13 +258,13 @@ class Notification {
let bean = await R.findOne("notification", " id = ? AND user_id = ? ", [ let bean = await R.findOne("notification", " id = ? AND user_id = ? ", [
notificationID, notificationID,
userID, userID,
]) ]);
if (! bean) { if (! bean) {
throw new Error("notification not found") throw new Error("notification not found");
} }
await R.trash(bean) await R.trash(bean);
} }
static checkApprise() { static checkApprise() {
@ -276,17 +284,17 @@ async function applyNotificationEveryMonitor(notificationID, userID) {
let checkNotification = await R.findOne("monitor_notification", " monitor_id = ? AND notification_id = ? ", [ let checkNotification = await R.findOne("monitor_notification", " monitor_id = ? AND notification_id = ? ", [
monitors[i].id, monitors[i].id,
notificationID, notificationID,
]) ]);
if (! checkNotification) { if (! checkNotification) {
let relation = R.dispense("monitor_notification"); let relation = R.dispense("monitor_notification");
relation.monitor_id = monitors[i].id; relation.monitor_id = monitors[i].id;
relation.notification_id = notificationID; relation.notification_id = notificationID;
await R.store(relation) await R.store(relation);
} }
} }
} }
module.exports = { module.exports = {
Notification, Notification,
} };

2
server/server.js

@ -971,7 +971,7 @@ exports.entryPage = "dashboard";
checkLogin(socket); checkLogin(socket);
let notificationText = `[Monitor Name] [Up/Down] Status Message (${notification.name} Testing)`; let notificationText = `[Monitor Name] [Up/Down] Status Message (${notification.name} Testing)`;
let msg = await Notification.send(notification, notificationText, Notification.generateTestMonitor(),Notification.generateTestHeartbeat()); let msg = await Notification.send(notification, notificationText, Notification.generateTestMonitor(), Notification.generateTestHeartbeat());
callback({ callback({
ok: true, ok: true,

25
src/components/NotificationDialog.vue

@ -22,7 +22,7 @@
<input id="notification-name" v-model="notification.name" type="text" class="form-control" required> <input id="notification-name" v-model="notification.name" type="text" class="form-control" required>
</div> </div>
<div class="mb-3" v-show="enableTemplateOptions" > <div v-show="enableTemplateOptions" class="mb-3">
<label for="notification-detail" class="form-label">{{ $t("Notification Message Detail") }}</label> <label for="notification-detail" class="form-label">{{ $t("Notification Message Detail") }}</label>
<select id="notification-detail" v-model="notification.detail" class="form-select"> <select id="notification-detail" v-model="notification.detail" class="form-select">
<option v-for="detail in detailLevels" :key="detail" :value="detail">{{ $t(detail) }}</option> <option v-for="detail in detailLevels" :key="detail" :value="detail">{{ $t(detail) }}</option>
@ -30,12 +30,12 @@
</div> </div>
<!-- using show so that if the user toggels to a different template level, they dont loose what is in the field. --> <!-- using show so that if the user toggels to a different template level, they dont loose what is in the field. -->
<div class="mb-3" v-show="notification.detail === 'Custom Template' && enableTemplateOptions"> <div v-show="notification.detail === 'Custom Template' && enableTemplateOptions" class="mb-3">
<label for="notification-text" class="form-label">{{ $t("Custom Message Template") }}</label> <label for="notification-text" class="form-label">{{ $t("Custom Message Template") }}</label>
<textarea id="notification-text" v-model="notification.template" type="text" class="form-control" ></textarea> <textarea id="notification-text" v-model="notification.template" type="text" class="form-control"></textarea>
<div v-pre class="form-text"> <div v-pre class="form-text">
Uses Liquid templates Via LiquidJS.<br/> Uses Liquid templates Via LiquidJS.<br />
See <a href="https://github.com/louislam/uptime-kuma/wiki">the Uptime Kuma Wiki</a> for full detauls.<br/> See <a href="https://github.com/louislam/uptime-kuma/wiki">the Uptime Kuma Wiki</a> for full detauls.<br />
</div> </div>
</div> </div>
@ -89,10 +89,9 @@ import { Modal } from "bootstrap";
import { ucfirst } from "../util.ts"; import { ucfirst } from "../util.ts";
import Confirm from "./Confirm.vue"; import Confirm from "./Confirm.vue";
import {NotificationFormList, NotificationDetailList, TemplateEnabledList} from "./notifications"; import { NotificationFormList, NotificationDetailList, TemplateEnabledList } from "./notifications";
// import from "./notifications"; // import from "./notifications";
export default { export default {
components: { components: {
Confirm, Confirm,
@ -113,7 +112,7 @@ export default {
// Do not set default value here, please scroll to show() // Do not set default value here, please scroll to show()
}, },
detailLevels: NotificationDetailList, detailLevels: NotificationDetailList,
}; };
}, },
@ -124,8 +123,8 @@ export default {
} }
return NotificationFormList[this.notification.type]; return NotificationFormList[this.notification.type];
}, },
enableTemplateOptions(){ enableTemplateOptions() {
return (TemplateEnabledList.includes(this.notification.type)) return (TemplateEnabledList.includes(this.notification.type));
} }
}, },
@ -142,8 +141,8 @@ export default {
this.notification.name = this.getUniqueDefaultName(to); this.notification.name = this.getUniqueDefaultName(to);
} }
}, },
"notification.detail"(to,from){ "notification.detail"(to, from) {
this.notification.detail = to this.notification.detail = to;
} }
}, },
mounted() { mounted() {
@ -177,7 +176,7 @@ export default {
// Set Default value here // Set Default value here
this.notification.type = this.notificationTypes[0]; this.notification.type = this.notificationTypes[0];
this.notification.detail = this.detailLevels[1]; this.notification.detail = this.detailLevels[1];
this.notification.template = "[{{monitor.name}}] [{{monitor.health}}] {{monitor.msg}}" this.notification.template = "[{{monitor.name}}] [{{monitor.health}}] {{monitor.msg}}";
} }

Loading…
Cancel
Save