mirror of
				https://github.com/louislam/uptime-kuma.git
				synced 2025-10-26 00:19:21 +08:00 
			
		
		
		
	feat: Add ServerChan Notification support
This commit is contained in:
		
							
								
								
									
										36
									
								
								server/notification-providers/serverchan.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								server/notification-providers/serverchan.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,36 @@ | |||||||
|  | const NotificationProvider = require("./notification-provider"); | ||||||
|  | const axios = require("axios"); | ||||||
|  | const { DOWN, UP } = require("../../src/util"); | ||||||
|  |  | ||||||
|  | class ServerChan extends NotificationProvider { | ||||||
|  |  | ||||||
|  |     name = "ServerChan"; | ||||||
|  |  | ||||||
|  |     async send(notification, msg, monitorJSON = null, heartbeatJSON = null) { | ||||||
|  |         let okMsg = "Sent Successfully."; | ||||||
|  |         try { | ||||||
|  |             await axios.post(`https://sctapi.ftqq.com/${notification.serverChanSendKey}.send`, { | ||||||
|  |                 "title": this.checkStatus(heartbeatJSON, monitorJSON), | ||||||
|  |                 "desp": msg, | ||||||
|  |             }); | ||||||
|  |  | ||||||
|  |             return okMsg; | ||||||
|  |  | ||||||
|  |         } catch (error) { | ||||||
|  |             this.throwGeneralAxiosError(error); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     checkStatus(heartbeatJSON, monitorJSON) { | ||||||
|  |         let title = "UptimeKuma Message"; | ||||||
|  |         if (heartbeatJSON != null && heartbeatJSON["status"] === UP) { | ||||||
|  |             title = "UptimeKuma Monitor Up " + monitorJSON["name"]; | ||||||
|  |         } | ||||||
|  |         if (heartbeatJSON != null && heartbeatJSON["status"] === DOWN) { | ||||||
|  |             title = "UptimeKuma Monitor Down " + monitorJSON["name"]; | ||||||
|  |         } | ||||||
|  |         return title; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | module.exports = ServerChan; | ||||||
| @@ -40,6 +40,7 @@ const Webhook = require("./notification-providers/webhook"); | |||||||
| const WeCom = require("./notification-providers/wecom"); | const WeCom = require("./notification-providers/wecom"); | ||||||
| const GoAlert = require("./notification-providers/goalert"); | const GoAlert = require("./notification-providers/goalert"); | ||||||
| const SMSManager = require("./notification-providers/smsmanager"); | const SMSManager = require("./notification-providers/smsmanager"); | ||||||
|  | const ServerChan = require("./notification-providers/serverchan"); | ||||||
|  |  | ||||||
| class Notification { | class Notification { | ||||||
|  |  | ||||||
| @@ -80,6 +81,7 @@ class Notification { | |||||||
|             new Pushover(), |             new Pushover(), | ||||||
|             new Pushy(), |             new Pushy(), | ||||||
|             new RocketChat(), |             new RocketChat(), | ||||||
|  |             new ServerChan(), | ||||||
|             new SerwerSMS(), |             new SerwerSMS(), | ||||||
|             new Signal(), |             new Signal(), | ||||||
|             new SMSManager(), |             new SMSManager(), | ||||||
|   | |||||||
							
								
								
									
										16
									
								
								src/components/notifications/ServerChan.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								src/components/notifications/ServerChan.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | <template> | ||||||
|  |     <div class="mb-3"> | ||||||
|  |         <label for="serverchan-sendkey" class="form-label">{{ $t("SendKey") }}</label> | ||||||
|  |         <HiddenInput id="serverchan-sendkey" v-model="$parent.notification.serverChanSendKey" :required="true" autocomplete="one-time-code"></HiddenInput> | ||||||
|  |     </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | import HiddenInput from "../HiddenInput.vue"; | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |     components: { | ||||||
|  |         HiddenInput, | ||||||
|  |     }, | ||||||
|  | }; | ||||||
|  | </script> | ||||||
| @@ -26,6 +26,7 @@ import PushDeer from "./PushDeer.vue"; | |||||||
| import Pushover from "./Pushover.vue"; | import Pushover from "./Pushover.vue"; | ||||||
| import Pushy from "./Pushy.vue"; | import Pushy from "./Pushy.vue"; | ||||||
| import RocketChat from "./RocketChat.vue"; | import RocketChat from "./RocketChat.vue"; | ||||||
|  | import ServerChan from "./ServerChan.vue"; | ||||||
| import SerwerSMS from "./SerwerSMS.vue"; | import SerwerSMS from "./SerwerSMS.vue"; | ||||||
| import Signal from "./Signal.vue"; | import Signal from "./Signal.vue"; | ||||||
| import SMSManager from "./SMSManager.vue"; | import SMSManager from "./SMSManager.vue"; | ||||||
| @@ -85,6 +86,7 @@ const NotificationFormList = { | |||||||
|     "webhook": Webhook, |     "webhook": Webhook, | ||||||
|     "WeCom": WeCom, |     "WeCom": WeCom, | ||||||
|     "GoAlert": GoAlert, |     "GoAlert": GoAlert, | ||||||
|  |     "ServerChan": ServerChan, | ||||||
| }; | }; | ||||||
|  |  | ||||||
| export default NotificationFormList; | export default NotificationFormList; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user