<?php
/**
 * View for Delete alerts in Massive Operations
 *
 * @category   Configuration
 * @package    Pandora FMS
 * @subpackage Massive Operations
 * @version    1.0.0
 * @license    See below
 *
 *    ______                 ___                    _______ _______ ________
 *   |   __ \.-----.--.--.--|  |.-----.----.-----. |    ___|   |   |     __|
 *  |    __/|  _  |     |  _  ||  _  |   _|  _  | |    ___|       |__     |
 * |___|   |___._|__|__|_____||_____|__| |___._| |___|   |__|_|__|_______|
 *
 * ============================================================================
 * Copyright (c) 2005-2021 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.
 * ============================================================================
 */

// Begin.
check_login();

if (! check_acl($config['id_user'], 0, 'AW')) {
    db_pandora_audit(
        AUDIT_LOG_ACL_VIOLATION,
        'Trying to access massive alert deletion'
    );
    include 'general/noaccess.php';
    return;
}

require_once 'include/functions_agents.php';
require_once 'include/functions_alerts.php';
require_once $config['homedir'].'/include/functions_modules.php';
require_once $config['homedir'].'/include/functions_users.php';

if (is_ajax()) {
    $get_agents = (bool) get_parameter('get_agents');
    $recursion = (int) get_parameter('recursion');
    $disabled_modules = (int) get_parameter('disabled_modules');

    if ($get_agents) {
        $id_group = (int) get_parameter('id_group');
        $id_alert_template = (int) get_parameter('id_alert_template');
        // Is is possible add keys prefix to avoid auto sorting in js object conversion
        $keys_prefix = (string) get_parameter('keys_prefix', '');

        if ($recursion) {
            $groups = groups_get_children_ids($id_group, true);
        } else {
            $groups = [$id_group];
        }

        if ($disabled_modules == 0) {
            $filter['tagente_modulo.disabled'] = '<> 1';
        } else {
            unset($filter['tagente_modulo.disabled']);
        }

        $agents_alerts = [];
        foreach ($groups as $group) {
            $agents_alerts_one_group = alerts_get_agents_with_alert_template(
                $id_alert_template,
                $group,
                $filter,
                [
                    'tagente.alias',
                    'tagente.id_agente',
                ]
            );
            if (is_array($agents_alerts_one_group)) {
                $agents_alerts = array_merge($agents_alerts, $agents_alerts_one_group);
            }
        }

        $agents = index_array($agents_alerts, 'id_agente', 'alias');

        asort($agents);

        // Add keys prefix
        if ($keys_prefix !== '') {
            foreach ($agents as $k => $v) {
                $agents[$keys_prefix.$k] = $v;
                unset($agents[$k]);
            }
        }

        echo json_encode($agents);
        return;
    }

    return;
}


function process_manage_delete($id_alert_template, $id_agents, $module_names)
{
    if (empty($id_alert_template)) {
        ui_print_error_message(__('No alert selected'));
        return false;
    }

    if (empty($id_agents) || $id_agents[0] == 0) {
        ui_print_error_message(__('No agents selected'));
        return false;
    }

    $module_selection_mode = get_parameter('modules_selection_mode');

    $alert_list = db_get_all_rows_filter('talert_template_modules', ['id_alert_template' => $id_alert_template], 'id_agent_module');

    foreach ($module_names as $module) {
        foreach ($id_agents as $id_agent) {
            $module_id = modules_get_agentmodule_id($module, $id_agent);
            // The module can exist in several of the selected agents, but we have to check if it has an alert.
            foreach ($alert_list as $alert) {
                if ($alert['id_agent_module'] == $module_id['id_agente_modulo']) {
                    $modules_id[] = $module_id['id_agente_modulo'];
                }
            }
        }
    }

    // If is selected "ANY" option then we need the module selection
    // mode: common or all modules
    if (count($module_names) == 1 && $module_names[0] == '0') {
        if ($module_selection_mode == 'common') {
            $sql = 'SELECT t1.id_agente_modulo
				FROM tagente_modulo t1
				WHERE t1.id_agente_modulo IN (
						SELECT t2.id_agent_module
						FROM talert_template_modules t2
						WHERE
							t2.id_alert_template = '.$id_alert_template.')
					AND t1.id_agente IN ('.implode(',', $id_agents).');';
            $modules = db_get_all_rows_sql($sql);

            if (empty($modules)) {
                $modules = [];
            }

            $modules_id = [];
            foreach ($modules as $module) {
                $modules_id[$module['id_agente_modulo']] = $module['id_agente_modulo'];
            }
        } else {
            // For agents selected
            $modules_id = [];

            foreach ($id_agents as $id_agent) {
                $current_modules_agent = agents_get_modules($id_agent, 'id_agente_modulo', ['disabled' => 0]);
                if ($current_modules_agent != false) {
                    // And their modules
                    foreach ($current_modules_agent as $current_module) {
                        $module_alerts = alerts_get_alerts_agent_module($current_module);

                        if ($module_alerts != false) {
                            // And for all alert in modules
                            foreach ($module_alerts as $module_alert) {
                                // Find the template in module
                                if ($module_alert['id_alert_template'] == $id_alert_template) {
                                    $modules_id[] = $module_alert['id_agent_module'];
                                }
                            }
                        }
                    }
                }
            }
        }
    }

    $conttotal = 0;
    $contsuccess = 0;
    foreach ($modules_id as $module) {
        $success = alerts_delete_alert_agent_module(
            false,
            [
                'id_agent_module'   => $module,
                'id_alert_template' => $id_alert_template,
            ]
        );

        if ($success) {
            $contsuccess++;
        }

        $conttotal++;
    }

    ui_print_result_message(
        $contsuccess > 0,
        __('Successfully deleted').'('.$contsuccess.'/'.$conttotal.')',
        __('Could not be deleted')
    );

    return (bool) ($contsuccess > 0);
}


$id_group = (int) get_parameter('id_group');
$id_agents = get_parameter('id_agents');
$module_names = get_parameter('module');
$id_alert_template = (int) get_parameter('id_alert_template');

$delete = (bool) get_parameter_post('delete');

if ($delete) {
    $result = process_manage_delete($id_alert_template, $id_agents, $module_names);

    $info = [
        'Agent'    => implode(',', $id_agents),
        'Template' => $id_alert_template,
        'Module'   => implode(',', $module_names),
    ];

    if ($result) {
        db_pandora_audit(
            AUDIT_LOG_MASSIVE_MANAGEMENT,
            'Delete alert ',
            false,
            false,
            json_encode($info)
        );
    } else {
        db_pandora_audit(
            AUDIT_LOG_MASSIVE_MANAGEMENT,
            'Fail try to delete alert',
            false,
            false,
            json_encode($info)
        );
    }
}

$groups = users_get_groups();
$own_info = get_user_info($config['id_user']);
if (!$own_info['is_admin'] && !check_acl($config['id_user'], 0, 'AW')) {
    $return_all_group = false;
} else {
    $return_all_group = true;
}

$table->id = 'delete_table';
$table->class = 'databox filters';
$table->width = '100%';
$table->data = [];
$table->style = [];
$table->style[0] = 'font-weight: bold;';
$table->style[2] = 'font-weight: bold;';
$table->size = [];
$table->size[0] = '15%';
$table->size[1] = '35%';
$table->size[2] = '15%';
$table->size[3] = '35%';

$table->data = [];

$usr_groups = users_get_groups($config['id_user'], 'LW', true);
$filter_groups = '';
$filter_groups = implode(',', array_keys($usr_groups));
$templates = alerts_get_alert_templates(['id_group IN ('.$filter_groups.')'], ['id', 'name']);
$table->data[0][0] = __('Alert template');
$table->data[0][1] = html_print_select(
    index_array($templates, 'id', 'name'),
    'id_alert_template',
    $id_alert_template,
    false,
    __('Select'),
    0,
    true,
    false,
    true,
    '',
    false,
    'width: 100%;'
);
$table->data[0][2] = '';
$table->data[0][3] = '';

$table->data[1][0] = __('Group');
$table->data[1][1] = html_print_select_groups(
    false,
    'AW',
    $return_all_group,
    'id_group',
    $id_group,
    '',
    '',
    '',
    true,
    false,
    true,
    '',
    $id_alert_template == 0,
    'width: 100%;'
);

$table->data[0][2] = __('Show alerts on disabled modules');
$table->data[0][3] = html_print_checkbox('disabled_modules', 1, false, true, false);


$table->data[1][2] = __('Group recursion');
$table->data[1][3] = html_print_checkbox('recursion', 1, false, true, false);

$table->data[2][0] = __('Agents');
$table->data[2][0] .= '<span id="agent_loading" class="invisible">';
$table->data[2][0] .= html_print_image('images/spinner.png', true);
$table->data[2][0] .= '</span>';
$agents_alerts = alerts_get_agents_with_alert_template(
    $id_alert_template,
    $id_group,
    false,
    [
        'tagente.alias',
        'tagente.id_agente',
    ]
);

$table->data[2][1] = html_print_select(
    index_array($agents_alerts, 'id_agente', 'alias'),
    'id_agents[]',
    '',
    '',
    '',
    '',
    true,
    true,
    true,
    '',
    $id_alert_template == 0
);
$table->data[2][2] = __('When select agents');
$table->data[2][2] .= '<br>';
$table->data[2][2] .= html_print_select(
    [
        'common' => __('Show common modules'),
        'all'    => __('Show all modules'),
    ],
    'modules_selection_mode',
    'common',
    false,
    '',
    '',
    true
);
$table->data[2][3] = html_print_select([], 'module[]', '', false, '', '', true, true, false);

echo '<form method="post" id="form_alerts" action="index.php?sec=gmassive&sec2=godmode/massive/massive_operations&option=delete_alerts" >';
html_print_table($table);

attachActionButton('delete', 'delete', $table->width);

echo '</form>';

// Hack to translate text "none" in PHP to javascript
echo '<span id ="none_text" class="invisible">'.__('None').'</span>';

echo '<h3 class="error invisible" id="message"> </h3>';

ui_require_jquery_file('form');
ui_require_jquery_file('pandora.controls');
?>

<script type="text/javascript">
/* <![CDATA[ */
var limit_parameters_massive = <?php echo $config['limit_parameters_massive']; ?>;


$(document).ready (function () {
    $("#form_alerts").submit(function() {
        var get_parameters_count = window.location.href.slice(
            window.location.href.indexOf('?') + 1).split('&').length;
        var post_parameters_count = $("#form_alerts").serializeArray().length;
        
        var count_parameters =
            get_parameters_count + post_parameters_count;
        
        if (count_parameters > limit_parameters_massive) {
            alert("<?php echo __('Unsucessful sending the data, please contact with your administrator or make with less elements.'); ?>");
            return false;
        }
    });
    
    
    $("#id_agents").change(agent_changed_by_multiple_agents_with_alerts);
    
    $("#id_alert_template").change (function () {
        if (this.value != 0) {
            $("#id_agents").enable ();
            $("#id_group").enable ().change ();
        }
        else {
            $("#id_group, #id_agents").disable ();
        }
    });
    
    $("#id_group").change (function () {
        var $select = $("#id_agents").disable ();
        showSpinner();
        $("option", $select).remove ();
        
        jQuery.post ("ajax.php",
            {"page" : "godmode/massive/massive_delete_alerts",
            "get_agents" : 1,
            "id_group" : this.value,
            "recursion" : $("#checkbox-recursion").is(":checked") ? 1 : 0,
            "disabled_modules" : $("#checkbox-disabled_modules").is(":checked") ? 1 : 0,
            "id_alert_template" : $("#id_alert_template").val(),
            // Add a key prefix to avoid auto sorting in js object conversion
            "keys_prefix" : "_"
            },
            function (data, status) {
                options = "";
                jQuery.each (data, function (id, value) {
                    // Remove keys_prefix from the index
                    id = id.substring(1);
                    
                    options += "<option value=\""+id+"\">"+value+"</option>";
                });
                $("#id_agents").append (options);
                hideSpinner();
                $select.enable ();
            },
            "json"
        );
    });
    
    $("#checkbox-recursion").click(function () {
        $("#id_group").trigger("change");
    });
    
    $("#modules_selection_mode").change (function() {
        $("#id_agents").trigger('change');
    });

    $("#checkbox-disabled_modules").click(function () {
        $("#id_group").trigger("change");
    });
});
/* ]]> */
</script>