Merge branch 'goalert-notification' of https://github.com/mhkarimi1383/uptime-kuma into pr-test
This commit is contained in:
		
						commit
						676e64c77d
					
				
					 7 changed files with 1577 additions and 1778 deletions
				
			
		
							
								
								
									
										3280
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										3280
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							|  | @ -65,7 +65,7 @@ | |||
|     "dependencies": { | ||||
|         "@louislam/sqlite3": "~15.0.6", | ||||
|         "args-parser": "~1.3.0", | ||||
|         "axios": "~0.26.1", | ||||
|         "axios": "~0.27.0", | ||||
|         "axios-ntlm": "^1.3.0", | ||||
|         "badge-maker": "^3.3.1", | ||||
|         "bcryptjs": "~2.4.3", | ||||
|  |  | |||
							
								
								
									
										35
									
								
								server/notification-providers/goalert.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								server/notification-providers/goalert.js
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,35 @@ | |||
| const NotificationProvider = require("./notification-provider"); | ||||
| const axios = require("axios"); | ||||
| const { UP } = require("../../src/util"); | ||||
| 
 | ||||
| class GoAlert extends NotificationProvider { | ||||
| 
 | ||||
|     name = "GoAlert"; | ||||
| 
 | ||||
|     async send(notification, msg, monitorJSON = null, heartbeatJSON = null) { | ||||
|         let okMsg = "Sent Successfully."; | ||||
|         try { | ||||
|             let closeAction = "close"; | ||||
|             let data = { | ||||
|                 summary: msg, | ||||
|             }; | ||||
|             if (heartbeatJSON != null && heartbeatJSON["status"] === UP) { | ||||
|                 data["action"] = closeAction; | ||||
|             } | ||||
|             let headers = { | ||||
|                 "Content-Type": "multipart/form-data", | ||||
|             }; | ||||
|             let config = { | ||||
|                 headers: headers | ||||
|             }; | ||||
|             let resp = await axios.post(`${notification.goAlertBaseURL}/api/v2/generic/incoming?token=${notification.goAlertToken}`, data, config); | ||||
|             return okMsg; | ||||
| 
 | ||||
|         } catch (error) { | ||||
|             let msg = (error.response.data) ? error.response.data : "Error without response"; | ||||
|             throw new Error(msg); | ||||
|         } | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| module.exports = GoAlert; | ||||
|  | @ -38,6 +38,7 @@ const TechulusPush = require("./notification-providers/techulus-push"); | |||
| const Telegram = require("./notification-providers/telegram"); | ||||
| const Webhook = require("./notification-providers/webhook"); | ||||
| const WeCom = require("./notification-providers/wecom"); | ||||
| const GoAlert = require("./notification-providers/goalert"); | ||||
| 
 | ||||
| class Notification { | ||||
| 
 | ||||
|  | @ -88,6 +89,7 @@ class Notification { | |||
|             new Telegram(), | ||||
|             new Webhook(), | ||||
|             new WeCom(), | ||||
|             new GoAlert(), | ||||
|         ]; | ||||
| 
 | ||||
|         for (let item of list) { | ||||
|  |  | |||
							
								
								
									
										30
									
								
								src/components/notifications/GoAlert.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								src/components/notifications/GoAlert.vue
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,30 @@ | |||
| <template> | ||||
|     <div class="mb-3"> | ||||
|         <label for="goalert-base-url" class="form-label">{{ $t("Base URL") }}</label> | ||||
|         <div class="input-group mb-3"> | ||||
|             <input id="goalert-base-url" v-model="$parent.notification.goAlertBaseURL" type="text" class="form-control" required> | ||||
|         </div> | ||||
|         <i18n-t tag="div" keypath="goAlertInfo" class="form-text"> | ||||
|             <a href="https://goalert.me" target="_blank">https://goalert.me</a> | ||||
|         </i18n-t> | ||||
|     </div> | ||||
| 
 | ||||
|     <div class="mb-3"> | ||||
|         <label for="goalert-token" class="form-label">{{ $t("Token") }}</label> | ||||
|         <HiddenInput id="goalert-token" v-model="$parent.notification.goAlertToken" autocomplete="one-time-code" :required="true"></HiddenInput> | ||||
| 
 | ||||
|         <div class="form-text"> | ||||
|             {{ $t("goAlertIntegrationKeyInfo") }} | ||||
|         </div> | ||||
|     </div> | ||||
| </template> | ||||
| 
 | ||||
| <script> | ||||
| import HiddenInput from "../HiddenInput.vue"; | ||||
| 
 | ||||
| export default { | ||||
|     components: { | ||||
|         HiddenInput, | ||||
|     }, | ||||
| }; | ||||
| </script> | ||||
|  | @ -36,6 +36,7 @@ import TechulusPush from "./TechulusPush.vue"; | |||
| import Telegram from "./Telegram.vue"; | ||||
| import Webhook from "./Webhook.vue"; | ||||
| import WeCom from "./WeCom.vue"; | ||||
| import GoAlert from "./GoAlert.vue"; | ||||
| 
 | ||||
| /** | ||||
|  * Manage all notification form. | ||||
|  | @ -81,6 +82,7 @@ const NotificationFormList = { | |||
|     "telegram": Telegram, | ||||
|     "webhook": Webhook, | ||||
|     "WeCom": WeCom, | ||||
|     "GoAlert": GoAlert, | ||||
| }; | ||||
| 
 | ||||
| export default NotificationFormList; | ||||
|  |  | |||
|  | @ -576,4 +576,8 @@ export default { | |||
|     "Then choose an action, for example switch the scene to where an RGB light is red.": "Then choose an action, for example switch the scene to where an RGB light is red.", | ||||
|     "Frontend Version": "Frontend Version", | ||||
|     "Frontend Version do not match backend version!": "Frontend Version do not match backend version!", | ||||
|     "Base URL": "Base URL", | ||||
|     goAlertInfo: "GoAlert is a An open source application for on-call scheduling, automated escalations and notifications (like SMS or voice calls). Automatically engage the right person, the right way, and at the right time! {0}", | ||||
|     goAlertIntegrationKeyInfo: "Get generic API integration key for the service in this format \"aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeee\" usually the value of token parameter of copied URL.", | ||||
|     goAlert: "GoAlert", | ||||
| }; | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue