2014-01-21 17:42:44 +01:00
|
|
|
<?php
|
2022-02-08 09:38:42 +01:00
|
|
|
/**
|
|
|
|
* Alerts details for agent.
|
|
|
|
*
|
|
|
|
* @category Alert
|
|
|
|
* @package Pandora FMS
|
|
|
|
* @subpackage Community
|
|
|
|
* @version 1.0.0
|
|
|
|
* @license See below
|
|
|
|
*
|
|
|
|
* ______ ___ _______ _______ ________
|
2023-06-08 12:42:10 +02:00
|
|
|
* | __ \.-----.--.--.--| |.-----.----.-----. | ___| | | __|
|
|
|
|
* | __/| _ | | _ || _ | _| _ | | ___| |__ |
|
2022-02-08 09:38:42 +01:00
|
|
|
* |___| |___._|__|__|_____||_____|__| |___._| |___| |__|_|__|_______|
|
|
|
|
*
|
|
|
|
* ============================================================================
|
2023-06-08 11:53:13 +02:00
|
|
|
* Copyright (c) 2005-2023 Pandora FMS
|
2023-06-08 13:19:01 +02:00
|
|
|
* Please see https://pandorafms.com/community/ for full contribution list
|
2022-02-08 09:38:42 +01:00
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation for version 2.
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
* ============================================================================
|
|
|
|
*/
|
|
|
|
|
|
|
|
// Load global vars.
|
2014-01-21 17:42:44 +01:00
|
|
|
global $config;
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
check_login();
|
2014-01-21 17:42:44 +01:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
if (! check_acl($config['id_user'], 0, 'LM')) {
|
|
|
|
db_pandora_audit(
|
2022-01-20 10:55:23 +01:00
|
|
|
AUDIT_LOG_ACL_VIOLATION,
|
2019-01-30 16:18:44 +01:00
|
|
|
'Trying to access Alert View (In management section)'
|
|
|
|
);
|
|
|
|
include 'general/noaccess.php';
|
|
|
|
exit;
|
2014-01-21 17:42:44 +01:00
|
|
|
}
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
enterprise_include_once('include/functions_policies.php');
|
2014-01-21 17:42:44 +01:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$id_alert = get_parameter('id_alert', 0);
|
2022-02-08 09:38:42 +01:00
|
|
|
// ID given as parameter.
|
2014-01-21 17:42:44 +01:00
|
|
|
$alert = alerts_get_alert_agent_module($id_alert);
|
2019-01-30 16:18:44 +01:00
|
|
|
$template = alerts_get_alert_template($alert['id_alert_template']);
|
|
|
|
$actions = alerts_get_alert_agent_module_actions($id_alert);
|
|
|
|
$agent_alias = modules_get_agentmodule_agent_alias($alert['id_agent_module']);
|
|
|
|
$agent = modules_get_agentmodule_agent($alert['id_agent_module']);
|
|
|
|
$module_name = modules_get_agentmodule_name($alert['id_agent_module']);
|
2014-01-21 17:42:44 +01:00
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
// Default action.
|
2014-01-21 17:42:44 +01:00
|
|
|
$default_action = $template['id_alert_action'];
|
|
|
|
if ($default_action != 0) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$default_action = alerts_get_alert_action($default_action);
|
2022-02-08 09:38:42 +01:00
|
|
|
$default_action['name'] .= ' ('.__('Default').')';
|
2019-01-30 16:18:44 +01:00
|
|
|
$default_action['default'] = 1;
|
|
|
|
$default_action['module_action_threshold'] = '0';
|
2014-01-21 17:42:44 +01:00
|
|
|
}
|
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
// Header.
|
2023-03-14 14:56:33 +01:00
|
|
|
ui_print_standard_header(
|
2022-02-08 09:38:42 +01:00
|
|
|
__('Alert details'),
|
|
|
|
'images/op_alerts.png',
|
|
|
|
false,
|
|
|
|
'',
|
|
|
|
false,
|
2023-03-14 14:56:33 +01:00
|
|
|
[],
|
|
|
|
[
|
|
|
|
[
|
|
|
|
'link' => '',
|
|
|
|
'label' => __('Alerts'),
|
|
|
|
],
|
|
|
|
]
|
2022-02-08 09:38:42 +01:00
|
|
|
);
|
2014-01-21 17:42:44 +01:00
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
// TABLE DETAILS.
|
|
|
|
$table_details = new stdClass;
|
2015-04-10 09:43:44 +02:00
|
|
|
$table_details->class = 'databox';
|
2014-01-21 17:42:44 +01:00
|
|
|
$table_details->width = '100%';
|
2019-01-30 16:18:44 +01:00
|
|
|
$table_details->size = [];
|
|
|
|
$table_details->data = [];
|
|
|
|
$table_details->style = [];
|
2014-01-21 17:42:44 +01:00
|
|
|
$table_details->style[0] = 'font-weight: bold;';
|
2019-01-30 16:18:44 +01:00
|
|
|
$data = [];
|
2014-01-21 17:42:44 +01:00
|
|
|
|
2015-01-23 12:21:57 +01:00
|
|
|
$data[0] = __('List alerts');
|
2021-03-11 15:40:23 +01:00
|
|
|
$data[1] = '<a class="size_7pt" href="index.php?sec=galertas&sec2=godmode/alerts/alert_list" title="'.__('List alerts').'"><b><span>'.__('List alerts').'</span></b></a>';
|
2015-01-23 12:21:57 +01:00
|
|
|
$table_details->data[] = $data;
|
|
|
|
|
2014-01-21 17:42:44 +01:00
|
|
|
$data[0] = __('Agent');
|
2021-03-11 15:40:23 +01:00
|
|
|
$data[1] = '<a class="size_7pt" href="index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente='.$agent.'" title="'.$agent_alias.'"><b><span>'.$agent_alias.'</span></b></a>';
|
2014-01-21 17:42:44 +01:00
|
|
|
$table_details->data[] = $data;
|
|
|
|
|
|
|
|
$data[0] = __('Module');
|
|
|
|
$data[1] = $module_name;
|
|
|
|
$table_details->data[] = $data;
|
|
|
|
|
|
|
|
$data[0] = __('Template');
|
2019-01-30 16:18:44 +01:00
|
|
|
$data[1] = $template['name'].ui_print_help_tip($template['description'], true);
|
2014-01-21 17:42:44 +01:00
|
|
|
$table_details->data[] = $data;
|
|
|
|
|
|
|
|
$data[0] = __('Last fired');
|
2019-01-30 16:18:44 +01:00
|
|
|
$data[1] = ui_print_timestamp($alert['last_fired'], true);
|
2014-01-21 17:42:44 +01:00
|
|
|
$table_details->data[] = $data;
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
if ($alert['times_fired'] > 0) {
|
|
|
|
$status = STATUS_ALERT_FIRED;
|
2022-11-29 12:04:03 +01:00
|
|
|
$title = __('Alert fired').' '.$alert['times_fired'].' '.__('time(s)');
|
2019-01-30 16:18:44 +01:00
|
|
|
} else if ($alert['disabled'] > 0) {
|
|
|
|
$status = STATUS_ALERT_DISABLED;
|
|
|
|
$title = __('Alert disabled');
|
|
|
|
} else {
|
|
|
|
$status = STATUS_ALERT_NOT_FIRED;
|
|
|
|
$title = __('Alert not fired');
|
2014-01-21 17:42:44 +01:00
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2014-01-21 17:42:44 +01:00
|
|
|
$data[0] = __('Status');
|
2021-03-11 15:40:23 +01:00
|
|
|
$data[1] = '<span class="mrg_r_5px">'.ui_print_status_image(
|
|
|
|
$status,
|
|
|
|
$title,
|
|
|
|
true
|
|
|
|
).'</span>'.$title;
|
2014-01-21 17:42:44 +01:00
|
|
|
$table_details->data[] = $data;
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$priorities = get_priorities();
|
2014-01-21 17:42:44 +01:00
|
|
|
|
|
|
|
$data[0] = __('Priority');
|
2021-03-11 15:40:23 +01:00
|
|
|
$data[1] = '<span title="'.$priorities[$template['priority']].'" class="'.get_priority_class($template['priority']).' span_priority"> </span>'.$priorities[$template['priority']];
|
2014-01-21 17:42:44 +01:00
|
|
|
$table_details->data[] = $data;
|
|
|
|
|
|
|
|
$data[0] = __('Stand by');
|
2022-02-08 09:38:42 +01:00
|
|
|
$data[1] = ($alert['standby'] == 1) ? __('Yes') : __('No');
|
2014-01-21 17:42:44 +01:00
|
|
|
$table_details->data[] = $data;
|
|
|
|
|
|
|
|
if (enterprise_installed() && $alert['id_policy_alerts'] != 0) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$policyInfo = policies_is_alert_in_policy2($alert['id'], false);
|
|
|
|
if ($policyInfo === false) {
|
|
|
|
$policy = __('N/A');
|
|
|
|
} else {
|
2021-03-11 15:40:23 +01:00
|
|
|
$img = 'images/policies_mc.png';
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
$policy = '<a href="?sec=gmodules&sec2=enterprise/godmode/policies/policies&id='.$policyInfo['id'].'">';
|
|
|
|
$policy .= html_print_image(
|
|
|
|
$img,
|
|
|
|
true,
|
|
|
|
['title' => $policyInfo['name']]
|
|
|
|
);
|
|
|
|
$policy .= '</a>';
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
$data[0] = __('Policy');
|
|
|
|
$data[1] = $policy;
|
|
|
|
$table_details->data[] = $data;
|
2014-01-21 17:42:44 +01:00
|
|
|
}
|
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
$table_conditions = new stdClass;
|
2015-04-10 09:43:44 +02:00
|
|
|
$table_conditions->class = 'databox';
|
2014-01-21 17:42:44 +01:00
|
|
|
$table_conditions->width = '100%';
|
2019-01-30 16:18:44 +01:00
|
|
|
$table_conditions->size = [];
|
|
|
|
$table_conditions->data = [];
|
|
|
|
$table_conditions->style = [];
|
2014-01-21 17:42:44 +01:00
|
|
|
$table_conditions->style[0] = 'font-weight: bold; width: 50%;';
|
2019-01-30 16:18:44 +01:00
|
|
|
$data = [];
|
2014-01-21 17:42:44 +01:00
|
|
|
$table_conditions->colspan[0][0] = 2;
|
|
|
|
|
|
|
|
switch ($template['type']) {
|
2019-01-30 16:18:44 +01:00
|
|
|
case 'regex':
|
|
|
|
if ($template['matches_value']) {
|
|
|
|
$condition = __('The alert would fire when the value matches <span id="value"></span>');
|
|
|
|
} else {
|
|
|
|
$condition = __('The alert would fire when the value doesn\'t match <span id="value"></span>');
|
|
|
|
}
|
|
|
|
|
|
|
|
$condition = str_replace('<span id="value"></span>', $template['value'], $condition);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'equal':
|
|
|
|
$condition = __('The alert would fire when the value is <span id="value"></span>');
|
|
|
|
$condition = str_replace('<span id="value"></span>', $template['value'], $condition);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'not_equal':
|
|
|
|
$condition = __('The alert would fire when the value is not <span id="value"></span>');
|
|
|
|
$condition = str_replace('<span id="value"></span>', $template['value'], $condition);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'max_min':
|
|
|
|
if ($template['matches_value']) {
|
2022-02-08 09:38:42 +01:00
|
|
|
$condition = __(
|
|
|
|
'The alert would fire when the value is between <span id="min"></span> and <span id="max"></span>'
|
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
2022-02-08 09:38:42 +01:00
|
|
|
$condition = __(
|
|
|
|
'The alert would fire when the value is not between <span id="min"></span> and <span id="max"></span>'
|
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
$condition = str_replace('<span id="min"></span>', $template['min_value'], $condition);
|
|
|
|
$condition = str_replace('<span id="max"></span>', $template['max_value'], $condition);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'max':
|
|
|
|
$condition = __('The alert would fire when the value is below <span id="min"></span>');
|
|
|
|
$condition = str_replace('<span id="min"></span>', $template['min_value'], $condition);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'min':
|
|
|
|
$condition = __('The alert would fire when the value is above <span id="max"></span>');
|
|
|
|
$condition = str_replace('<span id="max"></span>', $template['max_value'], $condition);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'onchange':
|
|
|
|
if ($template['matches_value']) {
|
|
|
|
$condition = __('The alert would fire when the module value changes');
|
|
|
|
} else {
|
|
|
|
$condition = __('The alert would fire when the module value does not change');
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'warning':
|
|
|
|
$condition = __('The alert would fire when the module is in warning status');
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'critical':
|
|
|
|
$condition = __('The alert would fire when the module is in critical status');
|
|
|
|
break;
|
|
|
|
|
2019-04-24 10:51:55 +02:00
|
|
|
case 'not_normal':
|
|
|
|
$condition = __('The alert would fire when the module is in not normal status');
|
|
|
|
break;
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
case 'unknown':
|
|
|
|
$condition = __('The alert would fire when the module is in unknown status');
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'always':
|
|
|
|
$condition = __('Always');
|
2022-02-08 09:38:42 +01:00
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
// Not possible.
|
|
|
|
break;
|
2014-01-21 17:42:44 +01:00
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2014-01-21 17:42:44 +01:00
|
|
|
$data[0] = $condition;
|
|
|
|
|
|
|
|
$table_conditions->data[] = $data;
|
|
|
|
|
2022-02-01 11:29:25 +01:00
|
|
|
$table_conditions->colspan[1][0] = 2;
|
2022-02-08 09:38:42 +01:00
|
|
|
$schedule = io_safe_output(
|
|
|
|
$template['schedule']
|
2022-02-01 11:29:25 +01:00
|
|
|
);
|
2014-01-21 17:42:44 +01:00
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
$data[0] = '';
|
|
|
|
$data[0] .= html_print_input_hidden('schedule', $schedule, true);
|
|
|
|
$data[0] .= '<div id="calendar_map"></div>';
|
2014-01-21 17:42:44 +01:00
|
|
|
|
2022-02-01 11:29:25 +01:00
|
|
|
$data[1] = '';
|
2014-01-21 17:42:44 +01:00
|
|
|
$table_conditions->data[] = $data;
|
|
|
|
|
|
|
|
$data[0] = __('Use special days list');
|
2019-01-30 16:18:44 +01:00
|
|
|
$data[1] = (isset($alert['special_day']) && $alert['special_day'] == 1) ? __('Yes') : __('No');
|
2014-01-21 17:42:44 +01:00
|
|
|
$table_conditions->data[] = $data;
|
|
|
|
|
|
|
|
$data[0] = __('Time threshold');
|
2019-01-30 16:18:44 +01:00
|
|
|
$data[1] = human_time_description_raw($template['time_threshold'], true);
|
2014-01-21 17:42:44 +01:00
|
|
|
$table_conditions->data[] = $data;
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$data[0] = __('Number of alerts').' ('.__('Min').'/'.__('Max').')';
|
|
|
|
$data[1] = $template['min_alerts'].'/'.$template['max_alerts'];
|
2014-01-21 17:42:44 +01:00
|
|
|
$table_conditions->data[] = $data;
|
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
// TABLE CONDITIONS END.
|
|
|
|
$table = new stdClass;
|
2014-01-21 17:42:44 +01:00
|
|
|
$table->class = 'alert_list databox';
|
|
|
|
$table->width = '98%';
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->size = [];
|
|
|
|
$table->head = [];
|
|
|
|
$table->data = [];
|
|
|
|
$table->style = [];
|
2014-01-21 17:42:44 +01:00
|
|
|
$table->style[0] = 'width: 50%;';
|
|
|
|
|
|
|
|
$table->head[0] = __('Alert details');
|
|
|
|
$table->head[1] = __('Firing conditions');
|
|
|
|
|
|
|
|
$table->data[0][0] = html_print_table($table_details, true);
|
|
|
|
$table->data[0][1] = html_print_table($table_conditions, true);
|
|
|
|
|
|
|
|
html_print_table($table);
|
|
|
|
unset($table);
|
|
|
|
|
2014-01-23 20:49:16 +01:00
|
|
|
$actions = alerts_get_actions_escalation($actions, $default_action);
|
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
// ESCALATION.
|
|
|
|
$table = new stdClass;
|
2014-01-23 20:49:16 +01:00
|
|
|
$table->class = 'alert_list databox alternate alert_escalation';
|
|
|
|
$table->width = '98%';
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->size = [];
|
|
|
|
$table->head = [];
|
|
|
|
$table->data = [];
|
2014-01-23 20:49:16 +01:00
|
|
|
$table->styleTable = 'text-align: center;';
|
|
|
|
|
2021-03-11 15:40:23 +01:00
|
|
|
echo '<div class="firing_action_all w100p" >';
|
2014-01-23 20:49:16 +01:00
|
|
|
$table->head[0] = __('Actions');
|
|
|
|
$table->style[0] = 'font-weight: bold; text-align: left;';
|
|
|
|
|
|
|
|
if (count($actions) == 1 && isset($actions[0])) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->head[1] = __('Every time that the alert is fired');
|
|
|
|
$table->data[0][0] = $actions[0]['name'];
|
2022-02-08 09:38:42 +01:00
|
|
|
$table->data[0][1] = html_print_image(
|
|
|
|
'images/tick.png',
|
|
|
|
true,
|
|
|
|
['class' => 'invert_filter']
|
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
|
|
|
foreach ($actions as $kaction => $action) {
|
|
|
|
$table->data[$kaction][0] = $action['name'];
|
2023-07-10 11:39:43 +02:00
|
|
|
if (count($action['escalation']) > 1) {
|
|
|
|
foreach ($action['escalation'] as $k => $v) {
|
|
|
|
$table->head[$k] = '#'.$k;
|
|
|
|
if ($v > 0) {
|
|
|
|
$table->data[$kaction][$k] .= html_print_image(
|
|
|
|
'images/tick.png',
|
|
|
|
true,
|
|
|
|
['class' => 'invert_filter']
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
$table->data[$kaction][$k] = html_print_image(
|
|
|
|
'images/blade.png',
|
|
|
|
true
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$table->head[1] = __('Every time that the alert is fired');
|
|
|
|
if (count($action['escalation']) > 0) {
|
|
|
|
if ($action['escalation'][0] > 0) {
|
|
|
|
$table->data[$kaction][1] .= html_print_image(
|
|
|
|
'images/tick.png',
|
|
|
|
true,
|
|
|
|
['class' => 'invert_filter']
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
$table->data[$kaction][1] = html_print_image(
|
|
|
|
'images/blade.png',
|
|
|
|
true
|
|
|
|
);
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
2023-07-10 11:39:43 +02:00
|
|
|
$table->data[$kaction][1] = html_print_image(
|
2022-02-08 09:38:42 +01:00
|
|
|
'images/blade.png',
|
|
|
|
true
|
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
2023-06-08 09:16:38 +02:00
|
|
|
}
|
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
$action_threshold = ($action['module_action_threshold'] > 0) ? $action['module_action_threshold'] : $action['action_threshold'];
|
2019-01-30 16:18:44 +01:00
|
|
|
|
|
|
|
if ($action_threshold == 0) {
|
2023-07-10 11:39:43 +02:00
|
|
|
$table->data[$kaction][] = __('No');
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
2023-07-10 11:39:43 +02:00
|
|
|
$table->data[$kaction][] = human_time_description_raw(
|
2022-02-08 09:38:42 +01:00
|
|
|
$action_threshold,
|
|
|
|
true,
|
|
|
|
'tiny'
|
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
}
|
2023-07-10 11:39:43 +02:00
|
|
|
|
|
|
|
$table->head[] = __('Threshold');
|
2014-01-23 20:49:16 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
html_print_table($table);
|
|
|
|
unset($table);
|
2019-01-30 16:18:44 +01:00
|
|
|
echo '</div>';
|
2022-02-08 09:38:42 +01:00
|
|
|
// ESCALATION TABLE.
|
|
|
|
$table = new stdClass;
|
2014-01-21 17:42:44 +01:00
|
|
|
$table->class = 'alert_list databox';
|
|
|
|
$table->width = '98%';
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->size = [];
|
|
|
|
$table->head = [];
|
|
|
|
$table->data = [];
|
2014-01-21 17:42:44 +01:00
|
|
|
$table->rowstyle[1] = 'font-weight: bold;';
|
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
if ((int) $default_action != 0) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$actions_select[0] = $default_action['name'];
|
2014-01-23 20:49:16 +01:00
|
|
|
}
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
foreach ($actions as $kaction => $action) {
|
|
|
|
$actions_select[$kaction] = $action['name'];
|
2014-01-21 17:42:44 +01:00
|
|
|
}
|
|
|
|
|
2014-01-23 20:49:16 +01:00
|
|
|
$table->data[0][0] = __('Select the desired action and mode to see the Firing/Recovery fields for this action');
|
2014-01-21 17:42:44 +01:00
|
|
|
$table->colspan[0][0] = 2;
|
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
$table->data[1][0] = __('Action');
|
|
|
|
$table->data[1][0] .= '<br>';
|
|
|
|
$table->data[1][0] .= html_print_select(
|
|
|
|
$actions_select,
|
|
|
|
'firing_action_select',
|
|
|
|
-1,
|
|
|
|
'',
|
|
|
|
__('Select the action'),
|
|
|
|
-1,
|
|
|
|
true,
|
|
|
|
false,
|
|
|
|
false
|
|
|
|
);
|
2014-01-21 17:42:44 +01:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$modes = [];
|
2014-01-21 17:42:44 +01:00
|
|
|
$modes['firing'] = __('Firing');
|
|
|
|
$modes['recovering'] = __('Recovering');
|
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
$table->data[1][1] = '<div class="action_details invisible" >';
|
|
|
|
$table->data[1][1] .= __('Mode');
|
|
|
|
$table->data[1][1] .= '<br>';
|
|
|
|
$table->data[1][1] .= html_print_select(
|
|
|
|
$modes,
|
|
|
|
'modes',
|
|
|
|
'firing',
|
|
|
|
'',
|
|
|
|
'',
|
|
|
|
0,
|
|
|
|
true,
|
|
|
|
false,
|
|
|
|
false
|
|
|
|
);
|
|
|
|
$table->data[1][1] .= '</div>';
|
2014-01-21 17:42:44 +01:00
|
|
|
|
|
|
|
html_print_table($table);
|
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
$table = new stdClass;
|
2014-01-21 17:42:44 +01:00
|
|
|
$table->class = 'alert_list databox alternate';
|
|
|
|
$table->width = '98%';
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->size = [];
|
|
|
|
$table->head = [];
|
|
|
|
$table->data = [];
|
2014-01-21 17:42:44 +01:00
|
|
|
$table->style[0] = 'width: 100px;';
|
|
|
|
$table->style[1] = 'width: 30%;';
|
|
|
|
$table->style[2] = 'width: 30%;';
|
|
|
|
$table->style[3] = 'font-weight: bold; width: 30%;';
|
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
$table->title = __('Firing fields');
|
|
|
|
$table->title .= ui_print_help_tip(
|
|
|
|
__('Fields passed to the command executed by this action when the alert is fired'),
|
|
|
|
true
|
|
|
|
);
|
2015-06-08 13:13:09 +02:00
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
$table->head[0] = __('Field');
|
|
|
|
$table->head[0] .= ui_print_help_tip(
|
|
|
|
__('Fields configured on the command associated to the action'),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
$table->head[1] = __('Template fields');
|
|
|
|
$table->head[1] .= ui_print_help_tip(
|
|
|
|
__('Triggering fields configured in template'),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
$table->head[2] = __('Action fields');
|
|
|
|
$table->head[2] .= ui_print_help_tip(
|
|
|
|
__('Triggering fields configured in action'),
|
|
|
|
true
|
|
|
|
);
|
2015-06-08 13:13:09 +02:00
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
$table->head[3] = __('Executed on firing');
|
|
|
|
$table->head[3] .= ui_print_help_tip(
|
|
|
|
__('Fields used on execution when the alert is fired'),
|
|
|
|
true
|
|
|
|
);
|
2014-01-21 17:42:44 +01:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$firing_fields = [];
|
2014-03-05 12:34:05 +01:00
|
|
|
|
2014-01-21 17:42:44 +01:00
|
|
|
foreach ($actions as $kaction => $action) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$command = alerts_get_alert_command($action['id_alert_command']);
|
|
|
|
$command_preview = $command['command'];
|
|
|
|
$firing_fields[$kaction] = $action;
|
|
|
|
$firing_fields[$kaction]['command'] = $command['command'];
|
|
|
|
|
|
|
|
$descriptions = json_decode($command['fields_descriptions'], true);
|
|
|
|
|
|
|
|
foreach ($descriptions as $kdesc => $desc) {
|
|
|
|
$field = 'field'.($kdesc + 1);
|
|
|
|
$data = [];
|
2022-02-08 09:38:42 +01:00
|
|
|
$data[0] = $desc;
|
|
|
|
$firing_fields[$kaction]['description'][$field] = $desc;
|
|
|
|
|
|
|
|
if (empty($data[0]) === false) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$data[0] = '<b>'.$data[0].'</b><br>';
|
|
|
|
}
|
|
|
|
|
2021-03-11 15:40:23 +01:00
|
|
|
$data[0] .= '<br><span class="redi xx-small">('.sprintf(
|
|
|
|
__('Field %s'),
|
|
|
|
($kdesc + 1)
|
|
|
|
).')</span>';
|
2019-01-30 16:18:44 +01:00
|
|
|
$data[1] = $template[$field];
|
|
|
|
$data[2] = $action[$field];
|
2022-02-08 09:38:42 +01:00
|
|
|
$data[3] = (empty($action[$field]) === true) ? $template[$field] : $action[$field];
|
|
|
|
|
|
|
|
$firing_fields[$kaction]['value'][$field] = (empty($action[$field]) === true) ? $template[$field] : $action[$field];
|
2019-01-30 16:18:44 +01:00
|
|
|
|
|
|
|
$first_level = $template[$field];
|
|
|
|
$second_level = $action[$field];
|
2022-02-08 09:38:42 +01:00
|
|
|
if (empty($second_level) === false || empty($first_level) === false) {
|
|
|
|
if (empty($second_level) === false) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->cellclass[count($table->data)][1] = 'used_field';
|
|
|
|
$table->cellclass[count($table->data)][2] = 'empty_field';
|
|
|
|
} else {
|
|
|
|
$table->cellclass[count($table->data)][1] = 'overrided_field';
|
|
|
|
$table->cellclass[count($table->data)][2] = 'used_field';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$table->data[] = $data;
|
|
|
|
|
|
|
|
$table->rowstyle[] = 'display: none;';
|
|
|
|
|
|
|
|
$table->rowclass[] = 'firing_action firing_action_'.$kaction;
|
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
if ($command_preview !== 'Internal type') {
|
2019-01-30 16:18:44 +01:00
|
|
|
$command_preview = str_replace('_'.$field.'_', $data[3], $command_preview);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$firing_fields[$kaction]['command_preview'] = $command_preview;
|
2014-01-21 17:42:44 +01:00
|
|
|
}
|
|
|
|
|
2021-03-11 15:40:23 +01:00
|
|
|
echo '<div class="mode_table mode_table_firing action_details invisible w100p">';
|
2014-01-21 17:42:44 +01:00
|
|
|
|
|
|
|
html_print_table($table);
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
foreach ($actions as $kaction => $action) {
|
2021-03-11 15:40:23 +01:00
|
|
|
echo '<div class="firing_action firing_action_'.$kaction.' invisible">';
|
2022-02-08 09:38:42 +01:00
|
|
|
ui_print_info_message(
|
|
|
|
[
|
|
|
|
'title' => __('Command preview'),
|
|
|
|
'message' => $firing_fields[$kaction]['command_preview'],
|
|
|
|
'no_close' => true,
|
|
|
|
]
|
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
echo '</div>';
|
2014-01-21 17:42:44 +01:00
|
|
|
}
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
echo '</div>';
|
2022-02-08 09:38:42 +01:00
|
|
|
// Firing table.
|
2021-03-11 15:40:23 +01:00
|
|
|
echo '<div class="mode_table mode_table_recovering action_details invisible w100p" >';
|
2022-02-08 09:38:42 +01:00
|
|
|
if ((int) $template['recovery_notify'] === 0) {
|
|
|
|
ui_print_info_message(
|
|
|
|
[
|
|
|
|
'title' => __('Disabled'),
|
|
|
|
'message' => __('The alert recovering is disabled on this template.'),
|
|
|
|
'no_close' => true,
|
|
|
|
]
|
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
2022-02-08 09:38:42 +01:00
|
|
|
$table = new stdClass;
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->class = 'alert_list databox alternate';
|
|
|
|
$table->width = '98%';
|
|
|
|
$table->size = [];
|
|
|
|
$table->head = [];
|
|
|
|
$table->data = [];
|
|
|
|
$table->style[0] = 'width: 100px;';
|
|
|
|
$table->style[1] = 'width: 25%;';
|
|
|
|
$table->style[2] = 'width: 25%;';
|
|
|
|
$table->style[3] = 'width: 25%;';
|
|
|
|
$table->style[3] = 'font-weight: bold; width: 25%;';
|
2022-02-08 09:38:42 +01:00
|
|
|
$table->title = __('Recovering fields');
|
|
|
|
$table->title .= ui_print_help_tip(
|
|
|
|
__('Fields passed to the command executed by this action when the alert is recovered'),
|
|
|
|
true
|
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
$table->head[0] = __('Field');
|
|
|
|
$table->head[0] .= ui_print_help_tip(
|
|
|
|
__('Fields configured on the command associated to the action'),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
$table->head[1] = __('Firing fields');
|
|
|
|
$table->head[1] .= ui_print_help_tip(
|
|
|
|
__('Fields used on execution when the alert is fired'),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
$table->head[2] = __('Template recovery fields');
|
|
|
|
$table->head[2] .= ui_print_help_tip(
|
|
|
|
__('Recovery fields configured in alert template'),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
$table->head[3] = __('Action recovery fields');
|
|
|
|
$table->head[3] .= ui_print_help_tip(
|
|
|
|
__('Recovery fields configured in alert action'),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
$table->head[4] = __('Executed on recovery');
|
|
|
|
$table->head[4] .= ui_print_help_tip(
|
|
|
|
__('Fields used on execution when the alert is recovered'),
|
|
|
|
true
|
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->style[4] = 'font-weight: bold;';
|
|
|
|
|
|
|
|
foreach ($firing_fields as $kaction => $firing) {
|
|
|
|
$data = [];
|
|
|
|
$command_preview = $firing_fields[$kaction]['command'];
|
|
|
|
$fieldn = 1;
|
|
|
|
foreach ($firing['description'] as $field => $desc) {
|
|
|
|
$data[0] = $desc;
|
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
if (empty($data[0]) === false) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$data[0] = '<b>'.$data[0].'</b><br>';
|
|
|
|
}
|
|
|
|
|
2021-03-11 15:40:23 +01:00
|
|
|
$data[0] .= '<br><span class="redi xx-small">('.sprintf(
|
|
|
|
__('Field %s'),
|
|
|
|
$fieldn
|
|
|
|
).')</span>';
|
2019-01-30 16:18:44 +01:00
|
|
|
$data[1] = $firing_fields[$kaction]['value'][$field];
|
|
|
|
$data[2] = $template[$field.'_recovery'];
|
|
|
|
$data[3] = $firing_fields[$kaction][$field.'_recovery'];
|
|
|
|
$data[4] = '';
|
|
|
|
|
|
|
|
$first_level = $data[1];
|
|
|
|
$second_level = $data[2];
|
|
|
|
$third_level = $data[3];
|
2022-02-08 09:38:42 +01:00
|
|
|
if (empty($third_level) === false || empty($second_level) === false || empty($first_level) === false) {
|
|
|
|
if (empty($third_level) === false) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->cellclass[count($table->data)][1] = 'overrided_field';
|
|
|
|
$table->cellclass[count($table->data)][2] = 'overrided_field';
|
|
|
|
$table->cellclass[count($table->data)][3] = 'used_field';
|
|
|
|
|
|
|
|
$data[4] = $data[3];
|
2022-02-08 09:38:42 +01:00
|
|
|
} else if (empty($second_level) === false) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->cellclass[count($table->data)][1] = 'overrided_field';
|
|
|
|
$table->cellclass[count($table->data)][2] = 'used_field';
|
|
|
|
$table->cellclass[count($table->data)][3] = 'empty_field';
|
|
|
|
|
|
|
|
$data[4] = $data[2];
|
|
|
|
} else {
|
|
|
|
$table->cellclass[count($table->data)][1] = 'used_field';
|
|
|
|
$table->cellclass[count($table->data)][2] = 'empty_field';
|
|
|
|
$table->cellclass[count($table->data)][3] = 'empty_field';
|
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
// All fields but field1 will have [RECOVER] prefix if no recovery fields are configured.
|
|
|
|
$data[4] = ((int) $fieldn === 1) ? $data[1] : '[RECOVER]'.$data[1];
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$table->data[] = $data;
|
|
|
|
unset($data);
|
|
|
|
|
|
|
|
$table->rowclass[] = 'firing_action firing_action_'.$kaction;
|
|
|
|
|
2022-02-08 09:38:42 +01:00
|
|
|
if ($command_preview !== 'Internal type') {
|
2019-01-30 16:18:44 +01:00
|
|
|
$command_preview = str_replace('_'.$field.'_', $data[4], $command_preview);
|
|
|
|
}
|
|
|
|
|
|
|
|
$fieldn++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
html_print_table($table);
|
|
|
|
unset($table);
|
2022-02-08 09:38:42 +01:00
|
|
|
ui_print_info_message(
|
|
|
|
[
|
|
|
|
'title' => __('Command preview'),
|
|
|
|
'message' => $command_preview,
|
|
|
|
'no_close' => true,
|
|
|
|
]
|
|
|
|
);
|
2014-01-21 17:42:44 +01:00
|
|
|
}
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
echo '</div>';
|
2022-02-08 09:38:42 +01:00
|
|
|
|
|
|
|
ui_require_css_file('main.min', 'include/javascript/fullcalendar/');
|
|
|
|
ui_require_javascript_file('main.min', 'include/javascript/fullcalendar/');
|
|
|
|
ui_require_javascript_file('pandora_fullcalendar');
|
2014-01-21 17:42:44 +01:00
|
|
|
?>
|
|
|
|
|
|
|
|
<script language="javascript" type="text/javascript">
|
|
|
|
$(document).ready (function () {
|
2022-02-08 09:38:42 +01:00
|
|
|
var calendarEl = document.getElementById('calendar_map');
|
|
|
|
if(calendarEl){
|
|
|
|
var eventsBBDD = $("#hidden-schedule").val();
|
|
|
|
if(eventsBBDD === '' || eventsBBDD === 'Array') {
|
|
|
|
eventsBBDD = '';
|
|
|
|
}
|
|
|
|
var events = loadEventBBDD(eventsBBDD);
|
|
|
|
|
|
|
|
var options = {
|
|
|
|
contentHeight: "auto",
|
|
|
|
headerToolbar: {
|
|
|
|
left: "",
|
|
|
|
center: "",
|
|
|
|
right: ''
|
|
|
|
},
|
|
|
|
buttonText: {},
|
|
|
|
dayHeaderFormat: { weekday: "short" },
|
|
|
|
initialView: "dayGridWeek",
|
|
|
|
navLinks: false,
|
|
|
|
selectable: true,
|
|
|
|
selectMirror: true,
|
|
|
|
slotDuration: "01:00:00",
|
|
|
|
slotLabelInterval: "02:00:00",
|
|
|
|
snapDuration: "01:00:00",
|
|
|
|
slotMinTime: "00:00:00",
|
|
|
|
slotMaxTime: "24:00:00",
|
|
|
|
scrollTime: "01:00:00",
|
|
|
|
locale: "en-GB",
|
|
|
|
firstDay: 1,
|
|
|
|
eventTimeFormat: {
|
|
|
|
hour: "numeric",
|
|
|
|
minute: "2-digit",
|
|
|
|
hour12: false
|
|
|
|
},
|
|
|
|
eventColor: "#82b92e",
|
|
|
|
editable: false,
|
|
|
|
dayMaxEvents: 3,
|
|
|
|
dayPopoverFormat: { weekday: "long" },
|
|
|
|
defaultAllDay: false,
|
|
|
|
displayEventTime: true,
|
|
|
|
displayEventEnd: true,
|
|
|
|
selectOverlap: false,
|
|
|
|
eventOverlap: false,
|
|
|
|
allDaySlot: true,
|
|
|
|
droppable: false,
|
|
|
|
select: false,
|
|
|
|
selectAllow: false,
|
|
|
|
eventAllow: false,
|
|
|
|
eventDrop: false,
|
|
|
|
eventDragStop: false,
|
|
|
|
eventResize: false,
|
|
|
|
eventMouseEnter: false,
|
|
|
|
eventMouseLeave: false,
|
|
|
|
eventClick: false,
|
|
|
|
};
|
|
|
|
|
|
|
|
var settings = {}
|
|
|
|
|
|
|
|
var calendar = fullCalendarPandora(calendarEl, options, settings, events);
|
|
|
|
calendar.render();
|
|
|
|
}
|
2014-01-21 17:42:44 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
$('#firing_action_select').change(function() {
|
2019-01-30 16:18:44 +01:00
|
|
|
if($(this).val() == -1) {
|
|
|
|
$('.action_details').hide();
|
|
|
|
$('#modes').val('firing');
|
|
|
|
$('.mode_table_recovering').hide();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$('.action_details').show();
|
|
|
|
}
|
2022-02-08 09:38:42 +01:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$('.firing_action').hide();
|
|
|
|
if($(this).val() != -1) {
|
|
|
|
$('.firing_action_' + $(this).val()).show();
|
|
|
|
$('#modes').trigger('change');
|
|
|
|
}
|
2014-01-21 17:42:44 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
$('#modes').change(function() {
|
2019-01-30 16:18:44 +01:00
|
|
|
$('.mode_table').hide();
|
|
|
|
$('.mode_table_' + $(this).val()).show();
|
2014-01-21 17:42:44 +01:00
|
|
|
});
|
|
|
|
</script>
|