mirror of
				https://github.com/louislam/uptime-kuma.git
				synced 2025-10-25 15:59:20 +08:00 
			
		
		
		
	Merge branch 'master' into alerta
# Conflicts: # server/notification.js # src/components/notifications/index.js # src/languages/en.js
This commit is contained in:
		
							
								
								
									
										42
									
								
								server/notification-providers/gorush.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								server/notification-providers/gorush.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,42 @@ | |||||||
|  | const NotificationProvider = require("./notification-provider"); | ||||||
|  | const axios = require("axios"); | ||||||
|  |  | ||||||
|  | class Gorush extends NotificationProvider { | ||||||
|  |  | ||||||
|  |     name = "gorush"; | ||||||
|  |  | ||||||
|  |     async send(notification, msg, monitorJSON = null, heartbeatJSON = null) { | ||||||
|  |         let okMsg = "Sent Successfully."; | ||||||
|  |  | ||||||
|  |         let platformMapping = { | ||||||
|  |             "ios": 1, | ||||||
|  |             "android": 2, | ||||||
|  |             "huawei": 3, | ||||||
|  |         }; | ||||||
|  |  | ||||||
|  |         try { | ||||||
|  |             let data = { | ||||||
|  |                 "notifications": [ | ||||||
|  |                     { | ||||||
|  |                         "tokens": [notification.gorushDeviceToken], | ||||||
|  |                         "platform": platformMapping[notification.gorushPlatform], | ||||||
|  |                         "message": msg, | ||||||
|  |                         // Optional | ||||||
|  |                         "title": notification.gorushTitle, | ||||||
|  |                         "priority": notification.gorushPriority, | ||||||
|  |                         "retry": parseInt(notification.gorushRetry) || 0, | ||||||
|  |                         "topic": notification.gorushTopic, | ||||||
|  |                     } | ||||||
|  |                 ] | ||||||
|  |             }; | ||||||
|  |             let config = {}; | ||||||
|  |  | ||||||
|  |             await axios.post(`${notification.gorushServerURL}/api/push`, data, config); | ||||||
|  |             return okMsg; | ||||||
|  |         } catch (error) { | ||||||
|  |             this.throwGeneralAxiosError(error); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | module.exports = Gorush; | ||||||
| @@ -27,6 +27,7 @@ const SerwerSMS = require("./notification-providers/serwersms"); | |||||||
| const Stackfield = require("./notification-providers/stackfield"); | const Stackfield = require("./notification-providers/stackfield"); | ||||||
| const WeCom = require("./notification-providers/wecom"); | const WeCom = require("./notification-providers/wecom"); | ||||||
| const GoogleChat = require("./notification-providers/google-chat"); | const GoogleChat = require("./notification-providers/google-chat"); | ||||||
|  | const Gorush = require("./notification-providers/gorush"); | ||||||
| const Alerta = require("./notification-providers/alerta"); | const Alerta = require("./notification-providers/alerta"); | ||||||
|  |  | ||||||
| class Notification { | class Notification { | ||||||
| @@ -67,6 +68,7 @@ class Notification { | |||||||
|             new Stackfield(), |             new Stackfield(), | ||||||
|             new WeCom(), |             new WeCom(), | ||||||
|             new GoogleChat(), |             new GoogleChat(), | ||||||
|  |             new Gorush(), | ||||||
|             new Alerta(), |             new Alerta(), | ||||||
|         ]; |         ]; | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										51
									
								
								src/components/notifications/Gorush.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								src/components/notifications/Gorush.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | |||||||
|  | <template> | ||||||
|  |     <div class="mb-3"> | ||||||
|  |         <label for="gorush-device-token" class="form-label">{{ $t("Device Token") }}</label><span style="color: red;"><sup>*</sup></span> | ||||||
|  |         <div class="input-group mb-3"> | ||||||
|  |             <input id="gorush-device-token" v-model="$parent.notification.gorushDeviceToken" type="text" class="form-control" required> | ||||||
|  |         </div> | ||||||
|  |     </div> | ||||||
|  |  | ||||||
|  |     <div class="mb-3"> | ||||||
|  |         <label for="gorush-server-url" class="form-label">{{ $t("Server URL") }}</label><span style="color: red;"><sup>*</sup></span> | ||||||
|  |         <div class="input-group mb-3"> | ||||||
|  |             <input id="gorush-server-url" v-model="$parent.notification.gorushServerURL" type="text" class="form-control" required> | ||||||
|  |         </div> | ||||||
|  |     </div> | ||||||
|  |  | ||||||
|  |     <div class="mb-3"> | ||||||
|  |         <label for="gorush-platform" class="form-label">{{ $t("Platform") }}</label><span style="color: red;"><sup>*</sup></span> | ||||||
|  |         <select id="gorush-platform" v-model="$parent.notification.gorushPlatform" class="form-select"> | ||||||
|  |             <option value="ios">{{ $t("iOS") }}</option> | ||||||
|  |             <option value="android">{{ $t("Android") }}</option> | ||||||
|  |             <option value="huawei">{{ $t("Huawei") }}</option> | ||||||
|  |         </select> | ||||||
|  |     </div> | ||||||
|  |  | ||||||
|  |     <div class="mb-3"> | ||||||
|  |         <label for="gorush-title" class="form-label">{{ $t("Title") }}</label> | ||||||
|  |         <input id="gorush-title" v-model="$parent.notification.gorushTitle" type="text" class="form-control"> | ||||||
|  |     </div> | ||||||
|  |  | ||||||
|  |     <div class="mb-3"> | ||||||
|  |         <label for="gorush-priority" class="form-label">{{ $t("Priority") }}</label> | ||||||
|  |         <select id="gorush-priority" v-model="$parent.notification.gorushPriority" class="form-select"> | ||||||
|  |             <option value="normal">{{ $t("Normal") }}</option> | ||||||
|  |             <option value="high">{{ $t("High") }}</option> | ||||||
|  |         </select> | ||||||
|  |     </div> | ||||||
|  |  | ||||||
|  |     <div class="mb-3"> | ||||||
|  |         <label for="gorush-retry" class="form-label">{{ $t("Retry") }}</label> | ||||||
|  |         <input id="gorush-retry" v-model="$parent.notification.gorushRetry" type="number" class="form-control"> | ||||||
|  |     </div> | ||||||
|  |  | ||||||
|  |     <div class="mb-3"> | ||||||
|  |         <label for="gorush-topic" class="form-label">{{ $t("Topic") }}</label> | ||||||
|  |         <input id="gorush-topic" v-model="$parent.notification.gorushTopic" type="text" class="form-control"> | ||||||
|  |     </div> | ||||||
|  |  | ||||||
|  |     <div class="form-text"> | ||||||
|  |         <span style="color: red;"><sup>*</sup></span>{{ $t("Required") }} | ||||||
|  |     </div> | ||||||
|  | </template> | ||||||
| @@ -26,6 +26,7 @@ import SerwerSMS from "./SerwerSMS.vue"; | |||||||
| import Stackfield from './Stackfield.vue'; | import Stackfield from './Stackfield.vue'; | ||||||
| import WeCom from "./WeCom.vue"; | import WeCom from "./WeCom.vue"; | ||||||
| import GoogleChat from "./GoogleChat.vue"; | import GoogleChat from "./GoogleChat.vue"; | ||||||
|  | import Gorush from "./Gorush.vue"; | ||||||
| import Alerta from "./Alerta.vue"; | import Alerta from "./Alerta.vue"; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -62,6 +63,7 @@ const NotificationFormList = { | |||||||
|     "stackfield": Stackfield, |     "stackfield": Stackfield, | ||||||
|     "WeCom": WeCom, |     "WeCom": WeCom, | ||||||
|     "GoogleChat": GoogleChat, |     "GoogleChat": GoogleChat, | ||||||
|  |     "gorush": Gorush, | ||||||
|     "alerta": Alerta, |     "alerta": Alerta, | ||||||
| }; | }; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -361,6 +361,7 @@ export default { | |||||||
|     smtpDkimHashAlgo: "Hash Algorithm (Optional)", |     smtpDkimHashAlgo: "Hash Algorithm (Optional)", | ||||||
|     smtpDkimheaderFieldNames: "Header Keys to sign (Optional)", |     smtpDkimheaderFieldNames: "Header Keys to sign (Optional)", | ||||||
|     smtpDkimskipFields: "Header Keys not to sign (Optional)", |     smtpDkimskipFields: "Header Keys not to sign (Optional)", | ||||||
|  |     gorush: "Gorush", | ||||||
|     alerta: 'Alerta', |     alerta: 'Alerta', | ||||||
|     alertaApiEndpoint: 'API Endpoint', |     alertaApiEndpoint: 'API Endpoint', | ||||||
|     alertaEnvironment: 'Environment', |     alertaEnvironment: 'Environment', | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user