/** * Grafana-Zabbix * Zabbix plugin for Grafana. * http://github.com/alexanderzobnin/grafana-zabbix * * Trigger panel. * This feature sponsored by CORE IT * http://www.coreit.fr * * Copyright 2015 Alexander Zobnin alexanderzobnin@gmail.com * Licensed under the Apache License, Version 2.0 */ import _ from 'lodash'; import $ from 'jquery'; class TriggerPanelEditorCtrl{ /** @ngInject */ constructor($scope, $q, uiSegmentSrv, datasourceSrv, templateSrv, popoverSrv) { $scope.editor = this; this.panelCtrl = $scope.ctrl; this.panel = this.panelCtrl.panel; this.datasourceSrv = datasourceSrv; this.templateSrv = templateSrv; this.popoverSrv = popoverSrv; // Map functions for bs-typeahead this.getGroupNames = _.partial(getMetricNames, this, 'groupList'); this.getHostNames = _.partial(getMetricNames, this, 'filteredHosts'); this.getApplicationNames = _.partial(getMetricNames, this, 'filteredApplications'); this.getItemNames = _.partial(getMetricNames, this, 'filteredItems'); this.ackFilters = [ 'all triggers', 'unacknowledged', 'acknowledged' ]; this.sortByFields = [ { text: 'last change', value: 'lastchange' }, { text: 'severity', value: 'priority' } ]; this.showEventsFields = [ { text: 'All', value: [0,1] }, { text: 'OK', value: [0] }, { text: 'Problems', value: 1 } ]; // Load scope defaults var scopeDefaults = { metric: {}, inputStyles: {}, oldTarget: _.cloneDeep(this.panel.triggers) }; _.defaults(this, scopeDefaults); var self = this; // Get zabbix data sources var datasources = _.filter(this.datasourceSrv.getMetricSources(), datasource => { return datasource.meta.id === 'zabbix-datasource'; }); this.datasources = _.map(datasources, 'name'); // Set default datasource if (!this.panel.datasource) { this.panel.datasource = this.datasources[0]; } // Load datasource this.datasourceSrv.get(this.panel.datasource).then(function (datasource) { self.datasource = datasource; self.initFilters(); self.panelCtrl.refresh(); }); } initFilters() { this.filterGroups(); this.filterHosts(); this.filterApplications(); } filterGroups() { var self = this; this.datasource.queryProcessor.getGroups().then(function(groups) { self.metric.groupList = groups; }); } filterHosts() { var self = this; var groupFilter = this.templateSrv.replace(this.panel.triggers.group.filter); this.datasource.queryProcessor.getHosts(groupFilter).then(function(hosts) { self.metric.filteredHosts = hosts; }); } filterApplications() { var self = this; var groupFilter = this.templateSrv.replace(this.panel.triggers.group.filter); var hostFilter = this.templateSrv.replace(this.panel.triggers.host.filter); this.datasource.queryProcessor.getApps(groupFilter, hostFilter) .then(function(apps) { self.metric.filteredApplications = apps; }); } onTargetPartChange(targetPart) { var regexStyle = {'color': '#CCA300'}; targetPart.isRegex = isRegex(targetPart.filter); targetPart.style = targetPart.isRegex ? regexStyle : {}; } parseTarget() { this.initFilters(); var newTarget = _.cloneDeep(this.panel.triggers); if (!_.isEqual(this.oldTarget, this.panel.triggers)) { this.oldTarget = newTarget; this.panelCtrl.refresh(); } } refreshTriggerSeverity() { _.each(this.triggerList, function(trigger) { trigger.color = this.panel.triggerSeverity[trigger.priority].color; trigger.severity = this.panel.triggerSeverity[trigger.priority].severity; }); this.panelCtrl.refresh(); } datasourceChanged() { this.panelCtrl.refresh(); } changeTriggerSeverityColor(trigger, color) { this.panel.triggerSeverity[trigger.priority].color = color; this.refreshTriggerSeverity(); } openTriggerColorSelector(event) { var el = $(event.currentTarget); var index = getTriggerIndexForElement(el); var popoverScope = this.$new(); popoverScope.trigger = this.panel.triggerSeverity[index]; popoverScope.changeTriggerSeverityColor = this.changeTriggerSeverityColor; this.popoverSrv.show({ element: el, placement: 'top', templateUrl: 'public/plugins/zabbix-app/panel-triggers/trigger.colorpicker.html', scope: popoverScope }); } openOkEventColorSelector(event) { var el = $(event.currentTarget); var popoverScope = this.$new(); popoverScope.trigger = {color: this.panel.okEventColor}; popoverScope.changeTriggerSeverityColor = function(trigger, color) { this.panel.okEventColor = color; this.refreshTriggerSeverity(); }; this.popoverSrv.show({ element: el, placement: 'top', templateUrl: 'public/plugins/zabbix-app/panel-triggers/trigger.colorpicker.html', scope: popoverScope }); } } // Get list of metric names for bs-typeahead directive function getMetricNames(scope, metricList) { return _.uniq(_.map(scope.metric[metricList], 'name')); } function getTriggerIndexForElement(el) { return el.parents('[data-trigger-index]').data('trigger-index'); } function isRegex(str) { // Pattern for testing regex var regexPattern = /^\/(.*)\/([gmi]*)$/m; return regexPattern.test(str); } export function triggerPanelEditor() { return { restrict: 'E', scope: true, templateUrl: 'public/plugins/zabbix-app/panel-triggers/editor.html', controller: TriggerPanelEditorCtrl, }; }