2012-08-23 16:24:43 +02:00
< ? php
2019-04-24 13:53:18 +02:00
/**
* Extension to manage a list of gateways and the node address where they should
* point to .
*
* @ category Planned Donwtimes
* @ package Pandora FMS
* @ subpackage Community
* @ version 1.0 . 0
* @ license See below
*
* ______ ___ _______ _______ ________
2023-06-08 12:42:10 +02:00
* | __ \ .-----.--.--.--| |.-----.----.-----. | ___ | | | __ |
* | __ /| _ | | _ || _ | _ | _ | | ___ | | __ |
2019-04-24 13:53:18 +02: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
2019-04-24 13:53:18 +02: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 .
* ============================================================================
*/
2012-08-23 16:24:43 +02:00
global $config ;
check_login ();
2019-01-30 16:18:44 +01:00
$agent_d = check_acl ( $config [ 'id_user' ], 0 , 'AD' );
$agent_w = check_acl ( $config [ 'id_user' ], 0 , 'AW' );
2016-09-08 16:06:12 +02:00
$access = ( $agent_d == true ) ? 'AD' : (( $agent_w == true ) ? 'AW' : 'AD' );
if ( ! $agent_d && ! $agent_w ) {
2019-01-30 16:18:44 +01:00
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 downtime scheduler'
);
include 'general/noaccess.php' ;
return ;
2012-08-23 16:24:43 +02:00
}
2019-04-24 13:53:18 +02:00
// Default.
2019-01-30 16:18:44 +01:00
set_unless_defined ( $config [ 'past_planned_downtimes' ], 1 );
2014-08-01 12:36:19 +02:00
2019-01-30 16:18:44 +01:00
require_once 'include/functions_users.php' ;
2022-08-16 18:42:51 +02:00
require_once $config [ 'homedir' ] . '/include/functions_cron.php' ;
2012-08-23 16:24:43 +02:00
2019-04-24 13:53:18 +02:00
// Buttons.
2019-01-30 16:18:44 +01:00
$buttons = [
2019-04-24 13:53:18 +02:00
'text' => " <a href='index.php?sec=extensions&sec2=godmode/agentes/planned_downtime.list'> " . html_print_image (
2023-03-08 15:02:12 +01:00
'images/logs@svg.svg' ,
2019-04-24 13:53:18 +02:00
true ,
2021-03-11 15:40:23 +01:00
[
'title' => __ ( 'List' ),
2023-03-08 15:02:12 +01:00
'class' => 'main_menu_icon invert_filter' ,
2021-03-11 15:40:23 +01:00
]
2019-04-24 13:53:18 +02:00
) . '</a>' ,
2019-01-30 16:18:44 +01:00
];
2015-05-25 19:54:11 +02:00
2019-04-24 13:53:18 +02:00
// Header.
2023-03-08 15:02:12 +01:00
ui_print_standard_header (
2021-05-10 11:06:43 +02:00
__ ( 'Scheduled Downtime' ),
2019-01-30 16:18:44 +01:00
'images/gm_monitoring.png' ,
false ,
2020-05-29 11:37:06 +02:00
'' ,
2019-01-30 16:18:44 +01:00
true ,
2023-03-08 15:02:12 +01:00
$buttons ,
[
[
'link' => '' ,
'label' => __ ( 'Tools' ),
],
[
'link' => '' ,
'label' => __ ( 'Scheduled Downtime' ),
],
]
2019-01-30 16:18:44 +01:00
);
2019-04-24 13:53:18 +02:00
// Recursion group filter.
2016-10-14 18:51:17 +02:00
$recursion = get_parameter ( 'recursion' , $_POST [ 'recursion' ]);
2021-03-04 16:27:14 +01:00
2019-04-24 13:53:18 +02:00
// Initialize data.
$id_group = ( int ) get_parameter ( 'id_group' );
$name = ( string ) get_parameter ( 'name' );
$description = ( string ) get_parameter ( 'description' );
2012-08-23 16:24:43 +02:00
2019-04-24 13:53:18 +02:00
$type_downtime = ( string ) get_parameter ( 'type_downtime' , 'quiet' );
$type_execution = ( string ) get_parameter ( 'type_execution' , 'once' );
$type_periodicity = ( string ) get_parameter ( 'type_periodicity' , 'weekly' );
2012-08-23 16:24:43 +02:00
2018-06-11 16:40:10 +02:00
$utimestamp = get_system_time ();
2019-04-24 13:53:18 +02:00
// Fake utimestamp to retrieve the string date of the system.
2019-01-30 16:18:44 +01:00
$system_time = ( $utimestamp - get_fixed_offset ());
2019-04-24 13:53:18 +02:00
$once_date_from = ( string ) get_parameter (
'once_date_from' ,
date ( DATE_FORMAT , $utimestamp )
);
$once_time_from = ( string ) get_parameter (
'once_time_from' ,
date ( TIME_FORMAT , $utimestamp )
);
$once_date_to = ( string ) get_parameter (
'once_date_to' ,
date ( DATE_FORMAT , $utimestamp )
);
$once_time_to = ( string ) get_parameter (
'once_time_to' ,
date ( TIME_FORMAT , ( $utimestamp + SECONDS_1HOUR ))
);
$periodically_day_from = ( int ) get_parameter (
'periodically_day_from' ,
1
);
$periodically_day_to = ( int ) get_parameter (
'periodically_day_to' ,
31
);
$periodically_time_from = ( string ) get_parameter (
'periodically_time_from' ,
date ( TIME_FORMAT , $system_time )
);
$periodically_time_to = ( string ) get_parameter (
'periodically_time_to' ,
date ( TIME_FORMAT , ( $system_time + SECONDS_1HOUR ))
);
2022-08-16 18:42:51 +02:00
$hour_from = get_parameter ( 'cron_hour_from' , '*' );
$minute_from = get_parameter ( 'cron_minute_from' , '*' );
$mday_from = get_parameter ( 'cron_mday_from' , '*' );
$month_from = get_parameter ( 'cron_month_from' , '*' );
$wday_from = get_parameter ( 'cron_wday_from' , '*' );
$hour_to = get_parameter ( 'cron_hour_to' , '*' );
$minute_to = get_parameter ( 'cron_minute_to' , '*' );
$mday_to = get_parameter ( 'cron_mday_to' , '*' );
$month_to = get_parameter ( 'cron_month_to' , '*' );
$wday_to = get_parameter ( 'cron_wday_to' , '*' );
2019-04-24 13:53:18 +02:00
$monday = ( bool ) get_parameter ( 'monday' );
$tuesday = ( bool ) get_parameter ( 'tuesday' );
$wednesday = ( bool ) get_parameter ( 'wednesday' );
$thursday = ( bool ) get_parameter ( 'thursday' );
$friday = ( bool ) get_parameter ( 'friday' );
$saturday = ( bool ) get_parameter ( 'saturday' );
$sunday = ( bool ) get_parameter ( 'sunday' );
$first_create = ( int ) get_parameter ( 'first_create' );
$create_downtime = ( int ) get_parameter ( 'create_downtime' );
$update_downtime = ( int ) get_parameter ( 'update_downtime' );
$edit_downtime = ( int ) get_parameter ( 'edit_downtime' );
2022-01-27 18:23:07 +01:00
$downtime_copy = ( int ) get_parameter ( 'downtime_copy' );
2019-04-24 13:53:18 +02:00
$id_downtime = ( int ) get_parameter ( 'id_downtime' );
$id_agent = ( int ) get_parameter ( 'id_agent' );
$insert_downtime_agent = ( int ) get_parameter ( 'insert_downtime_agent' );
$delete_downtime_agent = ( int ) get_parameter ( 'delete_downtime_agent' );
2012-08-23 16:24:43 +02:00
2017-09-08 12:32:21 +02:00
$modules_selection_mode = ( string ) get_parameter ( 'modules_selection_mode' );
2019-04-24 13:53:18 +02:00
// User groups with AD or AW permission for ACL checks.
$user_groups_ad = array_keys (
users_get_groups ( $config [ 'id_user' ], $access )
);
2015-07-16 13:53:57 +02:00
2019-04-24 13:53:18 +02:00
// INSERT A NEW DOWNTIME_AGENT ASSOCIATION.
2015-05-25 19:54:11 +02:00
if ( $insert_downtime_agent === 1 ) {
2021-03-04 16:27:14 +01:00
insert_downtime_agent ( $id_downtime , $user_groups_ad );
2012-08-23 16:24:43 +02:00
}
2019-04-24 13:53:18 +02:00
// DELETE A DOWNTIME_AGENT ASSOCIATION.
2015-05-25 19:54:11 +02:00
if ( $delete_downtime_agent === 1 ) {
2019-01-30 16:18:44 +01:00
$id_da = ( int ) get_parameter ( 'id_downtime_agent' );
2019-04-24 13:53:18 +02:00
// Check AD permission on downtime.
$downtime_group = db_get_value (
'id_group' ,
'tplanned_downtime' ,
'id' ,
$id_downtime
);
2019-01-30 16:18:44 +01:00
2019-04-24 13:53:18 +02:00
if ( $downtime_group === false
|| ! in_array ( $downtime_group , $user_groups_ad )
) {
2019-01-30 16:18:44 +01:00
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 downtime scheduler'
);
include 'general/noaccess.php' ;
return ;
}
2019-04-24 13:53:18 +02:00
// Check AD permission on agent.
$agent_group = db_get_value (
'id_grupo' ,
'tagente' ,
'id_agente' ,
$id_agent
);
2019-01-30 16:18:44 +01:00
2019-04-24 13:53:18 +02:00
if ( $agent_group === false
|| ! in_array ( $agent_group , $user_groups_ad )
) {
2019-01-30 16:18:44 +01:00
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 downtime scheduler'
);
include 'general/noaccess.php' ;
return ;
}
2019-04-24 13:53:18 +02:00
// 'Is running' check.
$is_running = ( bool ) db_get_value (
'executed' ,
'tplanned_downtime' ,
'id' ,
$id_downtime
);
2019-01-30 16:18:44 +01:00
if ( $is_running ) {
2019-04-24 13:53:18 +02:00
ui_print_error_message (
__ ( 'This elements cannot be modified while the downtime is being executed' )
);
2019-01-30 16:18:44 +01:00
} else {
$row_to_delete = db_get_row ( 'tplanned_downtime_agents' , 'id' , $id_da );
2019-04-24 13:53:18 +02:00
$result = db_process_sql_delete (
'tplanned_downtime_agents' ,
[ 'id' => $id_da ]
);
2019-01-30 16:18:44 +01:00
if ( $result ) {
2019-04-24 13:53:18 +02:00
// Delete modules in downtime.
2019-01-30 16:18:44 +01:00
db_process_sql_delete (
'tplanned_downtime_modules' ,
[
'id_downtime' => $row_to_delete [ 'id_downtime' ],
'id_agent' => $id_agent ,
]
);
}
}
2012-08-23 16:24:43 +02:00
}
2019-04-24 13:53:18 +02:00
// UPDATE OR CREATE A DOWNTIME (MAIN DATA, NOT AGENT ASSOCIATION).
2012-08-23 16:24:43 +02:00
if ( $create_downtime || $update_downtime ) {
2019-01-30 16:18:44 +01:00
$check = ( bool ) db_get_value ( 'name' , 'tplanned_downtime' , 'name' , $name );
$datetime_from = strtotime ( $once_date_from . ' ' . $once_time_from );
$datetime_to = strtotime ( $once_date_to . ' ' . $once_time_to );
$now = time ();
if ( $type_execution == 'once' && ! $config [ 'past_planned_downtimes' ] && $datetime_from < $now ) {
2019-04-24 13:53:18 +02:00
ui_print_error_message (
__ ( 'Not created. Error inserting data. Start time must be higher than the current time' )
);
2019-01-30 16:18:44 +01:00
} else if ( $type_execution == 'once' && $datetime_from >= $datetime_to ) {
2019-04-24 13:53:18 +02:00
ui_print_error_message (
__ ( 'Not created. Error inserting data' ) . '. ' . __ ( 'The end date must be higher than the start date' )
);
2019-01-30 16:18:44 +01:00
} else if ( $type_execution == 'once' && $datetime_to <= $now && ! $config [ 'past_planned_downtimes' ]) {
2019-04-24 13:53:18 +02:00
ui_print_error_message (
__ ( 'Not created. Error inserting data' ) . '. ' . __ ( 'The end date must be higher than the current time' )
);
2019-01-30 16:18:44 +01:00
} else if ( $type_execution == 'periodically'
2020-10-07 14:49:46 +02:00
&& $type_periodicity == 'monthly'
&& $periodically_day_from == $periodically_day_to
2021-12-29 18:27:18 +01:00
&& $periodically_time_from >= $periodically_time_to
2019-01-30 16:18:44 +01:00
) {
2019-04-24 13:53:18 +02:00
ui_print_error_message (
__ ( 'Not created. Error inserting data' ) . '. ' . __ ( 'The end time must be higher than the start time' )
);
2019-01-30 16:18:44 +01:00
} else if ( $type_execution == 'periodically' && $type_periodicity == 'monthly' && $periodically_day_from > $periodically_day_to ) {
2019-04-24 13:53:18 +02:00
ui_print_error_message (
__ ( 'Not created. Error inserting data' ) . '. ' . __ ( 'The end day must be higher than the start day' )
);
2019-01-30 16:18:44 +01:00
} else {
$sql = '' ;
2022-08-17 13:31:12 +02:00
$error_cron_from = false ;
$error_cron_to = false ;
$error_field = '' ;
2022-08-16 18:42:51 +02:00
if ( $type_execution === 'cron' ) {
// Validate 'from' cron values.
$hour_from = io_safe_output ( trim ( $hour_from ));
if ( preg_match ( '/^((?:([0-1]?[0-9]|2[0-3])|\*)\s*(?:(?:[\/-]([0-1]?[0-9]|2[0-3])))?\s*)$/' , $hour_from , $matches ) !== 1 ) {
$error_cron_from = true ;
$error_field = __ ( 'hour (from)' );
} else {
$interval_values = explode ( '-' , $hour_from );
if ( count ( $interval_values ) > 1 ) {
$interval_from = $interval_values [ 0 ];
$interval_to = $interval_values [ 1 ];
if (( int ) $interval_to < ( int ) $interval_from ) {
$error_cron_from = true ;
}
}
}
$minute_from = io_safe_output ( trim ( $minute_from ));
if ( preg_match ( '/^((?:(5[0-9]|[0-5]?[0-9])|\*)\s*(?:(?:[\/-](5[0-9]|[0-5]?[0-9])))?\s*)$/' , $minute_from , $matches ) !== 1 ) {
$error_cron_from = true ;
$error_field = __ ( 'minute (from)' );
} else {
$interval_values = explode ( '-' , $minute_from );
if ( count ( $interval_values ) > 1 ) {
$interval_from = $interval_values [ 0 ];
$interval_to = $interval_values [ 1 ];
if (( int ) $interval_to < ( int ) $interval_from ) {
$error_cron_from = true ;
}
}
}
$mday_from = io_safe_output ( trim ( $mday_from ));
if ( preg_match ( '/^((?:(0?[1-9]|[12][0-9]|3[01])|\*)\s*(?:(?:[\/-](0?[1-9]|[12][0-9]|3[01])))?\s*)$/' , $mday_from , $matches ) !== 1 ) {
$error_cron_from = true ;
$error_field = __ ( 'month day (from)' );
} else {
$interval_values = explode ( '-' , $mday_from );
if ( count ( $interval_values ) > 1 ) {
$interval_from = $interval_values [ 0 ];
$interval_to = $interval_values [ 1 ];
if (( int ) $interval_to < ( int ) $interval_from ) {
$error_cron_from = true ;
}
}
}
$month_from = io_safe_output ( trim ( $month_from ));
if ( preg_match ( '/^((?:([1-9]|1[012])|\*)\s*(?:(?:[\/-]([1-9]|1[012])))?\s*)$/' , $month_from , $matches ) !== 1 ) {
$error_cron_from = true ;
$error_field = __ ( 'month (from)' );
} else {
$interval_values = explode ( '-' , $month_from );
if ( count ( $interval_values ) > 1 ) {
$interval_from = $interval_values [ 0 ];
$interval_to = $interval_values [ 1 ];
if (( int ) $interval_to < ( int ) $interval_from ) {
$error_cron_from = true ;
}
}
}
$wday_from = io_safe_output ( trim ( $wday_from ));
if ( preg_match ( '/^((?:[0-6]|\*)\s*(?:(?:[\/-][0-6]))?\s*)$/' , $wday_from , $matches ) !== 1 ) {
$error_cron_from = true ;
$error_field = __ ( 'week day (from)' );
} else {
$interval_values = explode ( '-' , $wday_from );
if ( count ( $interval_values ) > 1 ) {
$interval_from = $interval_values [ 0 ];
$interval_to = $interval_values [ 1 ];
if (( int ) $interval_to < ( int ) $interval_from ) {
$error_cron_from = true ;
}
}
}
// Validate 'to' cron values.
$hour_to = io_safe_output ( trim ( $hour_to ));
if ( preg_match ( '/^((?:([0-1]?[0-9]|2[0-3])|\*)\s*(?:(?:[\/-]([0-1]?[0-9]|2[0-3])))?\s*)$/' , $hour_to , $matches ) !== 1 ) {
$error_cron_to = true ;
$error_field = __ ( 'hour (to)' );
} else {
$interval_values = explode ( '-' , $hour_to );
if ( count ( $interval_values ) > 1 ) {
$interval_from = $interval_values [ 0 ];
$interval_to = $interval_values [ 1 ];
if (( int ) $interval_to < ( int ) $interval_from ) {
$error_cron_to = true ;
}
}
}
$minute_to = io_safe_output ( trim ( $minute_to ));
if ( preg_match ( '/^((?:(5[0-9]|[0-5]?[0-9])|\*)\s*(?:(?:[\/-](5[0-9]|[0-5]?[0-9])))?\s*)$/' , $minute_to , $matches ) !== 1 ) {
$error_cron_to = true ;
$error_field = __ ( 'minute (to)' );
} else {
$interval_values = explode ( '-' , $minute_to );
if ( count ( $interval_values ) > 1 ) {
$interval_from = $interval_values [ 0 ];
$interval_to = $interval_values [ 1 ];
if (( int ) $interval_to < ( int ) $interval_from ) {
$error_cron_to = true ;
}
}
}
$mday_to = io_safe_output ( trim ( $mday_to ));
if ( preg_match ( '/^((?:(0?[1-9]|[12][0-9]|3[01])|\*)\s*(?:(?:[\/-](0?[1-9]|[12][0-9]|3[01])))?\s*)$/' , $mday_to , $matches ) !== 1 ) {
$error_cron_to = true ;
$error_field = __ ( 'month day (to)' );
} else {
$interval_values = explode ( '-' , $mday_to );
if ( count ( $interval_values ) > 1 ) {
$interval_from = $interval_values [ 0 ];
$interval_to = $interval_values [ 1 ];
if (( int ) $interval_to < ( int ) $interval_from ) {
$error_cron_to = true ;
}
}
}
$month_to = io_safe_output ( trim ( $month_to ));
if ( preg_match ( '/^((?:([1-9]|1[012])|\*)\s*(?:(?:[\/-]([1-9]|1[012])))?\s*)$/' , $month_to , $matches ) !== 1 ) {
$error_cron_to = true ;
$error_field = __ ( 'month (to)' );
} else {
$interval_values = explode ( '-' , $month_to );
if ( count ( $interval_values ) > 1 ) {
$interval_from = $interval_values [ 0 ];
$interval_to = $interval_values [ 1 ];
if (( int ) $interval_to < ( int ) $interval_from ) {
$error_cron_to = true ;
}
}
}
$wday_to = io_safe_output ( trim ( $wday_to ));
if ( preg_match ( '/^((?:[0-6]|\*)\s*(?:(?:[\/-][0-6]))?\s*)$/' , $wday_to , $matches ) !== 1 ) {
$error_cron_to = true ;
$error_field = __ ( 'week day (to)' );
} else {
$interval_values = explode ( '-' , $wday_to );
if ( count ( $interval_values ) > 1 ) {
$interval_from = $interval_values [ 0 ];
$interval_to = $interval_values [ 1 ];
if (( int ) $interval_to < ( int ) $interval_from ) {
$error_cron_to = true ;
}
}
}
$cron_interval_from = io_safe_output ( $minute_from . ' ' . $hour_from . ' ' . $mday_from . ' ' . $month_from . ' ' . $wday_from );
$cron_interval_to = io_safe_output ( $minute_to . ' ' . $hour_to . ' ' . $mday_to . ' ' . $month_to . ' ' . $wday_to );
}
if ( cron_check_syntax ( $cron_interval_from ) !== 1 ) {
$cron_interval_from = '' ;
}
if ( cron_check_syntax ( $cron_interval_to ) !== 1 ) {
$cron_interval_to = '' ;
}
2019-01-30 16:18:44 +01:00
if ( $create_downtime ) {
2019-04-24 13:53:18 +02:00
// Check AD permission on new downtime.
2019-01-30 16:18:44 +01:00
if ( ! in_array ( $id_group , $user_groups_ad )) {
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 downtime scheduler'
);
include 'general/noaccess.php' ;
return ;
}
2022-08-17 13:31:12 +02:00
if ( $error_cron_to === true || $error_cron_from === true ) {
if ( $error_cron_from === true ) {
ui_print_error_message (
__ ( 'Downtime start cron expression is not correct' ) . ': ' . $error_field
);
}
2019-01-30 16:18:44 +01:00
2022-08-17 13:31:12 +02:00
if ( $error_cron_to === true ) {
ui_print_error_message (
__ ( 'Downtime stop cron expression is not correct' ) . ': ' . $error_field
2019-04-24 13:53:18 +02:00
);
2022-08-17 13:31:12 +02:00
}
$result = false ;
} else {
if ( trim ( io_safe_output ( $name )) != '' ) {
if ( ! $check ) {
$values = [
'name' => $name ,
'description' => $description ,
'date_from' => $datetime_from ,
'date_to' => $datetime_to ,
'executed' => 0 ,
'id_group' => $id_group ,
'only_alerts' => 0 ,
'monday' => $monday ,
'tuesday' => $tuesday ,
'wednesday' => $wednesday ,
'thursday' => $thursday ,
'friday' => $friday ,
'saturday' => $saturday ,
'sunday' => $sunday ,
'periodically_time_from' => $periodically_time_from ,
'periodically_time_to' => $periodically_time_to ,
'periodically_day_from' => $periodically_day_from ,
'periodically_day_to' => $periodically_day_to ,
'type_downtime' => $type_downtime ,
'type_execution' => $type_execution ,
'type_periodicity' => $type_periodicity ,
'id_user' => $config [ 'id_user' ],
'cron_interval_from' => $cron_interval_from ,
'cron_interval_to' => $cron_interval_to ,
];
if ( $config [ 'dbtype' ] == 'oracle' ) {
$values [ 'periodically_time_from' ] = '1970/01/01 ' . $values [ 'periodically_time_from' ];
$values [ 'periodically_time_to' ] = '1970/01/01 ' . $values [ 'periodically_time_to' ];
}
$result = db_process_sql_insert (
'tplanned_downtime' ,
$values
);
} else {
ui_print_error_message (
__ ( 'Each scheduled downtime must have a different name' )
);
}
2019-01-30 16:18:44 +01:00
} else {
ui_print_error_message (
2022-08-17 13:31:12 +02:00
__ ( 'Scheduled downtime must have a name' )
2019-01-30 16:18:44 +01:00
);
}
}
} else if ( $update_downtime ) {
$old_downtime = db_get_row ( 'tplanned_downtime' , 'id' , $id_downtime );
2019-04-24 13:53:18 +02:00
// Check AD permission on OLD downtime.
2019-01-30 16:18:44 +01:00
if ( empty ( $old_downtime ) || ! in_array ( $old_downtime [ 'id_group' ], $user_groups_ad )) {
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 downtime scheduler'
);
include 'general/noaccess.php' ;
return ;
}
2019-04-24 13:53:18 +02:00
// Check AD permission on NEW downtime group.
2019-01-30 16:18:44 +01:00
if ( ! in_array ( $id_group , $user_groups_ad )) {
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 downtime scheduler'
);
include 'general/noaccess.php' ;
return ;
}
2019-04-24 13:53:18 +02:00
// 'Is running' check.
2019-01-30 16:18:44 +01:00
$is_running = ( bool ) $old_downtime [ 'executed' ];
$values = [];
if ( trim ( io_safe_output ( $name )) == '' ) {
2019-04-24 13:53:18 +02:00
ui_print_error_message (
2021-05-10 11:06:43 +02:00
__ ( 'Scheduled downtime must have a name' )
2019-04-24 13:53:18 +02:00
);
2019-01-30 16:18:44 +01:00
}
2019-04-24 13:53:18 +02:00
// When running only certain items can be modified for the 'once' type.
2019-01-30 16:18:44 +01:00
else if ( $is_running && $type_execution == 'once' ) {
$values = [
'description' => $description ,
'date_to' => $datetime_to ,
'id_user' => $config [ 'id_user' ],
];
} else {
$values = [
'name' => $name ,
'description' => $description ,
'date_from' => $datetime_from ,
'date_to' => $datetime_to ,
'id_group' => $id_group ,
'only_alerts' => 0 ,
'monday' => $monday ,
'tuesday' => $tuesday ,
'wednesday' => $wednesday ,
'thursday' => $thursday ,
'friday' => $friday ,
'saturday' => $saturday ,
'sunday' => $sunday ,
'periodically_time_from' => $periodically_time_from ,
'periodically_time_to' => $periodically_time_to ,
'periodically_day_from' => $periodically_day_from ,
'periodically_day_to' => $periodically_day_to ,
'type_downtime' => $type_downtime ,
'type_execution' => $type_execution ,
'type_periodicity' => $type_periodicity ,
'id_user' => $config [ 'id_user' ],
2022-08-16 18:42:51 +02:00
'cron_interval_from' => $cron_interval_from ,
'cron_interval_to' => $cron_interval_to ,
2019-01-30 16:18:44 +01:00
];
if ( $config [ 'dbtype' ] == 'oracle' ) {
$values [ 'periodically_time_from' ] = '1970/01/01 ' . $values [ 'periodically_time_from' ];
$values [ 'periodically_time_to' ] = '1970/01/01 ' . $values [ 'periodically_time_to' ];
}
}
2022-08-17 13:31:12 +02:00
if ( $error_cron_to === true || $error_cron_from === true ) {
if ( $error_cron_from === true ) {
ui_print_error_message (
__ ( 'Downtime start cron expression is not correct' ) . ': ' . $error_field
);
}
if ( $error_cron_to === true ) {
ui_print_error_message (
__ ( 'Downtime stop cron expression is not correct' ) . ': ' . $error_field
);
}
2021-03-10 13:02:17 +01:00
$result = false ;
2021-03-04 16:27:14 +01:00
} else {
2022-08-17 13:31:12 +02:00
if ( $is_running ) {
$result = false ;
} else {
if ( ! empty ( $values )) {
$result = db_process_sql_update (
'tplanned_downtime' ,
$values ,
[ 'id' => $id_downtime ]
);
}
2021-03-04 16:27:14 +01:00
}
2019-01-30 16:18:44 +01:00
}
}
if ( $result === false ) {
if ( $create_downtime ) {
ui_print_error_message ( __ ( 'Could not be created' ));
} else {
ui_print_error_message ( __ ( 'Could not be updated' ));
}
} else {
if ( $create_downtime && $name && ! $check ) {
$id_downtime = $result ;
2021-03-04 16:27:14 +01:00
insert_downtime_agent ( $id_downtime , $user_groups_ad );
2019-01-30 16:18:44 +01:00
ui_print_success_message ( __ ( 'Successfully created' ));
} else if ( $update_downtime && $name ) {
ui_print_success_message ( __ ( 'Successfully updated' ));
}
}
}
2012-08-23 16:24:43 +02:00
}
2022-01-27 18:23:07 +01:00
if ( $downtime_copy ) {
$result = planned_downtimes_copy ( $id_downtime );
2022-01-28 10:59:08 +01:00
if ( $result [ 'id_downtime' ] !== false ) {
$id_downtime = $result [ 'id_downtime' ];
ui_print_success_message ( $result [ 'success' ]);
2022-01-27 18:23:07 +01:00
} else {
2022-01-28 10:59:08 +01:00
ui_print_error_message ( __ ( $result [ 'error' ]));
2022-01-27 18:23:07 +01:00
}
}
2012-08-23 16:24:43 +02:00
// Have any data to show ?
if ( $id_downtime > 0 ) {
2019-04-24 13:53:18 +02:00
// Columns of the table tplanned_downtime.
2019-01-30 16:18:44 +01:00
$columns = [
'id' ,
'name' ,
'description' ,
'date_from' ,
'date_to' ,
'executed' ,
'id_group' ,
'only_alerts' ,
'monday' ,
'tuesday' ,
'wednesday' ,
'thursday' ,
'friday' ,
'saturday' ,
'sunday' ,
'periodically_time_from' ,
'periodically_time_to' ,
'periodically_day_from' ,
'periodically_day_to' ,
'type_downtime' ,
'type_execution' ,
'type_periodicity' ,
'id_user' ,
2022-08-16 18:42:51 +02:00
'cron_interval_from' ,
'cron_interval_to' ,
2019-01-30 16:18:44 +01:00
];
switch ( $config [ 'dbtype' ]) {
case 'mysql' :
case 'postgresql' :
$columns_str = implode ( ',' , $columns );
$sql = " SELECT $columns_str
2021-03-04 16:27:14 +01:00
FROM tplanned_downtime
WHERE id = $id_downtime " ;
2019-01-30 16:18:44 +01:00
break ;
case 'oracle' :
2019-04-24 13:53:18 +02:00
// Oracle doesn't have TIME type,
// so we should transform the DATE value.
2019-01-30 16:18:44 +01:00
$new_time_from = " TO_CHAR(periodically_time_from, 'HH24:MI:SS') AS periodically_time_from " ;
$new_time_to = " TO_CHAR(periodically_time_to, 'HH24:MI:SS') AS periodically_time_to " ;
$time_from_key = array_search ( 'periodically_time_from' , $columns );
$time_to_key = array_search ( 'periodically_time_to' , $columns );
if ( $time_from_key !== false ) {
$columns [ $time_from_key ] = $new_time_from ;
}
if ( $time_to_key !== false ) {
$columns [ $time_to_key ] = $new_time_to ;
}
$columns_str = implode ( ',' , $columns );
$sql = " SELECT $columns_str
2021-03-04 16:27:14 +01:00
FROM tplanned_downtime
WHERE id = $id_downtime " ;
2019-01-30 16:18:44 +01:00
break ;
}
$result = db_get_row_sql ( $sql );
// Permission check for the downtime with the AD user groups
if ( empty ( $result ) || ! in_array ( $result [ 'id_group' ], $user_groups_ad )) {
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 downtime scheduler'
);
include 'general/noaccess.php' ;
return ;
}
$name = ( string ) $result [ 'name' ];
$id_group = ( int ) $result [ 'id_group' ];
$description = ( string ) $result [ 'description' ];
$type_downtime = ( string ) $result [ 'type_downtime' ];
$type_execution = ( string ) $result [ 'type_execution' ];
$type_periodicity = ( string ) $result [ 'type_periodicity' ];
$once_date_from = date ( DATE_FORMAT , $result [ 'date_from' ]);
$once_date_to = date ( DATE_FORMAT , $result [ 'date_to' ]);
$once_time_from = date ( TIME_FORMAT , $result [ 'date_from' ]);
$once_time_to = date ( TIME_FORMAT , $result [ 'date_to' ]);
$periodically_time_from = ( string ) $result [ 'periodically_time_from' ];
$periodically_time_to = ( string ) $result [ 'periodically_time_to' ];
$periodically_day_from = ( int ) $result [ 'periodically_day_from' ];
$periodically_day_to = ( int ) $result [ 'periodically_day_to' ];
$monday = ( bool ) $result [ 'monday' ];
$tuesday = ( bool ) $result [ 'tuesday' ];
$wednesday = ( bool ) $result [ 'wednesday' ];
$thursday = ( bool ) $result [ 'thursday' ];
$friday = ( bool ) $result [ 'friday' ];
$saturday = ( bool ) $result [ 'saturday' ];
$sunday = ( bool ) $result [ 'sunday' ];
2022-08-16 18:42:51 +02:00
$cron_interval_from = explode ( ' ' , $result [ 'cron_interval_from' ]);
if ( isset ( $cron_interval_from [ 4 ]) === true ) {
$minute_from = $cron_interval_from [ 0 ];
$hour_from = $cron_interval_from [ 1 ];
$mday_from = $cron_interval_from [ 2 ];
$month_from = $cron_interval_from [ 3 ];
$wday_from = $cron_interval_from [ 4 ];
} else {
$minute_from = '*' ;
$hour_from = '*' ;
$mday_from = '*' ;
$month_from = '*' ;
$wday_from = '*' ;
}
$cron_interval_to = explode ( ' ' , $result [ 'cron_interval_to' ]);
if ( isset ( $cron_interval_to [ 4 ]) === true ) {
$minute_to = $cron_interval_to [ 0 ];
$hour_to = $cron_interval_to [ 1 ];
$mday_to = $cron_interval_to [ 2 ];
$month_to = $cron_interval_to [ 3 ];
$wday_to = $cron_interval_to [ 4 ];
} else {
$minute_to = '*' ;
$hour_to = '*' ;
$mday_to = '*' ;
$month_to = '*' ;
$wday_to = '*' ;
}
2019-01-30 16:18:44 +01:00
$running = ( bool ) $result [ 'executed' ];
2012-08-23 16:24:43 +02:00
}
2019-04-24 13:53:18 +02:00
// When the planned downtime is in execution,
// only action to postpone on once type is enabled and the other are disabled.
2015-07-16 13:53:57 +02:00
$disabled_in_execution = ( int ) $running ;
2015-04-06 07:29:58 +02:00
2022-06-01 14:00:33 +02:00
$return_all_group = false ;
if ( users_can_manage_group_all ( 'AW' ) === true || $disabled ) {
$return_all_group = true ;
}
2012-08-29 Miguel de Dios <miguel.dedios@artica.es>
* pandoradb.sql, pandoradb.postgreSQL.sql, pandoradb.oracle.sql,
include/db/mysql.php,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
godmode/agentes/planned_downtime.list.php,
godmode/agentes/planned_downtime.editor.php, godmode/menu.php,
include/ajax/planned_downtime.ajax.php: refactoriced the code for
planned downtime, now this have new feature such as set a downtime
with a periodicity each week, each month and set the agents and
the modules with Quiet state instead the old form (but the old still
is). And the page is more easy and quickly to set or config a
planned downtime.
* godmode/alerts/configure_alert_template.php,
include/javascript/pandora.js: cleaned source code style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6919 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-08-29 11:46:05 +02:00
$days = array_combine ( range ( 1 , 31 ), range ( 1 , 31 ));
2021-03-04 16:27:14 +01:00
$filter_group = ( int ) get_parameter ( 'filter_group' , 0 );
// User AD groups to str for the filter.
$id_groups_str = implode ( ',' , $user_groups_ad );
if ( empty ( $id_groups_str )) {
// Restrictive filter on error. This will filter all the downtimes.
$id_groups_str = '-1' ;
}
$filter_cond = '' ;
if ( $filter_group > 0 ) {
if ( $recursion ) {
$rg = groups_get_children_ids ( $filter_group , true );
$filter_cond .= ' AND id_grupo IN (' ;
$i = 0 ;
$len = count ( $rg );
foreach ( $rg as $key ) {
if ( $i == ( $len - 1 )) {
$filter_cond .= $key . ')' ;
} else {
$i ++ ;
$filter_cond .= $key . ',' ;
}
}
} else {
$filter_cond = " AND id_grupo = $filter_group " ;
}
}
$agents = get_planned_downtime_agents_list ( $id_downtime , $filter_cond , $id_groups_str );
$disabled_add_button = false ;
if ( empty ( $agents ) || $disabled_in_execution ) {
$disabled_add_button = true ;
}
2023-03-08 15:02:12 +01:00
2021-03-04 16:27:14 +01:00
$table = new StdClass ();
2023-03-08 15:02:12 +01:00
$table -> class = 'databox filter-table-adv' ;
$table -> id = 'principal_table_scheduled' ;
2021-03-04 16:27:14 +01:00
$table -> width = '100%' ;
2023-03-08 15:02:12 +01:00
$table -> size = [];
$table -> size [ 0 ] = '50%' ;
$table -> size [ 1 ] = '50%' ;
2021-03-04 16:27:14 +01:00
$table -> data = [];
2023-03-08 15:02:12 +01:00
$table -> data [ 'first_title' ][] = html_print_div (
[
'class' => 'section_table_title' ,
'content' => __ ( 'Editor' ),
],
true
);
$table -> data [ 0 ][] = html_print_label_input_block (
__ ( 'Name' ),
html_print_input_text (
'name' ,
$name ,
'' ,
25 ,
40 ,
true ,
$disabled_in_execution
)
);
2021-03-04 16:27:14 +01:00
2023-03-08 15:02:12 +01:00
$table -> data [ 0 ][] = html_print_label_input_block (
__ ( 'Group' ),
html_print_select_groups (
false ,
$access ,
$return_all_group ,
'id_group' ,
$id_group ,
'' ,
'' ,
0 ,
true ,
false ,
true ,
'' ,
$disabled_in_execution
)
2022-08-08 12:04:29 +02:00
);
2021-03-04 16:27:14 +01:00
2023-03-08 15:02:12 +01:00
$table -> data [ 1 ][] = html_print_label_input_block (
__ ( 'Description' ),
html_print_textarea (
'description' ,
3 ,
35 ,
$description ,
'' ,
true
)
);
2021-03-04 16:27:14 +01:00
2023-03-08 15:02:12 +01:00
$table -> data [ 1 ][] = html_print_label_input_block (
__ ( 'Type' ),
html_print_select (
[
'quiet' => __ ( 'Quiet' ),
'disable_agents' => __ ( 'Disabled Agents' ),
'disable_agent_modules' => __ ( 'Disable Modules' ),
'disable_agents_alerts' => __ ( 'Disabled only Alerts' ),
],
'type_downtime' ,
$type_downtime ,
'change_type_downtime()' ,
'' ,
0 ,
true ,
false ,
true ,
'' ,
$disabled_in_execution
) . ui_print_input_placeholder (
__ ( 'Quiet: Modules will not generate events or fire alerts.' ) . '<br>' . __ ( 'Disable Agents: Disables the selected agents.' ) . '<br>' . __ ( 'Disable Alerts: Disable alerts for the selected agents.' ),
true
)
);
2021-03-04 16:27:14 +01:00
2023-03-08 15:02:12 +01:00
$table -> data [ 2 ][] = html_print_label_input_block (
__ ( 'Execution' ),
html_print_select (
[
'once' => __ ( 'Once' ),
'periodically' => __ ( 'Periodically' ),
'cron' => __ ( 'Cron from/to' ),
],
'type_execution' ,
$type_execution ,
'change_type_execution();' ,
'' ,
0 ,
true ,
false ,
true ,
'' ,
$disabled_in_execution
)
);
$timeInputs = [];
$timeInputs [] = html_print_div (
[
'id' => 'once_time' ,
'style' => 'display: none' ,
'content' => html_print_div (
[
'class' => '' ,
'content' => html_print_input_text (
'once_date_from' ,
$once_date_from ,
'' ,
10 ,
10 ,
true ,
$disabled_in_execution
) . html_print_input_text (
'once_time_from' ,
$once_time_from ,
'' ,
9 ,
9 ,
true ,
$disabled_in_execution
) . '<span class="margin-lr-10 result_info_text">' . __ (
'To'
) . '</span>' . html_print_input_text (
'once_date_to' ,
$once_date_to ,
'' ,
10 ,
10 ,
true
) . html_print_input_text (
'once_time_to' ,
$once_time_to ,
'' ,
9 ,
9 ,
true
),
],
true
),
],
true
);
$timeInputs [] = html_print_div (
[
'id' => 'periodically_time' ,
'style' => 'display: none' ,
'content' => html_print_div (
[
'class' => 'filter-table-adv-manual w50p' ,
'content' => html_print_label_input_block (
__ ( 'Type Periodicity' ),
html_print_select (
[
'weekly' => __ ( 'Weekly' ),
'monthly' => __ ( 'Monthly' ),
],
'type_periodicity' ,
$type_periodicity ,
'change_type_periodicity();' ,
'' ,
0 ,
true ,
false ,
true ,
'' ,
$disabled_in_execution
)
),
],
true
) . html_print_div (
[
'id' => 'weekly_item' ,
'class' => '' ,
'content' => ' < ul class = " flex-row-center mrgn_top_15px mrgn_btn_15px " >
< li class = " flex " > '.__(' Mon ').html_print_checkbox(' monday ', 1, $monday, true, $disabled_in_execution, ' ', false, [' label_style ' => ' margin : 0 5 px ; ' ]).' </ li >
< li class = " flex " > '.__(' Tue ').html_print_checkbox(' tuesday ', 1, $tuesday, true, $disabled_in_execution, ' ', false, [' label_style ' => ' margin : 0 5 px ; ' ]).' </ li >
< li class = " flex " > '.__(' Wed ').html_print_checkbox(' wednesday ', 1, $wednesday, true, $disabled_in_execution, ' ', false, [' label_style ' => ' margin : 0 5 px ; ' ]).' </ li >
< li class = " flex " > '.__(' Thu ').html_print_checkbox(' thursday ', 1, $thursday, true, $disabled_in_execution, ' ', false, [' label_style ' => ' margin : 0 5 px ; ' ]).' </ li >
< li class = " flex " > '.__(' Fri ').html_print_checkbox(' friday ', 1, $friday, true, $disabled_in_execution, ' ', false, [' label_style ' => ' margin : 0 5 px ; ' ]).' </ li >
< li class = " flex " > '.__(' Sat ').html_print_checkbox(' saturday ', 1, $saturday, true, $disabled_in_execution, ' ', false, [' label_style ' => ' margin : 0 5 px ; ' ]).' </ li >
< li class = " flex " > '.__(' Sun ').html_print_checkbox(' sunday ', 1, $sunday, true, $disabled_in_execution, ' ', false, [' label_style ' => ' margin : 0 5 px ; ' ]).' </ li >
</ ul > ' ,
],
true
) . html_print_div (
[
'id' => 'monthly_item' ,
'style' => 'margin-top: 12px;' ,
'class' => 'filter-table-adv-manual flex-row-start w50p' ,
'content' => html_print_label_input_block (
__ ( 'From day' ),
html_print_select (
$days ,
'periodically_day_from' ,
$periodically_day_from ,
'' ,
'' ,
0 ,
true ,
false ,
true ,
'' ,
$disabled_in_execution
),
[ 'div_style' => 'flex: 50; margin-right: 5px;' ]
) . html_print_label_input_block (
__ ( 'To day' ),
html_print_select (
$days ,
'periodically_day_to' ,
$periodically_day_to ,
'' ,
'' ,
0 ,
true ,
false ,
true ,
'' ,
$disabled_in_execution
) . ui_print_input_placeholder (
__ ( 'The end day must be higher than the start day' ),
true
),
[ 'div_style' => 'flex: 50; margin-left: 5px;' ]
),
],
true
) . html_print_div (
[
'class' => 'filter-table-adv-manual flex-row-start w50p' ,
'content' => html_print_label_input_block (
__ ( 'From hour' ),
html_print_input_text (
'periodically_time_from' ,
$periodically_time_from ,
'' ,
7 ,
7 ,
true ,
$disabled_in_execution
) . ui_print_input_placeholder (
__ ( 'The start time must be lower than the end time' ),
true
),
[ 'div_style' => 'flex: 50; margin-right: 5px;' ]
) . html_print_label_input_block (
__ ( 'To hour' ),
html_print_input_text (
'periodically_time_to' ,
$periodically_time_to ,
'' ,
7 ,
7 ,
true ,
$disabled_in_execution
) . ui_print_input_placeholder (
__ ( 'The end time must be higher than the start time' ),
true
),
[ 'div_style' => 'flex: 50; margin-left: 5px;' ]
),
],
true
) . ui_get_using_system_timezone_warning (),
],
true
);
$timeInputs [] = html_print_div (
[
'id' => 'cron_time' ,
'style' => 'display: none' ,
'content' => html_print_label_input_block (
__ ( 'Cron from' ),
html_print_extended_select_for_cron ( $hour_from , $minute_from , $mday_from , $month_from , $wday_from , true , false , false , true , 'from' )
) . html_print_label_input_block (
__ ( 'Cron to' ),
html_print_extended_select_for_cron ( $hour_to , $minute_to , $mday_to , $month_to , $wday_to , true , false , true , true , 'to' )
),
],
true
);
$table -> colspan [ 3 ][ 0 ] = 2 ;
$table -> data [ 3 ][ 0 ] = html_print_label_input_block (
__ ( 'Configure the time' ),
implode ( '' , $timeInputs )
);
2021-03-04 16:27:14 +01:00
2023-03-08 15:02:12 +01:00
$table -> data [ 4 ][] = html_print_div (
[
'class' => 'section_table_title' ,
'content' => __ ( 'Filtering' ),
],
true
);
$table -> data [ 5 ][] = html_print_label_input_block (
__ ( 'Group filter' ),
html_print_select_groups (
false ,
$access ,
$return_all_group ,
'filter_group' ,
$filter_group ,
'' ,
'' ,
'' ,
true ,
false ,
true ,
'' ,
false ,
'min-width:180px;margin-right:15px;'
)
);
$table -> data [ 5 ][] = html_print_label_input_block (
__ ( 'Recursion' ),
html_print_checkbox_switch (
'recursion' ,
1 ,
$recursion ,
true ,
false ,
''
)
);
$table -> colspan [ 6 ][ 0 ] = 2 ;
$availableModules = html_print_label_input_block (
__ ( 'Available agents' ),
html_print_select (
$agents ,
'id_agents[]' ,
- 1 ,
'' ,
__ ( 'Any' ),
- 2 ,
true ,
true ,
true ,
'' ,
false ,
'min-width: 250px;width: 70%;'
),
[
'div_class' => 'flex-column' ,
'div_style' => 'flex: 33' ,
]
);
$availableModules .= html_print_label_input_block (
__ ( 'Selection mode' ),
html_print_select (
[
'common' => __ ( 'Show common modules' ),
'all' => __ ( 'Show all modules' ),
],
'modules_selection_mode' ,
'common' ,
false ,
'' ,
'' ,
true ,
false ,
true ,
'' ,
false ,
'min-width:180px;'
),
[
'div_class' => 'available_modules_selection_mode flex-column' ,
'div_style' => 'flex: 33' ,
]
);
$availableModules .= html_print_label_input_block (
__ ( 'Available modules' ),
html_print_select (
[],
'module[]' ,
'' ,
'' ,
'' ,
0 ,
true ,
true ,
true ,
'' ,
false ,
'min-width: 250px;width: 70%;'
) . ui_print_input_placeholder (
__ ( 'Only for type Quiet for downtimes.' ),
true
),
[
'div_class' => 'available_modules flex-column' ,
'div_style' => 'flex: 33' ,
]
);
$table -> data [ 6 ][ 0 ] = html_print_div (
[
'style' => 'flex-direction: row;align-items: flex-start;' ,
'content' => $availableModules ,
],
true
);
2021-03-04 16:27:14 +01:00
// Print agent table.
2023-03-08 15:02:12 +01:00
if ( $id_downtime > 0 ) {
echo " <form method=post action='index.php?sec=extensions&sec2=godmode/agentes/planned_downtime.editor&insert_downtime_agent=1&id_downtime= $id_downtime '> " ;
} else {
echo '<form method="POST" action="index.php?sec=extensions&sec2=godmode/agentes/planned_downtime.editor">' ;
}
2021-03-04 16:27:14 +01:00
2023-03-08 15:02:12 +01:00
html_print_table ( $table );
2021-03-04 16:27:14 +01:00
2023-03-08 15:02:12 +01:00
$buttons = '' ;
2019-01-30 16:18:44 +01:00
html_print_input_hidden ( 'id_agent' , $id_agent );
2023-03-08 15:02:12 +01:00
2015-06-25 10:07:53 +02:00
if ( $id_downtime > 0 ) {
2019-01-30 16:18:44 +01:00
html_print_input_hidden ( 'update_downtime' , 1 );
html_print_input_hidden ( 'id_downtime' , $id_downtime );
2023-03-08 15:02:12 +01:00
$buttons .= html_print_submit_button (
2019-04-24 13:53:18 +02:00
__ ( 'Update' ),
'updbutton' ,
false ,
2023-03-08 15:02:12 +01:00
[ 'icon' => 'update' ],
true
2019-04-24 13:53:18 +02:00
);
2019-01-30 16:18:44 +01:00
} else {
html_print_input_hidden ( 'create_downtime' , 1 );
2023-03-08 15:02:12 +01:00
$buttons .= html_print_submit_button (
2019-04-24 13:53:18 +02:00
__ ( 'Add' ),
'crtbutton' ,
false ,
2023-03-08 15:02:12 +01:00
[ 'icon' => 'wand' ],
true
2019-04-24 13:53:18 +02:00
);
2012-08-23 16:24:43 +02:00
}
2019-01-30 16:18:44 +01:00
2023-03-08 15:02:12 +01:00
html_print_action_buttons (
$buttons
);
2021-03-04 16:27:14 +01:00
html_print_input_hidden ( 'all_common_modules' , '' );
2012-08-23 16:24:43 +02:00
echo '</form>' ;
2021-03-04 16:27:14 +01:00
// Start Overview of existing planned downtime.
echo '<h4>' . __ ( 'Agents planned for this downtime' ) . ':</h4>' ;
// User the $id_groups_str built before.
$sql = sprintf (
' SELECT ta . nombre , tpda . id ,
ta . id_os , ta . id_agente , ta . id_grupo ,
ta . ultimo_contacto , tpda . all_modules
FROM tagente ta
INNER JOIN tplanned_downtime_agents tpda
ON ta . id_agente = tpda . id_agent
AND tpda . id_downtime = % d
WHERE ta . id_grupo IN ( % s ) ' ,
$id_downtime ,
$id_groups_str
);
$downtimes_agents = db_get_all_rows_sql ( $sql );
2019-01-30 16:18:44 +01:00
2021-03-04 16:27:14 +01:00
if ( empty ( $downtimes_agents )) {
echo '<div class="nf">' . __ ( 'There are no agents' ) . '</div>' ;
} else {
$table = new stdClass ();
$table -> id = 'list' ;
$table -> class = 'databox data' ;
$table -> width = '100%' ;
$table -> data = [];
$table -> head = [];
$table -> head [ 0 ] = __ ( 'Name' );
$table -> head [ 1 ] = __ ( 'Group' );
$table -> head [ 2 ] = __ ( 'OS' );
$table -> head [ 3 ] = __ ( 'Last contact' );
$table -> head [ 'count_modules' ] = __ ( 'Modules' );
2023-03-08 15:02:12 +01:00
$table -> align = [];
$table -> align [ 0 ] = 'center' ;
$table -> align [ 1 ] = 'center' ;
$table -> align [ 2 ] = 'center' ;
$table -> align [ 3 ] = 'center' ;
$table -> align [ 4 ] = 'center' ;
2021-03-04 16:27:14 +01:00
if ( ! $running ) {
$table -> head [ 5 ] = __ ( 'Actions' );
2023-03-08 15:02:12 +01:00
$table -> align [ 5 ] = 'right' ;
$table -> size [ 5 ] = '10%' ;
2019-01-30 16:18:44 +01:00
}
2021-03-04 16:27:14 +01:00
foreach ( $downtimes_agents as $downtime_agent ) {
$data = [];
2019-01-30 16:18:44 +01:00
2021-03-04 16:27:14 +01:00
$alias = db_get_value (
'alias' ,
'tagente' ,
'id_agente' ,
$downtime_agent [ 'id_agente' ]
);
$data [ 0 ] = $alias ;
2019-01-30 16:18:44 +01:00
2021-03-04 16:27:14 +01:00
$data [ 1 ] = db_get_sql (
' SELECT nombre
FROM tgrupo
WHERE id_grupo = '.$downtime_agent[' id_grupo ' ]
);
2019-01-30 16:18:44 +01:00
2023-03-08 15:02:12 +01:00
$data [ 2 ] = html_print_div (
[
'class' => 'main_menu_icon invert_filter' ,
'content' => ui_print_os_icon ( $downtime_agent [ 'id_os' ], false , true ),
],
true
);
2019-01-30 16:18:44 +01:00
2021-03-04 16:27:14 +01:00
$data [ 3 ] = $downtime_agent [ 'ultimo_contacto' ];
2019-01-30 16:18:44 +01:00
2021-03-04 16:27:14 +01:00
if ( $type_downtime == 'disable_agents_alerts' ) {
$data [ 'count_modules' ] = __ ( 'All alerts' );
} else if ( $type_downtime == 'disable_agents' ) {
$data [ 'count_modules' ] = __ ( 'Entire agent' );
} else {
if ( $downtime_agent [ 'all_modules' ]) {
$data [ 'count_modules' ] = __ ( 'All modules' );
2019-01-30 16:18:44 +01:00
} else {
2021-03-04 16:27:14 +01:00
$data [ 'count_modules' ] = __ ( 'Some modules' );
2019-01-30 16:18:44 +01:00
}
2021-03-04 16:27:14 +01:00
}
2019-01-30 16:18:44 +01:00
2021-03-04 16:27:14 +01:00
if ( ! $running ) {
$data [ 5 ] = '' ;
2022-01-03 11:42:06 +01:00
if ( $type_downtime !== 'disable_agents' ) {
2023-03-08 15:02:12 +01:00
$data [ 5 ] = '<a href="javascript:show_editor_module(' . $downtime_agent [ 'id_agente' ] . ');">' . html_print_image ( 'images/edit.svg' , true , [ 'alt' => __ ( 'Edit' ), 'class' => 'main_menu_icon invert_filter' ]) . '</a>' ;
2019-01-30 16:18:44 +01:00
}
2023-03-08 15:02:12 +01:00
$data [ 5 ] .= '<a href="index.php?sec=extensions&sec2=godmode/agentes/planned_downtime.editor&id_agent=' . $downtime_agent [ 'id_agente' ] . '&delete_downtime_agent=1&id_downtime_agent=' . $downtime_agent [ 'id' ] . '&id_downtime=' . $id_downtime . '">' . html_print_image ( 'images/delete.svg' , true , [ 'alt' => __ ( 'Delete' ), 'class' => 'main_menu_icon invert_filter' ]) . '</a>' ;
2019-01-30 16:18:44 +01:00
}
2021-03-04 16:27:14 +01:00
$table -> data [ 'agent_' . $downtime_agent [ 'id_agente' ]] = $data ;
2019-01-30 16:18:44 +01:00
}
2021-03-04 16:27:14 +01:00
html_print_table ( $table );
2012-08-23 16:24:43 +02:00
}
2023-03-08 15:02:12 +01:00
ui_print_spinner ( 'Loading' );
2012-08-29 Miguel de Dios <miguel.dedios@artica.es>
* pandoradb.sql, pandoradb.postgreSQL.sql, pandoradb.oracle.sql,
include/db/mysql.php,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
godmode/agentes/planned_downtime.list.php,
godmode/agentes/planned_downtime.editor.php, godmode/menu.php,
include/ajax/planned_downtime.ajax.php: refactoriced the code for
planned downtime, now this have new feature such as set a downtime
with a periodicity each week, each month and set the agents and
the modules with Quiet state instead the old form (but the old still
is). And the page is more easy and quickly to set or config a
planned downtime.
* godmode/alerts/configure_alert_template.php,
include/javascript/pandora.js: cleaned source code style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6919 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-08-29 11:46:05 +02:00
2015-06-25 10:07:53 +02:00
$table = new stdClass ();
2012-08-29 Miguel de Dios <miguel.dedios@artica.es>
* pandoradb.sql, pandoradb.postgreSQL.sql, pandoradb.oracle.sql,
include/db/mysql.php,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
godmode/agentes/planned_downtime.list.php,
godmode/agentes/planned_downtime.editor.php, godmode/menu.php,
include/ajax/planned_downtime.ajax.php: refactoriced the code for
planned downtime, now this have new feature such as set a downtime
with a periodicity each week, each month and set the agents and
the modules with Quiet state instead the old form (but the old still
is). And the page is more easy and quickly to set or config a
planned downtime.
* godmode/alerts/configure_alert_template.php,
include/javascript/pandora.js: cleaned source code style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6919 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-08-29 11:46:05 +02:00
$table -> id = 'editor' ;
2015-06-25 10:07:53 +02:00
$table -> width = '100%' ;
2023-05-08 13:54:31 +02:00
$table -> colspan [ 'module' ][ 1 ] = '6' ;
2019-01-30 16:18:44 +01:00
$table -> data = [];
$table -> data [ 'module' ] = [];
2023-05-08 13:54:31 +02:00
// $table->data['module'][0] = '';
2019-01-30 16:18:44 +01:00
$table -> data [ 'module' ][ 1 ] = '<h4>' . __ ( 'Modules' ) . '</h4>' ;
2012-08-29 Miguel de Dios <miguel.dedios@artica.es>
* pandoradb.sql, pandoradb.postgreSQL.sql, pandoradb.oracle.sql,
include/db/mysql.php,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
godmode/agentes/planned_downtime.list.php,
godmode/agentes/planned_downtime.editor.php, godmode/menu.php,
include/ajax/planned_downtime.ajax.php: refactoriced the code for
planned downtime, now this have new feature such as set a downtime
with a periodicity each week, each month and set the agents and
the modules with Quiet state instead the old form (but the old still
is). And the page is more easy and quickly to set or config a
planned downtime.
* godmode/alerts/configure_alert_template.php,
include/javascript/pandora.js: cleaned source code style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6919 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-08-29 11:46:05 +02:00
2019-01-30 16:18:44 +01:00
// List of modules, empty, it is populated by javascript.
2012-08-29 Miguel de Dios <miguel.dedios@artica.es>
* pandoradb.sql, pandoradb.postgreSQL.sql, pandoradb.oracle.sql,
include/db/mysql.php,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
godmode/agentes/planned_downtime.list.php,
godmode/agentes/planned_downtime.editor.php, godmode/menu.php,
include/ajax/planned_downtime.ajax.php: refactoriced the code for
planned downtime, now this have new feature such as set a downtime
with a periodicity each week, each month and set the agents and
the modules with Quiet state instead the old form (but the old still
is). And the page is more easy and quickly to set or config a
planned downtime.
* godmode/alerts/configure_alert_template.php,
include/javascript/pandora.js: cleaned source code style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6919 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-08-29 11:46:05 +02:00
$table -> data [ 'module' ][ 1 ] = "
2021-03-04 16:27:14 +01:00
< table cellspacing = '4' cellpadding = '4' border = '0' width = '100%'
id = 'modules_in_agent' class = 'databox_color' >
< thead >
< tr >
< th scope = 'col' class = 'header c0' > " .__('Module'). " </ th >
< th scope = 'col' class = 'header c1' > " .__('Action'). " </ th >
</ tr >
</ thead >
< tbody >
< tr class = 'datos' id = 'template' style = 'display: none;' >
< td class = 'name_module' style = '' ></ td >
< td class = 'cell_delete_button' style = 'text-align: right; width:10%;' id = '' > " .'<a class= " link_delete "
onclick = " if(!confirm( \ ''.__('Are you sure?').' \ ')) return false; "
href = " " > ' . html_print_image (
2023-03-10 12:40:21 +01:00
'images/delete.svg' ,
2022-02-23 12:11:44 +01:00
true ,
[
'border' => '0' ,
'alt' => __ ( 'Delete' ),
2023-05-08 13:54:31 +02:00
'class' => 'main_menu_icon invert_filter' ,
2022-02-23 12:11:44 +01:00
]
2019-01-30 16:18:44 +01:00
) . '</a>' . " </td>
2021-03-04 16:27:14 +01:00
</ tr >
< tr class = 'datos2' id = 'add_modules_row' >
< td class = 'datos2' style = '' id = '' > " .__('Add Module:').' '.html_print_select(
2019-01-30 16:18:44 +01:00
[],
'modules' ,
'' ,
'' ,
'' ,
0 ,
2021-06-08 07:43:43 +02:00
true ,
false ,
true ,
'' ,
false ,
false ,
false ,
false ,
false ,
'' ,
false ,
false ,
false ,
false ,
false
2019-01-30 16:18:44 +01:00
) . " </td>
2021-03-04 16:27:14 +01:00
< td class = 'datos2 button_cell' style = 'text-align: right; width:10%;' id = '' > " .'<div id= " add_button_div " >'.'<a class= " add_button " href= " " >'.html_print_image(
2019-01-30 16:18:44 +01:00
'images/add.png' ,
true ,
[
'border' => '0' ,
'alt' => __ ( 'Add' ),
2021-03-11 15:40:23 +01:00
'class' => 'invert_filter' ,
2019-01-30 16:18:44 +01:00
]
2021-03-15 12:13:05 +01:00
) . '</a></div>' . " <div id='spinner_add' style='display: none;'> " . html_print_image ( 'images/spinner.gif' , true ) . ' </ div ></ td >
2021-03-04 16:27:14 +01:00
</ tr >
</ tbody ></ table > ' ;
2012-08-29 Miguel de Dios <miguel.dedios@artica.es>
* pandoradb.sql, pandoradb.postgreSQL.sql, pandoradb.oracle.sql,
include/db/mysql.php,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
godmode/agentes/planned_downtime.list.php,
godmode/agentes/planned_downtime.editor.php, godmode/menu.php,
include/ajax/planned_downtime.ajax.php: refactoriced the code for
planned downtime, now this have new feature such as set a downtime
with a periodicity each week, each month and set the agents and
the modules with Quiet state instead the old form (but the old still
is). And the page is more easy and quickly to set or config a
planned downtime.
* godmode/alerts/configure_alert_template.php,
include/javascript/pandora.js: cleaned source code style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6919 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-08-29 11:46:05 +02:00
2021-03-11 15:40:23 +01:00
echo " <div class='invisible'> " ;
2019-01-30 16:18:44 +01:00
html_print_table ( $table );
echo '</div>' ;
2012-08-29 Miguel de Dios <miguel.dedios@artica.es>
* pandoradb.sql, pandoradb.postgreSQL.sql, pandoradb.oracle.sql,
include/db/mysql.php,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
godmode/agentes/planned_downtime.list.php,
godmode/agentes/planned_downtime.editor.php, godmode/menu.php,
include/ajax/planned_downtime.ajax.php: refactoriced the code for
planned downtime, now this have new feature such as set a downtime
with a periodicity each week, each month and set the agents and
the modules with Quiet state instead the old form (but the old still
is). And the page is more easy and quickly to set or config a
planned downtime.
* godmode/alerts/configure_alert_template.php,
include/javascript/pandora.js: cleaned source code style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6919 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-08-29 11:46:05 +02:00
2021-03-11 15:40:23 +01:00
echo " <div class='invisible'> " ;
2012-08-29 Miguel de Dios <miguel.dedios@artica.es>
* pandoradb.sql, pandoradb.postgreSQL.sql, pandoradb.oracle.sql,
include/db/mysql.php,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
godmode/agentes/planned_downtime.list.php,
godmode/agentes/planned_downtime.editor.php, godmode/menu.php,
include/ajax/planned_downtime.ajax.php: refactoriced the code for
planned downtime, now this have new feature such as set a downtime
with a periodicity each week, each month and set the agents and
the modules with Quiet state instead the old form (but the old still
is). And the page is more easy and quickly to set or config a
planned downtime.
* godmode/alerts/configure_alert_template.php,
include/javascript/pandora.js: cleaned source code style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6919 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-08-29 11:46:05 +02:00
echo " <div id='spinner_template'> " ;
2019-01-30 16:18:44 +01:00
html_print_image ( 'images/spinner.gif' );
echo '</div>' ;
echo '</div>' ;
2012-08-29 Miguel de Dios <miguel.dedios@artica.es>
* pandoradb.sql, pandoradb.postgreSQL.sql, pandoradb.oracle.sql,
include/db/mysql.php,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
godmode/agentes/planned_downtime.list.php,
godmode/agentes/planned_downtime.editor.php, godmode/menu.php,
include/ajax/planned_downtime.ajax.php: refactoriced the code for
planned downtime, now this have new feature such as set a downtime
with a periodicity each week, each month and set the agents and
the modules with Quiet state instead the old form (but the old still
is). And the page is more easy and quickly to set or config a
planned downtime.
* godmode/alerts/configure_alert_template.php,
include/javascript/pandora.js: cleaned source code style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6919 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-08-29 11:46:05 +02:00
2021-03-11 15:40:23 +01:00
echo " <div id='some_modules_text' class='invisible'> " ;
2012-08-29 Miguel de Dios <miguel.dedios@artica.es>
* pandoradb.sql, pandoradb.postgreSQL.sql, pandoradb.oracle.sql,
include/db/mysql.php,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
godmode/agentes/planned_downtime.list.php,
godmode/agentes/planned_downtime.editor.php, godmode/menu.php,
include/ajax/planned_downtime.ajax.php: refactoriced the code for
planned downtime, now this have new feature such as set a downtime
with a periodicity each week, each month and set the agents and
the modules with Quiet state instead the old form (but the old still
is). And the page is more easy and quickly to set or config a
planned downtime.
* godmode/alerts/configure_alert_template.php,
include/javascript/pandora.js: cleaned source code style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6919 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-08-29 11:46:05 +02:00
echo __ ( 'Some modules' );
2019-01-30 16:18:44 +01:00
echo '</div>' ;
2012-08-29 Miguel de Dios <miguel.dedios@artica.es>
* pandoradb.sql, pandoradb.postgreSQL.sql, pandoradb.oracle.sql,
include/db/mysql.php,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
godmode/agentes/planned_downtime.list.php,
godmode/agentes/planned_downtime.editor.php, godmode/menu.php,
include/ajax/planned_downtime.ajax.php: refactoriced the code for
planned downtime, now this have new feature such as set a downtime
with a periodicity each week, each month and set the agents and
the modules with Quiet state instead the old form (but the old still
is). And the page is more easy and quickly to set or config a
planned downtime.
* godmode/alerts/configure_alert_template.php,
include/javascript/pandora.js: cleaned source code style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6919 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-08-29 11:46:05 +02:00
2021-03-11 15:40:23 +01:00
echo " <div id='some_modules_text' class='invisible'> " ;
2012-08-29 Miguel de Dios <miguel.dedios@artica.es>
* pandoradb.sql, pandoradb.postgreSQL.sql, pandoradb.oracle.sql,
include/db/mysql.php,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
godmode/agentes/planned_downtime.list.php,
godmode/agentes/planned_downtime.editor.php, godmode/menu.php,
include/ajax/planned_downtime.ajax.php: refactoriced the code for
planned downtime, now this have new feature such as set a downtime
with a periodicity each week, each month and set the agents and
the modules with Quiet state instead the old form (but the old still
is). And the page is more easy and quickly to set or config a
planned downtime.
* godmode/alerts/configure_alert_template.php,
include/javascript/pandora.js: cleaned source code style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6919 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-08-29 11:46:05 +02:00
echo __ ( 'Some modules' );
2019-01-30 16:18:44 +01:00
echo '</div>' ;
2012-08-29 Miguel de Dios <miguel.dedios@artica.es>
* pandoradb.sql, pandoradb.postgreSQL.sql, pandoradb.oracle.sql,
include/db/mysql.php,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
godmode/agentes/planned_downtime.list.php,
godmode/agentes/planned_downtime.editor.php, godmode/menu.php,
include/ajax/planned_downtime.ajax.php: refactoriced the code for
planned downtime, now this have new feature such as set a downtime
with a periodicity each week, each month and set the agents and
the modules with Quiet state instead the old form (but the old still
is). And the page is more easy and quickly to set or config a
planned downtime.
* godmode/alerts/configure_alert_template.php,
include/javascript/pandora.js: cleaned source code style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6919 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-08-29 11:46:05 +02:00
2021-03-11 15:40:23 +01:00
echo " <div id='all_modules_text' class='invisible'> " ;
2019-01-30 16:18:44 +01:00
echo __ ( 'All modules' );
echo '</div>' ;
2012-08-29 Miguel de Dios <miguel.dedios@artica.es>
* pandoradb.sql, pandoradb.postgreSQL.sql, pandoradb.oracle.sql,
include/db/mysql.php,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
godmode/agentes/planned_downtime.list.php,
godmode/agentes/planned_downtime.editor.php, godmode/menu.php,
include/ajax/planned_downtime.ajax.php: refactoriced the code for
planned downtime, now this have new feature such as set a downtime
with a periodicity each week, each month and set the agents and
the modules with Quiet state instead the old form (but the old still
is). And the page is more easy and quickly to set or config a
planned downtime.
* godmode/alerts/configure_alert_template.php,
include/javascript/pandora.js: cleaned source code style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6919 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-08-29 11:46:05 +02:00
2014-06-02 Miguel de Dios <miguel.dedios@artica.es>
* godmode/alerts/configure_alert_template.php,
godmode/reporting/reporting_builder.item_editor.php,
godmode/agentes/planned_downtime.editor.php, godmode/setup/news.php,
include/ajax/module.php, include/functions.php,
include/functions_ui.php, extensions/insert_data.php,
operation/netflow/nf_live_view.php,
operation/reporting/reporting_viewer.php,
operation/reporting/graph_viewer.php, operation/tree.php,
operation/agentes/datos_agente.php,
operation/agentes/estado_monitores.php: fixed the i18n of the
timepicker.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@10076 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2014-06-02 17:57:36 +02:00
ui_include_time_picker ();
2019-01-30 16:18:44 +01:00
ui_require_jquery_file ( 'ui.datepicker-' . get_user_language (), 'include/javascript/i18n/' );
2012-08-23 16:24:43 +02:00
2021-03-04 16:27:14 +01:00
// Auxiliary function for downtime agent creation.
function insert_downtime_agent ( $id_downtime , $user_groups_ad )
{
// Check AD permission on downtime.
$downtime_group = db_get_value (
'id_group' ,
'tplanned_downtime' ,
'id' ,
$id_downtime
);
if ( $downtime_group === false
|| ! in_array ( $downtime_group , $user_groups_ad )
) {
db_pandora_audit (
2022-01-20 10:55:23 +01:00
AUDIT_LOG_ACL_VIOLATION ,
2021-03-04 16:27:14 +01:00
'Trying to access downtime scheduler'
);
include 'general/noaccess.php' ;
return ;
}
$agents = ( array ) get_parameter ( 'id_agents' );
2022-09-30 14:54:16 +02:00
$filter_group = ( int ) get_parameter ( 'filter_group' , 0 );
2021-03-04 16:27:14 +01:00
$module_names = ( array ) get_parameter ( 'module' );
$modules_selection_mode = ( string ) get_parameter ( 'modules_selection_mode' );
2022-09-30 14:54:16 +02:00
$type_downtime = ( string ) get_parameter ( 'type_downtime' , 'quiet' );
2022-10-18 19:55:45 +02:00
$recursion = ( bool ) get_parameter_checkbox ( 'recursion' , false );
2021-03-04 16:27:14 +01:00
$all_modules = ( $modules_selection_mode === 'all' && ( empty ( $module_names ) || ( string ) $module_names [ 0 ] === '0' ));
$all_common_modules = ( $modules_selection_mode === 'common' && ( empty ( $module_names ) || ( string ) $module_names [ 0 ] === '0' ));
2022-09-30 14:54:16 +02:00
if ( $type_downtime === 'disable_agents' ) {
$all_modules = true ;
}
2023-08-21 13:03:44 +02:00
if ( $all_common_modules === true || $all_modules === true ) {
2021-03-04 16:27:14 +01:00
$module_names = explode ( ',' , get_parameter ( 'all_common_modules' ));
}
// 'Is running' check.
$is_running = ( bool ) db_get_value (
'executed' ,
'tplanned_downtime' ,
'id' ,
$id_downtime
);
if ( $is_running ) {
ui_print_error_message (
__ ( 'This elements cannot be modified while the downtime is being executed' )
);
} else {
// If is selected 'Any', get all the agents.
if ( count ( $agents ) === 1 && ( int ) $agents [ 0 ] === - 2 ) {
2023-05-08 13:57:54 +02:00
$filter_group = groups_get_children_ids (
$filter_group ,
false ,
true ,
'AW'
);
2022-10-18 19:55:45 +02:00
2022-10-18 09:52:08 +02:00
$agents = db_get_all_rows_filter (
'tagente' ,
2022-09-30 14:54:16 +02:00
[ 'id_grupo' => $filter_group ],
2022-10-18 09:52:08 +02:00
'id_agente'
);
$agents = array_reduce (
$agents ,
function ( $carry , $item ) {
$carry [] = $item [ 'id_agente' ];
return $carry ;
}
2022-09-30 14:54:16 +02:00
);
2021-03-04 16:27:14 +01:00
}
foreach ( $agents as $agent_id ) {
2022-09-30 14:54:16 +02:00
$agent_id = ( int ) $agent_id ;
2021-03-04 16:27:14 +01:00
// Check module belongs to the agent.
2023-08-21 13:03:44 +02:00
if ( $modules_selection_mode == 'all' && ( $all_modules === false || $all_modules === true )) {
2021-03-04 16:27:14 +01:00
$check = false ;
foreach ( $module_names as $module_name ) {
$check_module = modules_get_agentmodule_id (
$module_name ,
$agent_id
);
if ( ! empty ( $check_module )) {
$check = true ;
}
}
if ( ! $check ) {
continue ;
}
}
// Check AD permission on agent.
$agent_group = db_get_value (
'id_grupo' ,
'tagente' ,
'id_agente' ,
$agent_id
);
if ( $agent_group === false
|| ! in_array ( $agent_group , $user_groups_ad )
) {
continue ;
}
2022-09-30 14:54:16 +02:00
// Check if agent is already in downtime.
$agent_in_downtime = db_get_value_filter (
'id_downtime' ,
2021-03-04 16:27:14 +01:00
'tplanned_downtime_agents' ,
2022-09-30 14:54:16 +02:00
[
'id_agent' => $agent_id ,
'id_downtime' => $id_downtime ,
]
2021-03-04 16:27:14 +01:00
);
2022-09-30 14:54:16 +02:00
if ( $agent_in_downtime !== false ) {
$values = [ 'all_modules' => $all_modules ];
$result = db_process_sql_update (
'tplanned_downtime_agents' ,
$values ,
[
'id_downtime' => $id_downtime ,
'id_agent' => $agent_id ,
]
);
} else {
$values = [
'id_downtime' => $id_downtime ,
'id_agent' => $agent_id ,
'all_modules' => $all_modules ,
];
$result = db_process_sql_insert (
'tplanned_downtime_agents' ,
$values
);
}
2023-08-21 13:03:44 +02:00
if ( $result !== false && (( bool ) $all_modules === false || ( bool ) $all_modules === true )) {
2021-03-04 16:27:14 +01:00
foreach ( $module_names as $module_name ) {
$module = modules_get_agentmodule_id (
$module_name ,
$agent_id
);
if ( empty ( $module )) {
continue ;
}
2022-09-30 14:54:16 +02:00
// Check if modules are already in downtime.
$module_in_downtime = db_get_value_filter (
'id_downtime' ,
2021-03-04 16:27:14 +01:00
'tplanned_downtime_modules' ,
2022-09-30 14:54:16 +02:00
[
'id_downtime' => $id_downtime ,
'id_agent' => $agent_id ,
'id_agent_module' => $module [ 'id_agente_modulo' ],
]
2021-03-04 16:27:14 +01:00
);
2022-09-30 14:54:16 +02:00
if ( $module_in_downtime !== false ) {
continue ;
} else {
$values = [
'id_downtime' => $id_downtime ,
'id_agent' => $agent_id ,
'id_agent_module' => $module [ 'id_agente_modulo' ],
];
$result = db_process_sql_insert (
'tplanned_downtime_modules' ,
$values
);
}
if ( $result !== false ) {
2021-03-04 16:27:14 +01:00
$values = [ 'id_user' => $config [ 'id_user' ]];
$result = db_process_sql_update (
'tplanned_downtime' ,
$values ,
[ 'id' => $id_downtime ]
);
}
}
}
}
}
}
2012-08-23 16:24:43 +02:00
?>
< script language = " javascript " type = " text/javascript " >
2019-01-30 16:18:44 +01:00
var id_downtime = < ? php echo $id_downtime ; ?> ;
var action_in_progress = false ;
2021-03-04 16:27:14 +01:00
var recursion = false ;
2019-01-30 16:18:44 +01:00
function change_type_downtime () {
switch ( $ ( " #type_downtime " ) . val ()) {
case 'disable_agents_alerts' :
case 'disable_agents' :
2023-03-08 15:04:07 +01:00
$ ( " .available_modules " ) . hide ();
$ ( " .available_modules_selection_mode " ) . hide ();
2019-01-30 16:18:44 +01:00
break ;
case 'quiet' :
2022-09-30 14:54:16 +02:00
case 'disable_agent_modules' :
2023-03-08 15:04:07 +01:00
$ ( " .available_modules_selection_mode " ) . show ();
$ ( " .available_modules " ) . show ();
2019-01-30 16:18:44 +01:00
break ;
}
}
function change_type_execution () {
switch ( $ ( " #type_execution " ) . val ()) {
case 'once' :
$ ( " #periodically_time " ) . hide ();
2022-08-16 18:42:51 +02:00
$ ( " #cron_time " ) . hide ();
2019-01-30 16:18:44 +01:00
$ ( " #once_time " ) . show ();
break ;
case 'periodically' :
$ ( " #once_time " ) . hide ();
2022-08-16 18:42:51 +02:00
$ ( " #cron_time " ) . hide ();
2019-01-30 16:18:44 +01:00
$ ( " #periodically_time " ) . show ();
break ;
2022-08-16 18:42:51 +02:00
case 'cron' :
$ ( " #once_time " ) . hide ();
$ ( " #periodically_time " ) . hide ();
$ ( " #cron_time " ) . show ();
break ;
2019-01-30 16:18:44 +01:00
}
}
function change_type_periodicity () {
switch ( $ ( " #type_periodicity " ) . val ()) {
case 'weekly' :
$ ( " #monthly_item " ) . hide ();
$ ( " #weekly_item " ) . show ();
break ;
case 'monthly' :
$ ( " #weekly_item " ) . hide ();
$ ( " #monthly_item " ) . show ();
break ;
}
}
function show_executing_alert () {
2019-05-14 11:11:27 +02:00
alert ( " <?php echo __('This elements cannot be modified while the downtime is being executed'); ?> " );
2019-01-30 16:18:44 +01:00
}
function show_editor_module ( id_agent ) {
//Avoid freak states.
if ( action_in_progress )
return ;
//Check if the row editor module exists
if ( $ ( '#loading_' + id_agent ) . length > 0 ) {
//The row exists
$ ( '#loading_' + id_agent ) . remove ();
}
else {
if ( $ ( '#module_editor_' + id_agent ) . length == 0 ) {
$ ( " #list-agent_ " + id_agent ) . after (
$ ( " #loading-loading " ) . clone () . attr ( 'id' , 'loading_' + id_agent ));
jQuery . post ( 'ajax.php' ,
{ " page " : " include/ajax/planned_downtime.ajax " ,
" get_modules_downtime " : 1 ,
" id_agent " : id_agent ,
" id_downtime " : id_downtime
},
function ( data ) {
if ( data [ 'correct' ]) {
//Check if the row editor module exists
2023-05-08 13:54:31 +02:00
if ( $ ( '#list-agent_' + id_agent ) . length > 0 ) {
2019-01-30 16:18:44 +01:00
//The row exists
2023-05-08 13:54:31 +02:00
//$('#loading_' + id_agent).remove();
2019-01-30 16:18:44 +01:00
$ ( " #list-agent_ " + id_agent ) . after (
$ ( " #editor-module " ) . clone ()
. attr ( 'id' , 'module_editor_' + id_agent )
. hide ());
2023-05-08 13:54:31 +02:00
2019-01-30 16:18:44 +01:00
fill_row_editor ( id_agent , data );
}
}
},
" json "
);
}
else {
if ( $ ( '#module_editor_' + id_agent ) . is ( ':visible' )) {
$ ( '#module_editor_' + id_agent ) . hide ();
}
else {
$ ( '#module_editor_' + id_agent ) . css ( 'display' , '' );
}
}
}
}
function fill_row_editor ( id_agent , data ) {
//$("#modules", $('#module_editor_' + id_agent)).empty();
//Fill the select for to add modules
$ . each ( data [ 'in_agent' ], function ( id_module , name ) {
$ ( " #modules " , $ ( '#module_editor_' + id_agent ))
. append ( $ ( " <option value=' " + id_module + " '> " + name + " </option> " ));
});
$ ( " .add_button " , $ ( '#module_editor_' + id_agent )) .
attr ( 'href' , 'javascript:' +
'add_module_in_downtime(' + id_agent + ')' );
//Fill the list of modules
$ . each ( data [ 'in_downtime' ], function ( id_module , name ) {
var template_row = $ ( " #template " ) . clone ();
$ ( template_row ) . css ( 'display' , '' );
$ ( template_row ) . attr ( 'id' , 'row_module_in_downtime_' + id_module );
$ ( " .name_module " , template_row ) . html ( name );
$ ( " .link_delete " , template_row ) . attr ( 'href' ,
'javascript:' +
'delete_module_from_downtime(' + id_downtime + ',' + id_module + ');' );
$ ( " #add_modules_row " , $ ( '#module_editor_' + id_agent ))
. before ( template_row );
});
//.show() is crap, because put a 'display: block;'.
$ ( '#module_editor_' + id_agent ) . css ( 'display' , '' );
}
function add_row_module ( id_downtime , id_agent , id_module , name ) {
var template_row = $ ( " #template " ) . clone ();
$ ( template_row ) . css ( 'display' , '' );
$ ( template_row ) . attr ( 'id' , 'row_module_in_downtime_' + id_module );
$ ( " .name_module " , template_row ) . html ( name );
$ ( " .link_delete " , template_row ) . attr ( 'href' ,
'javascript:' +
'delete_module_from_downtime(' + id_downtime + ',' + id_module + ');' );
$ ( " #add_modules_row " , $ ( '#module_editor_' + id_agent ))
. before ( template_row );
}
function fill_selectbox_modules ( id_downtime , id_agent ) {
jQuery . post ( 'ajax.php' ,
{ " page " : " include/ajax/planned_downtime.ajax " ,
" get_modules_downtime " : 1 ,
" id_agent " : id_agent ,
" id_downtime " : id_downtime ,
" none_value " : 1
},
function ( data ) {
if ( data [ 'correct' ]) {
$ ( " #modules " , $ ( '#module_editor_' + id_agent )) . empty ();
//Fill the select for to add modules
$ . each ( data [ 'in_agent' ], function ( id_module , name ) {
$ ( " #modules " , $ ( '#module_editor_' + id_agent ))
. append ( $ ( " <option value=' " + id_module + " '> " + name + " </option> " ));
});
$ ( " #modules " , $ ( '#module_editor_' + id_agent )) . val ( 0 );
}
},
" json "
);
}
function add_module_in_downtime ( id_agent ) {
var module_sel = $ ( " #modules " , $ ( '#module_editor_' + id_agent )) . val ();
if ( module_sel == 0 ) {
2019-05-14 11:11:27 +02:00
alert ( " <?php echo __('Please select a module.'); ?> " );
2019-01-30 16:18:44 +01:00
}
else {
action_in_progress = true ;
$ ( " #add_button_div " , $ ( '#module_editor_' + id_agent )) . toggle ();
$ ( " #spinner_add " , $ ( '#module_editor_' + id_agent )) . toggle ();
jQuery . post ( 'ajax.php' ,
{ " page " : " include/ajax/planned_downtime.ajax " ,
" add_module_into_downtime " : 1 ,
" id_agent " : id_agent ,
" id_module " : module_sel ,
" id_downtime " : id_downtime
},
function ( data ) {
if ( data [ 'correct' ]) {
$ ( " #list-agent_ "
+ id_agent
+ '-count_modules' ) . html (
$ ( " #some_modules_text " ) . html ());
add_row_module ( id_downtime , id_agent ,
module_sel , data [ 'name' ]);
fill_selectbox_modules ( id_downtime , id_agent );
$ ( " #add_button_div " , $ ( '#module_editor_' + id_agent ))
. toggle ();
$ ( " #spinner_add " , $ ( '#module_editor_' + id_agent ))
. toggle ();
}
else if ( data [ 'executed' ]) {
show_executing_alert ();
}
action_in_progress = false ;
},
" json "
);
}
}
function delete_module_from_downtime ( id_downtime , id_module ) {
var spinner = $ ( " #spinner_template " ) . clone ();
var old_cell_content =
$ ( " .cell_delete_button " , " #row_module_in_downtime_ " + id_module )
. clone ( true );
$ ( " .cell_delete_button " , " #row_module_in_downtime_ " + id_module )
. html ( spinner );
action_in_progress = true ;
jQuery . post ( 'ajax.php' ,
{ " page " : " include/ajax/planned_downtime.ajax " ,
" delete_module_from_downtime " : 1 ,
" id_downtime " : id_downtime ,
" id_module " : id_module
},
function ( data ) {
if ( data [ 'correct' ]) {
fill_selectbox_modules ( id_downtime , data [ 'id_agent' ]);
$ ( " #row_module_in_downtime_ " + id_module ) . remove ();
if ( data [ 'all_modules' ]) {
$ ( " #list-agent_ "
+ data [ 'id_agent' ]
+ '-count_modules' ) . html (
$ ( " #all_modules_text " ) . html ());
}
}
else if ( data [ 'executed' ]) {
show_executing_alert ();
}
else {
$ ( " .cell_delete_button " , " #row_module_in_downtime_ " + id_module )
. html ( $ ( old_cell_content ));
}
action_in_progress = false ;
},
" json "
);
}
$ ( document ) . ready ( function () {
2021-03-10 13:02:17 +01:00
populate_agents_selector ();
2022-12-27 15:22:39 +01:00
// Add data-pendingdelete attribute to exclude delete_pending modules
document . querySelector ( " #id_agents " ) . dataset . pendingdelete = true
document . querySelector ( " #modules_selection_mode " ) . dataset . pendingdelete = true
2019-01-30 16:18:44 +01:00
$ ( " #id_agents " ) . change ( agent_changed_by_multiple_agents );
$ ( " #modules_selection_mode " ) . change ( agent_changed_by_multiple_agents );
change_type_downtime ();
change_type_execution ();
change_type_periodicity ();
$ ( " #text-periodically_time_from, #text-periodically_time_to, #text-once_time_from, #text-once_time_to " ) . timepicker ({
showSecond : true ,
timeFormat : '<?php echo TIME_FORMAT_JS; ?>' ,
timeOnlyTitle : '<?php echo __(' Choose time '); ?>' ,
timeText : '<?php echo __(' Time '); ?>' ,
hourText : '<?php echo __(' Hour '); ?>' ,
minuteText : '<?php echo __(' Minute '); ?>' ,
secondText : '<?php echo __(' Second '); ?>' ,
currentText : '<?php echo __(' Now '); ?>' ,
closeText : '<?php echo __(' Close '); ?>' });
$ ( " #text-once_date_from, #text-once_date_to " ) . datepicker ({ dateFormat : " <?php echo DATE_FORMAT_JS; ?> " , showButtonPanel : true });
$ . datepicker . setDefaults ( $ . datepicker . regional [ " <?php echo get_user_language(); ?> " ]);
$ ( " #filter_group " ) . click ( function () {
$ ( this ) . css ( " width " , " auto " );
});
$ ( " #filter_group " ) . blur ( function () {
$ ( this ) . css ( " width " , " 180px " );
});
$ ( " #id_agent " ) . click ( function () {
$ ( this ) . css ( " width " , " auto " );
});
$ ( " #id_agent " ) . blur ( function () {
$ ( this ) . css ( " width " , " 180px " );
});
2021-05-10 11:06:43 +02:00
// Warning message about the problems caused updating a past scheduled downtime
2019-01-30 16:18:44 +01:00
var type_execution = " <?php echo $type_execution ; ?> " ;
var datetime_from = < ? php echo json_encode ( strtotime ( $once_date_from . ' ' . $once_time_from )); ?> ;
var datetime_now = < ? php echo json_encode ( $utimestamp ); ?> ;
var create = < ? php echo json_encode ( $create ); ?> ;
2023-05-08 13:54:31 +02:00
if ( ! create && ( type_execution == 'periodically' && ( type_execution == 'once' && datetime_from < datetime_now ))) {
2019-01-30 16:18:44 +01:00
$ ( " input#submit-updbutton, input#submit-add_item, table#list a " ) . click ( function ( e ) {
2021-05-10 11:06:43 +02:00
if ( ! confirm ( " <?php echo __('WARNING: If you edit this scheduled downtime, the data of future SLA reports may be altered'); ?> " )) {
2019-01-30 16:18:44 +01:00
e . preventDefault ();
}
});
}
// Disable datepickers when it has readonly attribute
$ ( 'input.hasDatepicker[readonly]' ) . disable ();
2021-03-04 16:27:14 +01:00
$ ( " #checkbox-recursion " ) . click ( function () {
$ ( " #filter_group " ) . trigger ( " change " );
});
// Change agent selector based on group.
$ ( " #filter_group " ) . change ( function () {
2021-03-10 13:02:17 +01:00
populate_agents_selector ();
});
function populate_agents_selector () {
2022-10-18 19:55:45 +02:00
recursion = $ ( " #checkbox-recursion " ) . prop ( 'checked' );
2021-03-04 16:27:14 +01:00
jQuery . post ( " ajax.php " ,
{ " page " : " operation/agentes/ver_agente " ,
" get_agents_group_json " : 1 ,
2021-03-10 13:02:17 +01:00
" id_group " : $ ( " #filter_group " ) . val (),
2021-03-04 16:27:14 +01:00
" privilege " : " AW " ,
" keys_prefix " : " _ " ,
" recursion " : recursion ,
},
function ( data , status ) {
$ ( " #id_agents " ) . empty ();
$ ( " #module " ) . html ( '' );
option_any = $ ( " <option></option> " )
. attr ( " value " , - 2 )
. html ( " Any " );
$ ( " #id_agents " ) . append ( option_any );
jQuery . each ( data , function ( id , value ) {
// Remove keys_prefix from the index
id = id . substring ( 1 );
option = $ ( " <option></option> " )
. attr ( " value " , value [ " id_agente " ])
. html ( value [ " alias " ]);
$ ( " #id_agents " ) . append ( option );
});
},
" json "
);
2021-03-10 13:02:17 +01:00
}
2019-01-30 16:18:44 +01:00
});
2012-11-04 15:41:14 +01:00
</ script >