984 lines
26 KiB
PHP
984 lines
26 KiB
PHP
<?php
|
|
/**
|
|
* General setup.
|
|
*
|
|
* @category Setup
|
|
* @package Pandora FMS
|
|
* @subpackage Opensource
|
|
* @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.
|
|
* ============================================================================
|
|
*/
|
|
|
|
// File begin.
|
|
global $config;
|
|
|
|
|
|
check_login();
|
|
|
|
if (is_ajax()) {
|
|
$test_address = get_parameter('test_address', '');
|
|
$params = io_safe_output(get_parameter('params', ''));
|
|
|
|
$res = send_test_email(
|
|
$test_address,
|
|
$params
|
|
);
|
|
|
|
echo $res;
|
|
|
|
// Exit after ajax response.
|
|
exit();
|
|
}
|
|
|
|
$performance_variables_control = (array) json_decode(io_safe_output($config['performance_variables_control']));
|
|
|
|
$table = new StdClass();
|
|
$table->class = 'databox filters';
|
|
$table->id = 'setup_general';
|
|
$table->width = '100%';
|
|
$table->data = [];
|
|
$table->size = [];
|
|
$table->size[0] = '30%';
|
|
$table->style[0] = 'font-weight:bold';
|
|
$table->size[1] = '70%';
|
|
|
|
$table_mail_conf = new stdClass();
|
|
$table_mail_conf->width = '100%';
|
|
$table_mail_conf->class = 'databox filters';
|
|
$table_mail_conf->data = [];
|
|
$table_mail_conf->style[0] = 'font-weight: bold';
|
|
|
|
// Current config["language"] could be set by user, not taken from global setup !
|
|
$current_system_lang = db_get_sql(
|
|
'SELECT `value` FROM tconfig WHERE `token` = "language"'
|
|
);
|
|
|
|
if ($current_system_lang == '') {
|
|
$current_system_lang = 'en';
|
|
}
|
|
|
|
$i = 0;
|
|
|
|
$table->data[$i][0] = __('Language code');
|
|
$table->data[$i++][1] = html_print_select_from_sql(
|
|
'SELECT id_language, name FROM tlanguage',
|
|
'language',
|
|
$current_system_lang,
|
|
'',
|
|
'',
|
|
'',
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Remote config directory');
|
|
$table->data[$i++][1] = html_print_input_text(
|
|
'remote_config',
|
|
io_safe_output($config['remote_config']),
|
|
'',
|
|
30,
|
|
100,
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Chromium path');
|
|
$table->data[$i++][1] = html_print_input_text(
|
|
'chromium_path',
|
|
io_safe_output(
|
|
$config['chromium_path']
|
|
),
|
|
'',
|
|
30,
|
|
100,
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Auto login (hash) password');
|
|
$table->data[$i][1] = html_print_input_password(
|
|
'loginhash_pwd',
|
|
io_output_password($config['loginhash_pwd']),
|
|
'',
|
|
15,
|
|
15,
|
|
true
|
|
);
|
|
$table->data[$i++][1] .= ui_print_reveal_password(
|
|
'loginhash_pwd',
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Time source');
|
|
$sources['system'] = __('System');
|
|
$sources['sql'] = __('Database');
|
|
$table->data[$i++][1] = html_print_select(
|
|
$sources,
|
|
'timesource',
|
|
$config['timesource'],
|
|
'',
|
|
'',
|
|
'',
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Automatic check for updates');
|
|
$table->data[$i++][1] = html_print_checkbox_switch(
|
|
'autoupdate',
|
|
1,
|
|
$config['autoupdate'],
|
|
true
|
|
);
|
|
|
|
echo "<div id='dialog' title='".__('Enforce https Information')."' class='invisible'>";
|
|
echo "<p class='center'>".__('If SSL is not properly configured you will lose access to ').get_product_name().__(' Console').'</p>';
|
|
echo '</div>';
|
|
|
|
$table->data[$i][0] = __('Enforce https');
|
|
$table->data[$i++][1] = html_print_checkbox_switch_extended(
|
|
'https',
|
|
1,
|
|
$config['https'],
|
|
false,
|
|
'',
|
|
'',
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Use cert of SSL');
|
|
$table->data[$i++][1] = html_print_checkbox_switch_extended(
|
|
'use_cert',
|
|
1,
|
|
$config['use_cert'],
|
|
false,
|
|
'',
|
|
'',
|
|
true
|
|
);
|
|
|
|
$table->rowstyle[$i] = 'display: none;';
|
|
$table->rowid[$i] = 'ssl-path-tr';
|
|
$table->data[$i][0] = __('Path of SSL Cert.');
|
|
$table->data[$i++][1] = html_print_input_text(
|
|
'cert_path',
|
|
io_safe_output($config['cert_path']),
|
|
'',
|
|
50,
|
|
255,
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Attachment store');
|
|
$table->data[$i++][1] = html_print_input_text(
|
|
'attachment_store',
|
|
io_safe_output($config['attachment_store']),
|
|
'',
|
|
50,
|
|
255,
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('IP list with API access');
|
|
if (isset($_POST['list_ACL_IPs_for_API'])) {
|
|
$list_ACL_IPs_for_API = get_parameter_post('list_ACL_IPs_for_API');
|
|
} else {
|
|
$list_ACL_IPs_for_API = get_parameter_get(
|
|
'list_ACL_IPs_for_API',
|
|
implode("\n", $config['list_ACL_IPs_for_API'])
|
|
);
|
|
}
|
|
|
|
$table->data[$i++][1] = html_print_textarea(
|
|
'list_ACL_IPs_for_API',
|
|
2,
|
|
25,
|
|
$list_ACL_IPs_for_API,
|
|
'class="height_130px w300px"',
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('API password');
|
|
$table->data[$i][1] = html_print_input_password(
|
|
'api_password',
|
|
io_output_password($config['api_password']),
|
|
'',
|
|
25,
|
|
255,
|
|
true
|
|
);
|
|
$table->data[$i++][1] .= ui_print_reveal_password('api_password', true);
|
|
|
|
$table->data[$i][0] = __('Enable GIS features');
|
|
$table->data[$i++][1] = html_print_checkbox_switch(
|
|
'activate_gis',
|
|
1,
|
|
$config['activate_gis'],
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Enable Netflow');
|
|
$rbt_disabled = false;
|
|
if (strtoupper(substr(PHP_OS, 0, 3)) == 'WIN') {
|
|
$rbt_disabled = true;
|
|
}
|
|
|
|
$table->data[$i++][1] = html_print_checkbox_switch_extended(
|
|
'activate_netflow',
|
|
1,
|
|
$config['activate_netflow'],
|
|
$rbt_disabled,
|
|
'',
|
|
'',
|
|
true
|
|
);
|
|
|
|
|
|
$zone_name = [
|
|
'Africa' => __('Africa'),
|
|
'America' => __('America'),
|
|
'Antarctica' => __('Antarctica'),
|
|
'Arctic' => __('Arctic'),
|
|
'Asia' => __('Asia'),
|
|
'Atlantic' => __('Atlantic'),
|
|
'Australia' => __('Australia'),
|
|
'Europe' => __('Europe'),
|
|
'Indian' => __('Indian'),
|
|
'Pacific' => __('Pacific'),
|
|
'UTC' => __('UTC'),
|
|
];
|
|
|
|
$zone_selected = get_parameter('zone');
|
|
if ($zone_selected == '') {
|
|
if ($config['timezone'] != '') {
|
|
$zone_array = explode('/', $config['timezone']);
|
|
$zone_selected = $zone_array[0];
|
|
} else {
|
|
$zone_selected = 'Europe';
|
|
}
|
|
}
|
|
|
|
$timezones = timezone_identifiers_list();
|
|
foreach ($timezones as $timezone) {
|
|
if (strpos($timezone, $zone_selected) !== false) {
|
|
$timezone_n[$timezone] = $timezone;
|
|
}
|
|
}
|
|
|
|
$table->data[$i][0] = __('Timezone setup');
|
|
$table->data[$i][1] = html_print_input_text_extended(
|
|
'timezone_text',
|
|
$config['timezone'],
|
|
'text-timezone_text',
|
|
'',
|
|
25,
|
|
25,
|
|
false,
|
|
'',
|
|
'readonly',
|
|
true
|
|
);
|
|
$table->data[$i][1] .= '<a id="change_timezone">'.html_print_image(
|
|
'images/edit.svg',
|
|
true,
|
|
[
|
|
'title' => __('Change timezone'),
|
|
'class' => 'main_menu_icon invert_filter',
|
|
]
|
|
).'</a>';
|
|
$table->data[$i][1] .= ' '.html_print_select(
|
|
$zone_name,
|
|
'zone',
|
|
$zone_selected,
|
|
'show_timezone();',
|
|
'',
|
|
'',
|
|
true
|
|
);
|
|
$table->data[$i++][1] .= ' '.html_print_select(
|
|
$timezone_n,
|
|
'timezone',
|
|
$config['timezone'],
|
|
'',
|
|
'',
|
|
'',
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Public URL');
|
|
$table->data[$i++][1] = html_print_input_text(
|
|
'public_url',
|
|
$config['public_url'],
|
|
'',
|
|
40,
|
|
255,
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Force use Public URL');
|
|
$table->data[$i++][1] = html_print_switch(
|
|
[
|
|
'name' => 'force_public_url',
|
|
'value' => $config['force_public_url'],
|
|
]
|
|
);
|
|
|
|
echo "<div id='force_public_url_dialog' title='".__(
|
|
'Enforce public URL usage information'
|
|
)."' class='invisible'>";
|
|
echo "<p class='center'>".__('If public URL is not properly configured you will lose access to ').get_product_name().__(' Console').'</p>';
|
|
echo '</div>';
|
|
|
|
$table->data[$i][0] = __('Public URL host exclusions');
|
|
$table->data[$i++][1] = html_print_textarea(
|
|
'public_url_exclusions',
|
|
2,
|
|
25,
|
|
$config['public_url_exclusions'],
|
|
'class="height_50px w300px"',
|
|
true
|
|
);
|
|
|
|
// Inventory changes blacklist.
|
|
$table->data[$i][0] = __('Inventory changes blacklist');
|
|
|
|
$inventory_changes_blacklist_id = get_parameter(
|
|
'inventory_changes_blacklist',
|
|
$config['inventory_changes_blacklist']
|
|
);
|
|
|
|
if (!is_array($inventory_changes_blacklist_id)) {
|
|
$inventory_changes_blacklist_id = explode(
|
|
',',
|
|
$inventory_changes_blacklist_id
|
|
);
|
|
}
|
|
|
|
$inventory_modules = db_get_all_rows_sql(
|
|
'SELECT mi.id_module_inventory, mi.name module_inventory_name, os.name os_name
|
|
FROM tmodule_inventory mi, tconfig_os os
|
|
WHERE os.id_os = mi.id_os'
|
|
);
|
|
|
|
$inventory_changes_blacklist = [];
|
|
$inventory_changes_blacklist_out = [];
|
|
|
|
foreach ($inventory_modules as $inventory_module) {
|
|
if (in_array($inventory_module['id_module_inventory'], $inventory_changes_blacklist_id)) {
|
|
$inventory_changes_blacklist[$inventory_module['id_module_inventory']] = $inventory_module['module_inventory_name'].' ('.$inventory_module['os_name'].')';
|
|
} else {
|
|
$inventory_changes_blacklist_out[$inventory_module['id_module_inventory']] = $inventory_module['module_inventory_name'].' ('.$inventory_module['os_name'].')';
|
|
}
|
|
}
|
|
|
|
$select_out = html_print_select(
|
|
$inventory_changes_blacklist_out,
|
|
'inventory_changes_blacklist_out[]',
|
|
'',
|
|
'',
|
|
'',
|
|
'',
|
|
true,
|
|
true,
|
|
true,
|
|
'',
|
|
false,
|
|
'width:200px'
|
|
);
|
|
$arrows = ' ';
|
|
$select_in = html_print_select(
|
|
$inventory_changes_blacklist,
|
|
'inventory_changes_blacklist[]',
|
|
'',
|
|
'',
|
|
'',
|
|
'',
|
|
true,
|
|
true,
|
|
true,
|
|
'',
|
|
false,
|
|
'width:200px'
|
|
);
|
|
|
|
$table_ichanges = '<table>
|
|
<tr>
|
|
<td>'.__('Out of black list').'</td>
|
|
<td></td>
|
|
<td>'.__('In black list').'</td>
|
|
</tr>
|
|
<tr>
|
|
<td>'.$select_out.'</td>
|
|
<td>
|
|
<a href="javascript:">'.html_print_image('images/arrow@svg.svg', true, ['style' => 'rotate: 180deg;', 'id' => 'right_iblacklist', 'alt' => __('Push selected modules into blacklist'), 'title' => __('Push selected modules into blacklist'), 'class' => 'main_menu_icon invert_filter']).'</a>
|
|
<br><br>
|
|
<a href="javascript:">'.html_print_image('images/arrow@svg.svg', true, ['style' => 'rotate: 0', 'id' => 'left_iblacklist', 'alt' => __('Pop selected modules out of blacklist'), 'title' => __('Pop selected modules out of blacklist'), 'class' => 'main_menu_icon invert_filter']).'</a>
|
|
</td>
|
|
<td>'.$select_in.'</td>
|
|
</tr>
|
|
</table>';
|
|
|
|
$table->data[$i++][1] = $table_ichanges;
|
|
|
|
$table->data[$i][0] = __('Referer security');
|
|
$table->data[$i++][1] = html_print_checkbox_switch(
|
|
'referer_security',
|
|
1,
|
|
$config['referer_security'],
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Event storm protection');
|
|
$table->data[$i++][1] = html_print_checkbox_switch(
|
|
'event_storm_protection',
|
|
1,
|
|
$config['event_storm_protection'],
|
|
true
|
|
);
|
|
|
|
|
|
$table->data[$i][0] = __('Command Snapshot');
|
|
$table->data[$i++][1] = html_print_checkbox_switch(
|
|
'command_snapshot',
|
|
1,
|
|
$config['command_snapshot'],
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Change remote config encoding');
|
|
$table->data[$i++][1] = html_print_checkbox_switch(
|
|
'use_custom_encoding',
|
|
1,
|
|
$config['use_custom_encoding'],
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Server logs directory');
|
|
$table->data[$i++][1] = html_print_input_text(
|
|
'server_log_dir',
|
|
$config['server_log_dir'],
|
|
'',
|
|
50,
|
|
255,
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Log size limit in system logs viewer extension');
|
|
$table->data[$i++][1] = html_print_input_text(
|
|
'max_log_size',
|
|
$config['max_log_size'],
|
|
'',
|
|
10,
|
|
255,
|
|
true
|
|
).html_print_label(' x1000', 'max_log_size', true);
|
|
|
|
$modes_tutorial = [
|
|
'full' => __('Full mode'),
|
|
'on_demand' => __('On demand'),
|
|
'expert' => __('Expert'),
|
|
];
|
|
$table->data[$i][0] = __('Tutorial mode');
|
|
$table->data[$i++][1] = html_print_select(
|
|
$modes_tutorial,
|
|
'tutorial_mode',
|
|
$config['tutorial_mode'],
|
|
'',
|
|
'',
|
|
0,
|
|
true
|
|
);
|
|
|
|
$config['past_planned_downtimes'] = isset(
|
|
$config['past_planned_downtimes']
|
|
) ? $config['past_planned_downtimes'] : 1;
|
|
$table->data[$i][0] = __('Allow create scheduled downtimes in the past');
|
|
$table->data[$i++][1] = html_print_checkbox_switch(
|
|
'past_planned_downtimes',
|
|
1,
|
|
$config['past_planned_downtimes'],
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Limit for bulk operations');
|
|
$table->data[$i++][1] = html_print_input(
|
|
[
|
|
'type' => 'number',
|
|
'size' => 5,
|
|
'max' => $performance_variables_control['limit_parameters_massive']->max,
|
|
'name' => 'limit_parameters_massive',
|
|
'value' => $config['limit_parameters_massive'],
|
|
'return' => true,
|
|
'min' => $performance_variables_control['limit_parameters_massive']->min,
|
|
'style' => 'width:50px',
|
|
]
|
|
);
|
|
|
|
$table->data[$i][0] = __('Include agents manually disabled');
|
|
$table->data[$i++][1] = html_print_checkbox_switch(
|
|
'include_agents',
|
|
1,
|
|
$config['include_agents'],
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Set alias as name by default in agent creation');
|
|
$table->data[$i++][1] = html_print_checkbox_switch(
|
|
'alias_as_name',
|
|
1,
|
|
$config['alias_as_name'],
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Unique IP');
|
|
$table->data[$i++][1] = html_print_checkbox_switch(
|
|
'unique_ip',
|
|
1,
|
|
$config['unique_ip'],
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Enable console log').ui_print_help_tip(
|
|
__('Log location').': pandora_console/log/console.log',
|
|
true
|
|
);
|
|
$table->data[$i++][1] = html_print_checkbox_switch(
|
|
'console_log_enabled',
|
|
1,
|
|
$config['console_log_enabled'],
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Enable audit log').ui_print_help_tip(
|
|
__('Log location').': pandora_console/log/audit.log',
|
|
true
|
|
);
|
|
$table->data[$i++][1] = html_print_checkbox_switch(
|
|
'audit_log_enabled',
|
|
1,
|
|
$config['audit_log_enabled'],
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Module custom ID readonly').ui_print_help_tip(
|
|
__('Useful for integrations'),
|
|
true
|
|
);
|
|
$table->data[$i++][1] = html_print_checkbox_switch(
|
|
'module_custom_id_ro',
|
|
1,
|
|
$config['module_custom_id_ro'],
|
|
true
|
|
);
|
|
|
|
$table->data[$i][0] = __('Enable console report').ui_print_help_tip(
|
|
__('Enable console report'),
|
|
true
|
|
);
|
|
$table->data[$i++][1] = html_print_checkbox_switch(
|
|
'reporting_console_enable',
|
|
1,
|
|
$config['reporting_console_enable'],
|
|
true
|
|
);
|
|
|
|
echo '<form id="form_setup" method="post" action="index.php?sec=gsetup&sec2=godmode/setup/setup&section=general&pure='.$config['pure'].'">';
|
|
|
|
echo '<fieldset>';
|
|
echo '<legend>'.__('General options').'</legend>';
|
|
|
|
html_print_input_hidden('update_config', 1);
|
|
html_print_table($table);
|
|
|
|
$encryption = [
|
|
'ssl' => 'SSL',
|
|
'sslv2' => 'SSLv2',
|
|
'sslv3' => 'SSLv3',
|
|
'tls' => 'STARTTLS',
|
|
];
|
|
|
|
echo '</fieldset>';
|
|
|
|
echo '<fieldset>';
|
|
echo '<legend>'.__('Mail configuration').'</legend>';
|
|
|
|
$table_mail_conf->data[0][0] = ui_print_warning_message(
|
|
__(
|
|
'Please notice that some providers like Gmail or Office365 need to setup/enable manually external connections using SMTP and you need to use STARTTLS on port 587.
|
|
|
|
If you have manual settings in your pandora_server.conf, please note these settings will ignore this console setup.'
|
|
)
|
|
);
|
|
|
|
$table_mail_conf->data[1][0] = __('From address');
|
|
$table_mail_conf->data[1][1] = html_print_input_text(
|
|
'email_from_dir',
|
|
$config['email_from_dir'],
|
|
'',
|
|
30,
|
|
100,
|
|
true
|
|
);
|
|
|
|
$table_mail_conf->data[2][0] = __('From name');
|
|
$table_mail_conf->data[2][1] = html_print_input_text(
|
|
'email_from_name',
|
|
$config['email_from_name'],
|
|
'',
|
|
30,
|
|
100,
|
|
true
|
|
);
|
|
|
|
$table_mail_conf->data[3][0] = __('SMTP Server');
|
|
$table_mail_conf->data[3][1] = html_print_input_text(
|
|
'email_smtpServer',
|
|
$config['email_smtpServer'],
|
|
'',
|
|
30,
|
|
100,
|
|
true
|
|
);
|
|
|
|
$table_mail_conf->data[4][0] = __('SMTP Port');
|
|
$table_mail_conf->data[4][1] = html_print_input_text(
|
|
'email_smtpPort',
|
|
$config['email_smtpPort'],
|
|
'',
|
|
30,
|
|
100,
|
|
true
|
|
);
|
|
|
|
$table_mail_conf->data[5][0] = __('Encryption');
|
|
$table_mail_conf->data[5][1] = html_print_select(
|
|
$encryption,
|
|
'email_encryption',
|
|
$config['email_encryption'],
|
|
'',
|
|
__('none'),
|
|
0,
|
|
true
|
|
);
|
|
|
|
$table_mail_conf->data[6][0] = __('Email user');
|
|
$table_mail_conf->data[6][1] = html_print_input_text(
|
|
'email_username',
|
|
$config['email_username'],
|
|
'',
|
|
30,
|
|
100,
|
|
true
|
|
);
|
|
|
|
$table_mail_conf->data[7][0] = __('Email password');
|
|
$table_mail_conf->data[7][1] = html_print_input_password(
|
|
'email_password',
|
|
io_output_password(
|
|
$config['email_password']
|
|
),
|
|
'',
|
|
30,
|
|
100,
|
|
true
|
|
);
|
|
$table_mail_conf->data[7][1] .= ui_print_reveal_password(
|
|
'email_password',
|
|
true
|
|
);
|
|
|
|
$uniqid = uniqid();
|
|
|
|
$table_mail_conf->data[8][0] = html_print_button(
|
|
__('Email test'),
|
|
'email_test_dialog',
|
|
false,
|
|
"show_email_test('".$uniqid."');",
|
|
[ 'icon' => 'next' ],
|
|
true
|
|
);
|
|
|
|
print_email_test_modal_window($uniqid);
|
|
|
|
html_print_input_hidden('update_config', 1);
|
|
html_print_table($table_mail_conf);
|
|
|
|
|
|
echo '</fieldset>';
|
|
|
|
|
|
html_print_div(
|
|
[
|
|
'class' => 'action-buttons w100p',
|
|
'content' => html_print_submit_button(
|
|
__('Update'),
|
|
'update_button',
|
|
false,
|
|
['icon' => 'update'],
|
|
true
|
|
),
|
|
]
|
|
);
|
|
|
|
echo '</form>';
|
|
|
|
|
|
/**
|
|
* Print the modal window for the summary of each alerts group
|
|
*
|
|
* @param string $id Id.
|
|
*
|
|
* @return void
|
|
*/
|
|
function print_email_test_modal_window($id)
|
|
{
|
|
// Email config table.
|
|
$table_mail_test = new stdClass();
|
|
$table_mail_test->width = '100%';
|
|
$table_mail_test->class = 'databox filters';
|
|
$table_mail_test->data = [];
|
|
$table_mail_test->style[0] = 'font-weight: bold;';
|
|
$table_mail_test->style[1] = 'font-weight: bold;display: flex;height: 54px;align-items: center;padding-left: 15px;';
|
|
|
|
$table_mail_test->data[0][0] = __('Address');
|
|
$table_mail_test->data[0][1] = html_print_input_text(
|
|
'email_test_address',
|
|
'',
|
|
'',
|
|
35,
|
|
100,
|
|
true
|
|
);
|
|
|
|
$table_mail_test->data[1][0] = '  <span id="email_test_sent_message" class="invisible"><b>Email sent</b></span><span id="email_test_failure_message" class=invisible"><b>Email could not be sent</b></span>';
|
|
|
|
$table_mail_test->data[1][1] = html_print_div(
|
|
[
|
|
'class' => 'action-buttons w100p',
|
|
'content' => html_print_button(
|
|
__('Send'),
|
|
'email_test',
|
|
false,
|
|
'',
|
|
[
|
|
'icon' => 'cog',
|
|
'mode' => 'mini',
|
|
],
|
|
true
|
|
),
|
|
],
|
|
true
|
|
);
|
|
|
|
echo '<div id="email_test_'.$id.'" title="'.__('Check mail configuration').'" class="invisible">'.html_print_table($table_mail_test, true).'</div>';
|
|
}
|
|
|
|
|
|
?>
|
|
<script type="text/javascript">
|
|
function show_timezone () {
|
|
zone = $("#zone").val();
|
|
$.ajax({
|
|
type: "POST",
|
|
url: "ajax.php",
|
|
data: "page=<?php echo $_GET['sec2']; ?>&select_timezone=1&zone=" + zone,
|
|
dataType: "json",
|
|
success: function(data) {
|
|
$("#timezone").empty();
|
|
jQuery.each (data, function (id, value) {
|
|
timezone = value;
|
|
$("select[name='timezone']").append($("<option>").val(timezone).html(timezone));
|
|
});
|
|
}
|
|
});
|
|
}
|
|
|
|
function show_email_test(id) {
|
|
$('#email_test_sent_message').hide();
|
|
$('#email_test_failure_message').hide();
|
|
|
|
$("#email_test_"+id).dialog({
|
|
resizable: true,
|
|
draggable: true,
|
|
modal: true,
|
|
width: 450,
|
|
overlay: {
|
|
opacity: 0.5,
|
|
background: "black"
|
|
}
|
|
});
|
|
}
|
|
|
|
function perform_email_test () {
|
|
$('#email_test_sent_message').hide();
|
|
$('#email_test_failure_message').hide();
|
|
|
|
var test_address = $('#text-email_test_address').val();
|
|
params = {
|
|
email_smtpServer : $('#text-email_smtpServer').val(),
|
|
email_smtpPort : $('#text-email_smtpPort').val(),
|
|
email_username : $('#text-email_username').val(),
|
|
email_password : $('#password-email_password').val(),
|
|
email_encryption : $( "#email_encryption option:selected" ).val(),
|
|
email_from_dir : $('#text-email_from_dir').val(),
|
|
email_from_name : $('#text-email_from_name').val()
|
|
};
|
|
|
|
$.ajax({
|
|
type: "POST",
|
|
url: "ajax.php",
|
|
data : {
|
|
page: "godmode/setup/setup_general",
|
|
test_address: test_address,
|
|
params: params
|
|
},
|
|
dataType: "json",
|
|
success: function(data) {
|
|
if (parseInt(data) === 1) {
|
|
$('#email_test_sent_message').show();
|
|
$('#email_test_failure_message').hide();
|
|
} else {
|
|
$('#email_test_failure_message').show();
|
|
$('#email_test_sent_message').hide();
|
|
}
|
|
},
|
|
error: function() {
|
|
$('#email_test_failure_message').show();
|
|
$('#email_test_sent_message').hide();
|
|
},
|
|
});
|
|
}
|
|
|
|
$(document).ready (function () {
|
|
|
|
$("#zone").attr("hidden", true);
|
|
$("#timezone").attr("hidden", true);
|
|
|
|
$("#change_timezone").click(function () {
|
|
$("#zone").attr("hidden", false);
|
|
$("#timezone").attr("hidden", false);
|
|
});
|
|
|
|
if ($("input[name=use_cert]").is(':checked')) {
|
|
$('#ssl-path-tr').show();
|
|
}
|
|
|
|
$("input[name=use_cert]").change(function () {
|
|
if( $(this).is(":checked") )
|
|
$('#ssl-path-tr').show();
|
|
else
|
|
$('#ssl-path-tr').hide();
|
|
|
|
});
|
|
$("input[name=https]").change(function (){
|
|
if($("input[name=https]").prop('checked')) {
|
|
$("#dialog").dialog({
|
|
modal: true,
|
|
width: 500,
|
|
buttons:[
|
|
{
|
|
class: 'ui-widget ui-state-default ui-corner-all ui-button-text-only sub upd submit-next',
|
|
text: "<?php echo __('OK'); ?>",
|
|
click: function(){
|
|
$(this).dialog("close");
|
|
}
|
|
}
|
|
]
|
|
});
|
|
}
|
|
})
|
|
|
|
$("input[name=force_public_url]").change(function (){
|
|
if($("input[name=force_public_url]").prop('checked')) {
|
|
$("#force_public_url_dialog").dialog({
|
|
modal: true,
|
|
width: 500,
|
|
buttons: [
|
|
{
|
|
class: 'ui-widget ui-state-default ui-corner-all ui-button-text-only sub upd submit-next',
|
|
text: "<?php echo __('OK'); ?>",
|
|
click: function(){
|
|
$(this).dialog("close");
|
|
}
|
|
}
|
|
]
|
|
});
|
|
}
|
|
})
|
|
|
|
$('#button-email_test').click(perform_email_test);
|
|
|
|
$("#right_iblacklist").click (function () {
|
|
jQuery.each($("select[name='inventory_changes_blacklist_out[]'] option:selected"), function (key, value) {
|
|
imodule_name = $(value).html();
|
|
if (imodule_name != <?php echo "'".__('None')."'"; ?>) {
|
|
id_imodule = $(value).attr('value');
|
|
$("select[name='inventory_changes_blacklist[]']")
|
|
.append(
|
|
$("<option></option>")
|
|
.val(id_imodule)
|
|
.html('<i>' + imodule_name + '</i>')
|
|
);
|
|
$("#inventory_changes_blacklist_out")
|
|
.find("option[value='" + id_imodule + "']").remove();
|
|
$("#inventory_changes_blacklist")
|
|
.find("option[value='']").remove();
|
|
if($("#inventory_changes_blacklist_out option").length == 0) {
|
|
$("select[name='inventory_changes_blacklist_out[]']")
|
|
.append(
|
|
$("<option></option>")
|
|
.val('')
|
|
.html('<i><?php echo __('None'); ?></i>')
|
|
);
|
|
}
|
|
}
|
|
});
|
|
});
|
|
$("#left_iblacklist").click (function () {
|
|
jQuery.each($("select[name='inventory_changes_blacklist[]'] option:selected"), function (key, value) {
|
|
imodule_name = $(value).html();
|
|
if (imodule_name != <?php echo "'".__('None')."'"; ?>) {
|
|
id_imodule = $(value).attr('value');
|
|
$("select[name='inventory_changes_blacklist_out[]']")
|
|
.append(
|
|
$("<option></option>")
|
|
.val(id_imodule)
|
|
.html('<i>' + imodule_name + '</i>')
|
|
);
|
|
$("#inventory_changes_blacklist")
|
|
.find("option[value='" + id_imodule + "']").remove();
|
|
$("#inventory_changes_blacklist_out")
|
|
.find("option[value='']").remove();
|
|
if($("#inventory_changes_blacklist option").length == 0) {
|
|
$("select[name='inventory_changes_blacklist[]']")
|
|
.append(
|
|
$("<option></option>")
|
|
.val('')
|
|
.html('<i><?php echo __('None'); ?></i>')
|
|
);
|
|
}
|
|
}
|
|
});
|
|
});
|
|
|
|
$("#submit-update_button").click(function () {
|
|
$('#inventory_changes_blacklist option').map(function(){
|
|
$(this).prop('selected', true);
|
|
});
|
|
});
|
|
});
|
|
</script>
|