2014-01-21 17:42:44 +01:00
< ? php
2021-11-04 16:28:15 +01:00
// Pandora FMS - http://pandorafms.com
2014-01-21 17:42:44 +01:00
// ==================================================
2020-11-27 13:52:35 +01:00
// Copyright (c) 2005-2021 Artica Soluciones Tecnologicas
2014-01-21 17:42:44 +01:00
// Please see http://pandorafms.org for full contribution list
// 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
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 (
'ACL Violation' ,
'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 );
// 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
// Default action
$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 );
$default_action [ 'name' ] .= ' ' . '(' . __ ( 'Default' ) . ')' ;
$default_action [ 'default' ] = 1 ;
$default_action [ 'module_action_threshold' ] = '0' ;
2014-01-21 17:42:44 +01:00
}
// Header
2019-01-30 16:18:44 +01:00
ui_print_page_header ( __ ( 'Alert details' ), 'images/op_alerts.png' , false , '' , false , '' );
2014-01-21 17:42:44 +01:00
// TABLE DETAILS
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 ;
$title = __ ( 'Alert fired' ) . ' ' . $alert [ 'internal_counter' ] . ' ' . __ ( 'time(s)' );
} 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' );
$data [ 1 ] = $alert [ 'standby' ] == 1 ? __ ( 'Yes' ) : __ ( 'No' );
$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
$policy = '<a href="?sec=gmodules&sec2=enterprise/godmode/policies/policies&id=' . $policyInfo [ 'id' ] . '">' . html_print_image ( $img , true , [ 'title' => $policyInfo [ 'name' ]]) . '</a>' ;
}
$data [ 0 ] = __ ( 'Policy' );
$data [ 1 ] = $policy ;
$table_details -> data [] = $data ;
2014-01-21 17:42:44 +01:00
}
// TABLE DETAILS END
// TABLE CONDITIONS
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' ]) {
$condition = __ ( 'The alert would fire when the value is between <span id="min"></span> and <span id="max"></span>' );
} else {
$condition = __ ( 'The alert would fire when the value is not between <span id="min"></span> and <span id="max"></span>' );
}
$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' );
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 ;
2019-01-30 16:18:44 +01:00
// DAYS
2014-01-21 17:42:44 +01:00
$table_days -> class = 'databox alert_days' ;
$table_days -> width = '100%' ;
2019-01-30 16:18:44 +01:00
$table_days -> size = [];
$table_days -> data = [];
$table_days -> style = [];
2014-01-21 17:42:44 +01:00
$table_days -> styleTable = 'padding: 1px; margin: 0px; text-align: center; height: 80px;' ;
$table_days -> head [ 0 ] = __ ( 'Mon' );
$table_days -> head [ 1 ] = __ ( 'Tue' );
$table_days -> head [ 2 ] = __ ( 'Wed' );
$table_days -> head [ 3 ] = __ ( 'Thu' );
$table_days -> head [ 4 ] = __ ( 'Fri' );
$table_days -> head [ 5 ] = __ ( 'Sat' );
$table_days -> head [ 6 ] = __ ( 'Sun' );
2014-01-23 20:49:16 +01:00
$table_days -> data [ 0 ] = array_fill ( 0 , 7 , html_print_image ( 'images/blade.png' , true ));
2014-01-21 17:42:44 +01:00
2019-01-30 16:18:44 +01:00
$days = [];
2014-01-21 17:42:44 +01:00
if ( $template [ 'monday' ]) {
2021-06-04 13:03:35 +02:00
$table_days -> data [ 0 ][ 0 ] = html_print_image ( 'images/tick.png' , true , [ 'class' => 'invert_filter' ]);
2014-01-21 17:42:44 +01:00
}
2019-01-30 16:18:44 +01:00
2014-01-21 17:42:44 +01:00
if ( $template [ 'tuesday' ]) {
2021-06-04 13:03:35 +02:00
$table_days -> data [ 0 ][ 1 ] = html_print_image ( 'images/tick.png' , true , [ 'class' => 'invert_filter' ]);
2014-01-21 17:42:44 +01:00
}
2019-01-30 16:18:44 +01:00
2014-01-21 17:42:44 +01:00
if ( $template [ 'wednesday' ]) {
2021-06-04 13:03:35 +02:00
$table_days -> data [ 0 ][ 2 ] = html_print_image ( 'images/tick.png' , true , [ 'class' => 'invert_filter' ]);
2014-01-21 17:42:44 +01:00
}
2019-01-30 16:18:44 +01:00
2014-01-21 17:42:44 +01:00
if ( $template [ 'thursday' ]) {
2021-06-04 13:03:35 +02:00
$table_days -> data [ 0 ][ 3 ] = html_print_image ( 'images/tick.png' , true , [ 'class' => 'invert_filter' ]);
2014-01-21 17:42:44 +01:00
}
2019-01-30 16:18:44 +01:00
2014-01-21 17:42:44 +01:00
if ( $template [ 'friday' ]) {
2021-06-04 13:03:35 +02:00
$table_days -> data [ 0 ][ 4 ] = html_print_image ( 'images/tick.png' , true , [ 'class' => 'invert_filter' ]);
2014-01-21 17:42:44 +01:00
}
2019-01-30 16:18:44 +01:00
2014-01-21 17:42:44 +01:00
if ( $template [ 'saturday' ]) {
2021-06-04 13:03:35 +02:00
$table_days -> data [ 0 ][ 5 ] = html_print_image ( 'images/tick.png' , true , [ 'class' => 'invert_filter' ]);
2014-01-21 17:42:44 +01:00
}
2019-01-30 16:18:44 +01:00
2014-01-21 17:42:44 +01:00
if ( $template [ 'sunday' ]) {
2021-06-04 13:03:35 +02:00
$table_days -> data [ 0 ][ 6 ] = html_print_image ( 'images/tick.png' , true , [ 'class' => 'invert_filter' ]);
2014-01-21 17:42:44 +01:00
}
$data [ 0 ] = html_print_table ( $table_days , true );
unset ( $table_days );
// TIME
$table_time -> class = 'databox alert_time' ;
$table_time -> width = '100%' ;
2019-01-30 16:18:44 +01:00
$table_time -> size = [];
$table_time -> data = [];
$table_time -> style = [];
2014-01-21 17:42:44 +01:00
$table_time -> styleTable = 'padding: 1px; margin: 0px; text-align: center; height: 80px; width: 100%;' ;
2019-01-30 16:18:44 +01:00
// $data[0] = __('Time from') . ' / ' . __('Time to');
2014-01-21 17:42:44 +01:00
if ( $template [ 'time_from' ] == $template [ 'time_to' ]) {
2019-01-30 16:18:44 +01:00
$table_time -> head [ 0 ] = '00:00:00<br>-<br>23:59:59' ;
2021-06-04 13:03:35 +02:00
$table_time -> data [ 0 ][ 0 ] = html_print_image ( 'images/tick.png' , true , [ 'class' => 'invert_filter' ]);
2019-01-30 16:18:44 +01:00
} else {
$from_array = explode ( ':' , $template [ 'time_from' ]);
$from = ( $from_array [ 0 ] * SECONDS_1HOUR + $from_array [ 1 ] * SECONDS_1MINUTE + $from_array [ 2 ]);
$to_array = explode ( ':' , $template [ 'time_to' ]);
$to = ( $to_array [ 0 ] * SECONDS_1HOUR + $to_array [ 1 ] * SECONDS_1MINUTE + $to_array [ 2 ]);
if ( $to > $from ) {
if ( $template [ 'time_from' ] != '00:00:00' ) {
$table_time -> head [ 0 ] = '00:00:00<br>-<br>' . $template [ 'time_from' ];
$table_time -> data [ 0 ][ 0 ] = html_print_image ( 'images/blade.png' , true );
}
$table_time -> head [ 1 ] = $template [ 'time_from' ] . '<br>-<br>' . $template [ 'time_to' ];
2021-06-04 13:03:35 +02:00
$table_time -> data [ 0 ][ 1 ] = html_print_image ( 'images/tick.png' , true , [ 'class' => 'invert_filter' ]);
2019-01-30 16:18:44 +01:00
if ( $template [ 'time_to' ] != '23:59:59' ) {
$table_time -> head [ 2 ] = $template [ 'time_to' ] . '<br>-<br>23:59:59' ;
$table_time -> data [ 0 ][ 2 ] = html_print_image ( 'images/blade.png' , true );
}
} else {
if ( $template [ 'time_to' ] != '00:00:00' ) {
$table_time -> head [ 0 ] = '00:00:00<br>-<br>' . $template [ 'time_to' ];
2021-06-04 13:03:35 +02:00
$table_time -> data [ 0 ][ 0 ] = html_print_image ( 'images/tick.png' , true , [ 'class' => 'invert_filter' ]);
2019-01-30 16:18:44 +01:00
}
$table_time -> head [ 1 ] = $template [ 'time_to' ] . '<br>-<br>' . $template [ 'time_from' ];
2021-06-04 13:03:35 +02:00
$table_time -> data [ 0 ][ 1 ] = html_print_image ( 'images/blade.png' , true , [ 'class' => 'invert_filter' ]);
2019-01-30 16:18:44 +01:00
if ( $template [ 'time_from' ] != '23:59:59' ) {
$table_time -> head [ 2 ] = $template [ 'time_from' ] . '<br>-<br>23:59:59' ;
2021-06-04 13:03:35 +02:00
$table_time -> data [ 0 ][ 2 ] = html_print_image ( 'images/tick.png' , true , [ 'class' => 'invert_filter' ]);
2019-01-30 16:18:44 +01:00
}
}
$data [ 1 ] = $template [ 'time_from' ] . ' / ' . $template [ 'time_to' ];
2014-01-21 17:42:44 +01:00
}
$data [ 1 ] = html_print_table ( $table_time , true );
unset ( $table_time );
$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 ;
// TABLE CONDITIONS END
$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 );
// ESCALATION
$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' ];
2021-06-04 13:03:35 +02: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' ];
if ( $kaction == 0 ) {
$table -> data [ $kaction ][ 0 ] .= ui_print_help_tip ( __ ( 'The default actions will be executed every time that the alert is fired and no other action is executed' ), true );
}
foreach ( $action [ 'escalation' ] as $k => $v ) {
if ( $v > 0 ) {
2021-06-04 13:03:35 +02:00
$table -> data [ $kaction ][ $k ] = html_print_image ( 'images/tick.png' , true , [ 'class' => 'invert_filter' ]);
2019-01-30 16:18:44 +01:00
} else {
$table -> data [ $kaction ][ $k ] = html_print_image ( 'images/blade.png' , true );
}
if ( count ( $table -> head ) <= count ( $action [ 'escalation' ])) {
if ( $k == count ( $action [ 'escalation' ])) {
if ( $k == 1 ) {
$table -> head [ $k ] = __ ( 'Every time that the alert is fired' );
} else {
$table -> head [ $k ] = '>#' . ( $k - 1 );
}
} else {
$table -> head [ $k ] = '#' . $k ;
}
}
}
$action_threshold = $action [ 'module_action_threshold' ] > 0 ? $action [ 'module_action_threshold' ] : $action [ 'action_threshold' ];
if ( $action_threshold == 0 ) {
$table -> data [ $kaction ][( $k + 1 )] = __ ( 'No' );
} else {
$table -> data [ $kaction ][( $k + 1 )] = human_time_description_raw ( $action_threshold , true , 'tiny' );
}
2019-05-24 14:26:28 +02:00
$table -> head [( $k + 1 )] = __ ( 'Threshold' );
2019-01-30 16:18:44 +01:00
}
2014-01-23 20:49:16 +01:00
}
html_print_table ( $table );
unset ( $table );
2019-01-30 16:18:44 +01:00
echo '</div>' ;
// ESCALATION TABLE
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;' ;
2014-01-23 20:49:16 +01:00
if ( $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 ;
2019-01-30 16:18:44 +01:00
$table -> data [ 1 ][ 0 ] = __ ( 'Action' ) . '<br>' . 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' );
2021-03-11 15:40:23 +01:00
$table -> data [ 1 ][ 1 ] = '<div class="action_details invisible" >' . __ ( 'Mode' ) . '<br>' . html_print_select ( $modes , 'modes' , 'firing' , '' , '' , 0 , true , false , false ) . '</div>' ;
2014-01-21 17:42:44 +01:00
html_print_table ( $table );
unset ( $table );
$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%;' ;
2019-01-30 16:18:44 +01:00
$table -> title = __ ( 'Firing fields' ) . 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
2019-01-30 16:18:44 +01:00
$table -> head [ 0 ] = __ ( 'Field' ) . ui_print_help_tip ( __ ( 'Fields configured on the command associated to the action' ), true );
$table -> head [ 1 ] = __ ( 'Template fields' ) . ui_print_help_tip ( __ ( 'Triggering fields configured in template' ), true );
$table -> head [ 2 ] = __ ( 'Action fields' ) . ui_print_help_tip ( __ ( 'Triggering fields configured in action' ), true );
2015-06-08 13:13:09 +02:00
2019-01-30 16:18:44 +01:00
$table -> head [ 3 ] = __ ( 'Executed on firing' ) . 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 ) {
if ( empty ( $desc )) {
// continue;
}
$field = 'field' . ( $kdesc + 1 );
$data = [];
$data [ 0 ] = $firing_fields [ $kaction ][ 'description' ][ $field ] = $desc ;
if ( ! empty ( $data [ 0 ])) {
$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 ];
$data [ 3 ] = $firing_fields [ $kaction ][ 'value' ][ $field ] = empty ( $action [ $field ]) ? $template [ $field ] : $action [ $field ];
$first_level = $template [ $field ];
$second_level = $action [ $field ];
if ( ! empty ( $second_level ) || ! empty ( $first_level )) {
if ( empty ( $second_level )) {
$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 ;
if ( $command_preview != 'Internal type' ) {
$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 );
unset ( $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">' ;
2019-01-30 16:18:44 +01:00
ui_print_info_message ([ 'title' => __ ( 'Command preview' ), 'message' => $firing_fields [ $kaction ][ 'command_preview' ], 'no_close' => true ]);
echo '</div>' ;
2014-01-21 17:42:44 +01:00
}
2019-01-30 16:18:44 +01:00
echo '</div>' ;
// Firing table
2021-03-11 15:40:23 +01:00
echo '<div class="mode_table mode_table_recovering action_details invisible w100p" >' ;
2014-01-21 17:42:44 +01:00
if ( $template [ 'recovery_notify' ] == 0 ) {
2019-01-30 16:18:44 +01:00
ui_print_info_message ([ 'title' => __ ( 'Disabled' ), 'message' => __ ( 'The alert recovering is disabled on this template.' ), 'no_close' => true ]);
} else {
$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%;' ;
$table -> title = __ ( 'Recovering fields' ) . ui_print_help_tip ( __ ( 'Fields passed to the command executed by this action when the alert is recovered' ), true );
$table -> head [ 0 ] = __ ( 'Field' ) . ui_print_help_tip ( __ ( 'Fields configured on the command associated to the action' ), true );
$table -> head [ 1 ] = __ ( 'Firing fields' ) . ui_print_help_tip ( __ ( 'Fields used on execution when the alert is fired' ), true );
$table -> head [ 2 ] = __ ( 'Template recovery fields' ) . ui_print_help_tip ( __ ( 'Recovery fields configured in alert template' ), true );
$table -> head [ 3 ] = __ ( 'Action recovery fields' ) . ui_print_help_tip ( __ ( 'Recovery fields configured in alert action' ), true );
$table -> head [ 4 ] = __ ( 'Executed on recovery' ) . ui_print_help_tip ( __ ( 'Fields used on execution when the alert is recovered' ), true );
$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 ;
if ( ! empty ( $data [ 0 ])) {
$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 ];
if ( ! empty ( $third_level ) || ! empty ( $second_level ) || ! empty ( $first_level )) {
if ( ! empty ( $third_level )) {
$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 ];
} else if ( ! empty ( $second_level )) {
$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' ;
// All fields but field1 will have [RECOVER] prefix if no recovery fields are configured
$data [ 4 ] = $fieldn == 1 ? $data [ 1 ] : '[RECOVER]' . $data [ 1 ];
}
}
$table -> data [] = $data ;
unset ( $data );
$table -> rowclass [] = 'firing_action firing_action_' . $kaction ;
if ( $command_preview != 'Internal type' ) {
$command_preview = str_replace ( '_' . $field . '_' , $data [ 4 ], $command_preview );
}
$fieldn ++ ;
}
}
html_print_table ( $table );
unset ( $table );
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>' ;
// Recovering table
2014-01-21 17:42:44 +01:00
?>
< script language = " javascript " type = " text/javascript " >
$ ( document ) . ready ( function () {
2019-01-30 16:18:44 +01:00
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 ();
}
$ ( '.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 >