continue feedback mail
This commit is contained in:
parent
e37af1598a
commit
f06a55c6bb
|
@ -1,796 +1,2 @@
|
||||||
<script type="text/javascript">
|
|
||||||
|
|
||||||
function effectFadeOut() {
|
|
||||||
$('.content').fadeOut(800).fadeIn(800)
|
|
||||||
}
|
|
||||||
$(document).ready(function(){
|
|
||||||
setInterval(effectFadeOut, 1600);
|
|
||||||
});
|
|
||||||
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<?php
|
<?php
|
||||||
|
// remove file.
|
||||||
// Pandora FMS - the Flexible Monitoring System
|
|
||||||
// ============================================
|
|
||||||
// Copyright (c) 2010 Artica Soluciones Tecnologicas, http://www.artica.es
|
|
||||||
// Please see http://pandora.sourceforge.net 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.
|
|
||||||
global $config;
|
|
||||||
check_login();
|
|
||||||
|
|
||||||
if (! check_acl($config['id_user'], 0, 'PM')) {
|
|
||||||
db_pandora_audit('ACL Violation', 'Trying to change License settings');
|
|
||||||
include 'general/noaccess.php';
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$update_settings = (bool) get_parameter_post('update_settings');
|
|
||||||
|
|
||||||
if ($update_settings) {
|
|
||||||
foreach ($_POST['keys'] as $key => $value) {
|
|
||||||
db_process_sql_update(
|
|
||||||
'tupdate_settings',
|
|
||||||
[db_escape_key_identifier('value') => $value],
|
|
||||||
[db_escape_key_identifier('key') => $key]
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
ui_print_success_message(__('License updated'));
|
|
||||||
}
|
|
||||||
|
|
||||||
ui_require_javascript_file_enterprise('load_enterprise');
|
|
||||||
enterprise_include_once('include/functions_license.php');
|
|
||||||
$license = enterprise_hook('license_get_info');
|
|
||||||
|
|
||||||
$rows = db_get_all_rows_in_table('tupdate_settings');
|
|
||||||
|
|
||||||
$settings = new StdClass;
|
|
||||||
foreach ($rows as $row) {
|
|
||||||
$settings->{$row['key']} = $row['value'];
|
|
||||||
}
|
|
||||||
|
|
||||||
echo '<script type="text/javascript">';
|
|
||||||
if (enterprise_installed()) {
|
|
||||||
print_js_var_enteprise();
|
|
||||||
}
|
|
||||||
|
|
||||||
echo '</script>';
|
|
||||||
|
|
||||||
|
|
||||||
function render_info($table)
|
|
||||||
{
|
|
||||||
global $console_mode;
|
|
||||||
|
|
||||||
$info = db_get_sql("SELECT COUNT(*) FROM $table");
|
|
||||||
render_row($info, "DB Table $table");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function render_info_data($query, $label)
|
|
||||||
{
|
|
||||||
global $console_mode;
|
|
||||||
|
|
||||||
$info = db_get_sql($query);
|
|
||||||
render_row($info, $label);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function render_row($data, $label)
|
|
||||||
{
|
|
||||||
global $console_mode;
|
|
||||||
|
|
||||||
if ($console_mode == 1) {
|
|
||||||
echo $label;
|
|
||||||
echo '|';
|
|
||||||
echo $data;
|
|
||||||
echo "\n";
|
|
||||||
} else {
|
|
||||||
echo '<tr>';
|
|
||||||
echo "<td style='padding:2px;border:0px;' width='60%'><div style='padding:5px;background-color:#f2f2f2;border-radius:2px;text-align:left;border:0px;'>".$label;
|
|
||||||
echo '</div></td>';
|
|
||||||
echo "<td style='font-weight:bold;padding:2px;border:0px;' width='40%'><div style='padding:5px;background-color:#f2f2f2;border-radius:2px;text-align:left;border:0px;'>".$data;
|
|
||||||
echo '</div></td>';
|
|
||||||
echo '</tr>';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function get_value_sum($arr)
|
|
||||||
{
|
|
||||||
foreach ($arr as $clave) {
|
|
||||||
foreach ($clave as $valor) {
|
|
||||||
if (is_numeric($valor) === true) {
|
|
||||||
$result += $valor;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $result;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function execution_time()
|
|
||||||
{
|
|
||||||
$times = db_get_all_rows_sql('SELECT datos FROM tagente_datos WHERE id_agente_modulo = 29 ORDER BY utimestamp DESC LIMIT 2');
|
|
||||||
if ($times[0]['datos'] > ($times[1]['datos'] * 1.2)) {
|
|
||||||
return "<a class= 'content' style= 'color: red;'>Warning Status</a><a>   The execution time could be degrading. For a more extensive information of this data consult the Execution Time graph</a>";
|
|
||||||
} else {
|
|
||||||
return "<a style ='color: green;'>Normal Status</a><a>   The execution time is correct. For more information about this data, check the Execution Time graph</a>";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function get_logs_size($file)
|
|
||||||
{
|
|
||||||
$file_name = '/var'.$file.'';
|
|
||||||
$size_server_log = filesize($file_name);
|
|
||||||
return $size_server_log;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function get_status_logs($path)
|
|
||||||
{
|
|
||||||
$status_server_log = '';
|
|
||||||
$size_server_log = number_format(get_logs_size($path));
|
|
||||||
$size_server_log = (0 + str_replace(',', '', $size_server_log));
|
|
||||||
if ($size_server_log <= 10485760) {
|
|
||||||
$status_server_log = "<a style ='color: green;text-decoration: none;'>Normal Status</a><a style ='text-decoration: none;'>   You have less than 10 MB of logs</a>";
|
|
||||||
} else {
|
|
||||||
$status_server_log = "<a class= 'content' style= 'color: red;text-decoration: none;'>Warning Status</a><a style ='text-decoration: none;'>   You have more than 10 MB of logs</a>";
|
|
||||||
}
|
|
||||||
|
|
||||||
return $status_server_log;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function percentage_modules_per_agent()
|
|
||||||
{
|
|
||||||
$status_average_modules = '';
|
|
||||||
$total_agents = db_get_value_sql('SELECT count(*) FROM tagente');
|
|
||||||
$total_modules = db_get_value_sql('SELECT count(*) FROM tagente_modulo');
|
|
||||||
$average_modules_per_agent = ($total_modules / $total_agents);
|
|
||||||
if ($average_modules_per_agent <= 40) {
|
|
||||||
$status_average_modules = "<a style ='color: green;text-decoration: none;'>Normal Status</a><a style ='text-decoration: none;'>   The average of modules per agent is less than 40</a>";
|
|
||||||
} else {
|
|
||||||
$status_average_modules = "<a class= 'content' style= 'color: red;text-decoration: none;'>Warning Status</a><a style ='text-decoration: none;'>  The average of modules per agent is more than 40. You can have performance problems</a>";
|
|
||||||
}
|
|
||||||
|
|
||||||
return $status_average_modules;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function license_capacity()
|
|
||||||
{
|
|
||||||
$license = enterprise_hook('license_get_info');
|
|
||||||
$license_limit = $license['limit'];
|
|
||||||
$status_license_capacity = '';
|
|
||||||
$current_count = db_get_value_sql('SELECT count(*) FROM tagente');
|
|
||||||
if ($current_count > ($license_limit * 90 / 100)) {
|
|
||||||
$status_license_capacity = "<a class= 'content' style= 'color: red;text-decoration: none;'>Warning Status</a><a style ='text-decoration: none;'>   License capacity exceeds 90 percent</a>";
|
|
||||||
} else {
|
|
||||||
$status_license_capacity = "<a style= 'color: green;text-decoration: none;'>Normal Status</a><a style ='text-decoration: none;'>   License capacity is less than 90 percent</a>";
|
|
||||||
}
|
|
||||||
|
|
||||||
return $status_license_capacity;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function status_license_params($license_param)
|
|
||||||
{
|
|
||||||
$status_license_par = '';
|
|
||||||
if ($license_param <= 0) {
|
|
||||||
$status_license_par = 'OFF';
|
|
||||||
} else {
|
|
||||||
$status_license_par = 'ON';
|
|
||||||
}
|
|
||||||
|
|
||||||
return $status_license_par;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function interval_average_of_network_modules()
|
|
||||||
{
|
|
||||||
$total_network_modules = db_get_value_sql('SELECT count(*) FROM tagente_modulo WHERE id_tipo_modulo BETWEEN 6 AND 18');
|
|
||||||
$total_module_interval_time = db_get_value_sql('SELECT SUM(module_interval) FROM tagente_modulo WHERE id_tipo_modulo BETWEEN 6 AND 18');
|
|
||||||
$average_time = ((int) $total_module_interval_time / $total_network_modules);
|
|
||||||
|
|
||||||
if ($average_time < 180) {
|
|
||||||
$status_average_modules = "<a class= 'content' style= 'color: red;text-decoration: none;'>Warning Status</a><a style ='text-decoration: none;'>   The system is overloaded (average time $average_time) and a very fine configuration is required</a>";
|
|
||||||
} else {
|
|
||||||
$status_average_modules = "<a style ='color: green;text-decoration: none;'>Normal Status</a><a style ='text-decoration: none;'>   The system is not overloaded (average time $average_time) </a>";
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($average_time == 0) {
|
|
||||||
$status_average_modules = "<a style ='color: green;text-decoration: none;'>Normal Status</a><a style ='text-decoration: none;'>   The system has no load</a>";
|
|
||||||
}
|
|
||||||
|
|
||||||
return $status_average_modules;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
$attachment_total_files = count(glob($config['homedir'].'/attachment/{*.*}', GLOB_BRACE));
|
|
||||||
|
|
||||||
|
|
||||||
function files_attachment_folder($total_files)
|
|
||||||
{
|
|
||||||
if ($total_files <= 700) {
|
|
||||||
$status_total_files = "<a style ='color: green;text-decoration: none;'>Normal Status</a><a style ='text-decoration: none;'>   The attached folder contains less than 700 files.</a>";
|
|
||||||
} else {
|
|
||||||
$status_total_files = "<a class= 'content' style= 'color: red;text-decoration: none;'>Warning Status</a><a style ='text-decoration: none;'>   The attached folder contains more than 700 files.</a>";
|
|
||||||
}
|
|
||||||
|
|
||||||
return $status_total_files;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
$tagente_datos_size = db_get_value_sql('SELECT COUNT(*) FROM tagente_datos');
|
|
||||||
|
|
||||||
|
|
||||||
function status_tagente_datos($tagente_datos_size)
|
|
||||||
{
|
|
||||||
if ($tagente_datos_size <= 3000000) {
|
|
||||||
$tagente_datos_size = "<a style ='color: green;text-decoration: none;'>Normal Status</a><a style ='text-decoration: none;'>   The tagente_datos table contains an acceptable amount of data.</a>";
|
|
||||||
} else {
|
|
||||||
$tagente_datos_size = "<a class= 'content' style ='color: red;text-decoration: none;'>Warning Status</a><a>   The tagente_datos table contains too much data. A historical database is recommended.</a>";
|
|
||||||
}
|
|
||||||
|
|
||||||
return $tagente_datos_size;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function status_values($val_rec, $val)
|
|
||||||
{
|
|
||||||
if ($val_rec <= $val) {
|
|
||||||
return $val."<a style='text-decoration: none;'> (Min. Recommended Value </a>".$val_rec.'<a>)</a>';
|
|
||||||
} else {
|
|
||||||
return $val."<a style='text-decoration: none;'> (Min. Recommended Value </a>".$val_rec."<a>)</a><a class= 'content' style ='color: red;text-decoration: none;'> Warning Status</a>";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
$tables_fragmentation = db_get_sql(
|
|
||||||
"SELECT (data_free/(index_length+data_length))
|
|
||||||
as frag_ratio from information_schema.tables where DATA_FREE > 0 and table_name='tagente_datos' and table_schema='pandora'"
|
|
||||||
);
|
|
||||||
$db_size = db_get_all_rows_sql(
|
|
||||||
'SELECT table_schema,
|
|
||||||
ROUND(SUM(data_length+index_length)/1024/1024,3)
|
|
||||||
FROM information_schema.TABLES
|
|
||||||
GROUP BY table_schema;'
|
|
||||||
);
|
|
||||||
|
|
||||||
if (strtoupper(substr(PHP_OS, 0, 3)) !== 'WIN') {
|
|
||||||
$total_server_threads = shell_exec('ps -T aux | grep pandora_server | grep -v grep | wc -l');
|
|
||||||
$percentage_threads_ram = shell_exec("ps axo pmem,cmd | grep pandora_server | awk '{sum+=$1} END {print sum}'");
|
|
||||||
$percentage_threads_cpu = shell_exec("ps axo pcpu,cmd | grep pandora_server | awk '{sum+=$1} END {print sum}'");
|
|
||||||
$innodb_buffer_pool_size_min_rec_value = shell_exec("cat /proc/meminfo | grep -i total | head -1 | awk '{print $(NF-1)*0.4/1024}'");
|
|
||||||
}
|
|
||||||
|
|
||||||
$path_server_logs = '/log/pandora/pandora_server.log';
|
|
||||||
$path_err_logs = '/log/pandora/pandora_server.error';
|
|
||||||
$path_console_logs = '/www/html/pandora_console/pandora_console.log';
|
|
||||||
$innodb_log_file_size_min_rec_value = '64M';
|
|
||||||
$innodb_log_buffer_size_min_rec_value = '16M';
|
|
||||||
$innodb_flush_log_at_trx_commit_min_rec_value = 0;
|
|
||||||
$query_cache_limit_min_rec_value = 2;
|
|
||||||
$max_allowed_packet_min_rec_value = 32;
|
|
||||||
$innodb_buffer_pool_size_min_rec_value = shell_exec("cat /proc/meminfo | grep -i total | head -1 | awk '{print $(NF-1)*0.4/1024}'");
|
|
||||||
$sort_buffer_size_min_rec_value = 32;
|
|
||||||
$join_buffer_size_min_rec_value = 265;
|
|
||||||
$query_cache_type_min_rec_value = 'ON';
|
|
||||||
$query_cache_size_min_rec_value = 24;
|
|
||||||
$innodb_lock_wait_timeout_max_rec_value = 120;
|
|
||||||
$tables_fragmentation_max_rec_value = 10;
|
|
||||||
$thread_cache_size_max_rec_value = 8;
|
|
||||||
$thread_stack_min_rec_value = 256;
|
|
||||||
$max_connections_max_rec_value = 150;
|
|
||||||
$key_buffer_size_min_rec_value = 256;
|
|
||||||
$read_buffer_size_min_rec_value = 32;
|
|
||||||
$read_rnd_buffer_size_min_rec_value = 32;
|
|
||||||
$query_cache_min_res_unit_min_rec_value = 2;
|
|
||||||
$innodb_file_per_table_min_rec_value = 1;
|
|
||||||
|
|
||||||
|
|
||||||
function status_fragmentation_tables($tables_fragmentation_max_rec_value, $tables_fragmentation)
|
|
||||||
{
|
|
||||||
$status_tables_frag = '';
|
|
||||||
if ($tables_fragmentation > $tables_fragmentation_max_rec_value) {
|
|
||||||
$status_tables_frag = "<a class= 'content' style ='color: red; text-decoration: none;'>Warning Status</a><a style ='text-decoration: none;'>   Table fragmentation is higher than recommended. They should be defragmented.</a>";
|
|
||||||
} else {
|
|
||||||
$status_tables_frag = "<a style ='color: green; text-decoration: none;'>Normal Status</a><a style ='text-decoration: none;'>   Table fragmentation is correct.</a>";
|
|
||||||
}
|
|
||||||
|
|
||||||
return $status_tables_frag;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
$console_mode = 1;
|
|
||||||
if (!isset($argc)) {
|
|
||||||
$console_mode = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($console_mode == 1) {
|
|
||||||
echo "\nPandora FMS PHP diagnostic tool v3.2 (c) Artica ST 2009-2010 \n";
|
|
||||||
|
|
||||||
if ($argc == 1 || in_array($argv[1], ['--help', '-help', '-h', '-?'])) {
|
|
||||||
echo "\nThis command line script contains information about Pandora FMS database.
|
|
||||||
This program can only be executed from the console, and it needs a parameter, the
|
|
||||||
full path to Pandora FMS 'config.php' file.
|
|
||||||
|
|
||||||
Usage:
|
|
||||||
php pandora_diag.php path_to_pandora_console
|
|
||||||
|
|
||||||
Example:
|
|
||||||
php pandora_diag.php /var/www/pandora_console
|
|
||||||
|
|
||||||
";
|
|
||||||
exit;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (preg_match('/[^a-zA-Z0-9_\/\.]|(\/\/)|(\.\.)/', $argv[1])) {
|
|
||||||
echo "Invalid path: $argv[1]. Always use absolute paths.";
|
|
||||||
exit;
|
|
||||||
}
|
|
||||||
|
|
||||||
include $argv[1].'/include/config.php';
|
|
||||||
} else {
|
|
||||||
if (file_exists('../include/config.php')) {
|
|
||||||
include '../include/config.php';
|
|
||||||
}
|
|
||||||
|
|
||||||
// Not from console, this is a web session.
|
|
||||||
if ((!isset($config['id_user'])) || (!check_acl($config['id_user'], 0, 'PM'))) {
|
|
||||||
echo "<h2>You don't have privileges to use diagnostic tool</h2>";
|
|
||||||
echo '<p>Please login with an administrator account before try to use this tool</p>';
|
|
||||||
exit;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Header.
|
|
||||||
ui_print_page_header(
|
|
||||||
__('Pandora FMS Diagnostic tool'),
|
|
||||||
'',
|
|
||||||
false,
|
|
||||||
'diagnostic_tool_tab',
|
|
||||||
true
|
|
||||||
);
|
|
||||||
|
|
||||||
echo "<table id='diagnostic_info' width='1000px' border='0' style='border:0px;' class='databox data' cellpadding='4' cellspacing='4'>";
|
|
||||||
echo "<tr><th style='background-color:#b1b1b1;font-weight:bold;font-style:italic;border-radius:2px;' align=center colspan='2'>".__('Pandora status info').'</th></tr>';
|
|
||||||
}
|
|
||||||
|
|
||||||
render_row($build_version, 'Pandora FMS Build');
|
|
||||||
render_row($pandora_version, 'Pandora FMS Version');
|
|
||||||
render_info_data("SELECT value FROM tconfig where token ='MR'", 'Minor Release');
|
|
||||||
render_row($config['homedir'], 'Homedir');
|
|
||||||
render_row($config['homeurl'], 'HomeUrl');
|
|
||||||
render_info_data(
|
|
||||||
"SELECT `value`
|
|
||||||
FROM tconfig
|
|
||||||
WHERE `token` = 'enterprise_installed'",
|
|
||||||
'Enterprise installed'
|
|
||||||
);
|
|
||||||
|
|
||||||
$full_key = db_get_sql(
|
|
||||||
"SELECT value
|
|
||||||
FROM tupdate_settings
|
|
||||||
WHERE `key` = 'customer_key'"
|
|
||||||
);
|
|
||||||
|
|
||||||
$compressed_key = substr($full_key, 0, 5).'...'.substr($full_key, -5);
|
|
||||||
|
|
||||||
render_row($compressed_key, 'Update Key');
|
|
||||||
|
|
||||||
render_info_data(
|
|
||||||
"SELECT value
|
|
||||||
FROM tupdate_settings
|
|
||||||
WHERE `key` = 'updating_code_path'",
|
|
||||||
'Updating code path'
|
|
||||||
);
|
|
||||||
|
|
||||||
render_info_data(
|
|
||||||
"SELECT value
|
|
||||||
FROM tupdate_settings
|
|
||||||
WHERE `key` = 'current_update'",
|
|
||||||
'Current Update #'
|
|
||||||
);
|
|
||||||
|
|
||||||
|
|
||||||
echo "<tr><th style='background-color:#b1b1b1;font-weight:bold;font-style:italic;border-radius:2px;' align=center colspan='2'>".__('PHP setup').'</th></tr>';
|
|
||||||
|
|
||||||
|
|
||||||
render_row(phpversion(), 'PHP Version');
|
|
||||||
|
|
||||||
render_row(ini_get('max_execution_time').' seconds', 'PHP Max execution time');
|
|
||||||
|
|
||||||
render_row(ini_get('max_input_time').' seconds', 'PHP Max input time');
|
|
||||||
|
|
||||||
render_row(ini_get('memory_limit'), 'PHP Memory limit');
|
|
||||||
|
|
||||||
render_row(ini_get('session.cookie_lifetime'), 'Session cookie lifetime');
|
|
||||||
|
|
||||||
echo "<tr><th style='background-color:#b1b1b1;font-weight:bold;font-style:italic;border-radius:2px;' align=center colspan='2'>".__('Database size stats').'</th></tr>';
|
|
||||||
|
|
||||||
render_info_data('SELECT COUNT(*) FROM tagente', 'Total agents');
|
|
||||||
render_info_data('SELECT COUNT(*) FROM tagente_modulo', 'Total modules');
|
|
||||||
render_info_data('SELECT COUNT(*) FROM tgrupo', 'Total groups');
|
|
||||||
render_info_data('SELECT COUNT(*) FROM tagente_datos', 'Total module data records');
|
|
||||||
render_info_data('SELECT COUNT(*) FROM tagent_access', 'Total agent access record');
|
|
||||||
render_info_data('SELECT COUNT(*) FROM tevento', 'Total events');
|
|
||||||
|
|
||||||
if ($config['enterprise_installed']) {
|
|
||||||
render_info_data('SELECT COUNT(*) FROM ttrap', 'Total traps');
|
|
||||||
}
|
|
||||||
|
|
||||||
render_info_data('SELECT COUNT(*) FROM tusuario', 'Total users');
|
|
||||||
render_info_data('SELECT COUNT(*) FROM tsesion', 'Total sessions');
|
|
||||||
|
|
||||||
echo "<tr><th style='background-color:#b1b1b1;font-weight:bold;font-style:italic;border-radius:2px;' align=center colspan='2'>".__('Database sanity').'</th></tr>';
|
|
||||||
|
|
||||||
render_info_data(
|
|
||||||
'SELECT COUNT( DISTINCT tagente.id_agente)
|
|
||||||
FROM tagente_estado, tagente, tagente_modulo
|
|
||||||
WHERE tagente.disabled = 0
|
|
||||||
AND tagente_modulo.id_agente_modulo = tagente_estado.id_agente_modulo
|
|
||||||
AND tagente_modulo.disabled = 0
|
|
||||||
AND tagente_estado.id_agente = tagente.id_agente
|
|
||||||
AND tagente_estado.estado = 3',
|
|
||||||
'Total unknown agents'
|
|
||||||
);
|
|
||||||
|
|
||||||
render_info_data(
|
|
||||||
'SELECT COUNT(tagente_estado.estado)
|
|
||||||
FROM tagente_estado
|
|
||||||
WHERE tagente_estado.estado = 4',
|
|
||||||
'Total not-init modules'
|
|
||||||
);
|
|
||||||
|
|
||||||
|
|
||||||
$last_run_difference = '';
|
|
||||||
|
|
||||||
$diferencia = (time() - date(
|
|
||||||
db_get_sql(
|
|
||||||
"SELECT `value`
|
|
||||||
FROM tconfig
|
|
||||||
WHERE `token` = 'db_maintance'"
|
|
||||||
)
|
|
||||||
));
|
|
||||||
|
|
||||||
$last_run_difference_months = 0;
|
|
||||||
$last_run_difference_weeks = 0;
|
|
||||||
$last_run_difference_days = 0;
|
|
||||||
$last_run_difference_minutos = 0;
|
|
||||||
$last_run_difference_seconds = 0;
|
|
||||||
|
|
||||||
while ($diferencia >= 2419200) {
|
|
||||||
$diferencia -= 2419200;
|
|
||||||
$last_run_difference_months++;
|
|
||||||
}
|
|
||||||
|
|
||||||
while ($diferencia >= 604800) {
|
|
||||||
$diferencia -= 604800;
|
|
||||||
$last_run_difference_weeks++;
|
|
||||||
}
|
|
||||||
|
|
||||||
while ($diferencia >= 86400) {
|
|
||||||
$diferencia -= 86400;
|
|
||||||
$last_run_difference_days++;
|
|
||||||
}
|
|
||||||
|
|
||||||
while ($diferencia >= 3600) {
|
|
||||||
$diferencia -= 3600;
|
|
||||||
$last_run_difference_hours++;
|
|
||||||
}
|
|
||||||
|
|
||||||
while ($diferencia >= 60) {
|
|
||||||
$diferencia -= 60;
|
|
||||||
$last_run_difference_minutes++;
|
|
||||||
}
|
|
||||||
|
|
||||||
$last_run_difference_seconds = $diferencia;
|
|
||||||
|
|
||||||
if ($last_run_difference_months > 0) {
|
|
||||||
$last_run_difference .= $last_run_difference_months.'month/s ';
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($last_run_difference_weeks > 0) {
|
|
||||||
$last_run_difference .= $last_run_difference_weeks.' week/s ';
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($last_run_difference_days > 0) {
|
|
||||||
$last_run_difference .= $last_run_difference_days.' day/s ';
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($last_run_difference_hours > 0) {
|
|
||||||
$last_run_difference .= $last_run_difference_hours.' hour/s ';
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($last_run_difference_minutes > 0) {
|
|
||||||
$last_run_difference .= $last_run_difference_minutes.' minute/s ';
|
|
||||||
}
|
|
||||||
|
|
||||||
$last_run_difference .= $last_run_difference_seconds.' second/s ago';
|
|
||||||
|
|
||||||
render_row(
|
|
||||||
date(
|
|
||||||
'Y/m/d H:i:s',
|
|
||||||
db_get_sql(
|
|
||||||
"SELECT `value`
|
|
||||||
FROM tconfig
|
|
||||||
WHERE `token` = 'db_maintance'"
|
|
||||||
)
|
|
||||||
).' ('.$last_run_difference.')'.' *',
|
|
||||||
'PandoraDB Last run'
|
|
||||||
);
|
|
||||||
|
|
||||||
echo "<tr><th style='background-color:#b1b1b1;font-weight:bold;font-style:italic;border-radius:2px;' align=center colspan='2'>".__('Database status info').'</th></tr>';
|
|
||||||
|
|
||||||
switch ($config['dbtype']) {
|
|
||||||
case 'mysql':
|
|
||||||
render_info_data(
|
|
||||||
"SELECT `value`
|
|
||||||
FROM tconfig
|
|
||||||
WHERE `token` = 'db_scheme_first_version'",
|
|
||||||
'DB Schema Version (first installed)'
|
|
||||||
);
|
|
||||||
render_info_data(
|
|
||||||
"SELECT `value`
|
|
||||||
FROM tconfig
|
|
||||||
WHERE `token` = 'db_scheme_version'",
|
|
||||||
'DB Schema Version (actual)'
|
|
||||||
);
|
|
||||||
render_info_data(
|
|
||||||
"SELECT `value`
|
|
||||||
FROM tconfig
|
|
||||||
WHERE `token` = 'db_scheme_build'",
|
|
||||||
'DB Schema Build'
|
|
||||||
);
|
|
||||||
|
|
||||||
render_row(get_value_sum($db_size).'M', 'DB Size');
|
|
||||||
|
|
||||||
|
|
||||||
if (strtoupper(substr(PHP_OS, 0, 3)) !== 'WIN') {
|
|
||||||
echo "<tr><th style='background-color:#b1b1b1;font-weight:bold;font-style:italic;border-radius:2px;' align=center colspan='2'>".__('System info').'</th></tr>';
|
|
||||||
|
|
||||||
$output = 'cat /proc/cpuinfo | grep "model name" | tail -1 | cut -f 2 -d ":"';
|
|
||||||
$output2 = 'cat /proc/cpuinfo | grep "processor" | wc -l';
|
|
||||||
|
|
||||||
render_row(exec($output).' x '.exec($output2), 'CPU');
|
|
||||||
|
|
||||||
$output = 'cat /proc/meminfo | grep "MemTotal"';
|
|
||||||
|
|
||||||
render_row(exec($output), 'RAM');
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 'postgresql':
|
|
||||||
render_info_data(
|
|
||||||
"SELECT \"value\"
|
|
||||||
FROM tconfig
|
|
||||||
WHERE \"token\" = 'db_scheme_version'",
|
|
||||||
'DB Schema Version'
|
|
||||||
);
|
|
||||||
render_info_data(
|
|
||||||
"SELECT \"value\"
|
|
||||||
FROM tconfig
|
|
||||||
WHERE \"token\" = 'db_scheme_build'",
|
|
||||||
'DB Schema Build'
|
|
||||||
);
|
|
||||||
render_info_data(
|
|
||||||
"SELECT \"value\"
|
|
||||||
FROM tconfig
|
|
||||||
WHERE \"token\" = 'enterprise_installed'",
|
|
||||||
'Enterprise installed'
|
|
||||||
);
|
|
||||||
render_row(
|
|
||||||
date(
|
|
||||||
'Y/m/d H:i:s',
|
|
||||||
db_get_sql(
|
|
||||||
"SELECT \"value\"
|
|
||||||
FROM tconfig WHERE \"token\" = 'db_maintance'"
|
|
||||||
)
|
|
||||||
),
|
|
||||||
'PandoraDB Last run'
|
|
||||||
);
|
|
||||||
|
|
||||||
render_info_data(
|
|
||||||
"SELECT value
|
|
||||||
FROM tupdate_settings
|
|
||||||
WHERE \"key\" = 'customer_key';",
|
|
||||||
'Update Key'
|
|
||||||
);
|
|
||||||
render_info_data(
|
|
||||||
"SELECT value
|
|
||||||
FROM tupdate_settings
|
|
||||||
WHERE \"key\" = 'updating_code_path'",
|
|
||||||
'Updating code path'
|
|
||||||
);
|
|
||||||
render_info_data(
|
|
||||||
"SELECT value
|
|
||||||
FROM tupdate_settings
|
|
||||||
WHERE \"key\" = 'current_update'",
|
|
||||||
'Current Update #'
|
|
||||||
);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 'oracle':
|
|
||||||
render_info_data(
|
|
||||||
"SELECT value
|
|
||||||
FROM tconfig
|
|
||||||
WHERE token = 'db_scheme_version'",
|
|
||||||
'DB Schema Version'
|
|
||||||
);
|
|
||||||
render_info_data(
|
|
||||||
"SELECT value
|
|
||||||
FROM tconfig
|
|
||||||
WHERE token = 'db_scheme_build'",
|
|
||||||
'DB Schema Build'
|
|
||||||
);
|
|
||||||
render_info_data(
|
|
||||||
"SELECT value
|
|
||||||
FROM tconfig
|
|
||||||
WHERE token = 'enterprise_installed'",
|
|
||||||
'Enterprise installed'
|
|
||||||
);
|
|
||||||
render_row(
|
|
||||||
db_get_sql(
|
|
||||||
"SELECT value
|
|
||||||
FROM tconfig
|
|
||||||
WHERE token = 'db_maintance'"
|
|
||||||
),
|
|
||||||
'PandoraDB Last run'
|
|
||||||
);
|
|
||||||
|
|
||||||
render_info_data(
|
|
||||||
'SELECT '.db_escape_key_identifier('value')." FROM tupdate_settings
|
|
||||||
WHERE \"key\" = 'customer_key'",
|
|
||||||
'Update Key'
|
|
||||||
);
|
|
||||||
render_info_data(
|
|
||||||
'SELECT '.db_escape_key_identifier('value')." FROM tupdate_settings
|
|
||||||
WHERE \"key\" = 'updating_code_path'",
|
|
||||||
'Updating code path'
|
|
||||||
);
|
|
||||||
render_info_data(
|
|
||||||
'SELECT '.db_escape_key_identifier('value')." FROM tupdate_settings
|
|
||||||
WHERE \"key\" = 'current_update'",
|
|
||||||
'Current Update #'
|
|
||||||
);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
$innodb_log_file_size = (db_get_value_sql('SELECT @@innodb_log_file_size') / 1048576);
|
|
||||||
$innodb_log_buffer_size = (db_get_value_sql('SELECT @@innodb_log_buffer_size') / 1048576);
|
|
||||||
$innodb_flush_log_at_trx_commit = db_get_value_sql('SELECT @@innodb_flush_log_at_trx_commit');
|
|
||||||
$max_allowed_packet = (db_get_value_sql('SELECT @@max_allowed_packet') / 1048576);
|
|
||||||
$innodb_buffer_pool_size = (db_get_value_sql('SELECT @@innodb_buffer_pool_size') / 1024);
|
|
||||||
$sort_buffer_size = number_format((db_get_value_sql('SELECT @@sort_buffer_size') / 1024), 2);
|
|
||||||
$join_buffer_size = (db_get_value_sql('SELECT @@join_buffer_size') / 1024);
|
|
||||||
$query_cache_type = db_get_value_sql('SELECT @@query_cache_type');
|
|
||||||
$query_cache_size = (db_get_value_sql('SELECT @@query_cache_size') / 1048576);
|
|
||||||
$query_cache_limit = (db_get_value_sql('SELECT @@query_cache_limit') / 1048576);
|
|
||||||
$innodb_lock_wait_timeout = db_get_value_sql('SELECT @@innodb_lock_wait_timeout');
|
|
||||||
$thread_cache_size = db_get_value_sql('SELECT @@thread_cache_size');
|
|
||||||
$thread_stack = (db_get_value_sql('SELECT @@thread_stack') / 1024);
|
|
||||||
$max_connections = db_get_value_sql('SELECT @@max_connections');
|
|
||||||
$key_buffer_size = (db_get_value_sql('SELECT @@key_buffer_size') / 1024);
|
|
||||||
$read_buffer_size = (db_get_value_sql('SELECT @@read_buffer_size') / 1024);
|
|
||||||
$read_rnd_buffer_size = (db_get_value_sql('SELECT @@read_rnd_buffer_size') / 1024);
|
|
||||||
$query_cache_min_res_unit = (db_get_value_sql('SELECT @@query_cache_min_res_unit') / 1024);
|
|
||||||
$innodb_file_per_table = db_get_value_sql('SELECT @@innodb_file_per_table');
|
|
||||||
echo "<tr><th style='background-color:#b1b1b1;font-weight:bold;font-style:italic;border-radius:2px;' align=center colspan='2'>".__('MySQL Performance metrics').' '.ui_print_help_icon('performance_metrics_tab', true).'</th></tr>';
|
|
||||||
|
|
||||||
render_row(status_values($innodb_log_file_size_min_rec_value, $innodb_log_file_size), 'InnoDB log file size ', 'InnoDB log file size ');
|
|
||||||
render_row(status_values($innodb_log_buffer_size_min_rec_value, $innodb_log_buffer_size), 'InnoDB log buffer size ', 'InnoDB log buffer size ');
|
|
||||||
render_row(status_values($innodb_flush_log_at_trx_commit_min_rec_value, $innodb_flush_log_at_trx_commit), 'InnoDB flush log at trx-commit ', 'InnoDB flush log at trx-commit ');
|
|
||||||
render_row(status_values($max_allowed_packet_min_rec_value, $max_allowed_packet), 'Maximun allowed packet ', 'Maximun allowed packet ');
|
|
||||||
render_row(status_values($innodb_buffer_pool_size_min_rec_value, $innodb_buffer_pool_size), 'InnoDB buffer pool size ', 'InnoDB buffer pool size ');
|
|
||||||
render_row(status_values($sort_buffer_size_min_rec_value, $sort_buffer_size), 'Sort buffer size ', 'Sort buffer size ');
|
|
||||||
render_row(status_values($join_buffer_size_min_rec_value, $join_buffer_size), 'Join buffer size ', 'Join buffer size ');
|
|
||||||
render_row(status_values($query_cache_type_min_rec_value, $query_cache_type), 'Query cache type ', 'Query cache type ');
|
|
||||||
render_row(status_values($query_cache_size_min_rec_value, $query_cache_size), 'Query cache size ', 'Query cache size ');
|
|
||||||
render_row(status_values($query_cache_limit_min_rec_value, $query_cache_limit), 'Query cache limit ', 'Query cache limit ');
|
|
||||||
render_row(status_values($innodb_lock_wait_timeout_max_rec_value, $innodb_lock_wait_timeout), 'InnoDB lock wait timeout ', 'InnoDB lock wait timeout ');
|
|
||||||
render_row(status_values($thread_cache_size_max_rec_value, $thread_cache_size), 'Thread cache size ', 'Thread cache size ');
|
|
||||||
render_row(status_values($thread_stack_min_rec_value, $thread_stack), 'Thread stack ', 'Thread stack ');
|
|
||||||
render_row(status_values($max_connections_max_rec_value, $max_connections), 'Maximum connections ', 'Maximun connections ');
|
|
||||||
render_row(status_values($key_buffer_size_min_rec_value, $key_buffer_size), 'Key buffer size ', 'Key buffer size ');
|
|
||||||
render_row(status_values($read_buffer_size_min_rec_value, $read_buffer_size), 'Read buffer size ', 'Read buffer size ');
|
|
||||||
render_row(status_values($read_rnd_buffer_size_min_rec_value, $read_rnd_buffer_size), 'Read rnd-buffer size ', 'Read rnd-buffer size ');
|
|
||||||
render_row(status_values($query_cache_min_res_unit_min_rec_value, $query_cache_min_res_unit), 'Query cache min-res-unit ', 'Query cache min-res-unit ');
|
|
||||||
render_row(status_values($innodb_file_per_table_min_rec_value, $innodb_file_per_table), 'InnoDB file per table ', 'InnoDB file per table ');
|
|
||||||
echo "<tr><th style='background-color:#b1b1b1;font-weight:bold;font-style:italic;border-radius:2px;' align=center colspan='2'>".__('Tables fragmentation in the Pandora FMS database').'</th></tr>';
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
render_row($tables_fragmentation_max_rec_value.'%', 'Tables fragmentation (maximum recommended value)');
|
|
||||||
render_row(number_format($tables_fragmentation, 2).'%', 'Tables fragmentation (current value)');
|
|
||||||
render_row(status_fragmentation_tables($tables_fragmentation_max_rec_value, $tables_fragmentation), 'Table fragmentation status');
|
|
||||||
|
|
||||||
echo "<tr><th style='background-color:#b1b1b1;font-weight:bold;font-style:italic;border-radius:2px;' align=center colspan='2'>".__(' Pandora FMS logs dates').'</th></tr>';
|
|
||||||
|
|
||||||
render_row(number_format((get_logs_size($path_server_logs) / 1048576), 3).'M', 'Size server logs (current value)');
|
|
||||||
render_row(get_status_logs($path_server_logs), 'Status server logs');
|
|
||||||
render_row(number_format((get_logs_size($path_err_logs) / 1048576), 3).'M', 'Size error logs (current value)');
|
|
||||||
render_row(get_status_logs($path_err_logs), 'Status error logs');
|
|
||||||
render_row(number_format((get_logs_size($path_console_logs) / 1048576), 3).'M', 'Size console logs (current value)');
|
|
||||||
render_row(get_status_logs($path_console_logs), 'Status console logs');
|
|
||||||
|
|
||||||
echo "<tr><th style='background-color:#b1b1b1;font-weight:bold;font-style:italic;border-radius:2px;' align=center colspan='2'>".__(' Pandora FMS Licence Information').'</th></tr>';
|
|
||||||
|
|
||||||
render_row(html_print_textarea('keys[customer_key]', 10, 255, $settings->customer_key, 'style="height:40px; width:450px;"', true), 'Customer key');
|
|
||||||
render_row($license['expiry_date'], $license['expiry_caption']);
|
|
||||||
render_row($license['limit'].' agents', 'Platform Limit');
|
|
||||||
render_row($license['count'].' agents', 'Current Platform Count');
|
|
||||||
render_row($license['count_enabled'].' agents', 'Current Platform Count (enabled: items)');
|
|
||||||
render_row($license['count_disabled'].' agents', 'Current Platform Count (disabled: items)');
|
|
||||||
render_row($license['license_mode'], 'License Mode');
|
|
||||||
render_row(status_license_params($license['nms']), 'Network Management System');
|
|
||||||
render_row(status_license_params($license['dhpm']), 'Satellite');
|
|
||||||
render_row($license['licensed_to'], 'Licensed to');
|
|
||||||
render_row(license_capacity(), 'Status of agents capacity');
|
|
||||||
render_row(percentage_modules_per_agent(), 'Status of average modules per agent');
|
|
||||||
render_row(interval_average_of_network_modules(), 'Interval average of the network modules');
|
|
||||||
|
|
||||||
echo "<tr><th style='background-color:#b1b1b1;font-weight:bold;font-style:italic;border-radius:2px;' align=center colspan='2'>".__(' Status of the attachment folder').'</th></tr>';
|
|
||||||
|
|
||||||
render_row($attachment_total_files, 'Total files in the attached folder');
|
|
||||||
render_row(files_attachment_folder($attachment_total_files), 'Status of the attachment folder');
|
|
||||||
|
|
||||||
echo "<tr><th style='background-color:#b1b1b1;font-weight:bold;font-style:italic;border-radius:2px;' align=center colspan='2'>".__(' Information from the tagente_datos table').'</th></tr>';
|
|
||||||
|
|
||||||
render_row($tagente_datos_size, 'Total data in tagente_datos table');
|
|
||||||
render_row(status_tagente_datos($tagente_datos_size), 'Tangente_datos table status');
|
|
||||||
render_row(execution_time(), 'Execution time degradation when executing a count');
|
|
||||||
|
|
||||||
echo "<tr><th style='background-color:#b1b1b1;font-weight:bold;font-style:italic;border-radius:2px;' align=center colspan='2'>".__(' Pandora FMS server threads').'</th></tr>';
|
|
||||||
|
|
||||||
render_row($total_server_threads, 'Total server threads');
|
|
||||||
render_row($percentage_threads_ram.'%', 'Percentage of threads used by the RAM');
|
|
||||||
render_row($percentage_threads_cpu.'%', 'Percentage of threads used by the CPU');
|
|
||||||
|
|
||||||
echo "<tr><th style='background-color:#b1b1b1;font-weight:bold;font-style:italic;border-radius:2px;' align=center colspan='2'>".__(' Graphs modules that represent the self-monitoring system').'</th></tr>';
|
|
||||||
|
|
||||||
$server_name = db_get_value_sql('SELECT name FROM tserver WHERE master = 1');
|
|
||||||
$agent_id = db_get_value_sql("SELECT id_agente FROM tagente WHERE nombre = '$server_name'");
|
|
||||||
|
|
||||||
$id_modules = agents_get_modules($agent_id);
|
|
||||||
|
|
||||||
$id_modules = [
|
|
||||||
modules_get_agentmodule_id('Agents_Unknown', $agent_id),
|
|
||||||
modules_get_agentmodule_id('Database Maintenance', $agent_id),
|
|
||||||
modules_get_agentmodule_id('FreeDisk_SpoolDir', $agent_id),
|
|
||||||
modules_get_agentmodule_id('Free_RAM', $agent_id),
|
|
||||||
modules_get_agentmodule_id('Queued_Modules', $agent_id),
|
|
||||||
modules_get_agentmodule_id('Status', $agent_id),
|
|
||||||
modules_get_agentmodule_id('System_Load_AVG', $agent_id),
|
|
||||||
modules_get_agentmodule_id('Execution_time', $agent_id),
|
|
||||||
];
|
|
||||||
|
|
||||||
foreach ($id_modules as $id_module) {
|
|
||||||
$params = [
|
|
||||||
'agent_module_id' => $id_module['id_agente_modulo'],
|
|
||||||
'period' => SECONDS_1MONTH,
|
|
||||||
'date' => time(),
|
|
||||||
'height' => '150',
|
|
||||||
];
|
|
||||||
render_row(grafico_modulo_sparse($params), 'Graph of the '.$id_module['nombre'].' module.');
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($console_mode == 0) {
|
|
||||||
echo '</table>';
|
|
||||||
}
|
|
||||||
|
|
||||||
echo "<hr color='#b1b1b1' size=1 width=1000 align=left>";
|
|
||||||
|
|
||||||
echo '<span>'.__(
|
|
||||||
'(*) Please check your Pandora Server setup and make sure that the database maintenance daemon is running. It\' is very important to
|
|
||||||
keep the database up-to-date to get the best performance and results in Pandora'
|
|
||||||
).'</span><br><br><br>';
|
|
||||||
|
|
|
@ -332,6 +332,7 @@ if ($config['menu_type'] == 'classic') {
|
||||||
if (enterprise_installed()) {
|
if (enterprise_installed()) {
|
||||||
$header_feedback = '<div id="feedback-icon-header">';
|
$header_feedback = '<div id="feedback-icon-header">';
|
||||||
$header_feedback .= '<div id="modal-feedback-form" style="display:none;"></div>';
|
$header_feedback .= '<div id="modal-feedback-form" style="display:none;"></div>';
|
||||||
|
$header_feedback .= '<div id="msg-header" style="display: none"></div>';
|
||||||
$header_feedback .= html_print_image(
|
$header_feedback .= html_print_image(
|
||||||
'/images/icono_warning.png',
|
'/images/icono_warning.png',
|
||||||
true,
|
true,
|
||||||
|
@ -627,7 +628,7 @@ if ($config['menu_type'] == 'classic') {
|
||||||
});
|
});
|
||||||
|
|
||||||
var fixed_header = <?php echo json_encode((bool) $config_fixed_header); ?>;
|
var fixed_header = <?php echo json_encode((bool) $config_fixed_header); ?>;
|
||||||
|
|
||||||
var new_chat = <?php echo (int) $_SESSION['new_chat']; ?>;
|
var new_chat = <?php echo (int) $_SESSION['new_chat']; ?>;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -644,8 +645,6 @@ if ($config['menu_type'] == 'classic') {
|
||||||
var title = '<?php echo __('Report an issue'); ?>';
|
var title = '<?php echo __('Report an issue'); ?>';
|
||||||
var url = '<?php echo 'tools/diagnostics'; ?>';
|
var url = '<?php echo 'tools/diagnostics'; ?>';
|
||||||
|
|
||||||
console.log('entra');
|
|
||||||
|
|
||||||
load_modal({
|
load_modal({
|
||||||
target: $('#modal-feedback-form'),
|
target: $('#modal-feedback-form'),
|
||||||
form: 'modal_form_feedback',
|
form: 'modal_form_feedback',
|
||||||
|
@ -662,9 +661,11 @@ if ($config['menu_type'] == 'classic') {
|
||||||
onsubmit: {
|
onsubmit: {
|
||||||
page: url,
|
page: url,
|
||||||
method: 'createdScheduleFeedbackTask',
|
method: 'createdScheduleFeedbackTask',
|
||||||
}
|
dataType: 'json',
|
||||||
|
},
|
||||||
|
ajax_callback: generalShowMsg,
|
||||||
|
idMsgCallback: 'msg-header',
|
||||||
});
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$(document).ready (function () {
|
$(document).ready (function () {
|
||||||
|
@ -719,6 +720,9 @@ if ($config['menu_type'] == 'classic') {
|
||||||
|
|
||||||
// Feedback.
|
// Feedback.
|
||||||
$("#feedback-header").click(function () {
|
$("#feedback-header").click(function () {
|
||||||
|
// Clean DOM.
|
||||||
|
$("#feedback-header").empty();
|
||||||
|
// Function charge Modal.
|
||||||
show_feedback();
|
show_feedback();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -59,8 +59,10 @@ class Diagnostics extends Wizard
|
||||||
* @param string $page Page.
|
* @param string $page Page.
|
||||||
* @param boolean $pdf PDF View.
|
* @param boolean $pdf PDF View.
|
||||||
*/
|
*/
|
||||||
public function __construct(string $page, bool $pdf)
|
public function __construct(
|
||||||
{
|
string $page='tools/diagnostics',
|
||||||
|
bool $pdf=false
|
||||||
|
) {
|
||||||
global $config;
|
global $config;
|
||||||
|
|
||||||
// Check access.
|
// Check access.
|
||||||
|
@ -105,6 +107,7 @@ class Diagnostics extends Wizard
|
||||||
'getAttachmentFolder',
|
'getAttachmentFolder',
|
||||||
'getInfoTagenteDatos',
|
'getInfoTagenteDatos',
|
||||||
'getServerThreads',
|
'getServerThreads',
|
||||||
|
'getShowEngine',
|
||||||
'datatablesDraw',
|
'datatablesDraw',
|
||||||
'getChartAjax',
|
'getChartAjax',
|
||||||
'formFeedback',
|
'formFeedback',
|
||||||
|
@ -134,35 +137,7 @@ class Diagnostics extends Wizard
|
||||||
{
|
{
|
||||||
global $config;
|
global $config;
|
||||||
|
|
||||||
$urlPdf = ui_get_full_url(false, false, false, false);
|
ui_require_css_file('diagnostics');
|
||||||
$urlPdf .= 'enterprise/operation/reporting/reporting_viewer_pdf.php';
|
|
||||||
$textPdf = '<a href="'.$urlPdf.'" target="_new">';
|
|
||||||
|
|
||||||
$textPdf .= html_print_image(
|
|
||||||
'images/pdf.png',
|
|
||||||
true,
|
|
||||||
['title' => __('PDF Report')]
|
|
||||||
);
|
|
||||||
$textPdf .= '</a>';
|
|
||||||
|
|
||||||
$textCsv = '<a href="index.php?sec=gextensions&sec2='.$this->ajaxController.'">';
|
|
||||||
$textCsv .= html_print_image(
|
|
||||||
'images/csv.png',
|
|
||||||
true,
|
|
||||||
['title' => __('Csv Report')]
|
|
||||||
);
|
|
||||||
$textCsv .= '</a>';
|
|
||||||
|
|
||||||
$buttonsHeader = [
|
|
||||||
'diagnosticsPdf' => [
|
|
||||||
'text' => $textPdf,
|
|
||||||
'active' => false,
|
|
||||||
],
|
|
||||||
'diagnosticsCsv' => [
|
|
||||||
'text' => $textCsv,
|
|
||||||
'active' => false,
|
|
||||||
],
|
|
||||||
];
|
|
||||||
|
|
||||||
// Header.
|
// Header.
|
||||||
ui_print_page_header(
|
ui_print_page_header(
|
||||||
|
@ -170,8 +145,6 @@ class Diagnostics extends Wizard
|
||||||
'images/gm_massive_operations.png',
|
'images/gm_massive_operations.png',
|
||||||
false,
|
false,
|
||||||
'diagnostic_tool_tab',
|
'diagnostic_tool_tab',
|
||||||
true,
|
|
||||||
$buttonsHeader,
|
|
||||||
true
|
true
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -184,7 +157,6 @@ class Diagnostics extends Wizard
|
||||||
echo '<div class="footer-self-monitoring">';
|
echo '<div class="footer-self-monitoring">';
|
||||||
echo $this->checkPandoraDB();
|
echo $this->checkPandoraDB();
|
||||||
echo '</div>';
|
echo '</div>';
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -224,6 +196,10 @@ class Diagnostics extends Wizard
|
||||||
'getServerThreads',
|
'getServerThreads',
|
||||||
];
|
];
|
||||||
|
|
||||||
|
if ($this->pdf === true) {
|
||||||
|
$infoMethods[] = 'getShowEngine';
|
||||||
|
}
|
||||||
|
|
||||||
$return = '';
|
$return = '';
|
||||||
|
|
||||||
foreach ($infoMethods as $key => $method) {
|
foreach ($infoMethods as $key => $method) {
|
||||||
|
@ -282,6 +258,10 @@ class Diagnostics extends Wizard
|
||||||
$title = __('Pandora FMS server threads');
|
$title = __('Pandora FMS server threads');
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case 'getShowEngine':
|
||||||
|
$title = __('SQL show engine innodb status');
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
// Not possible.
|
// Not possible.
|
||||||
$title = '';
|
$title = '';
|
||||||
|
@ -376,7 +356,9 @@ class Diagnostics extends Wizard
|
||||||
];
|
];
|
||||||
|
|
||||||
$return .= '<div class="title-self-monitoring">';
|
$return .= '<div class="title-self-monitoring">';
|
||||||
$return .= __('Graphs modules that represent the self-monitoring system');
|
$return .= __(
|
||||||
|
'Graphs modules that represent the self-monitoring system'
|
||||||
|
);
|
||||||
$return .= '</div>';
|
$return .= '</div>';
|
||||||
$return .= '<div class="container-self-monitoring">';
|
$return .= '<div class="container-self-monitoring">';
|
||||||
foreach ($agentMonitoring as $key => $value) {
|
foreach ($agentMonitoring as $key => $value) {
|
||||||
|
@ -1298,7 +1280,7 @@ class Diagnostics extends Wizard
|
||||||
$result = [
|
$result = [
|
||||||
'error' => false,
|
'error' => false,
|
||||||
'data' => [
|
'data' => [
|
||||||
[
|
'totalServerThreads' => [
|
||||||
'name' => __('Total server threads'),
|
'name' => __('Total server threads'),
|
||||||
'value' => $totalServerThreads,
|
'value' => $totalServerThreads,
|
||||||
],
|
],
|
||||||
|
@ -1317,6 +1299,52 @@ class Diagnostics extends Wizard
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SQL show engine innodb status.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getShowEngine(): string
|
||||||
|
{
|
||||||
|
global $config;
|
||||||
|
|
||||||
|
try {
|
||||||
|
// Trick to avoid showing error in case
|
||||||
|
// you don't have enough permissions.
|
||||||
|
$backup = error_reporting();
|
||||||
|
error_reporting(0);
|
||||||
|
$innodb = db_get_all_rows_sql('show engine innodb status');
|
||||||
|
error_reporting($backup);
|
||||||
|
} catch (Exception $e) {
|
||||||
|
$innodb['Status'] = $e->getMessage();
|
||||||
|
}
|
||||||
|
|
||||||
|
$result = [];
|
||||||
|
if (isset($innodb[0]['Status']) === true
|
||||||
|
&& $innodb[0]['Status'] !== false
|
||||||
|
) {
|
||||||
|
$lenght = strlen($innodb[0]['Status']);
|
||||||
|
|
||||||
|
$data = [];
|
||||||
|
for ($i = 0; $i < $lenght; $i = ($i + 500)) {
|
||||||
|
$str = substr($innodb[0]['Status'], $i, ($i + 500));
|
||||||
|
$data['showEngine-'.$i] = [
|
||||||
|
'name' => '',
|
||||||
|
'value' => '<pre>'.$str.'</pre>',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
$result = [
|
||||||
|
'error' => false,
|
||||||
|
'data' => $data,
|
||||||
|
'id' => 'showEngine',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
return json_encode($result);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Agent Id whit name is equal to Server Name.
|
* Agent Id whit name is equal to Server Name.
|
||||||
*
|
*
|
||||||
|
@ -1482,13 +1510,26 @@ class Diagnostics extends Wizard
|
||||||
|
|
||||||
$table = new stdClass();
|
$table = new stdClass();
|
||||||
$table->width = '100%';
|
$table->width = '100%';
|
||||||
$table->class = '';
|
$table->class = 'pdf-report';
|
||||||
|
$table->style = [];
|
||||||
|
$table->style[0] = 'font-weight: bolder;';
|
||||||
|
|
||||||
|
// FIX tables break content.
|
||||||
|
if ($data['idTable'] === 'showEngine') {
|
||||||
|
$table->styleTable = 'page-break-inside: auto;';
|
||||||
|
} else {
|
||||||
|
$table->autosize = 1;
|
||||||
|
}
|
||||||
|
|
||||||
$table->head = [];
|
$table->head = [];
|
||||||
$table->head_colspan[0] = 3;
|
$table->head_colspan[0] = 3;
|
||||||
$table->head[0] = $title;
|
$table->head[0] = $title;
|
||||||
$table->data = [];
|
$table->data = [];
|
||||||
|
|
||||||
if (isset($data) === true && is_array($data) === true) {
|
if (isset($data) === true
|
||||||
|
&& is_array($data) === true
|
||||||
|
&& count($data) > 0
|
||||||
|
) {
|
||||||
$i = 0;
|
$i = 0;
|
||||||
foreach ($data['data'] as $key => $value) {
|
foreach ($data['data'] as $key => $value) {
|
||||||
$table->data[$i][0] = $value['name'];
|
$table->data[$i][0] = $value['name'];
|
||||||
|
@ -1676,7 +1717,11 @@ class Diagnostics extends Wizard
|
||||||
$data = json_decode($this->{$method}(), true);
|
$data = json_decode($this->{$method}(), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($data) === true && is_array($data) === true) {
|
$result = [];
|
||||||
|
if (isset($data) === true
|
||||||
|
&& is_array($data) === true
|
||||||
|
&& count($data) > 0
|
||||||
|
) {
|
||||||
$items = $data['data'];
|
$items = $data['data'];
|
||||||
$dataReduce = array_reduce(
|
$dataReduce = array_reduce(
|
||||||
array_keys($data['data']),
|
array_keys($data['data']),
|
||||||
|
@ -1711,6 +1756,17 @@ class Diagnostics extends Wizard
|
||||||
// FIX for customer key.
|
// FIX for customer key.
|
||||||
if ($key === 'customerKey') {
|
if ($key === 'customerKey') {
|
||||||
$spanValue = '<span>'.$items[$key]['value'].'</span>';
|
$spanValue = '<span>'.$items[$key]['value'].'</span>';
|
||||||
|
if ($this->pdf === true) {
|
||||||
|
$spanValue = '<span>';
|
||||||
|
$spanValue .= wordwrap(
|
||||||
|
$items[$key]['value'],
|
||||||
|
10,
|
||||||
|
"\n",
|
||||||
|
true
|
||||||
|
);
|
||||||
|
$spanValue .= '</span>';
|
||||||
|
}
|
||||||
|
|
||||||
$items[$key]['value'] = $spanValue;
|
$items[$key]['value'] = $spanValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1722,34 +1778,37 @@ class Diagnostics extends Wizard
|
||||||
return $carry;
|
return $carry;
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
}
|
|
||||||
|
|
||||||
$result = json_encode(
|
$result = [
|
||||||
[
|
|
||||||
'data' => $dataReduce,
|
'data' => $dataReduce,
|
||||||
'recordsTotal' => count($dataReduce),
|
'recordsTotal' => count($dataReduce),
|
||||||
'recordsFiltered' => count($dataReduce),
|
'recordsFiltered' => count($dataReduce),
|
||||||
]
|
'idTable' => (isset($data['id']) === true) ? $data['id'] : '',
|
||||||
);
|
];
|
||||||
|
}
|
||||||
|
|
||||||
// Datatables format: RecordsTotal && recordsfiltered.
|
// Datatables format: RecordsTotal && recordsfiltered.
|
||||||
if ($return === false) {
|
if ($return === false) {
|
||||||
echo $result;
|
echo json_encode($result);
|
||||||
return null;
|
return null;
|
||||||
} else {
|
} else {
|
||||||
return $result;
|
return json_encode($result);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public function createdScheduleFeedbackTask()
|
/**
|
||||||
|
* Create cron task form feedback.
|
||||||
|
*
|
||||||
|
* @return void Json result AJAX request.
|
||||||
|
*/
|
||||||
|
public function createdScheduleFeedbackTask():void
|
||||||
{
|
{
|
||||||
global $config;
|
global $config;
|
||||||
|
|
||||||
$email = 'daniel.barbero@artica.es';
|
$email = 'daniel.barbero@artica.es';
|
||||||
$subject = 'PandoraFMS Report '.$config['pandora_uid'];
|
$subject = 'PandoraFMS Report '.$config['pandora_uid'];
|
||||||
$text = get_parameter('what-happened', '');
|
$text = get_parameter('what-happened', '');
|
||||||
$type = get_parameter('include-installation-data', '');
|
$attachment = get_parameter_switch('include_installation_data', 0);
|
||||||
|
|
||||||
$idUserTask = db_get_value(
|
$idUserTask = db_get_value(
|
||||||
'id',
|
'id',
|
||||||
|
@ -1758,15 +1817,17 @@ class Diagnostics extends Wizard
|
||||||
'cron_task_feedback_send_mail'
|
'cron_task_feedback_send_mail'
|
||||||
);
|
);
|
||||||
|
|
||||||
|
// Params for send mail with cron.
|
||||||
$parameters = [
|
$parameters = [
|
||||||
0 => '0',
|
0 => '0',
|
||||||
1 => $email,
|
1 => $email,
|
||||||
2 => $subject,
|
2 => $subject,
|
||||||
3 => $text,
|
3 => $text,
|
||||||
4 => $type,
|
4 => $attachment,
|
||||||
'first_execution' => strtotime('now'),
|
'first_execution' => strtotime('now'),
|
||||||
];
|
];
|
||||||
|
|
||||||
|
// Values insert task cron.
|
||||||
$values = [
|
$values = [
|
||||||
'id_usuario' => $config['id_user'],
|
'id_usuario' => $config['id_user'],
|
||||||
'id_user_task' => $idUserTask,
|
'id_user_task' => $idUserTask,
|
||||||
|
@ -1775,24 +1836,54 @@ class Diagnostics extends Wizard
|
||||||
'id_grupo' => 0,
|
'id_grupo' => 0,
|
||||||
];
|
];
|
||||||
|
|
||||||
$result = db_process_sql_insert('tuser_task_scheduled', $values);
|
$result = db_process_sql_insert(
|
||||||
|
'tuser_task_scheduled',
|
||||||
|
$values
|
||||||
|
);
|
||||||
|
|
||||||
|
$error = 1;
|
||||||
|
if ($result === false) {
|
||||||
|
$error = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
$return = [
|
||||||
|
'error' => $error,
|
||||||
|
'title' => [
|
||||||
|
__('Failed'),
|
||||||
|
__('Success'),
|
||||||
|
],
|
||||||
|
'text' => [
|
||||||
|
ui_print_error_message(__('Mal'), '', true),
|
||||||
|
ui_print_success_message(__('bien'), '', true),
|
||||||
|
],
|
||||||
|
];
|
||||||
|
|
||||||
|
exit(json_encode($return));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Print Diagnostics PDF report.
|
* Print Diagnostics PDF report.
|
||||||
*
|
*
|
||||||
|
* @param string|null $filename Filename.
|
||||||
|
*
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public static function exportPDF($filename=false)
|
public function exportPDF(?string $filename=null):void
|
||||||
{
|
{
|
||||||
global $config;
|
global $config;
|
||||||
|
|
||||||
|
$this->pdf = true;
|
||||||
|
|
||||||
enterprise_include_once('/include/class/Pdf.class.php');
|
enterprise_include_once('/include/class/Pdf.class.php');
|
||||||
$pdf = new Pdf([]);
|
$mpdf = new Pdf([]);
|
||||||
$diagnostics = new Diagnostics('tools/diagnostics', true);
|
|
||||||
|
// ADD style.
|
||||||
|
$mpdf->addStyle($config['homedir'].'/include/styles/diagnostics.css');
|
||||||
|
|
||||||
|
// ADD Metadata.
|
||||||
$product_name = io_safe_output(get_product_name());
|
$product_name = io_safe_output(get_product_name());
|
||||||
$pdf->setMetadata(
|
$mpdf->setMetadata(
|
||||||
__('Diagnostics Info'),
|
__('Diagnostics Info'),
|
||||||
$product_name.' Enteprise',
|
$product_name.' Enteprise',
|
||||||
$product_name,
|
$product_name,
|
||||||
|
@ -1801,18 +1892,24 @@ class Diagnostics extends Wizard
|
||||||
$product_name
|
$product_name
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
$pdf->setHeaderHTML(__('Diagnostics Info'));
|
|
||||||
|
|
||||||
$pdf->addHTML(
|
// ADD Header.
|
||||||
$diagnostics->printMethodsDiagnostigsInfo()
|
$mpdf->setHeaderHTML(__('Diagnostics Info'));
|
||||||
|
|
||||||
|
// ADD content to report.
|
||||||
|
$mpdf->addHTML(
|
||||||
|
$this->printMethodsDiagnostigsInfo()
|
||||||
);
|
);
|
||||||
|
|
||||||
$pdf->addHTML(
|
$mpdf->addHTML(
|
||||||
$diagnostics->printCharts()
|
$this->printCharts()
|
||||||
);
|
);
|
||||||
|
|
||||||
$pdf->setFooterHTML();
|
// ADD Footer.
|
||||||
$pdf->writePDFfile($filename);
|
$mpdf->setFooterHTML();
|
||||||
|
|
||||||
|
// Write html filename.
|
||||||
|
$mpdf->writePDFfile($filename);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1860,14 +1957,13 @@ class Diagnostics extends Wizard
|
||||||
];
|
];
|
||||||
|
|
||||||
$inputs[] = [
|
$inputs[] = [
|
||||||
'label' => __('include installation data'),
|
'label' => __('Include installation data'),
|
||||||
'class' => 'flex-row-vcenter',
|
'class' => 'flex-row-vcenter',
|
||||||
'arguments' => [
|
'arguments' => [
|
||||||
'name' => 'include-installation-data',
|
'name' => 'include_installation_data',
|
||||||
'id' => 'include-installation-data',
|
'id' => 'include_installation_data',
|
||||||
'type' => 'switch',
|
'type' => 'switch',
|
||||||
'return' => true,
|
'value' => 1,
|
||||||
'value' => 1,
|
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
|
|
||||||
|
@ -1883,4 +1979,67 @@ class Diagnostics extends Wizard
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Send Csv md5 files.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function csvMd5Files():string
|
||||||
|
{
|
||||||
|
global $config;
|
||||||
|
|
||||||
|
// Extract files.
|
||||||
|
$files = $this->recursiveDirValidation($config['homedir']);
|
||||||
|
|
||||||
|
// Type divider.
|
||||||
|
$divider = html_entity_decode($config['csv_divider']);
|
||||||
|
|
||||||
|
// BOM.
|
||||||
|
$result = pack('C*', 0xEF, 0xBB, 0xBF);
|
||||||
|
|
||||||
|
$result .= __('Path').$divider.__('MD5')."\n";
|
||||||
|
foreach ($files as $key => $value) {
|
||||||
|
$result .= $key.$divider.$value."\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
return $result;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to return array with name file -> MD%.
|
||||||
|
*
|
||||||
|
* @param string $dir Directory.
|
||||||
|
*
|
||||||
|
* @return array Result all files in directory recursively.
|
||||||
|
*/
|
||||||
|
private function recursiveDirValidation(string $dir):array
|
||||||
|
{
|
||||||
|
$result = [];
|
||||||
|
|
||||||
|
$dir_content = scandir($dir);
|
||||||
|
|
||||||
|
// Dont check attachment.
|
||||||
|
if (strpos($dir, $config['homedir'].'/attachment') === false) {
|
||||||
|
if (is_array($dir_content) === true) {
|
||||||
|
foreach (scandir($dir) as $file) {
|
||||||
|
if ('.' === $file || '..' === $file) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_dir($dir.'/'.$file) === true) {
|
||||||
|
$result += $this->recursiveDirValidation(
|
||||||
|
$dir.'/'.$file
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
$result[$dir.'/'.$file] = md5_file($dir.'/'.$file);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $result;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1898,6 +1898,7 @@ function html_get_predefined_table($model='transparent', $columns=4)
|
||||||
* $table->titlestyle - Title style
|
* $table->titlestyle - Title style
|
||||||
* $table->titleclass - Title class
|
* $table->titleclass - Title class
|
||||||
* $table->styleTable - Table style
|
* $table->styleTable - Table style
|
||||||
|
* $table->autosize - Autosize
|
||||||
* $table->caption - Table title
|
* $table->caption - Table title
|
||||||
* @param bool Whether to return an output string or echo now
|
* @param bool Whether to return an output string or echo now
|
||||||
*
|
*
|
||||||
|
@ -2008,6 +2009,12 @@ function html_print_table(&$table, $return=false)
|
||||||
// $table->width = '80%';
|
// $table->width = '80%';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (isset($table->autosize) === true) {
|
||||||
|
$table->autosize = 'autosize = "1"';
|
||||||
|
} else {
|
||||||
|
$table->autosize = '';
|
||||||
|
}
|
||||||
|
|
||||||
if (empty($table->border)) {
|
if (empty($table->border)) {
|
||||||
if (empty($table)) {
|
if (empty($table)) {
|
||||||
$table = new stdClass();
|
$table = new stdClass();
|
||||||
|
@ -2042,9 +2049,9 @@ function html_print_table(&$table, $return=false)
|
||||||
$tableid = empty($table->id) ? 'table'.$table_count : $table->id;
|
$tableid = empty($table->id) ? 'table'.$table_count : $table->id;
|
||||||
|
|
||||||
if (!empty($table->width)) {
|
if (!empty($table->width)) {
|
||||||
$output .= '<table style="width:'.$table->width.'; '.$styleTable.' '.$table->tablealign;
|
$output .= '<table '.$table->autosize.' style="width:'.$table->width.'; '.$styleTable.' '.$table->tablealign;
|
||||||
} else {
|
} else {
|
||||||
$output .= '<table style="'.$styleTable.' '.$table->tablealign;
|
$output .= '<table '.$table->autosize.' style="'.$styleTable.' '.$table->tablealign;
|
||||||
}
|
}
|
||||||
|
|
||||||
$output .= ' cellpadding="'.$table->cellpadding.'" cellspacing="'.$table->cellspacing.'"';
|
$output .= ' cellpadding="'.$table->cellpadding.'" cellspacing="'.$table->cellspacing.'"';
|
||||||
|
@ -3003,23 +3010,24 @@ function html_print_csrf_error()
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Print an swith button
|
* Print an swith button.
|
||||||
*
|
*
|
||||||
* @param array $atributes. Valid params:
|
* @param array $attributes Valid params.
|
||||||
* name: Usefull to handle in forms
|
* name: Usefull to handle in forms.
|
||||||
* value: If is checked or not
|
* value: If is checked or not.
|
||||||
* disabled: Disabled. Cannot be pressed.
|
* disabled: Disabled. Cannot be pressed.
|
||||||
* id: Optional id for the switch.
|
* id: Optional id for the switch.
|
||||||
* class: Additional classes (string).
|
* class: Additional classes (string).
|
||||||
* @return string with HTML of button
|
*
|
||||||
|
* @return string with HTML of button.
|
||||||
*/
|
*/
|
||||||
function html_print_switch($attributes=[])
|
function html_print_switch($attributes=[])
|
||||||
{
|
{
|
||||||
$html_expand = '';
|
$html_expand = '';
|
||||||
|
|
||||||
// Check the load values on status.
|
// Check the load values on status.
|
||||||
$html_expand .= (bool) $attributes['value'] ? ' checked' : '';
|
$html_expand .= (bool) ($attributes['value']) ? ' checked' : '';
|
||||||
$html_expand .= (bool) $attributes['disabled'] ? ' disabled' : '';
|
$html_expand .= (bool) ($attributes['disabled']) ? ' disabled' : '';
|
||||||
|
|
||||||
// Only load the valid attributes.
|
// Only load the valid attributes.
|
||||||
$valid_attrs = [
|
$valid_attrs = [
|
||||||
|
@ -3042,7 +3050,7 @@ function html_print_switch($attributes=[])
|
||||||
}
|
}
|
||||||
|
|
||||||
return "<label class='p-switch' style='".$attributes['style']."'>
|
return "<label class='p-switch' style='".$attributes['style']."'>
|
||||||
<input type='checkbox' $html_expand>
|
<input type='checkbox' ".$html_expand.">
|
||||||
<span class='p-slider'></span>
|
<span class='p-slider'></span>
|
||||||
</label>";
|
</label>";
|
||||||
}
|
}
|
||||||
|
|
|
@ -1944,6 +1944,10 @@ function load_modal(settings) {
|
||||||
if (settings.onsubmit.preaction != undefined) {
|
if (settings.onsubmit.preaction != undefined) {
|
||||||
settings.onsubmit.preaction();
|
settings.onsubmit.preaction();
|
||||||
}
|
}
|
||||||
|
if (settings.onsubmit.dataType == undefined) {
|
||||||
|
settings.onsubmit.dataType = "html";
|
||||||
|
}
|
||||||
|
|
||||||
var formdata = new FormData();
|
var formdata = new FormData();
|
||||||
if (settings.extradata) {
|
if (settings.extradata) {
|
||||||
settings.extradata.forEach(function(item) {
|
settings.extradata.forEach(function(item) {
|
||||||
|
@ -1960,7 +1964,13 @@ function load_modal(settings) {
|
||||||
formdata.append(this.name, $(this).prop("files")[0]);
|
formdata.append(this.name, $(this).prop("files")[0]);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
formdata.append(this.name, $(this).val());
|
if ($(this).attr("type") == "checkbox") {
|
||||||
|
if (this.checked) {
|
||||||
|
formdata.append(this.name, "on");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
formdata.append(this.name, $(this).val());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -1970,9 +1980,14 @@ function load_modal(settings) {
|
||||||
processData: false,
|
processData: false,
|
||||||
contentType: false,
|
contentType: false,
|
||||||
data: formdata,
|
data: formdata,
|
||||||
|
dataType: settings.onsubmit.dataType,
|
||||||
success: function(data) {
|
success: function(data) {
|
||||||
if (settings.ajax_callback != undefined) {
|
if (settings.ajax_callback != undefined) {
|
||||||
settings.ajax_callback(data);
|
if (settings.idMsgCallback != undefined) {
|
||||||
|
settings.ajax_callback(data, settings.idMsgCallback);
|
||||||
|
} else {
|
||||||
|
settings.ajax_callback(data);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
AJAX_RUNNING = 0;
|
AJAX_RUNNING = 0;
|
||||||
}
|
}
|
||||||
|
@ -1989,6 +2004,58 @@ function load_modal(settings) {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to show modal with message Validation.
|
||||||
|
*
|
||||||
|
* @param {json} data Json example:
|
||||||
|
* $return = [
|
||||||
|
* 'error' => 0 or 1,
|
||||||
|
* 'title' => [
|
||||||
|
* Failed,
|
||||||
|
* Success,
|
||||||
|
* ],
|
||||||
|
* 'text' => [
|
||||||
|
* Failed,
|
||||||
|
* Success,
|
||||||
|
* ],
|
||||||
|
*];
|
||||||
|
* @param {string} idMsg ID div charge modal.
|
||||||
|
*
|
||||||
|
* @return {void}
|
||||||
|
*/
|
||||||
|
function generalShowMsg(data, idMsg) {
|
||||||
|
var title = data.title[data.error];
|
||||||
|
var text = data.text[data.error];
|
||||||
|
var failed = !data.error;
|
||||||
|
|
||||||
|
$("#" + idMsg).empty();
|
||||||
|
$("#" + idMsg).html(text);
|
||||||
|
$("#" + idMsg).dialog({
|
||||||
|
width: 450,
|
||||||
|
position: {
|
||||||
|
my: "center",
|
||||||
|
at: "center",
|
||||||
|
of: window,
|
||||||
|
collision: "fit"
|
||||||
|
},
|
||||||
|
title: title,
|
||||||
|
buttons: [
|
||||||
|
{
|
||||||
|
class:
|
||||||
|
"ui-widget ui-state-default ui-corner-all ui-button-text-only sub ok submit-next",
|
||||||
|
text: "OK",
|
||||||
|
click: function(e) {
|
||||||
|
if (!failed) {
|
||||||
|
$(".ui-dialog-content").dialog("close");
|
||||||
|
} else {
|
||||||
|
$(this).dialog("close");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Function for AJAX request.
|
* Function for AJAX request.
|
||||||
*
|
*
|
||||||
|
|
|
@ -0,0 +1,58 @@
|
||||||
|
.pdf-report {
|
||||||
|
page-break-inside: avoid;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pdf-report th,
|
||||||
|
.title-self-monitoring,
|
||||||
|
.caption_table caption {
|
||||||
|
text-align: center;
|
||||||
|
font-size: 1.5em;
|
||||||
|
font-weight: bolder;
|
||||||
|
color: #fff;
|
||||||
|
background: #282828;
|
||||||
|
padding: 8px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pdf-report tr {
|
||||||
|
text-align: justify;
|
||||||
|
}
|
||||||
|
|
||||||
|
.datatables-td-title {
|
||||||
|
width: 25% !important;
|
||||||
|
font-weight: bolder;
|
||||||
|
}
|
||||||
|
|
||||||
|
.datatables-td-max {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: row;
|
||||||
|
flex-wrap: wrap;
|
||||||
|
}
|
||||||
|
|
||||||
|
.datatables-td-max img {
|
||||||
|
margin-right: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.datatables-td-max span {
|
||||||
|
width: 400px;
|
||||||
|
display: inline-block;
|
||||||
|
word-wrap: break-word;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pdf-report td {
|
||||||
|
font-size: 1.2em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.container-self-monitoring {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: row;
|
||||||
|
flex-wrap: wrap;
|
||||||
|
}
|
||||||
|
|
||||||
|
.element-self-monitoring {
|
||||||
|
flex: 2 1 600px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-self-monitoring {
|
||||||
|
margin: 30px;
|
||||||
|
font-style: italic;
|
||||||
|
}
|
|
@ -5910,49 +5910,3 @@ table.table_modal_alternate tr td:first-child {
|
||||||
.flot-text {
|
.flot-text {
|
||||||
width: 101%;
|
width: 101%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.title-self-monitoring,
|
|
||||||
.caption_table caption {
|
|
||||||
text-align: center;
|
|
||||||
font-size: 1.5em;
|
|
||||||
font-weight: bolder;
|
|
||||||
color: #fff;
|
|
||||||
background: #282828;
|
|
||||||
padding: 8px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.datatables-td-title {
|
|
||||||
width: 25% !important;
|
|
||||||
font-weight: bolder;
|
|
||||||
}
|
|
||||||
|
|
||||||
.datatables-td-max {
|
|
||||||
display: flex;
|
|
||||||
flex-direction: row;
|
|
||||||
flex-wrap: wrap;
|
|
||||||
}
|
|
||||||
|
|
||||||
.datatables-td-max img {
|
|
||||||
margin-right: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.datatables-td-max span {
|
|
||||||
width: 400px;
|
|
||||||
display: inline-block;
|
|
||||||
word-wrap: break-word;
|
|
||||||
}
|
|
||||||
|
|
||||||
.container-self-monitoring {
|
|
||||||
display: flex;
|
|
||||||
flex-direction: row;
|
|
||||||
flex-wrap: wrap;
|
|
||||||
}
|
|
||||||
|
|
||||||
.element-self-monitoring {
|
|
||||||
flex: 2 1 600px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.footer-self-monitoring {
|
|
||||||
margin: 30px;
|
|
||||||
font-style: italic;
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in New Issue