Merge remote-tracking branch 'origin/develop' into ent-6012-servicios-dinamicos
Conflicts: pandora_console/install.php
This commit is contained in:
commit
a8671078f1
|
@ -1,5 +1,5 @@
|
|||
package: pandorafms-agent-unix
|
||||
Version: 7.0NG.746-200622
|
||||
Version: 7.0NG.746-200625
|
||||
Architecture: all
|
||||
Priority: optional
|
||||
Section: admin
|
||||
|
|
|
@ -14,7 +14,7 @@
|
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
|
||||
pandora_version="7.0NG.746-200622"
|
||||
pandora_version="7.0NG.746-200625"
|
||||
|
||||
echo "Test if you has the tools for to make the packages."
|
||||
whereis dpkg-deb | cut -d":" -f2 | grep dpkg-deb > /dev/null
|
||||
|
|
|
@ -55,7 +55,7 @@ my $Sem = undef;
|
|||
my $ThreadSem = undef;
|
||||
|
||||
use constant AGENT_VERSION => '7.0NG.746';
|
||||
use constant AGENT_BUILD => '200622';
|
||||
use constant AGENT_BUILD => '200625';
|
||||
|
||||
# Agent log default file size maximum and instances
|
||||
use constant DEFAULT_MAX_LOG_SIZE => 600000;
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
#
|
||||
%define name pandorafms_agent_unix
|
||||
%define version 7.0NG.746
|
||||
%define release 200622
|
||||
%define release 200625
|
||||
|
||||
Summary: Pandora FMS Linux agent, PERL version
|
||||
Name: %{name}
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
#
|
||||
%define name pandorafms_agent_unix
|
||||
%define version 7.0NG.746
|
||||
%define release 200622
|
||||
%define release 200625
|
||||
|
||||
Summary: Pandora FMS Linux agent, PERL version
|
||||
Name: %{name}
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
# **********************************************************************
|
||||
|
||||
PI_VERSION="7.0NG.746"
|
||||
PI_BUILD="200622"
|
||||
PI_BUILD="200625"
|
||||
OS_NAME=`uname -s`
|
||||
|
||||
FORCE=0
|
||||
|
|
|
@ -186,7 +186,7 @@ UpgradeApplicationID
|
|||
{}
|
||||
|
||||
Version
|
||||
{200622}
|
||||
{200625}
|
||||
|
||||
ViewReadme
|
||||
{Yes}
|
||||
|
|
|
@ -30,7 +30,7 @@ using namespace Pandora;
|
|||
using namespace Pandora_Strutils;
|
||||
|
||||
#define PATH_SIZE _MAX_PATH+1
|
||||
#define PANDORA_VERSION ("7.0NG.746(Build 200622)")
|
||||
#define PANDORA_VERSION ("7.0NG.746(Build 200625)")
|
||||
|
||||
string pandora_path;
|
||||
string pandora_dir;
|
||||
|
|
|
@ -11,7 +11,7 @@ BEGIN
|
|||
VALUE "LegalCopyright", "Artica ST"
|
||||
VALUE "OriginalFilename", "PandoraAgent.exe"
|
||||
VALUE "ProductName", "Pandora FMS Windows Agent"
|
||||
VALUE "ProductVersion", "(7.0NG.746(Build 200622))"
|
||||
VALUE "ProductVersion", "(7.0NG.746(Build 200625))"
|
||||
VALUE "FileVersion", "1.0.0.0"
|
||||
END
|
||||
END
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
package: pandorafms-console
|
||||
Version: 7.0NG.746-200622
|
||||
Version: 7.0NG.746-200625
|
||||
Architecture: all
|
||||
Priority: optional
|
||||
Section: admin
|
||||
|
|
|
@ -14,7 +14,7 @@
|
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
|
||||
pandora_version="7.0NG.746-200622"
|
||||
pandora_version="7.0NG.746-200625"
|
||||
|
||||
package_pear=0
|
||||
package_pandora=1
|
||||
|
|
|
@ -83,9 +83,9 @@ foreach ($osList as $os) {
|
|||
}
|
||||
|
||||
if (isset($data)) {
|
||||
ui_pagination($count_osList, false, $offset);
|
||||
ui_pagination($count_osList, ui_get_url_refresh(['message' => false]), $offset);
|
||||
html_print_table($table);
|
||||
ui_pagination($count_osList, false, $offset, 0, false, 'offset', true, 'pagination-bottom');
|
||||
ui_pagination($count_osList, ui_get_url_refresh(['message' => false]), $offset, 0, false, 'offset', true, 'pagination-bottom');
|
||||
} else {
|
||||
ui_print_info_message(['no_close' => true, 'message' => __('There are no defined operating systems') ]);
|
||||
}
|
||||
|
|
|
@ -24,6 +24,7 @@ if (! check_acl($config['id_user'], 0, 'PM') && ! is_user_admin($config['id_user
|
|||
|
||||
$action = get_parameter('action', 'new');
|
||||
$idOS = get_parameter('id_os', 0);
|
||||
$id_message = get_parameter('message', 0);
|
||||
if (is_metaconsole()) {
|
||||
$tab = get_parameter('tab2', 'list');
|
||||
} else {
|
||||
|
@ -50,6 +51,7 @@ switch ($action) {
|
|||
$textButton = __('Create');
|
||||
$classButton = 'class="sub next"';
|
||||
break;
|
||||
|
||||
case 'edit':
|
||||
$actionHidden = 'update';
|
||||
$textButton = __('Update');
|
||||
|
@ -71,14 +73,20 @@ switch ($action) {
|
|||
}
|
||||
|
||||
if ($resultOrId === false) {
|
||||
$message = ui_print_error_message(__('Fail creating OS'), '', true);
|
||||
$message = 2;
|
||||
$tab = 'builder';
|
||||
$actionHidden = 'save';
|
||||
$textButton = __('Create');
|
||||
$classButton = 'class="sub next"';
|
||||
} else {
|
||||
$message = ui_print_success_message(__('Success creating OS'), '', true);
|
||||
$tab = 'list';
|
||||
$message = 1;
|
||||
}
|
||||
|
||||
if (is_metaconsole()) {
|
||||
header('Location:'.$config['homeurl'].'index.php?sec=advanced&sec2=advanced/component_management&tab=os_manage&tab2='.$tab.'&message='.$message);
|
||||
} else {
|
||||
header('Location:'.$config['homeurl'].'index.php?sec=gsetup&sec2=godmode/setup/os&tab='.$tab.'&message='.$message);
|
||||
}
|
||||
break;
|
||||
|
||||
|
@ -100,10 +108,11 @@ switch ($action) {
|
|||
$result = db_process_sql_update('tconfig_os', $values, ['id_os' => $idOS]);
|
||||
}
|
||||
|
||||
$message = ui_print_result_message($result, __('Success updatng OS'), __('Error updating OS'), '', true);
|
||||
if ($result !== false) {
|
||||
$message = 3;
|
||||
$tab = 'list';
|
||||
} else {
|
||||
$message = 4;
|
||||
$tab = 'builder';
|
||||
$os = db_get_row_filter('tconfig_os', ['id_os' => $idOS]);
|
||||
$name = $os['name'];
|
||||
|
@ -112,6 +121,11 @@ switch ($action) {
|
|||
$actionHidden = 'update';
|
||||
$textButton = __('Update');
|
||||
$classButton = 'class="sub upd"';
|
||||
if (is_metaconsole()) {
|
||||
header('Location:'.$config['homeurl'].'index.php?sec=advanced&sec2=advanced/component_management&tab=os_manage&tab2='.$tab.'&message='.$message);
|
||||
} else {
|
||||
header('Location:'.$config['homeurl'].'index.php?sec=gsetup&sec2=godmode/setup/os&tab='.$tab.'&message='.$message);
|
||||
}
|
||||
break;
|
||||
|
||||
case 'delete':
|
||||
|
@ -120,11 +134,20 @@ switch ($action) {
|
|||
$count = $count[0]['count'];
|
||||
|
||||
if ($count > 0) {
|
||||
$message = ui_print_error_message(__('There are agents with this OS.'), '', true);
|
||||
$message = 5;
|
||||
} else {
|
||||
$result = (bool) db_process_sql_delete('tconfig_os', ['id_os' => $idOS]);
|
||||
if ($result) {
|
||||
$message = 6;
|
||||
} else {
|
||||
$message = 7;
|
||||
}
|
||||
}
|
||||
|
||||
$message = ui_print_result_message($result, __('Success deleting'), __('Error deleting'), '', true);
|
||||
if (is_metaconsole()) {
|
||||
header('Location:'.$config['homeurl'].'index.php?sec=advanced&sec2=advanced/component_management&tab=os_manage&tab2='.$tab.'&message='.$message);
|
||||
} else {
|
||||
header('Location:'.$config['homeurl'].'index.php?sec=gsetup&sec2=godmode/setup/os&tab='.$tab.'&message='.$message);
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
@ -143,11 +166,45 @@ $buttons = [
|
|||
$buttons[$tab]['active'] = true;
|
||||
|
||||
if (!is_metaconsole()) {
|
||||
// Header
|
||||
// Header.
|
||||
ui_print_page_header(__('Edit OS'), '', false, '', true, $buttons);
|
||||
}
|
||||
|
||||
echo $message;
|
||||
if (!empty($id_message)) {
|
||||
switch ($id_message) {
|
||||
case 1:
|
||||
echo ui_print_success_message(__('Success creating OS'), '', true);
|
||||
break;
|
||||
|
||||
case 2:
|
||||
echo ui_print_error_message(__('Fail creating OS'), '', true);
|
||||
break;
|
||||
|
||||
case 3:
|
||||
echo ui_print_success_message(__('Success updating OS'), '', true);
|
||||
break;
|
||||
|
||||
case 4:
|
||||
echo ui_print_error_message(__('Error updating OS'), '', true);
|
||||
break;
|
||||
|
||||
case 5:
|
||||
echo ui_print_error_message(__('There are agents with this OS.'), '', true);
|
||||
break;
|
||||
|
||||
case 6:
|
||||
echo ui_print_success_message(__('Success deleting'), '', true);
|
||||
break;
|
||||
|
||||
case 7:
|
||||
echo ui_print_error_message(__('Error deleting'), '', true);
|
||||
break;
|
||||
|
||||
default:
|
||||
// Default.
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
switch ($tab) {
|
||||
case 'list':
|
||||
|
|
|
@ -1065,8 +1065,12 @@ $row++;
|
|||
}
|
||||
}
|
||||
|
||||
// Logo
|
||||
$table_report->data['custom_report_front-logo'][0] = __('Custom report front').' - '.__('Custom logo');
|
||||
// Logo.
|
||||
$table_report->data['custom_report_front-logo'][0] = __('Custom report front').' - '.__('Custom logo').ui_print_help_tip(
|
||||
__("The dir of custom logos is in your www Console in 'images/custom_logo'. You can upload more files (ONLY JPEG AND PNG) in upload tool in console."),
|
||||
true
|
||||
);
|
||||
|
||||
$table_report->data['custom_report_front-logo'][1] = html_print_select(
|
||||
$customLogos,
|
||||
'custom_report_front_logo',
|
||||
|
@ -1076,7 +1080,7 @@ $row++;
|
|||
'',
|
||||
true
|
||||
);
|
||||
// Preview
|
||||
// Preview.
|
||||
$table_report->data['custom_report_front-preview'][0] = __('Custom report front').' - '.'Preview';
|
||||
if (empty($config['custom_report_front_logo'])) {
|
||||
$config['custom_report_front_logo'] = 'images/pandora_logo_white.jpg';
|
||||
|
@ -1084,23 +1088,32 @@ $row++;
|
|||
|
||||
$table_report->data['custom_report_front-preview'][1] = '<span id="preview_image">'.html_print_image($config['custom_report_front_logo'], true).'</span>';
|
||||
|
||||
// Header
|
||||
// Header.
|
||||
$table_report->data['custom_report_front-header'][0] = __('Custom report front').' - '.__('Header');
|
||||
|
||||
// Do not remove io_safe_output in textarea. TinyMCE avoids XSS injection.
|
||||
$table_report->data['custom_report_front-header'][1] = html_print_textarea(
|
||||
'custom_report_front_header',
|
||||
5,
|
||||
15,
|
||||
$config['custom_report_front_header'],
|
||||
io_safe_output($config['custom_report_front_header']),
|
||||
'style="width: 38em;"',
|
||||
true
|
||||
);
|
||||
|
||||
// First page
|
||||
// First page.
|
||||
// Do not remove io_safe_output in textarea. TinyMCE avoids XSS injection.
|
||||
if ($config['custom_report_front']) {
|
||||
$firstpage_content = $config['custom_report_front_firstpage'];
|
||||
} else {
|
||||
$firstpage_content = io_safe_output($config['custom_report_front_firstpage']);
|
||||
}
|
||||
|
||||
$table_report->data['custom_report_front-first_page'][0] = __('Custom report front').' - '.__('First page');
|
||||
$custom_report_front_firstpage = str_replace(
|
||||
'(_URLIMAGE_)',
|
||||
ui_get_full_url(false, true, false, false),
|
||||
$config['custom_report_front_firstpage']
|
||||
io_safe_output($firstpage_content)
|
||||
);
|
||||
$table_report->data['custom_report_front-first_page'][1] = html_print_textarea(
|
||||
'custom_report_front_firstpage',
|
||||
|
@ -1111,13 +1124,15 @@ $row++;
|
|||
true
|
||||
);
|
||||
|
||||
// Footer
|
||||
// Footer.
|
||||
$table_report->data['custom_report_front-footer'][0] = __('Custom report front').' - '.__('Footer');
|
||||
|
||||
// Do not remove io_safe_output in textarea. TinyMCE avoids XSS injection.
|
||||
$table_report->data['custom_report_front-footer'][1] = html_print_textarea(
|
||||
'custom_report_front_footer',
|
||||
5,
|
||||
15,
|
||||
$config['custom_report_front_footer'],
|
||||
io_safe_output($config['custom_report_front_footer']),
|
||||
'style="width: 38em;"',
|
||||
true
|
||||
);
|
||||
|
|
|
@ -13,6 +13,7 @@
|
|||
// GNU General Public License for more details.
|
||||
require_once $config['homedir'].'/include/functions_config.php';
|
||||
require_once $config['homedir'].'/include/functions_snmp_browser.php';
|
||||
require_once $config['homedir'].'/include/functions_snmp.php';
|
||||
require_once $config['homedir'].'/include/functions_network_components.php';
|
||||
|
||||
|
||||
|
@ -112,6 +113,17 @@ if (is_ajax()) {
|
|||
$output .= '</div>';
|
||||
$output .= '</div>';
|
||||
|
||||
// Dialog no agent selected.
|
||||
$output .= '<div id="dialog_no_agents_selected" style="display:none" title="'.__('SNMP modules').'">';
|
||||
$output .= '<div>';
|
||||
$output .= "<div style='width:25%; float:left'><img style='padding-left:20px; padding-top:20px;' src='images/icono_error_mr.png'></div>";
|
||||
$output .= "<div style='width:75%; float:left;'><h3><strong style='font-family:Verdana; font-size:13pt;'>ERROR</strong></h3>";
|
||||
$output .= "<p style='font-family:Verdana; font-size:12pt;margin-bottom: 0px'>".__('Module must be applied to an agent or a policy').'</p>';
|
||||
$output .= "<p id='error_text' style='font-family:Verdana; font-size:12pt;'></p>";
|
||||
$output .= '</div>';
|
||||
$output .= '</div>';
|
||||
$output .= '</div>';
|
||||
|
||||
echo $output;
|
||||
}
|
||||
|
||||
|
@ -158,6 +170,11 @@ if (is_ajax()) {
|
|||
$id_target = explode(',', $id_items[0]);
|
||||
}
|
||||
|
||||
if (empty($id_items[0])) {
|
||||
echo json_encode([0 => -1]);
|
||||
exit;
|
||||
}
|
||||
|
||||
$snmp_extradata = get_parameter('snmp_extradata', '');
|
||||
|
||||
if (!is_array($snmp_extradata)) {
|
||||
|
|
|
@ -1363,7 +1363,7 @@ class ConsoleSupervisor
|
|||
$this->cleanNotifications('NOTIF.PHP.INPUT_TIME');
|
||||
}
|
||||
|
||||
if ($PHPmax_execution_time !== '0') {
|
||||
if ((int) $PHPmax_execution_time !== 0) {
|
||||
$url = 'http://php.net/manual/en/info.configuration.php#ini.max-execution-time';
|
||||
if ($config['language'] == 'es') {
|
||||
$url = 'http://php.net/manual/es/info.configuration.php#ini.max-execution-time';
|
||||
|
|
|
@ -20,7 +20,7 @@
|
|||
/**
|
||||
* Pandora build version and version
|
||||
*/
|
||||
$build_version = 'PC200622';
|
||||
$build_version = 'PC200625';
|
||||
$pandora_version = 'v7.0NG.746';
|
||||
|
||||
// Do not overwrite default timezone set if defined.
|
||||
|
|
|
@ -285,7 +285,7 @@ function clippy_context_help($help=null)
|
|||
|
||||
$return = '';
|
||||
|
||||
include_once 'include/help/clippy/'.$help.'.php';
|
||||
include_once $config['homedir'].'/include/help/clippy/'.$help.'.php';
|
||||
|
||||
ob_start();
|
||||
$function = 'clippy_'.$help;
|
||||
|
|
|
@ -217,8 +217,8 @@ function io_safe_output_array(&$item, $key=false, $utf8=true)
|
|||
* plain ascii file, to render to console, or to put in any kind of data field
|
||||
* who doesn't make the HTML render by itself.
|
||||
*
|
||||
* @param mixed String or array of strings to be cleaned.
|
||||
* @param boolean $utf8 Flag, set the output encoding in utf8, by default true.
|
||||
* @param string|array $value String or array of strings to be cleaned.
|
||||
* @param boolean $utf8 Flag, set the output encoding in utf8, by default true.
|
||||
*
|
||||
* @return unknown_type
|
||||
*/
|
||||
|
|
|
@ -455,3 +455,61 @@ function print_snmp_tags_active_filters($filter_resume=[])
|
|||
ui_print_tags_view($title, $tags_set);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Retunr module type for snmp data type
|
||||
*
|
||||
* @param [type] $snmp_data_type
|
||||
* @return void
|
||||
*/
|
||||
function snmp_module_get_type(string $snmp_data_type)
|
||||
{
|
||||
if (preg_match('/INTEGER/i', $snmp_data_type)) {
|
||||
$type = 'remote_snmp';
|
||||
} else if (preg_match('/Integer32/i', $snmp_data_type)) {
|
||||
$type = 'remote_snmp';
|
||||
} else if (preg_match('/octect string/i', $snmp_data_type)) {
|
||||
$type = 'remote_snmp';
|
||||
} else if (preg_match('/bits/i', $snmp_data_type)) {
|
||||
$type = 'remote_snmp';
|
||||
} else if (preg_match('/object identifier/i', $snmp_data_type)) {
|
||||
$type = 'remote_snmp_string';
|
||||
} else if (preg_match('/IpAddress/i', $snmp_data_type)) {
|
||||
$type = 'remote_snmp_string';
|
||||
} else if (preg_match('/Counter/i', $snmp_data_type)) {
|
||||
$type = 'remote_snmp_inc';
|
||||
} else if (preg_match('/Counter32/i', $snmp_data_type)) {
|
||||
$type = 'remote_snmp_inc';
|
||||
} else if (preg_match('/Gauge/i', $snmp_data_type)) {
|
||||
$type = 'remote_snmp';
|
||||
} else if (preg_match('/Gauge32/i', $snmp_data_type)) {
|
||||
$type = 'remote_snmp';
|
||||
} else if (preg_match('/Gauge64/i', $snmp_data_type)) {
|
||||
$type = 'remote_snmp';
|
||||
} else if (preg_match('/Unsigned32/i', $snmp_data_type)) {
|
||||
$type = 'remote_snmp_inc';
|
||||
} else if (preg_match('/TimeTicks/i', $snmp_data_type)) {
|
||||
$type = 'remote_snmp';
|
||||
} else if (preg_match('/Opaque/i', $snmp_data_type)) {
|
||||
$type = 'remote_snmp_string';
|
||||
} else if (preg_match('/Counter64/i', $snmp_data_type)) {
|
||||
$type = 'remote_snmp_inc';
|
||||
} else if (preg_match('/UInteger32/i', $snmp_data_type)) {
|
||||
$type = 'remote_snmp';
|
||||
} else if (preg_match('/BIT STRING/i', $snmp_data_type)) {
|
||||
$type = 'remote_snmp_string';
|
||||
} else if (preg_match('/STRING/i', $snmp_data_type)) {
|
||||
$type = 'remote_snmp_string';
|
||||
} else {
|
||||
$type = 'remote_snmp_string';
|
||||
}
|
||||
|
||||
if (!$type) {
|
||||
$type = 'remote_snmp';
|
||||
}
|
||||
|
||||
$type_id = modules_get_type_id($type);
|
||||
|
||||
return $type_id;
|
||||
}
|
||||
|
|
|
@ -945,6 +945,12 @@ function snmp_browser_create_modules_snmp(string $module_target, array $snmp_val
|
|||
$description = io_safe_input(preg_replace('/\s+/', ' ', $oid['description']));
|
||||
}
|
||||
|
||||
if (!empty($oid['type'])) {
|
||||
$module_type = snmp_module_get_type($oid['type']);
|
||||
} else {
|
||||
$module_type = 17;
|
||||
}
|
||||
|
||||
if ($module_target == 'network_component') {
|
||||
$name_check = db_get_value(
|
||||
'name',
|
||||
|
@ -956,7 +962,7 @@ function snmp_browser_create_modules_snmp(string $module_target, array $snmp_val
|
|||
if (!$name_check) {
|
||||
$id = network_components_create_network_component(
|
||||
$oid['oid'],
|
||||
17,
|
||||
$module_type,
|
||||
1,
|
||||
[
|
||||
'description' => $description,
|
||||
|
@ -1009,12 +1015,13 @@ function snmp_browser_create_modules_snmp(string $module_target, array $snmp_val
|
|||
'min_ff_event_critical' => 0,
|
||||
'ff_type' => 0,
|
||||
'each_ff' => 0,
|
||||
'history_data' => 1,
|
||||
]
|
||||
);
|
||||
}
|
||||
} else if ($module_target == 'agent') {
|
||||
$values = [
|
||||
'id_tipo_modulo' => 17,
|
||||
'id_tipo_modulo' => $module_type,
|
||||
'descripcion' => $description,
|
||||
'module_interval' => 300,
|
||||
'max' => 0,
|
||||
|
@ -1065,6 +1072,7 @@ function snmp_browser_create_modules_snmp(string $module_target, array $snmp_val
|
|||
'ff_type' => 0,
|
||||
'each_ff' => 0,
|
||||
'ip_target' => $target_ip,
|
||||
'history_data' => 1,
|
||||
];
|
||||
foreach ($id_target as $agent) {
|
||||
$ids[] = modules_create_agent_module($agent, $oid['oid'], $values);
|
||||
|
@ -1073,7 +1081,7 @@ function snmp_browser_create_modules_snmp(string $module_target, array $snmp_val
|
|||
// Policies only in enterprise version.
|
||||
if (enterprise_installed()) {
|
||||
$values = [
|
||||
'id_tipo_modulo' => 17,
|
||||
'id_tipo_modulo' => $module_type,
|
||||
'description' => $description,
|
||||
'module_interval' => 300,
|
||||
'max' => 0,
|
||||
|
@ -1123,6 +1131,7 @@ function snmp_browser_create_modules_snmp(string $module_target, array $snmp_val
|
|||
'each_ff' => 0,
|
||||
'ip_target' => $target_ip,
|
||||
'configuration_data' => '',
|
||||
'history_data' => 1,
|
||||
];
|
||||
|
||||
enterprise_include_once('include/functions_policies.php');
|
||||
|
|
|
@ -3220,13 +3220,9 @@ function visual_map_get_image_status_element($layoutData, $status=false)
|
|||
|
||||
switch ($status) {
|
||||
case 1:
|
||||
// Critical (BAD).
|
||||
$img .= '_bad.png';
|
||||
break;
|
||||
|
||||
case 4:
|
||||
// Critical (ALERT).
|
||||
$img = '4'.$img.'_bad.png';
|
||||
// Critical or critical alert (BAD).
|
||||
$img .= '_bad.png';
|
||||
break;
|
||||
|
||||
case 0:
|
||||
|
@ -3235,13 +3231,9 @@ function visual_map_get_image_status_element($layoutData, $status=false)
|
|||
break;
|
||||
|
||||
case 2:
|
||||
// Warning.
|
||||
$img .= '_warning.png';
|
||||
break;
|
||||
|
||||
case 10:
|
||||
// Warning (ALERT).
|
||||
$img = '4'.$img.'_warning.png';
|
||||
// Warning or warning alert.
|
||||
$img .= '_warning.png';
|
||||
break;
|
||||
|
||||
case 3:
|
||||
|
@ -4075,6 +4067,7 @@ function visual_map_get_layout_status($layout_id, $status_data=[], $depth=0)
|
|||
case 'default':
|
||||
$num_items_critical_alert = $num_elements_by_status[VISUAL_MAP_STATUS_CRITICAL_ALERT];
|
||||
$num_items_critical = $num_elements_by_status[VISUAL_MAP_STATUS_CRITICAL_BAD];
|
||||
$num_items_warning_alert = $num_elements_by_status[VISUAL_MAP_STATUS_WARNING_ALERT];
|
||||
$num_items_warning = $num_elements_by_status[VISUAL_MAP_STATUS_WARNING];
|
||||
$num_items_unknown = $num_elements_by_status[VISUAL_MAP_STATUS_UNKNOWN];
|
||||
|
||||
|
@ -4082,6 +4075,8 @@ function visual_map_get_layout_status($layout_id, $status_data=[], $depth=0)
|
|||
return VISUAL_MAP_STATUS_CRITICAL_ALERT;
|
||||
} else if ($num_items_critical > 0) {
|
||||
return VISUAL_MAP_STATUS_CRITICAL_BAD;
|
||||
} else if ($num_items_warning_alert > 0) {
|
||||
return VISUAL_MAP_STATUS_WARNING_ALERT;
|
||||
} else if ($num_items_warning > 0) {
|
||||
return VISUAL_MAP_STATUS_WARNING;
|
||||
} else if ($num_items_unknown > 0) {
|
||||
|
@ -4095,17 +4090,18 @@ function visual_map_get_layout_status($layout_id, $status_data=[], $depth=0)
|
|||
$num_items = count($valid_layout_items);
|
||||
$num_items_critical_alert = $num_elements_by_status[VISUAL_MAP_STATUS_CRITICAL_ALERT];
|
||||
$num_items_critical = $num_elements_by_status[VISUAL_MAP_STATUS_CRITICAL_BAD];
|
||||
$num_items_warning_alert = $num_elements_by_status[VISUAL_MAP_STATUS_WARNING_ALERT];
|
||||
$num_items_warning = $num_elements_by_status[VISUAL_MAP_STATUS_WARNING];
|
||||
$num_items_unknown = $num_elements_by_status[VISUAL_MAP_STATUS_UNKNOWN];
|
||||
|
||||
if ($num_items_critical > 0
|
||||
if (($num_items_critical > 0 || $num_items_critical_alert > 0)
|
||||
&& ((($num_items_critical_alert + $num_items_critical) * 100) / $num_items) >= $weight
|
||||
) {
|
||||
return ($num_items_critical_alert > 0) ? VISUAL_MAP_STATUS_CRITICAL_ALERT : VISUAL_MAP_STATUS_CRITICAL_BAD;
|
||||
} else if ($num_items_warning > 0
|
||||
&& (($num_items_warning * 100) / $num_items) >= $weight
|
||||
} else if (($num_items_warning > 0 || $num_items_warning_alert > 0)
|
||||
&& (($num_items_warning_alert + $num_items_warning * 100) / $num_items) >= $weight
|
||||
) {
|
||||
return VISUAL_MAP_STATUS_WARNING;
|
||||
return ($num_items_warning_alert > 0) ? VISUAL_MAP_STATUS_WARNING_ALERT : VISUAL_MAP_STATUS_WARNING;
|
||||
} else if ($num_items_unknown > 0
|
||||
&& (($num_items_unknown * 100) / $num_items) >= $weight
|
||||
) {
|
||||
|
@ -4119,9 +4115,12 @@ function visual_map_get_layout_status($layout_id, $status_data=[], $depth=0)
|
|||
$num_items_critical = ($num_elements_by_status[VISUAL_MAP_STATUS_CRITICAL_BAD] + $num_elements_by_status[VISUAL_MAP_STATUS_CRITICAL_ALERT]);
|
||||
$critical_percentage = (($num_items_critical * 100) / count($valid_layout_items));
|
||||
|
||||
if ($critical_percentage >= $status_data['linked_layout_status_as_service_critical']) {
|
||||
$num_items_warning = ($num_elements_by_status[VISUAL_MAP_STATUS_WARNING] + $num_elements_by_status[VISUAL_MAP_STATUS_WARNING_ALERT]);
|
||||
$warning_percentage = (($num_items_warning * 100) / count($valid_layout_items));
|
||||
|
||||
if ($critical_percentage >= $status_data['linked_layout_status_as_service_critical'] && $critical_percentage !== 0) {
|
||||
return VISUAL_MAP_STATUS_CRITICAL_BAD;
|
||||
} else if ($critical_percentage >= $status_data['linked_layout_status_as_service_warning']) {
|
||||
} else if ($critical_percentage >= $status_data['linked_layout_status_as_service_warning'] && $warning_percentage !== 0) {
|
||||
return VISUAL_MAP_STATUS_WARNING;
|
||||
} else {
|
||||
return VISUAL_MAP_STATUS_NORMAL;
|
||||
|
|
|
@ -625,6 +625,20 @@ function snmp_browser_create_modules(module_target, return_post = true) {
|
|||
);
|
||||
$("input[name=create_modules_" + module_target + "]").addClass("sub spinn");
|
||||
|
||||
$("#dialog_error").on("dialogclose", function(event) {
|
||||
$("input[name=create_modules_" + module_target + "]").removeClass(
|
||||
"sub spinn"
|
||||
);
|
||||
$("input[name=create_modules_" + module_target + "]").addClass("sub add");
|
||||
});
|
||||
|
||||
$("#dialog_success").on("dialogclose", function(event) {
|
||||
$("input[name=create_modules_" + module_target + "]").removeClass(
|
||||
"sub spinn"
|
||||
);
|
||||
$("input[name=create_modules_" + module_target + "]").addClass("sub add");
|
||||
});
|
||||
|
||||
$.ajax({
|
||||
method: "post",
|
||||
url: "ajax.php",
|
||||
|
|
|
@ -59,7 +59,9 @@ class Agent extends Entity
|
|||
*/
|
||||
public function __construct(?int $id_agent=null, ?bool $load_modules=false)
|
||||
{
|
||||
if (is_numeric($id_agent) === true) {
|
||||
if (is_numeric($id_agent) === true
|
||||
&& $id_agent > 0
|
||||
) {
|
||||
parent::__construct('tagente', ['id_agente' => $id_agent]);
|
||||
if ($load_modules === true) {
|
||||
$rows = \db_get_all_rows_filter(
|
||||
|
|
|
@ -129,7 +129,7 @@
|
|||
<div style='height: 10px'>
|
||||
<?php
|
||||
$version = '7.0NG.746';
|
||||
$build = '200618';
|
||||
$build = '200625';
|
||||
$banner = "v$version Build $build";
|
||||
|
||||
error_reporting(0);
|
||||
|
|
|
@ -349,16 +349,6 @@ switch ($action) {
|
|||
$agent = new Agent();
|
||||
$agent->show();
|
||||
break;
|
||||
|
||||
case 'visualmaps':
|
||||
$visualmaps = new Visualmaps();
|
||||
$visualmaps->show();
|
||||
break;
|
||||
|
||||
case 'visualmap':
|
||||
$visualmap = new Visualmap();
|
||||
$visualmap->show();
|
||||
break;
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
|
|
@ -80,14 +80,8 @@ class Home
|
|||
'menu_item' => true,
|
||||
'icon' => 'modules',
|
||||
];
|
||||
$items['visualmaps'] = [
|
||||
'name' => __('Visual consoles'),
|
||||
'filename' => 'visualmaps.php',
|
||||
'menu_item' => true,
|
||||
'icon' => 'visual_console',
|
||||
];
|
||||
|
||||
// Not in home
|
||||
// Not in home.
|
||||
$items['agent'] = [
|
||||
'name' => __('Agent'),
|
||||
'filename' => 'agent.php',
|
||||
|
@ -100,12 +94,6 @@ class Home
|
|||
'menu_item' => false,
|
||||
'icon' => '',
|
||||
];
|
||||
$items['visualmap'] = [
|
||||
'name' => __('Visualmap'),
|
||||
'filename' => 'visualmap.php',
|
||||
'menu_item' => false,
|
||||
'icon' => '',
|
||||
];
|
||||
}
|
||||
|
||||
$this->pagesItems = $items;
|
||||
|
|
|
@ -241,20 +241,41 @@ function snmp_show_result_message(data) {
|
|||
if (dato.length !== 0) {
|
||||
$("#error_text").text("");
|
||||
|
||||
dato.forEach(function (valor, indice, array) {
|
||||
$("#error_text").append("<br/>" + valor);
|
||||
});
|
||||
$("#dialog_error").dialog({
|
||||
resizable: true,
|
||||
draggable: true,
|
||||
modal: true,
|
||||
height: 300,
|
||||
width: 500,
|
||||
overlay: {
|
||||
opacity: 0.5,
|
||||
background: "black"
|
||||
}
|
||||
});
|
||||
if (dato[0] === -1) {
|
||||
$("#dialog_no_agents_selected").dialog({
|
||||
resizable: true,
|
||||
draggable: true,
|
||||
modal: true,
|
||||
height: 300,
|
||||
width: 500,
|
||||
close: function(e, ui) {
|
||||
$("input[name=create_modules_network_component]").removeClass("sub spinn");
|
||||
$("input[name=create_modules_network_component]").addClass("sub add");
|
||||
},
|
||||
overlay: {
|
||||
opacity: 0.5,
|
||||
background: "black"
|
||||
}
|
||||
});
|
||||
} else {
|
||||
$("#error_text").text("");
|
||||
|
||||
dato.forEach(function (valor, indice, array) {
|
||||
$("#error_text").append("<br/>" + valor);
|
||||
});
|
||||
$("#dialog_error").dialog({
|
||||
resizable: true,
|
||||
draggable: true,
|
||||
modal: true,
|
||||
height: 300,
|
||||
width: 500,
|
||||
overlay: {
|
||||
opacity: 0.5,
|
||||
background: "black"
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
} else {
|
||||
$("#dialog_success").dialog({
|
||||
resizable: true,
|
||||
|
|
|
@ -196,7 +196,6 @@ $ignored_params['refr'] = '';
|
|||
|
||||
$('body').css('background-color','<?php echo $layout['background_color']; ?>');
|
||||
$('body').css('margin','0');
|
||||
$('body').css('overflow','hidden');
|
||||
$(".module_graph .menu_graph").css('display','none');
|
||||
|
||||
$(".parent_graph").each(function(){
|
||||
|
|
|
@ -257,7 +257,6 @@ if ($config['pure']) {
|
|||
body.pure {
|
||||
min-height: 100px;
|
||||
margin: 0px;
|
||||
overflow: hidden;
|
||||
height: 100%;
|
||||
<?php
|
||||
echo 'background-color: '.$layout['background_color'].';';
|
||||
|
|
|
@ -373,7 +373,6 @@ if ($pure === true) {
|
|||
body.pure {
|
||||
min-height: 100px;
|
||||
margin: 0px;
|
||||
overflow: hidden;
|
||||
height: 100%;
|
||||
background-color: <?php echo $visualConsoleData['backgroundColor']; ?>;
|
||||
}
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
#
|
||||
%define name pandorafms_console
|
||||
%define version 7.0NG.746
|
||||
%define release 200622
|
||||
%define release 200625
|
||||
|
||||
# User and Group under which Apache is running
|
||||
%define httpd_name httpd
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
#
|
||||
%define name pandorafms_console
|
||||
%define version 7.0NG.746
|
||||
%define release 200622
|
||||
%define release 200625
|
||||
|
||||
# User and Group under which Apache is running
|
||||
%define httpd_name httpd
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
#
|
||||
%define name pandorafms_console
|
||||
%define version 7.0NG.746
|
||||
%define release 200622
|
||||
%define release 200625
|
||||
%define httpd_name httpd
|
||||
# User and Group under which Apache is running
|
||||
%define httpd_name apache2
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
package: pandorafms-server
|
||||
Version: 7.0NG.746-200622
|
||||
Version: 7.0NG.746-200625
|
||||
Architecture: all
|
||||
Priority: optional
|
||||
Section: admin
|
||||
|
|
|
@ -14,7 +14,7 @@
|
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
|
||||
pandora_version="7.0NG.746-200622"
|
||||
pandora_version="7.0NG.746-200625"
|
||||
|
||||
package_cpan=0
|
||||
package_pandora=1
|
||||
|
|
|
@ -45,7 +45,7 @@ our @EXPORT = qw(
|
|||
|
||||
# version: Defines actual version of Pandora Server for this module only
|
||||
my $pandora_version = "7.0NG.746";
|
||||
my $pandora_build = "200622";
|
||||
my $pandora_build = "200625";
|
||||
our $VERSION = $pandora_version." ".$pandora_build;
|
||||
|
||||
# Setup hash
|
||||
|
|
|
@ -33,7 +33,7 @@ our @ISA = qw(Exporter);
|
|||
|
||||
# version: Defines actual version of Pandora Server for this module only
|
||||
my $pandora_version = "7.0NG.746";
|
||||
my $pandora_build = "200622";
|
||||
my $pandora_build = "200625";
|
||||
our $VERSION = $pandora_version." ".$pandora_build;
|
||||
|
||||
our %EXPORT_TAGS = ( 'all' => [ qw() ] );
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
#
|
||||
%define name pandorafms_server
|
||||
%define version 7.0NG.746
|
||||
%define release 200622
|
||||
%define release 200625
|
||||
|
||||
Summary: Pandora FMS Server
|
||||
Name: %{name}
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
#
|
||||
%define name pandorafms_server
|
||||
%define version 7.0NG.746
|
||||
%define release 200622
|
||||
%define release 200625
|
||||
|
||||
Summary: Pandora FMS Server
|
||||
Name: %{name}
|
||||
|
|
|
@ -9,7 +9,7 @@
|
|||
# **********************************************************************
|
||||
|
||||
PI_VERSION="7.0NG.746"
|
||||
PI_BUILD="200622"
|
||||
PI_BUILD="200625"
|
||||
|
||||
MODE=$1
|
||||
if [ $# -gt 1 ]; then
|
||||
|
|
|
@ -35,7 +35,7 @@ use PandoraFMS::Config;
|
|||
use PandoraFMS::DB;
|
||||
|
||||
# version: define current version
|
||||
my $version = "7.0NG.746 PS200622";
|
||||
my $version = "7.0NG.746 PS200625";
|
||||
|
||||
# Pandora server configuration
|
||||
my %conf;
|
||||
|
@ -478,7 +478,7 @@ sub pandora_compactdb ($$) {
|
|||
$limit_utime = $conf->{'_last_compact'};
|
||||
}
|
||||
|
||||
if ($start_utime <= $limit_utime) {
|
||||
if ($start_utime <= $limit_utime || ( defined ($conf->{'_last_compact'}) && (($conf->{'_last_compact'} + 24 * 60 * 60) > $start_utime))) {
|
||||
log_message ('COMPACT', "Data already compacted.");
|
||||
return;
|
||||
}
|
||||
|
@ -512,7 +512,7 @@ sub pandora_compactdb ($$) {
|
|||
next unless defined ($module_type);
|
||||
|
||||
# Mark proc modules.
|
||||
if ($module_type == 2 || $module_type == 6 || $module_type == 9 || $module_type == 18 || $module_type == 21 || $module_type == 31) {
|
||||
if ($module_type == 2 || $module_type == 6 || $module_type == 9 || $module_type == 18 || $module_type == 21 || $module_type == 31 || $module_type == 35 || $module_type == 100) {
|
||||
$module_proc_hash{$id_module} = 1;
|
||||
}
|
||||
else {
|
||||
|
@ -537,7 +537,9 @@ sub pandora_compactdb ($$) {
|
|||
}
|
||||
|
||||
# Delete interval from the database
|
||||
db_do ($dbh, 'DELETE FROM tagente_datos WHERE utimestamp < ? AND utimestamp >= ?', $start_utime, $stop_utime);
|
||||
db_do ($dbh, 'DELETE ad FROM tagente_datos ad
|
||||
INNER JOIN tagente_modulo am ON ad.id_agente_modulo = am.id_agente_modulo AND am.id_tipo_modulo NOT IN (2,6,9,18,21,31,35,100)
|
||||
WHERE ad.utimestamp < ? AND ad.utimestamp >= ?', $start_utime, $stop_utime);
|
||||
|
||||
# Insert interval average value
|
||||
foreach my $key (keys(%value_hash)) {
|
||||
|
|
|
@ -36,7 +36,7 @@ use Encode::Locale;
|
|||
Encode::Locale::decode_argv;
|
||||
|
||||
# version: define current version
|
||||
my $version = "7.0NG.746 PS200622";
|
||||
my $version = "7.0NG.746 PS200625";
|
||||
|
||||
# save program name for logging
|
||||
my $progname = basename($0);
|
||||
|
|
Loading…
Reference in New Issue