Merge pull request #2575 from Joseph-Irving/victorops_notifications
Add Splunk Notification Provider
This commit is contained in:
		
						commit
						98d001b38b
					
				
					 4 changed files with 149 additions and 0 deletions
				
			
		
							
								
								
									
										113
									
								
								server/notification-providers/splunk.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										113
									
								
								server/notification-providers/splunk.js
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,113 @@ | ||||||
|  | const NotificationProvider = require("./notification-provider"); | ||||||
|  | const axios = require("axios"); | ||||||
|  | const { UP, DOWN, getMonitorRelativeURL } = require("../../src/util"); | ||||||
|  | const { setting } = require("../util-server"); | ||||||
|  | let successMessage = "Sent Successfully."; | ||||||
|  | 
 | ||||||
|  | class Splunk extends NotificationProvider { | ||||||
|  |     name = "Splunk"; | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * @inheritdoc | ||||||
|  |      */ | ||||||
|  |     async send(notification, msg, monitorJSON = null, heartbeatJSON = null) { | ||||||
|  |         try { | ||||||
|  |             if (heartbeatJSON == null) { | ||||||
|  |                 const title = "Uptime Kuma Alert"; | ||||||
|  |                 const monitor = { | ||||||
|  |                     type: "ping", | ||||||
|  |                     url: "Uptime Kuma Test Button", | ||||||
|  |                 }; | ||||||
|  |                 return this.postNotification(notification, title, msg, monitor, "trigger"); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             if (heartbeatJSON.status === UP) { | ||||||
|  |                 const title = "Uptime Kuma Monitor ✅ Up"; | ||||||
|  |                 return this.postNotification(notification, title, heartbeatJSON.msg, monitorJSON, "recovery"); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             if (heartbeatJSON.status === DOWN) { | ||||||
|  |                 const title = "Uptime Kuma Monitor 🔴 Down"; | ||||||
|  |                 return this.postNotification(notification, title, heartbeatJSON.msg, monitorJSON, "trigger"); | ||||||
|  |             } | ||||||
|  |         } catch (error) { | ||||||
|  |             this.throwGeneralAxiosError(error); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * Check if result is successful, result code should be in range 2xx | ||||||
|  |      * @param {Object} result Axios response object | ||||||
|  |      * @throws {Error} The status code is not in range 2xx | ||||||
|  |      */ | ||||||
|  |     checkResult(result) { | ||||||
|  |         if (result.status == null) { | ||||||
|  |             throw new Error("Splunk notification failed with invalid response!"); | ||||||
|  |         } | ||||||
|  |         if (result.status < 200 || result.status >= 300) { | ||||||
|  |             throw new Error("Splunk notification failed with status code " + result.status); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * Send the message | ||||||
|  |      * @param {BeanModel} notification Message title | ||||||
|  |      * @param {string} title Message title | ||||||
|  |      * @param {string} body Message | ||||||
|  |      * @param {Object} monitorInfo Monitor details (For Up/Down only) | ||||||
|  |      * @param {?string} eventAction Action event for PagerDuty (trigger, acknowledge, resolve) | ||||||
|  |      * @returns {string} | ||||||
|  |      */ | ||||||
|  |     async postNotification(notification, title, body, monitorInfo, eventAction = "trigger") { | ||||||
|  | 
 | ||||||
|  |         let monitorUrl; | ||||||
|  |         if (monitorInfo.type === "port") { | ||||||
|  |             monitorUrl = monitorInfo.hostname; | ||||||
|  |             if (monitorInfo.port) { | ||||||
|  |                 monitorUrl += ":" + monitorInfo.port; | ||||||
|  |             } | ||||||
|  |         } else if (monitorInfo.hostname != null) { | ||||||
|  |             monitorUrl = monitorInfo.hostname; | ||||||
|  |         } else { | ||||||
|  |             monitorUrl = monitorInfo.url; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         if (eventAction === "recovery") { | ||||||
|  |             if (notification.splunkAutoResolve === "0") { | ||||||
|  |                 return "No action required"; | ||||||
|  |             } | ||||||
|  |             eventAction = notification.splunkAutoResolve; | ||||||
|  |         } else { | ||||||
|  |             eventAction = notification.splunkSeverity; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         const options = { | ||||||
|  |             method: "POST", | ||||||
|  |             url: notification.splunkRestURL, | ||||||
|  |             headers: { "Content-Type": "application/json" }, | ||||||
|  |             data: { | ||||||
|  |                 message_type: eventAction, | ||||||
|  |                 state_message: `[${title}] [${monitorUrl}] ${body}`, | ||||||
|  |                 entity_display_name: "Uptime Kuma Alert: " + monitorInfo.name, | ||||||
|  |                 routing_key: notification.pagerdutyIntegrationKey, | ||||||
|  |                 entity_id: "Uptime Kuma/" + monitorInfo.id, | ||||||
|  |             } | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         const baseURL = await setting("primaryBaseURL"); | ||||||
|  |         if (baseURL && monitorInfo) { | ||||||
|  |             options.client = "Uptime Kuma"; | ||||||
|  |             options.client_url = baseURL + getMonitorRelativeURL(monitorInfo.id); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         let result = await axios.request(options); | ||||||
|  |         this.checkResult(result); | ||||||
|  |         if (result.statusText != null) { | ||||||
|  |             return "Splunk notification succeed: " + result.statusText; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         return successMessage; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | module.exports = Splunk; | ||||||
|  | @ -40,6 +40,7 @@ const Stackfield = require("./notification-providers/stackfield"); | ||||||
| const Teams = require("./notification-providers/teams"); | const Teams = require("./notification-providers/teams"); | ||||||
| const TechulusPush = require("./notification-providers/techulus-push"); | const TechulusPush = require("./notification-providers/techulus-push"); | ||||||
| const Telegram = require("./notification-providers/telegram"); | const Telegram = require("./notification-providers/telegram"); | ||||||
|  | const Splunk = require("./notification-providers/splunk"); | ||||||
| const Webhook = require("./notification-providers/webhook"); | 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"); | ||||||
|  | @ -100,6 +101,7 @@ class Notification { | ||||||
|             new Teams(), |             new Teams(), | ||||||
|             new TechulusPush(), |             new TechulusPush(), | ||||||
|             new Telegram(), |             new Telegram(), | ||||||
|  |             new Splunk(), | ||||||
|             new Webhook(), |             new Webhook(), | ||||||
|             new WeCom(), |             new WeCom(), | ||||||
|             new GoAlert(), |             new GoAlert(), | ||||||
|  |  | ||||||
							
								
								
									
										32
									
								
								src/components/notifications/Splunk.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/components/notifications/Splunk.vue
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,32 @@ | ||||||
|  | <template> | ||||||
|  |     <div class="mb-3"> | ||||||
|  |         <label for="splunk-rest-url" class="form-label">{{ $t("Splunk Rest URL") }}</label> | ||||||
|  |         <HiddenInput id="splunk-rest-url" v-model="$parent.notification.splunkRestURL" :required="true" autocomplete="false"></HiddenInput> | ||||||
|  |     </div> | ||||||
|  |     <div class="mb-3"> | ||||||
|  |         <label for="splunk-severity" class="form-label">{{ $t("Severity") }}</label> | ||||||
|  |         <select id="splunk-severity" v-model="$parent.notification.splunkSeverity" class="form-select"> | ||||||
|  |             <option value="INFO">{{ $t("info") }}</option> | ||||||
|  |             <option value="WARNING">{{ $t("warning") }}</option> | ||||||
|  |             <option value="CRITICAL" selected="selected">{{ $t("critical") }}</option> | ||||||
|  |         </select> | ||||||
|  |     </div> | ||||||
|  |     <div class="mb-3"> | ||||||
|  |         <label for="splunk-resolve" class="form-label">{{ $t("Auto resolve or acknowledged") }}</label> | ||||||
|  |         <select id="splunk-resolve" v-model="$parent.notification.splunkAutoResolve" class="form-select"> | ||||||
|  |             <option value="0" selected="selected">{{ $t("do nothing") }}</option> | ||||||
|  |             <option value="ACKNOWLEDGEMENT">{{ $t("auto acknowledged") }}</option> | ||||||
|  |             <option value="RECOVERY">{{ $t("auto resolve") }}</option> | ||||||
|  |         </select> | ||||||
|  |     </div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | import HiddenInput from "../HiddenInput.vue"; | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  |     components: { | ||||||
|  |         HiddenInput, | ||||||
|  |     }, | ||||||
|  | }; | ||||||
|  | </script> | ||||||
|  | @ -44,6 +44,7 @@ import Webhook from "./Webhook.vue"; | ||||||
| import WeCom from "./WeCom.vue"; | import WeCom from "./WeCom.vue"; | ||||||
| import GoAlert from "./GoAlert.vue"; | import GoAlert from "./GoAlert.vue"; | ||||||
| import ZohoCliq from "./ZohoCliq.vue"; | import ZohoCliq from "./ZohoCliq.vue"; | ||||||
|  | import Splunk from "./Splunk.vue"; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * Manage all notification form. |  * Manage all notification form. | ||||||
|  | @ -92,6 +93,7 @@ const NotificationFormList = { | ||||||
|     "stackfield": Stackfield, |     "stackfield": Stackfield, | ||||||
|     "teams": Teams, |     "teams": Teams, | ||||||
|     "telegram": Telegram, |     "telegram": Telegram, | ||||||
|  |     "Splunk": Splunk, | ||||||
|     "webhook": Webhook, |     "webhook": Webhook, | ||||||
|     "WeCom": WeCom, |     "WeCom": WeCom, | ||||||
|     "GoAlert": GoAlert, |     "GoAlert": GoAlert, | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue