mirror of
				https://github.com/louislam/uptime-kuma.git
				synced 2025-10-26 16:49:20 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			124 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			124 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| //
 | |
| //  bark.js
 | |
| //  UptimeKuma
 | |
| //
 | |
| //  Created by Lakr Aream on 2021/10/24.
 | |
| //  Copyright © 2021 Lakr Aream. All rights reserved.
 | |
| //
 | |
| 
 | |
| const NotificationProvider = require("./notification-provider");
 | |
| const { DOWN, UP } = require("../../src/util");
 | |
| const { default: axios } = require("axios");
 | |
| 
 | |
| // bark is an APN bridge that sends notifications to Apple devices.
 | |
| 
 | |
| const barkNotificationAvatar = "https://github.com/louislam/uptime-kuma/raw/master/public/icon.png";
 | |
| const successMessage = "Successes!";
 | |
| 
 | |
| class Bark extends NotificationProvider {
 | |
|     name = "Bark";
 | |
| 
 | |
|     /**
 | |
|      * @inheritdoc
 | |
|      */
 | |
|     async send(notification, msg, monitorJSON = null, heartbeatJSON = null) {
 | |
|         let barkEndpoint = notification.barkEndpoint;
 | |
| 
 | |
|         // check if the endpoint has a "/" suffix, if so, delete it first
 | |
|         if (barkEndpoint.endsWith("/")) {
 | |
|             barkEndpoint = barkEndpoint.substring(0, barkEndpoint.length - 1);
 | |
|         }
 | |
| 
 | |
|         if (msg != null && heartbeatJSON != null && heartbeatJSON["status"] === UP) {
 | |
|             let title = "UptimeKuma Monitor Up";
 | |
|             return await this.postNotification(notification, title, msg, barkEndpoint);
 | |
|         }
 | |
| 
 | |
|         if (msg != null && heartbeatJSON != null && heartbeatJSON["status"] === DOWN) {
 | |
|             let title = "UptimeKuma Monitor Down";
 | |
|             return await this.postNotification(notification, title, msg, barkEndpoint);
 | |
|         }
 | |
| 
 | |
|         if (msg != null) {
 | |
|             let title = "UptimeKuma Message";
 | |
|             return await this.postNotification(notification, title, msg, barkEndpoint);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Add additional parameter for Bark v1 endpoints.
 | |
|      * Leads to better on device styles (iOS 15 optimized)
 | |
|      * @param {BeanModel} notification Notification to send
 | |
|      * @returns {string} Additional URL parameters
 | |
|      */
 | |
|     additionalParameters(notification) {
 | |
|         // set icon to uptime kuma icon, 11kb should be fine
 | |
|         let params = "?icon=" + barkNotificationAvatar;
 | |
|         // grouping all our notifications
 | |
|         if (notification.barkGroup != null) {
 | |
|             params += "&group=" + notification.barkGroup;
 | |
|         } else {
 | |
|             // default name
 | |
|             params += "&group=" + "UptimeKuma";
 | |
|         }
 | |
|         // picked a sound, this should follow system's mute status when arrival
 | |
|         if (notification.barkSound != null) {
 | |
|             params += "&sound=" + notification.barkSound;
 | |
|         } else {
 | |
|             // default sound
 | |
|             params += "&sound=" + "telegraph";
 | |
|         }
 | |
|         return params;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Check if result is successful
 | |
|      * @param {object} result Axios response object
 | |
|      * @returns {void}
 | |
|      * @throws {Error} The status code is not in range 2xx
 | |
|      */
 | |
|     checkResult(result) {
 | |
|         if (result.status == null) {
 | |
|             throw new Error("Bark notification failed with invalid response!");
 | |
|         }
 | |
|         if (result.status < 200 || result.status >= 300) {
 | |
|             throw new Error("Bark notification failed with status code " + result.status);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Send the message
 | |
|      * @param {BeanModel} notification Notification to send
 | |
|      * @param {string} title Message title
 | |
|      * @param {string} subtitle Message
 | |
|      * @param {string} endpoint Endpoint to send request to
 | |
|      * @returns {Promise<string>} Success message
 | |
|      */
 | |
|     async postNotification(notification, title, subtitle, endpoint) {
 | |
|         let result;
 | |
|         if (notification.apiVersion === "v1" || notification.apiVersion == null) {
 | |
|             // url encode title and subtitle
 | |
|             title = encodeURIComponent(title);
 | |
|             subtitle = encodeURIComponent(subtitle);
 | |
|             const params = this.additionalParameters(notification);
 | |
|             result = await axios.get(`${endpoint}/${title}/${subtitle}${params}`);
 | |
|         } else {
 | |
|             result = await axios.post(`${endpoint}/push`, {
 | |
|                 title,
 | |
|                 body: subtitle,
 | |
|                 icon: barkNotificationAvatar,
 | |
|                 sound: notification.barkSound || "telegraph", // default sound is telegraph
 | |
|                 group: notification.barkGroup || "UptimeKuma", // default group is UptimeKuma
 | |
|             });
 | |
|         }
 | |
|         this.checkResult(result);
 | |
|         if (result.statusText != null) {
 | |
|             return "Bark notification succeed: " + result.statusText;
 | |
|         }
 | |
|         // because returned in range 200 ..< 300
 | |
|         return successMessage;
 | |
|     }
 | |
| }
 | |
| 
 | |
| module.exports = Bark;
 |