mirror of
				https://github.com/louislam/uptime-kuma.git
				synced 2025-11-04 13:46:13 +08:00 
			
		
		
		
	Merge pull request #2575 from Joseph-Irving/victorops_notifications
Add Splunk Notification Provider
This commit is contained in:
		
							
								
								
									
										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 TechulusPush = require("./notification-providers/techulus-push");
 | 
			
		||||
const Telegram = require("./notification-providers/telegram");
 | 
			
		||||
const Splunk = require("./notification-providers/splunk");
 | 
			
		||||
const Webhook = require("./notification-providers/webhook");
 | 
			
		||||
const WeCom = require("./notification-providers/wecom");
 | 
			
		||||
const GoAlert = require("./notification-providers/goalert");
 | 
			
		||||
@@ -100,6 +101,7 @@ class Notification {
 | 
			
		||||
            new Teams(),
 | 
			
		||||
            new TechulusPush(),
 | 
			
		||||
            new Telegram(),
 | 
			
		||||
            new Splunk(),
 | 
			
		||||
            new Webhook(),
 | 
			
		||||
            new WeCom(),
 | 
			
		||||
            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 GoAlert from "./GoAlert.vue";
 | 
			
		||||
import ZohoCliq from "./ZohoCliq.vue";
 | 
			
		||||
import Splunk from "./Splunk.vue";
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Manage all notification form.
 | 
			
		||||
@@ -92,6 +93,7 @@ const NotificationFormList = {
 | 
			
		||||
    "stackfield": Stackfield,
 | 
			
		||||
    "teams": Teams,
 | 
			
		||||
    "telegram": Telegram,
 | 
			
		||||
    "Splunk": Splunk,
 | 
			
		||||
    "webhook": Webhook,
 | 
			
		||||
    "WeCom": WeCom,
 | 
			
		||||
    "GoAlert": GoAlert,
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user