2010-08-10 11:01:06 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
// Pandora FMS - http://pandorafms.com
|
|
|
|
// ==================================================
|
|
|
|
// Copyright (c) 2005-2010 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.
|
|
|
|
|
|
|
|
// Load global vars
|
|
|
|
global $config;
|
|
|
|
|
|
|
|
check_login ();
|
|
|
|
|
|
|
|
if (! give_acl ($config['id_user'], 0, "PM") && ! is_user_admin ($config['id_user'])) {
|
2010-10-27 Miguel de Dios <miguel.dedios@artica.es>
* godmode/admin_access_logs.php: added hooks to enterprise code, and added
new filter with more options.
* include/functions_db.php: erase the deprecated function "audit_db", and
added in function "pandora_audit" two new parameters $user_id, $ip for
pass this values when it are differents to the default values. Finally
replaced the depecrated "audit_db" for "pandora_audit".
* include/functions_events.php, include/functions_filemanager.php,
include/ajax/reporting.ajax.php,
include/ajax/visual_console_builder.ajax.php,
include/ajax/alert_list.ajax.php, include/help/es/modu_group_list.php,
include/functions_incidents.php, index.php, extensions/agents_modules.php,
extensions/insert_data.php, extensions/system_info.php,
extensions/dbmanager.php, extensions/update_manager/settings.php,
extensions/pandora_logs.php, extensions/plugin_registration.php,
operation/incidents/incident.php, operation/incidents/incident_detail.php,
operation/incidents/incident_statistics.php, operation/extensions.php,
operation/visual_console/render_view.php,
operation/agentes/status_monitor.php, operation/agentes/export_csv.php,
operation/agentes/datos_agente.php, operation/agentes/alerts_status.php,
operation/agentes/estado_generalagente.php,
operation/agentes/custom_fields.php, operation/agentes/estado_agente.php,
operation/agentes/networkmap.topology.php,
operation/agentes/networkmap.groups.php, operation/agentes/sla_view.php,
operation/agentes/gis_view.php, operation/agentes/estado_monitores.php,
operation/agentes/ver_agente.php, operation/agentes/graphs.php,
operation/agentes/agent_fields.php, operation/agentes/tactical.php,
operation/agentes/group_view.php, operation/agentes/networkmap.php,
operation/servers/view_server.php,operation/servers/view_server_detail.php,
operation/snmpconsole/snmp_view.php, operation/users/user_edit.php,
operation/gis_maps/render_view.php, operation/events/event_statistics.php,
operation/events/sound_events.php, operation/events/events_validate.php,
operation/events/events_list.php, operation/events/events_marquee.php,
operation/events/events.php, operation/reporting/reporting_xml.php,
operation/reporting/reporting_viewer.php,
operation/reporting/graph_viewer.php,
mobile/operation/agents/view_agents.php, mobile/index.php,
godmode/groups/modu_group_list.php, godmode/groups/configure_group.php,
godmode/groups/configure_modu_group.php, godmode/groups/group_list.php,
godmode/extensions.php, godmode/db/db_main.php, godmode/db/db_audit.php,
godmode/db/db_sanity.php, godmode/db/db_refine.php, godmode/db/db_info.php,
godmode/db/db_event.php, godmode/db/db_purge.php,
godmode/agentes/fields_manager.php, godmode/agentes/module_manager.php,
godmode/agentes/modificar_agente.php, godmode/agentes/configurar_agente.php,
godmode/agentes/configure_field.php, godmode/agentes/planned_downtime.php,
godmode/agentes/manage_config_remote.php, godmode/agentes/agent_manager.php,
godmode/servers/manage_export.php, godmode/servers/recon_script.php,
godmode/servers/manage_export_form.php, godmode/servers/plugin.php,
godmode/servers/manage_recontask.php, godmode/servers/modificar_server.php,
godmode/servers/manage_recontask_form.php,
godmode/alerts/alert_list.list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_template.php,
godmode/alerts/alert_templates.php,
godmode/alerts/configure_alert_action.php,
godmode/alerts/configure_alert_command.php,
godmode/alerts/alert_actions.php, godmode/alerts/alert_list.builder.php,
godmode/alerts/alert_commands.php, godmode/snmpconsole/snmp_alert.php,
godmode/snmpconsole/snmp_filters.php, godmode/setup/file_manager.php,
godmode/setup/os.list.php, godmode/setup/news.php,
godmode/setup/gis_step_2.php, godmode/setup/links.php,
godmode/setup/setup.php, godmode/setup/os.php,
godmode/setup/performance.php, godmode/setup/setup_auth.php,
godmode/setup/gis.php, godmode/setup/os.builder.php,
godmode/setup/setup_visuals.php, godmode/users/user_list.php,
godmode/users/configure_user.php, godmode/users/configure_profile.php,
godmode/gis_maps/configure_gis_map.php, godmode/gis_maps/index.php,
godmode/massive/massive_add_alerts.php,
godmode/massive/massive_copy_modules.php,
godmode/massive/massive_delete_agents.php,
godmode/massive/massive_enable_disable_alerts.php,
godmode/massive/massive_operations.php,
godmode/massive/massive_delete_profiles.php,
godmode/massive/massive_edit_agents.php,
godmode/massive/massive_delete_action_alerts.php,
godmode/massive/massive_delete_modules.php,
godmode/massive/massive_add_profiles.php,
godmode/massive/massive_delete_alerts.php,
godmode/massive/massive_edit_modules.php,
godmode/massive/massive_standby_alerts.php,
godmode/massive/massive_add_action_alerts.php,
godmode/modules/manage_network_components_form.php,
godmode/modules/manage_nc_groups_form.php,
godmode/modules/manage_network_templates.php,
godmode/modules/module_list.php,
godmode/modules/manage_network_components_form_common.php,
godmode/modules/manage_network_components_form_network.php,
godmode/modules/manage_network_templates_form.php,
godmode/modules/manage_network_components_form_wmi.php,
godmode/modules/manage_network_components.php,
godmode/modules/manage_nc_groups.php,
godmode/reporting/reporting_builder.list_items.php,
godmode/reporting/graph_builder.main.php,
godmode/reporting/visual_console_builder.wizard.php,
godmode/reporting/visual_console_builder.php,
godmode/reporting/reporting_builder.preview.php,
godmode/reporting/reporting_builder.main.php,
godmode/reporting/visual_console_builder.data.php,
godmode/reporting/map_builder_wizard.php,
godmode/reporting/visual_console_builder.elements.php,
godmode/reporting/graph_builder.php,
godmode/reporting/visual_console_builder.preview.php,
godmode/reporting/graph_builder.graph_editor.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/visual_console_builder.editor.php,
godmode/reporting/reporting_builder.item_editor.php,
godmode/reporting/graphs.php, godmode/reporting/graph_builder.preview.php:
Replaced the depecrated "audit_db" for "pandora_audit".
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@3467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2010-10-27 12:47:07 +02:00
|
|
|
pandora_audit("ACL Violation", "Trying to access Setup Management");
|
2010-08-10 11:01:06 +02:00
|
|
|
require ("general/noaccess.php");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Load enterprise extensions
|
|
|
|
enterprise_include ('godmode/setup/setup_auth.php');
|
|
|
|
|
|
|
|
// Header
|
|
|
|
print_page_header (__('Authentication configuration'), "", false, "", true);
|
|
|
|
|
|
|
|
$table->data = array ();
|
|
|
|
$table->width = '90%';
|
|
|
|
$table->size[0] = '30%';
|
|
|
|
|
|
|
|
$table->data[0][0] = __('Authentication method');
|
|
|
|
$auth_methods = array ('mysql' => __('Local Pandora FMS'), __('ldap') => 'LDAP');
|
|
|
|
enterprise_hook ('add_enterprise_auth_methods', array (&$auth_methods));
|
|
|
|
$table->data[0][1] = print_select ($auth_methods, 'auth', $config['auth'], 'show_selected_rows ();', '', 0, true);
|
|
|
|
|
|
|
|
$table->data[1][0] = __('Autocreate remote users');
|
|
|
|
$table->data[1][1] = __('Yes').' '.print_radio_button_extended ('autocreate_remote_users', 1, '', $config['autocreate_remote_users'], false, 'enable_profile_options ();', '', true).' ';
|
|
|
|
$table->data[1][1] .= __('No').' '.print_radio_button_extended ('autocreate_remote_users', 0, '', $config['autocreate_remote_users'], false, 'enable_profile_options ();', '', true);
|
|
|
|
$table->rowstyle[1] = $config['auth'] != 'mysql' ? '' : 'display: none;';
|
|
|
|
$table->data[2][0] = __('Autocreate profile');
|
|
|
|
$profile_list = get_profiles ();
|
|
|
|
if ($profile_list === false) {
|
|
|
|
$profile_list = array ();
|
|
|
|
}
|
|
|
|
$table->data[2][1] = print_select ($profile_list, 'default_remote_profile', $config['default_remote_profile'], '', '', '', true, false, true, '', $config['autocreate_remote_users'] == 0);
|
|
|
|
$table->data[3][0] = __('Autocreate profile group');
|
|
|
|
$table->data[3][1] = print_select_groups ($config['id_user'], "AR", true, 'default_remote_group', $config['default_remote_group'], '', '', '', true, false, true, '', $config['autocreate_remote_users'] == 0);
|
2010-08-10 13:25:44 +02:00
|
|
|
$table->data[4][0] = __('Autocreate blacklist') . print_help_icon ('autocreate_blacklist', true);
|
|
|
|
$table->data[4][1] = print_input_text ('autocreate_blacklist', $config['autocreate_blacklist'], '', 60, 100, true);
|
|
|
|
for ($i = 1; $i <= 4; $i++) {
|
2010-08-10 11:01:06 +02:00
|
|
|
$table->rowstyle[$i] = $config['auth'] != 'mysql' ? '' : 'display: none;';
|
|
|
|
$table->rowclass[$i] = 'remote';
|
|
|
|
}
|
|
|
|
|
2010-08-10 13:25:44 +02:00
|
|
|
$table->data[5][0] = __('LDAP server');
|
|
|
|
$table->data[5][1] = print_input_text ('ldap_server', $config['ldap_server'], '', 30, 100, true);
|
|
|
|
$table->data[6][0] = __('LDAP port');
|
|
|
|
$table->data[6][1] = print_input_text ('ldap_port', $config['ldap_port'], '', 10, 100, true);
|
|
|
|
$table->data[7][0] = __('LDAP version');
|
2010-08-10 11:01:06 +02:00
|
|
|
$ldap_versions = array (1 => 'LDAPv1', 2 => 'LDAPv2', 3 => 'LDAPv3');
|
2010-08-10 13:25:44 +02:00
|
|
|
$table->data[7][1] = print_select ($ldap_versions, 'ldap_version', $config['ldap_version'], '', '', 0, true);
|
|
|
|
$table->data[8][0] = __('Start TLS');
|
|
|
|
$table->data[8][1] = __('Yes').' '.print_radio_button ('ldap_start_tls', 1, '', $config['ldap_start_tls'], true).' ';
|
|
|
|
$table->data[8][1] .= __('No').' '.print_radio_button ('ldap_start_tls', 0, '', $config['ldap_start_tls'], true);
|
|
|
|
$table->data[9][0] = __('Base DN');
|
|
|
|
$table->data[9][1] = print_input_text ('ldap_base_dn', $config['ldap_base_dn'], '', 60, 100, true);
|
|
|
|
$table->data[10][0] = __('Login attribute');
|
|
|
|
$table->data[10][1] = print_input_text ('ldap_login_attr', $config['ldap_login_attr'], '', 60, 100, true);
|
2010-08-10 11:01:06 +02:00
|
|
|
|
|
|
|
// Hide LDAP configuration options
|
2010-08-10 13:25:44 +02:00
|
|
|
for ($i = 5; $i <= 10; $i++) {
|
2010-08-10 11:01:06 +02:00
|
|
|
$table->rowstyle[$i] = $config['auth'] == 'ldap' ? '' : 'display: none;';
|
|
|
|
$table->rowclass[$i] = 'ldap';
|
|
|
|
}
|
|
|
|
|
|
|
|
// Add enterprise authentication options
|
2010-08-10 13:25:44 +02:00
|
|
|
enterprise_hook ('add_enterprise_auth_options', array (&$table, 11));
|
2010-08-10 11:01:06 +02:00
|
|
|
|
|
|
|
echo '<form id="form_setup" method="post">';
|
|
|
|
print_input_hidden ('update_config', 1);
|
|
|
|
print_table ($table);
|
|
|
|
echo '<div class="action-buttons" style="width: '.$table->width.'">';
|
|
|
|
print_submit_button (__('Update'), 'update_button', false, 'class="sub upd"');
|
|
|
|
echo '</div>';
|
|
|
|
echo '</form>';
|
|
|
|
?>
|
|
|
|
|
|
|
|
<script type="text/javascript">
|
|
|
|
function show_selected_rows () {
|
|
|
|
var auth_method = $("#auth").val ();
|
|
|
|
|
|
|
|
$(".remote").css("display", "none");
|
|
|
|
$(".ldap").css("display", "none");
|
|
|
|
$(".ad").css("display", "none");
|
|
|
|
$(".pandora").css("display", "none");
|
|
|
|
$(".babel").css("display", "none");
|
2010-08-10 11:21:20 +02:00
|
|
|
$(".integria").css("display", "none");
|
2010-08-10 11:01:06 +02:00
|
|
|
|
|
|
|
if (auth_method != "mysql") {
|
|
|
|
$(".remote").css("display", "");
|
|
|
|
}
|
|
|
|
$("." + auth_method).css('display', '');
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
function enable_profile_options () {
|
|
|
|
var remote_auto = $("input:radio[name=autocreate_remote_users]:checked").val();
|
|
|
|
|
|
|
|
if (remote_auto == 0) {
|
|
|
|
$("#default_remote_profile").attr("disabled", true);
|
|
|
|
$("#default_remote_group").attr("disabled", true);
|
2010-08-10 13:32:36 +02:00
|
|
|
$("#text-autocreate_blacklist").attr("disabled", true);
|
2010-08-10 11:01:06 +02:00
|
|
|
} else {
|
|
|
|
$("#default_remote_profile").attr("disabled", false);
|
|
|
|
$("#default_remote_group").attr("disabled", false);
|
2010-08-10 13:32:36 +02:00
|
|
|
$("#text-autocreate_blacklist").attr("disabled", false);
|
2010-08-10 11:01:06 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|