2012-10-09 18:05:32 +02:00
|
|
|
<?php
|
2023-02-09 16:13:30 +01:00
|
|
|
/**
|
|
|
|
* Event responses view handler.
|
|
|
|
*
|
|
|
|
* @category Events
|
|
|
|
* @package Pandora FMS
|
|
|
|
* @subpackage Community
|
|
|
|
* @version 1.0.0
|
|
|
|
* @license See below
|
|
|
|
*
|
|
|
|
* ______ ___ _______ _______ ________
|
|
|
|
* | __ \.-----.--.--.--| |.-----.----.-----. | ___| | | __|
|
|
|
|
* | __/| _ | | _ || _ | _| _ | | ___| |__ |
|
|
|
|
* |___| |___._|__|__|_____||_____|__| |___._| |___| |__|_|__|_______|
|
|
|
|
*
|
|
|
|
* ============================================================================
|
|
|
|
* Copyright (c) 2005-2023 Artica Soluciones Tecnologicas
|
|
|
|
* 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.
|
|
|
|
* ============================================================================
|
|
|
|
*/
|
2012-10-09 18:05:32 +02:00
|
|
|
|
2023-02-09 16:13:30 +01:00
|
|
|
// Load global vars.
|
2015-06-08 13:13:09 +02:00
|
|
|
global $config;
|
2012-10-09 18:05:32 +02:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
require_once $config['homedir'].'/include/functions_event_responses.php';
|
2018-12-10 18:46:01 +01:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
check_login();
|
2012-10-09 18:05:32 +02:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
if (! check_acl($config['id_user'], 0, 'PM')) {
|
|
|
|
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 Group Management'
|
|
|
|
);
|
|
|
|
include 'general/noaccess.php';
|
|
|
|
return;
|
2012-10-09 18:05:32 +02:00
|
|
|
}
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$mode = get_parameter('mode', 'list');
|
2012-10-09 18:05:32 +02:00
|
|
|
$action = get_parameter('action');
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
switch ($action) {
|
|
|
|
case 'create_response':
|
|
|
|
$values = [];
|
|
|
|
$values['name'] = get_parameter('name');
|
|
|
|
$values['description'] = get_parameter('description');
|
|
|
|
$values['target'] = get_parameter('target');
|
|
|
|
$values['type'] = get_parameter('type');
|
|
|
|
$values['id_group'] = get_parameter('id_group', 0);
|
|
|
|
$values['modal_width'] = get_parameter('modal_width');
|
|
|
|
$values['modal_height'] = get_parameter('modal_height');
|
|
|
|
$values['new_window'] = get_parameter('new_window');
|
|
|
|
$values['params'] = get_parameter('params');
|
2022-02-01 14:30:25 +01:00
|
|
|
$values['display_command'] = get_parameter('display_command');
|
2019-01-30 16:18:44 +01:00
|
|
|
$values['server_to_exec'] = get_parameter('server_to_exec');
|
2019-12-10 11:54:30 +01:00
|
|
|
$values['command_timeout'] = get_parameter('command_timeout', 90);
|
2019-01-30 16:18:44 +01:00
|
|
|
|
|
|
|
$result = event_responses_create_response($values);
|
|
|
|
|
|
|
|
if ($result) {
|
|
|
|
ui_print_success_message(__('Response added succesfully'));
|
|
|
|
} else {
|
|
|
|
ui_print_error_message(__('Response cannot be added'));
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'update_response':
|
|
|
|
$values = [];
|
|
|
|
$values['name'] = get_parameter('name');
|
|
|
|
$values['description'] = get_parameter('description');
|
|
|
|
$values['target'] = get_parameter('target');
|
|
|
|
$values['type'] = get_parameter('type');
|
|
|
|
$values['id_group'] = get_parameter('id_group', 0);
|
|
|
|
$values['modal_width'] = get_parameter('modal_width');
|
|
|
|
$values['modal_height'] = get_parameter('modal_height');
|
|
|
|
$values['new_window'] = get_parameter('new_window');
|
|
|
|
$values['params'] = get_parameter('params');
|
2022-02-01 14:30:25 +01:00
|
|
|
$values['display_command'] = get_parameter('display_command');
|
2019-01-30 16:18:44 +01:00
|
|
|
$values['server_to_exec'] = get_parameter('server_to_exec');
|
|
|
|
$response_id = get_parameter('id_response', 0);
|
2019-12-10 11:54:30 +01:00
|
|
|
$values['command_timeout'] = get_parameter('command_timeout', '90');
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
|
|
|
|
$result = event_responses_update_response($response_id, $values);
|
|
|
|
|
|
|
|
if ($result) {
|
|
|
|
ui_print_success_message(__('Response updated succesfully'));
|
|
|
|
} else {
|
|
|
|
ui_print_error_message(__('Response cannot be updated'));
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'delete_response':
|
|
|
|
$response_id = get_parameter('id_response', 0);
|
|
|
|
|
|
|
|
$result = db_process_sql_delete('tevent_response', ['id' => $response_id]);
|
|
|
|
|
|
|
|
if ($result) {
|
|
|
|
ui_print_success_message(__('Response deleted succesfully'));
|
|
|
|
} else {
|
|
|
|
ui_print_error_message(__('Response cannot be deleted'));
|
|
|
|
}
|
|
|
|
break;
|
2012-10-09 18:05:32 +02:00
|
|
|
}
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
switch ($mode) {
|
|
|
|
case 'list':
|
|
|
|
include 'event_responses.list.php';
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'editor':
|
|
|
|
include 'event_responses.editor.php';
|
|
|
|
break;
|
2012-10-09 18:05:32 +02:00
|
|
|
}
|