diff --git a/extras/deploy-scripts/pandora_deploy_community_ubuntu_2204.sh b/extras/deploy-scripts/pandora_deploy_community_ubuntu_2204.sh index c5c8edbb34..1c1ed4b5f8 100644 --- a/extras/deploy-scripts/pandora_deploy_community_ubuntu_2204.sh +++ b/extras/deploy-scripts/pandora_deploy_community_ubuntu_2204.sh @@ -850,6 +850,11 @@ systemctl enable postfix --now &>> "$LOGFILE" systemctl disable --now snmptrapd &>> "$LOGFILE" systemctl disable --now snmptrapd.socket &>> "$LOGFILE" +# Adding legacy to openssl +sed -i '/default = default_sect/a legacy = legacy_sect' /etc/ssl/openssl.cnf +sed -i 's/# activate = 1/activate = 1/' /etc/ssl/openssl.cnf +sed -i '/activate = 1/a [legacy_sect]\nactivate = 1' /etc/ssl/openssl.cnf + #SSH banner [ "$(curl -s ifconfig.me)" ] && ipplublic=$(curl -s ifconfig.me) diff --git a/pandora_agents/pc/Win32/pandora_agent.conf b/pandora_agents/pc/Win32/pandora_agent.conf index 216e3149e3..f1cc960a5c 100644 --- a/pandora_agents/pc/Win32/pandora_agent.conf +++ b/pandora_agents/pc/Win32/pandora_agent.conf @@ -122,6 +122,7 @@ module_min_critical 91 module_max_critical 0 module_end + # Number processes module_begin module_name Number processes diff --git a/pandora_agents/unix/DEBIAN/control b/pandora_agents/unix/DEBIAN/control index 0872a0b459..366e1ec0cb 100644 --- a/pandora_agents/unix/DEBIAN/control +++ b/pandora_agents/unix/DEBIAN/control @@ -1,5 +1,5 @@ package: pandorafms-agent-unix -Version: 7.0NG.775-240221 +Version: 7.0NG.775-240227 Architecture: all Priority: optional Section: admin diff --git a/pandora_agents/unix/DEBIAN/make_deb_package.sh b/pandora_agents/unix/DEBIAN/make_deb_package.sh index 7be602ffea..a0e23e10ee 100644 --- a/pandora_agents/unix/DEBIAN/make_deb_package.sh +++ b/pandora_agents/unix/DEBIAN/make_deb_package.sh @@ -14,7 +14,7 @@ # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. -pandora_version="7.0NG.775-240221" +pandora_version="7.0NG.775-240227" echo "Test if you has the tools for to make the packages." whereis dpkg-deb | cut -d":" -f2 | grep dpkg-deb > /dev/null diff --git a/pandora_agents/unix/pandora_agent b/pandora_agents/unix/pandora_agent index e1662fe5ee..bfea44a925 100755 --- a/pandora_agents/unix/pandora_agent +++ b/pandora_agents/unix/pandora_agent @@ -1039,7 +1039,7 @@ my $Sem = undef; my $ThreadSem = undef; use constant AGENT_VERSION => '7.0NG.775'; -use constant AGENT_BUILD => '240221'; +use constant AGENT_BUILD => '240227'; # Agent log default file size maximum and instances use constant DEFAULT_MAX_LOG_SIZE => 600000; diff --git a/pandora_agents/unix/pandora_agent.redhat.spec b/pandora_agents/unix/pandora_agent.redhat.spec index 89d47ca273..cbd83fc2f1 100644 --- a/pandora_agents/unix/pandora_agent.redhat.spec +++ b/pandora_agents/unix/pandora_agent.redhat.spec @@ -4,7 +4,7 @@ %global __os_install_post %{nil} %define name pandorafms_agent_linux %define version 7.0NG.775 -%define release 240221 +%define release 240227 Summary: Pandora FMS Linux agent, PERL version Name: %{name} diff --git a/pandora_agents/unix/pandora_agent.redhat_bin.el8.spec b/pandora_agents/unix/pandora_agent.redhat_bin.el8.spec index 6528f85557..04b3a359b6 100644 --- a/pandora_agents/unix/pandora_agent.redhat_bin.el8.spec +++ b/pandora_agents/unix/pandora_agent.redhat_bin.el8.spec @@ -5,7 +5,7 @@ %define name pandorafms_agent_linux_bin %define source_name pandorafms_agent_linux %define version 7.0NG.775 -%define release 240221 +%define release 240227 %define debug_package %{nil} Summary: Pandora FMS Linux agent, binary version diff --git a/pandora_agents/unix/pandora_agent.redhat_bin.el9.spec b/pandora_agents/unix/pandora_agent.redhat_bin.el9.spec index db4e7db193..35f3b996c3 100644 --- a/pandora_agents/unix/pandora_agent.redhat_bin.el9.spec +++ b/pandora_agents/unix/pandora_agent.redhat_bin.el9.spec @@ -5,7 +5,7 @@ %define name pandorafms_agent_linux_bin %define source_name pandorafms_agent_linux %define version 7.0NG.775 -%define release 240221 +%define release 240227 %define debug_package %{nil} Summary: Pandora FMS Linux agent, binary version diff --git a/pandora_agents/unix/pandora_agent.redhat_bin.spec b/pandora_agents/unix/pandora_agent.redhat_bin.spec index 44ed74c612..ed5d2bae39 100644 --- a/pandora_agents/unix/pandora_agent.redhat_bin.spec +++ b/pandora_agents/unix/pandora_agent.redhat_bin.spec @@ -5,7 +5,7 @@ %define name pandorafms_agent_linux_bin %define source_name pandorafms_agent_linux %define version 7.0NG.775 -%define release 240221 +%define release 240227 Summary: Pandora FMS Linux agent, binary version Name: %{name} diff --git a/pandora_agents/unix/pandora_agent.spec b/pandora_agents/unix/pandora_agent.spec index 377b1a26bf..7773cebed3 100644 --- a/pandora_agents/unix/pandora_agent.spec +++ b/pandora_agents/unix/pandora_agent.spec @@ -4,7 +4,7 @@ %global __os_install_post %{nil} %define name pandorafms_agent_linux %define version 7.0NG.775 -%define release 240221 +%define release 240227 Summary: Pandora FMS Linux agent, PERL version Name: %{name} diff --git a/pandora_agents/unix/pandora_agent_installer b/pandora_agents/unix/pandora_agent_installer index 386f26d550..f0feb34207 100755 --- a/pandora_agents/unix/pandora_agent_installer +++ b/pandora_agents/unix/pandora_agent_installer @@ -10,7 +10,7 @@ # ********************************************************************** PI_VERSION="7.0NG.775" -PI_BUILD="240221" +PI_BUILD="240227" OS_NAME=`uname -s` FORCE=0 diff --git a/pandora_agents/win32/bin/pandora_agent.conf b/pandora_agents/win32/bin/pandora_agent.conf index 2ff61033c6..d832ba792a 100644 --- a/pandora_agents/win32/bin/pandora_agent.conf +++ b/pandora_agents/win32/bin/pandora_agent.conf @@ -157,8 +157,8 @@ ehorus_conf "C:\Program Files\ehorus_agent\ehorus_agent.conf" module_begin module_name CPU Load module_type generic_data -module_wmiquery SELECT LoadPercentage FROM Win32_Processor -module_wmicolumn LoadPercentage +module_wmiquery SELECT PercentProcessorTime FROM Win32_PerfFormattedData_PerfOS_Processor where name like '_Total' +module_wmicolumn PercentProcessorTime module_max 100 module_min 0 module_description User CPU Usage (%) @@ -526,7 +526,7 @@ module_plugin "%PROGRAMFILES%\Pandora_Agent\util\autodiscover.exe" --default # Hardening plugin for security compliance analysis. #module_begin -#module_plugin "%PROGRAMFILES%\Pandora_Agent\util\pandora_hardening.exe -t 150" +#module_plugin "%PROGRAMFILES%\Pandora_Agent\util\pandora_hardening.exe" -t 150 #module_absoluteinterval 7d #module_end diff --git a/pandora_agents/win32/bin/util/pandora_hardening.exe b/pandora_agents/win32/bin/util/pandora_hardening.exe index 25776c36b6..f13a1f0a6a 100755 --- a/pandora_agents/win32/bin/util/pandora_hardening.exe +++ b/pandora_agents/win32/bin/util/pandora_hardening.exe @@ -1,3 +1,3 @@ version https://git-lfs.github.com/spec/v1 -oid sha256:db207ef67053764be7e9b42cd04ea5509cc2a023548aab1c037745ca277b68a3 -size 4858753 +oid sha256:520619d823dd5396cc90de59e745d9ab3872d25d85358c9abb4890987b5f5426 +size 4859595 diff --git a/pandora_agents/win32/installer/pandora.mpi b/pandora_agents/win32/installer/pandora.mpi index 05b006e87e..22dece60e2 100644 --- a/pandora_agents/win32/installer/pandora.mpi +++ b/pandora_agents/win32/installer/pandora.mpi @@ -186,7 +186,7 @@ UpgradeApplicationID {} Version -{240221} +{240227} ViewReadme {Yes} diff --git a/pandora_agents/win32/pandora.cc b/pandora_agents/win32/pandora.cc index 323a6555f9..ed9c1be337 100644 --- a/pandora_agents/win32/pandora.cc +++ b/pandora_agents/win32/pandora.cc @@ -30,7 +30,7 @@ using namespace Pandora; using namespace Pandora_Strutils; #define PATH_SIZE _MAX_PATH+1 -#define PANDORA_VERSION ("7.0NG.775 Build 240221") +#define PANDORA_VERSION ("7.0NG.775 Build 240227") string pandora_path; string pandora_dir; diff --git a/pandora_agents/win32/versioninfo.rc b/pandora_agents/win32/versioninfo.rc index 3007022b4c..65ca2d63d6 100644 --- a/pandora_agents/win32/versioninfo.rc +++ b/pandora_agents/win32/versioninfo.rc @@ -11,7 +11,7 @@ BEGIN VALUE "LegalCopyright", "Pandora FMS" VALUE "OriginalFilename", "PandoraAgent.exe" VALUE "ProductName", "Pandora FMS Windows Agent" - VALUE "ProductVersion", "(7.0NG.775(Build 240221))" + VALUE "ProductVersion", "(7.0NG.775(Build 240227))" VALUE "FileVersion", "1.0.0.0" END END diff --git a/pandora_console/DEBIAN/control b/pandora_console/DEBIAN/control index d51dcca24b..a7a4d0ecb3 100644 --- a/pandora_console/DEBIAN/control +++ b/pandora_console/DEBIAN/control @@ -1,5 +1,5 @@ package: pandorafms-console -Version: 7.0NG.775-240221 +Version: 7.0NG.775-240227 Architecture: all Priority: optional Section: admin diff --git a/pandora_console/DEBIAN/make_deb_package.sh b/pandora_console/DEBIAN/make_deb_package.sh index 34e36f6c53..e163d0f901 100644 --- a/pandora_console/DEBIAN/make_deb_package.sh +++ b/pandora_console/DEBIAN/make_deb_package.sh @@ -14,7 +14,7 @@ # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. -pandora_version="7.0NG.775-240221" +pandora_version="7.0NG.775-240227" package_pear=0 package_pandora=1 diff --git a/pandora_console/extensions/agents_modules.php b/pandora_console/extensions/agents_modules.php index 90c9527e55..0b43ce0bba 100644 --- a/pandora_console/extensions/agents_modules.php +++ b/pandora_console/extensions/agents_modules.php @@ -496,6 +496,10 @@ function mainAgentsModules() $agents = []; } + if (isset($agents_id) === false) { + $agents_id = ''; + } + $filter_agents = html_print_label_input_block( __('Agents'), html_print_select( diff --git a/pandora_console/extensions/module_groups.php b/pandora_console/extensions/module_groups.php index 957d3a17a1..15c9e614ee 100644 --- a/pandora_console/extensions/module_groups.php +++ b/pandora_console/extensions/module_groups.php @@ -91,7 +91,7 @@ function mainModuleGroups() $module_group_search = get_parameter('module_group_search', ''); // Check the user's group permissions. - $user_groups = users_get_groups($config['user'], 'AR'); + $user_groups = users_get_groups($config['id_user'], 'AR'); $info = array_filter( $info, function ($v) use ($user_groups) { @@ -112,7 +112,7 @@ function mainModuleGroups() ); if (empty($info) === false) { - $groups_view = ($is_not_paginated) ? $info : array_slice( + $groups_view = (isset($is_not_paginated) === true) ? $info : array_slice( $info, $offset, $config['block_size'] @@ -374,6 +374,10 @@ function mainModuleGroups() '…' ); $j = 1; + if (isset($background_color) === false) { + $background_color = 'none'; + } + if (isset($array_data[$key])) { foreach ($value['gm'] as $k => $v) { if (isset($array_data[$key][$k])) { diff --git a/pandora_console/extensions/quick_shell.php b/pandora_console/extensions/quick_shell.php index a3f5872f84..d47d65ef56 100644 --- a/pandora_console/extensions/quick_shell.php +++ b/pandora_console/extensions/quick_shell.php @@ -273,6 +273,14 @@ function buildConnectionURL($method) { global $config; + if (isset($config['gotty_ssh_use_ssl']) === false) { + $config['gotty_ssh_use_ssl'] = ''; + } + + if (isset($config['gotty_telnet_use_ssl']) === false) { + $config['gotty_telnet_use_ssl'] = ''; + } + $address = (empty($config['gotty_addr']) === true) ? $_SERVER['SERVER_ADDR'] : $config['gotty_addr']; $use_ssl = ($method === 'ssh') ? $config['gotty_ssh_use_ssl'] : $config['gotty_telnet_use_ssl']; $protocol = ((bool) $use_ssl === true) ? 'https://' : 'http://'; @@ -353,6 +361,18 @@ function quickShellSettings() config_update_value('gotty_telnet_enabled', $gotty_telnet_enabled); } + if (isset($config['gotty_addr']) === false) { + $config['gotty_addr'] = ''; + } + + if (isset($config['gotty_ssh_use_ssl']) === false) { + $config['gotty_ssh_use_ssl'] = ''; + } + + if (isset($config['gotty_telnet_use_ssl']) === false) { + $config['gotty_telnet_use_ssl'] = ''; + } + if ($config['gotty_addr'] != $gotty_addr) { config_update_value('gotty_addr', $gotty_addr); } @@ -389,6 +409,25 @@ function quickShellSettings() $general_table->data = []; $general_table->style = []; $general_table->style[0] = 'width: 50%;'; + if (isset($config['gotty_addr']) === false) { + $config['gotty_addr'] = ''; + } + + if (isset($config['gotty_ssh_enabled']) === false) { + $config['gotty_ssh_enabled'] = ''; + } + + if (isset($config['gotty_ssh_use_ssl']) === false) { + $config['gotty_ssh_use_ssl'] = ''; + } + + if (isset($disable_agentaccess) === false) { + $disable_agentaccess = ''; + } + + if (isset($config['gotty_telnet_use_ssl']) === false) { + $config['gotty_telnet_use_ssl'] = ''; + } $general_table->data[0][] = html_print_label_input_block( __('Address'), diff --git a/pandora_console/extensions/users_connected.php b/pandora_console/extensions/users_connected.php index 4b76957344..712dcd014d 100644 --- a/pandora_console/extensions/users_connected.php +++ b/pandora_console/extensions/users_connected.php @@ -229,7 +229,7 @@ function users_extension_main_god($god=true) $data = []; $data[0] = ''.$row['id_user'].''; - $data[1] = $last_login_data['ip_origin']; + $data[1] = $last_login_data['ip_origen']; $data[2] = date($config['date_format'], $last_login_data['utimestamp']); $data[3] = date($config['date_format'], $row['last_connect']); array_push($table->data, $data); diff --git a/pandora_console/extras/mr/68.sql b/pandora_console/extras/mr/68.sql index 6c05751dc4..7bb89a432a 100644 --- a/pandora_console/extras/mr/68.sql +++ b/pandora_console/extras/mr/68.sql @@ -1,5 +1,14 @@ START TRANSACTION; +-- Watch out! The following field migration must be done before altering the corresponding table. +UPDATE `tevent_filter` +SET `search` = `regex`, + `regex` = '1' +WHERE `regex` IS NOT NULL AND `regex` != ''; + +-- Watch out! The following alter command must be done after the previous update of this table. +ALTER TABLE `tevent_filter` MODIFY COLUMN `regex` TINYINT unsigned NOT NULL DEFAULT 0; + CREATE TABLE IF NOT EXISTS `tmerge_error` ( `id` int(10) NOT NULL auto_increment, `id_node` int(10) default 0, @@ -7771,4 +7780,14 @@ UPDATE `trecon_task` ; -- END MIGRATION SAP DESET -- + +ALTER TABLE `tdatabase` ADD COLUMN `disabled` TINYINT NOT NULL DEFAULT 0; + +CREATE TABLE IF NOT EXISTS `tmetaconsole_ha_databases` ( + `node_id` int NOT NULL, + `host` varchar(255) DEFAULT '', + `master` tinyint unsigned DEFAULT '0', + PRIMARY KEY (`node_id`, `host`) +) ENGINE=InnoDB DEFAULT CHARSET=UTF8MB4; + COMMIT; \ No newline at end of file diff --git a/pandora_console/general/header.php b/pandora_console/general/header.php index e2573bd859..5eee6a6669 100644 --- a/pandora_console/general/header.php +++ b/pandora_console/general/header.php @@ -161,6 +161,10 @@ echo sprintf('
', $menuTypeClass); 'code' => false, ]; + if (isset($_GET['sec']) === false) { + $_GET['sec'] = ''; + } + if (!isset($_GET['sec2'])) { $_GET['sec2'] = ''; } diff --git a/pandora_console/general/noaccess.php b/pandora_console/general/noaccess.php index b2fe4515a2..9299489864 100644 --- a/pandora_console/general/noaccess.php +++ b/pandora_console/general/noaccess.php @@ -152,9 +152,11 @@ echo __('Access to this page is restricted to authorized users only, please contact system administrator if you need assistance.'); echo '

'; echo __('Please know that all attempts to access this page are recorded in security logs of %s System Database', get_product_name()); - if ($config['logged'] == false) { - if (session_status() === PHP_SESSION_ACTIVE) { - session_destroy(); + if (isset($config['logged']) === true) { + if ($config['logged'] == false) { + if (session_status() === PHP_SESSION_ACTIVE) { + session_destroy(); + } } } ?> diff --git a/pandora_console/godmode/agentes/agent_manager.php b/pandora_console/godmode/agentes/agent_manager.php index 18722508e9..c1c9159134 100644 --- a/pandora_console/godmode/agentes/agent_manager.php +++ b/pandora_console/godmode/agentes/agent_manager.php @@ -246,6 +246,7 @@ if ($new_agent === true) { // QR Code table. +$CodeQRContent = ''; if ($new_agent === false) { $CodeQRContent .= html_print_div(['id' => 'qr_container_image'], true); $CodeQRContent .= html_print_anchor( @@ -354,7 +355,7 @@ $tableAgent->rowspan = []; // Agent name. if ($new_agent === false) { - $tableAgent->data['caption_name'][0] = __('Agent name'); + $tableAgent->data['caption_name'][0] = __('Agent name').ui_print_help_tip(__('The agent name is a unique identifier (which is automatically generated in software agents). If you set it manually, make sure it is not duplicated. Although it accepts spaces, we do not recommend you to use them in the agent name, you may use them in the agent alias. The agent name is not displayed in the interface, it is an internal name.'), true); $tableAgent->rowclass['name'] = 'w540px'; $tableAgent->cellstyle['name'][0] = 'width: 100%;'; $tableAgent->data['name'][0] = html_print_input_text( @@ -404,7 +405,7 @@ if ($new_agent === false) { } // Alias. -$tableAgent->data['caption_alias'][0] = __('Alias'); +$tableAgent->data['caption_alias'][0] = __('Alias').ui_print_help_tip(__('This will be the text label that will represent the agent on all types of screens and reports. It may be duplicated, contain spaces and non-ASCII characters.'), true); $tableAgent->rowclass['alias'] = 'w540px'; $tableAgent->data['alias'][0] = html_print_input_text('alias', $alias, '', 50, 100, true, false, true, '', 'w540px'); if ($new_agent === true) { @@ -487,7 +488,7 @@ if ($new_agent === false) { } // Select primary group. -$tableAgent->data['caption_primary_group'][0] = __('Primary group'); +$tableAgent->data['caption_primary_group'][0] = __('Primary group').ui_print_help_tip(__('Although an agent can belong to multiple groups, it can only have a parent group.'), true); if (isset($groups[$grupo]) === true || $new_agent === true) { $tableAgent->rowclass['primary_group'] = 'w540px'; // Cannot change primary group if user have not permission for that group. @@ -554,7 +555,7 @@ if (enterprise_installed()) { } if ($broker === false) { - $tableAgent->data['caption_interval'][0] = __('Interval'); + $tableAgent->data['caption_interval'][0] = __('Interval').ui_print_help_tip(__('Time that elapses when updating data in the agent. Remote modules have their own interval, but this time is used to find out if an agent stopped responding (unknown state). When twice the time interval defined in an agent goes by, it is considered to be in unknown state (or also if all its remote modules are in unknown state). An agent may be in unknown state if all of its local (software agent-based) modules have a last contact time longer than twice the agent interval, even if it has updated remote modules.'), true); // $tableAgent->rowstyle['interval'] = 'width: 260px'; $tableAgent->rowclass['interval'] = 'w540px'; $tableAgent->data['interval'][0] = html_print_extended_select_for_time( @@ -618,7 +619,7 @@ $tableAgent->data['os_version'][0] = html_print_input_text( 'w540px' ); -$tableAgent->data['caption_server'][0] = __('Server'); +$tableAgent->data['caption_server'][0] = __('Server').ui_print_help_tip(__('Server that will preferentially execute remote tasks.'), true); $tableAgent->rowclass['server'] = 'w540px'; $tableAgent->data['server'][0] = html_print_select( $servers, @@ -935,7 +936,7 @@ $switchButtons[] = html_print_radio_button_extended( ); $tableAdvancedAgent->data['module_definition'][] = html_print_label_input_block( - __('Module definition'), + __('Module definition').ui_print_help_tip(__('Three working modes can be selected for module definition. Learning mode: Default mode, if an XML arrives with new modules, they will be created automatically; it is a learning behavior. Normal mode: If an XML arrives with new modules, they will only be created if they are previously declared in the Console. Autodisable mode: It is the same as learning mode, but if all modules go into unknown, the agent will be disabled until information arrives again.'), true), html_print_div( [ 'class' => 'switch_radio_button', @@ -947,7 +948,7 @@ $tableAdvancedAgent->data['module_definition'][] = html_print_label_input_block( // CPS - Cascade Protection Services. $tableAdvancedAgent->data['cps_value'][] = html_print_label_input_block( - __('Cascade protection services'), + __('Cascade protection services').ui_print_help_tip(__('To avoid an avalanche of cascading alerts. You may choose any agent module (any) or a specific module. In the first case, when there is at least one module in critical, that event/alert will be launched, but no other of another module of the same agent. In the second case, when the specified module is in critical, the agent will not generate alerts/events.'), true), html_print_checkbox_switch('cps', $cps_val, ($cps >= 0), true) ); @@ -1036,7 +1037,7 @@ $tableAdvancedAgent->data['url_description'][] = html_print_label_input_block( // Agent status. $tableAdvancedAgent->data['agent_status'][] = html_print_label_input_block( - __('Disabled mode'), + __('Disabled mode').ui_print_help_tip(__('A deactivated agent does not generate activity (or issue events/alerts) or process data or actively generate monitoring. In many listings it does not even appear.'), true), html_print_checkbox_switch( 'disabled', 1, @@ -1047,7 +1048,7 @@ $tableAdvancedAgent->data['agent_status'][] = html_print_label_input_block( // Quiet mode. $tableAdvancedAgent->data['agent_quiet'][] = html_print_label_input_block( - __('Quiet'), + __('Quiet').ui_print_help_tip(__('A \'silent\' agent continues to process monitoring data, but does not generate events or alerts.'), true), html_print_checkbox_switch('quiet', 1, $quiet, true) ); @@ -1113,7 +1114,7 @@ $safeOperationElements[] = html_print_select( ); $tableAdvancedAgent->data['safe_operation'][] = html_print_label_input_block( - __('Safe operation mode'), + __('Safe operation mode').ui_print_help_tip(__('When the module set in this option goes into critical state, the other modules of the agent are automatically deactivated. This option can be very useful to avoid wasting resources, especially in remote checks. For example, if a Host alive module is chosen, SNMP checks will not be performed on the device when there is no connectivity with it.'), true), html_print_div( [ 'class' => 'flex-row-center', diff --git a/pandora_console/godmode/agentes/configurar_agente.php b/pandora_console/godmode/agentes/configurar_agente.php index c6b5f2b691..6a1084e605 100644 --- a/pandora_console/godmode/agentes/configurar_agente.php +++ b/pandora_console/godmode/agentes/configurar_agente.php @@ -816,6 +816,23 @@ if ($id_agente) { $helper = ($help_header === 'main_tab') ? 'main_tab' : ''; $pure = (int) get_parameter('pure'); + $menu_tabs = []; + // Agent details. + $menu_tab_url = ''.__('General setup').''; + array_push($menu_tabs, $menu_tab_url); + // Agent details. + $menu_tab_url = ''.__('Agent detail').''; + array_push($menu_tabs, $menu_tab_url); + // Manage agents. + $menu_tab_url = ''.__('Manage agents').''; + array_push($menu_tabs, $menu_tab_url); + // Events. + $menu_tab_url = ''.__('View events').''; + array_push($menu_tabs, $menu_tab_url); + // Events. + $menu_tab_url = ''.__('Custom reports').''; + array_push($menu_tabs, $menu_tab_url); + $dots = dot_tab($menu_tabs); if ($pure === 0) { ui_print_standard_header( __('Agent setup view').' ( '.strtolower(agents_get_alias($id_agente)).' )', @@ -837,7 +854,9 @@ if ($id_agente) { 'link' => '', 'label' => $tab_name, ], - ] + ], + [], + $dots ); } } else { @@ -857,7 +876,9 @@ if ($id_agente) { 'link' => 'index.php?sec=gagente&sec2=godmode/agentes/modificar_agente', 'label' => __('Manage agents'), ], - ] + ], + [], + $dots ); } @@ -2334,6 +2355,23 @@ if ($delete_module) { exit; } + // Check if module is used by agent for Safe mode. + $is_safe_mode_module = modules_check_safe_mode($id_borrar_modulo); + if ($is_safe_mode_module === true && isset($id_agente) === true) { + db_process_sql_update('tagente', ['safe_mode_module' => '0'], ['id_agente' => $id_agente]); + db_process_sql_update( + 'tagente_modulo', + [ + 'disabled' => 0, + 'disabled_by_safe_mode' => 0, + ], + [ + 'id_agente' => $id_agente, + 'disabled_by_safe_mode' => 1, + ] + ); + } + // Before delete the main module, check and delete the childrens from the original module. module_check_childrens_and_delete($id_borrar_modulo); diff --git a/pandora_console/godmode/agentes/configure_field.php b/pandora_console/godmode/agentes/configure_field.php index 904b807bbd..44332487ce 100755 --- a/pandora_console/godmode/agentes/configure_field.php +++ b/pandora_console/godmode/agentes/configure_field.php @@ -55,7 +55,7 @@ if ($id_field) { $display_on_front = $field['display_on_front']; $is_password_type = $field['is_password_type']; $combo_values = $field['combo_values'] ? $field['combo_values'] : ''; - $is_combo_enable = $config['is_combo_enable']; + $is_combo_enable = (isset($config['is_combo_enable']) === true) ? $config['is_combo_enable'] : false; $is_link_enabled = $field['is_link_enabled']; $header_title = __('Update agent custom field'); } else { @@ -162,6 +162,10 @@ $table->data[2][0] = html_print_label_input_block( ) ); +if (isset($config['is_combo_enable']) === false) { + $config['is_combo_enable'] = false; +} + $table->data[2][1] = html_print_label_input_block( __('Enabled combo'), html_print_checkbox_switch_extended( diff --git a/pandora_console/godmode/agentes/module_manager_editor.php b/pandora_console/godmode/agentes/module_manager_editor.php index 543d241fc9..20fe16c626 100644 --- a/pandora_console/godmode/agentes/module_manager_editor.php +++ b/pandora_console/godmode/agentes/module_manager_editor.php @@ -765,7 +765,7 @@ $outputForm .= ui_toggle( $outputForm .= ui_toggle( html_print_table($table_macros, true), - ''.__('Custom macros').'', + ''.__('Custom macros').ui_print_help_tip(__('Allows you to set custom macros for this module (e.g. name \'_location_\', value \'Office\'). These macros can then be used in alerts to provide additional information about the module in question.'), true).'', '', '', true, @@ -784,7 +784,7 @@ if ((int) $moduletype !== 13) { $table_relations, true ), - ''.__('Module relations').'', + ''.__('Module relations').ui_print_help_tip(__('Used to replace the module in SLA reports, either directly () or in Failover mode ().'), true).'', '', '', true, diff --git a/pandora_console/godmode/agentes/module_manager_editor_common.php b/pandora_console/godmode/agentes/module_manager_editor_common.php index a9d809d29f..fda655f314 100644 --- a/pandora_console/godmode/agentes/module_manager_editor_common.php +++ b/pandora_console/godmode/agentes/module_manager_editor_common.php @@ -446,7 +446,9 @@ $tableBasicThresholds->rowclass['caption_warning_threshold'] = 'field_half_width $tableBasicThresholds->rowclass['warning_threshold'] = 'field_half_width'; $tableBasicThresholds->data['caption_warning_threshold'][0] .= __('Warning threshold').' '; -$tableBasicThresholds->data['caption_warning_threshold'][0] .= '('.__('Min / Max').')'; +$tableBasicThresholds->data['caption_warning_threshold'][0] .= '
('.__('Min / Max').')
'; +$tableBasicThresholds->data['caption_warning_threshold'][0] .= ''; +$tableBasicThresholds->data['caption_warning_threshold'][0] .= ui_print_help_tip(__('Normal: Any value within the specified range will cause a state change. Inverse interval: Any value outside the specified range will cause a state change. Percentage: This mode takes into account the module variation percentage (regarding its previous value), and will cause a change of state if it complies with the indicated increase or decrease values. A value that matches the Warning and Critical thresholds will trigger the Critical status. In numeric modules, a Max 0 value represents infinity.'), true); $tableBasicThresholds->data['warning_threshold'][0] .= html_print_input_text( 'min_warning', $min_warning, @@ -534,7 +536,9 @@ $tableBasicThresholds->data['warning_time'][1] .= '  '.__('interval $tableBasicThresholds->rowclass['caption_critical_threshold'] = 'field_half_width pdd_t_10px'; $tableBasicThresholds->rowclass['critical_threshold'] = 'field_half_width'; $tableBasicThresholds->data['caption_critical_threshold'][0] .= __('Critical threshold').' '; -$tableBasicThresholds->data['caption_critical_threshold'][0] .= '('.__('Min / Max').')'; +$tableBasicThresholds->data['caption_critical_threshold'][0] .= '
('.__('Min / Max').')
'; +$tableBasicThresholds->data['caption_critical_threshold'][0] .= ''; +$tableBasicThresholds->data['caption_critical_threshold'][0] .= ui_print_help_tip(__('Normal: Any value within the specified range will cause a state change.\nInverse interval: Any value outside the specified range will cause a state change. Percentage: This mode takes into account the module variation percentage (regarding its previous value), and will cause a change of state if it complies with the indicated increase or decrease values. A value that matches the Warning and Critical thresholds will trigger the Critical status. In numeric modules, a Max 0 value represents infinity.'), true).'
'; $tableBasicThresholds->data['critical_threshold'][0] .= html_print_input_text( 'min_critical', $min_critical, @@ -622,7 +626,7 @@ if (modules_is_string_type($id_module_type) === false || (bool) $edit === true) } $table_simple->rowclass['caption_historical_data'] = 'mrgn_top_10px'; -$table_simple->data['caption_historical_data'][0] = __('Historical data'); +$table_simple->data['caption_historical_data'][0] = __('Historical data').ui_print_help_tip(__('If disabled, it will only save the last known data, being unable to display graphs. It is useful to save DB space. It should be disabled only in those cases where it is necessary for the system to flow faster and save resources.'), true); if ($disabledBecauseInPolicy) { // If is disabled, we send a hidden in his place and print a false // checkbox because HTML dont send disabled fields @@ -1134,7 +1138,7 @@ if (isset($id_agente) === true && (int) $moduletype === MODULE_DATA) { $table_advanced->rowclass['cron_section'] = 'table_section full_section mrgn_top_mod_0px'; $table_advanced->data['cron_section'] = html_print_table($tableCron, true); -$table_advanced->data['title_3'] = html_print_subtitle_table(__('Thresholds and state changes')); +$table_advanced->data['title_3'] = html_print_subtitle_table(__('Thresholds and state changes').ui_print_help_tip(__('It indicates the minimum and maximum values accepted by the module. Any value outside this range will be discarded. For example, with a Max. value of 100, a data value of 200 will not be saved in a database.'), true)); $table_advanced->rowclass['caption_min_max_values'] = 'w50p pdd_t_10px'; $table_advanced->rowclass['min_max_values'] = 'w50p pdd_b_10px'; @@ -1152,7 +1156,7 @@ $tableDynamicThreshold->style = []; $tableDynamicThreshold->rowclass = []; $tableDynamicThreshold->data = []; -$tableDynamicThreshold->data['caption_dynamic_threshold_interval'][0] = __('Dynamic Threshold Interval'); +$tableDynamicThreshold->data['caption_dynamic_threshold_interval'][0] = __('Dynamic Threshold Interval').ui_print_help_tip(__('If this option is enabled, the module thresholds will be automatically adjusted based on the mean and standard deviation of their values in the specified time interval.'), true); $tableDynamicThreshold->rowclass['dynamic_threshold_interval'] = 'w540px'; $tableDynamicThreshold->data['dynamic_threshold_interval'][0] = html_print_extended_select_for_time( 'dynamic_interval', @@ -1174,8 +1178,8 @@ $tableDynamicThreshold->cellclass['caption_adv_dynamic_threshold_interval'][0] = $tableDynamicThreshold->cellclass['caption_adv_dynamic_threshold_interval'][1] = 'w33p'; $tableDynamicThreshold->cellclass['adv_dynamic_threshold_interval'][0] = 'w33p'; $tableDynamicThreshold->cellclass['adv_dynamic_threshold_interval'][1] = 'w33p'; -$tableDynamicThreshold->data['caption_adv_dynamic_threshold_interval'][0] = __('Min.'); -$tableDynamicThreshold->data['caption_adv_dynamic_threshold_interval'][1] = __('Max.'); +$tableDynamicThreshold->data['caption_adv_dynamic_threshold_interval'][0] = __('Min.').ui_print_help_tip(__('It allows to adjust the lower limit of the dynamic threshold, in percentage. For example, if the module average value is 60 and the lower critical state threshold was set to 80, a Dynamic Threshold Max to 10 would set the threshold to 88, 10% lower than what was set.'), true); +$tableDynamicThreshold->data['caption_adv_dynamic_threshold_interval'][1] = __('Max.').ui_print_help_tip(__('It allows to adjust the upper limit of the dynamic threshold, in percentage. For example, if the module average value is 60 and the upper critical state threshold has been set to 80, a Dynamic Threshold Max to 10 would set the threshold to 88, 10% higher than what was set.'), true); $tableDynamicThreshold->data['adv_dynamic_threshold_interval'][0] = html_print_input_text( 'dynamic_min', $dynamic_min, @@ -1205,7 +1209,7 @@ $tableDynamicThreshold->rowclass['caption_adv_dynamic_threshold_twotailed'] = 'p $tableDynamicThreshold->rowclass['adv_dynamic_threshold_twotailed'] = 'w100p'; $tableDynamicThreshold->cellclass['caption_adv_dynamic_threshold_twotailed'][0] = 'w33p'; $tableDynamicThreshold->cellclass['adv_dynamic_threshold_twotailed'][0] = 'w33p'; -$tableDynamicThreshold->data['caption_adv_dynamic_threshold_twotailed'][0] = __('Two Tailed'); +$tableDynamicThreshold->data['caption_adv_dynamic_threshold_twotailed'][0] = __('Two Tailed').ui_print_help_tip(__('It allows to set a lower threshold in addition to the upper one by default. If enabled, both very high and very low values will cause a state change.'), true); $tableDynamicThreshold->data['adv_dynamic_threshold_twotailed'][0] = html_print_checkbox_switch( 'dynamic_two_tailed', 1, @@ -1224,7 +1228,7 @@ $tableFFThreshold->style = []; $tableFFThreshold->rowclass = []; $tableFFThreshold->data = []; // FF stands for Flip-flop. -$tableFFThreshold->data['caption_ff_main_thresholds'][0] = __('FF threshold'); +$tableFFThreshold->data['caption_ff_main_thresholds'][0] = __('FF threshold').ui_print_help_tip(__('It indicates the number of consecutive values at a threshold that must be received for the module to change state. For example, with a value 0 (default) the module will change state as soon as it receives a data within the critical threshold, but with a value 2 the module must receive two more critical data (consecutively) to change to critical state. It is possible to set the same \'tolerance\' for all status changes or choose a different value for each one. This option is especially useful in unstable environments, as it helps prevent false positives.'), true); $tableFFThreshold->rowclass['ff_main_thresholds'] = 'w100p'; $tableFFThreshold->data['ff_main_thresholds'][0] = html_print_switch_radio_button( [ @@ -1366,7 +1370,7 @@ $table_advanced->data['title_4'] = html_print_subtitle_table(__('Data and their $table_advanced->rowclass['caption_process_unit'] = 'w50p'; $table_advanced->rowclass['process_unit'] = 'w50p'; $table_advanced->data['caption_process_unit'][0] = __('Unit'); -$table_advanced->data['caption_process_unit'][1] = __('Post process'); +$table_advanced->data['caption_process_unit'][1] = __('Post process').ui_print_help_tip(__('It allows you to change the unit of the received data. To do this, multiply the data received by the value set in this option (e.g. Seconds * 0.016666666667 = Minutes). The data is saved already transformed in the database, so changing this parameter when the module has data can cause anomalies in graphs and other elements.'), true); $table_advanced->data['process_unit'][0] = html_print_extended_select_for_unit( 'unit', $unit, @@ -1449,7 +1453,7 @@ $table_advanced->data['discard_unknown'][0] = html_print_checkbox_switch( $disabledBecauseInPolicy ); -$table_advanced->data['caption_quiet'][0] = __('Quiet'); +$table_advanced->data['caption_quiet'][0] = __('Quiet').ui_print_help_tip(__('A module in silent mode will continue to receive and store data, but will not trigger alerts or generate events.'), true); $table_advanced->data['quiet'][0] = html_print_checkbox_switch( 'quiet_module', 1, @@ -1458,7 +1462,7 @@ $table_advanced->data['quiet'][0] = html_print_checkbox_switch( $disabledBecauseInPolicy ); -$table_advanced->data['caption_cascade_protection'][0] = __('Cascade Protection Services'); +$table_advanced->data['caption_cascade_protection'][0] = __('Cascade Protection Services').ui_print_help_tip(__('To avoid an avalanche of cascading alerts. You may choose any agent module (any) or a specific module. In the first case, when there is at least one module in critical, that event/alert will be launched, but no other of another module of the same agent. In the second case, when the specified module is in critical, the agent will not generate alerts/events.'), true); $table_advanced->data['cascade_protection'][0] = html_print_select($cps_array, 'cps_module', $cps_module, '', '', 0, true, false, true, '', $disabledBecauseInPolicy); @@ -2377,11 +2381,21 @@ ui_require_jquery_file('json'); if ($('#radius-percentage_warning').is(':checked') === true){ min_w = 0; max_w = 0; + $('#caption_warning_minmax').addClass('invisible'); + $('#caption_warning_crease').removeClass('invisible'); + } else { + $('#caption_warning_minmax').removeClass('invisible'); + $('#caption_warning_crease').addClass('invisible'); } if ($('#radius-percentage_critical').is(':checked') === true){ min_c = 0; max_c = 0; + $('#caption_critical_minmax').addClass('invisible'); + $('#caption_critical_crease').removeClass('invisible'); + } else { + $('#caption_critical_minmax').removeClass('invisible'); + $('#caption_critical_crease').addClass('invisible'); } paint_graph_status( diff --git a/pandora_console/godmode/alerts/alert_commands.php b/pandora_console/godmode/alerts/alert_commands.php index a5b4de7c80..b242e41e29 100644 --- a/pandora_console/godmode/alerts/alert_commands.php +++ b/pandora_console/godmode/alerts/alert_commands.php @@ -109,7 +109,7 @@ if (is_ajax()) { for ($i = 1; $i <= $config['max_macro_fields']; $i++) { $field_description = $fields_descriptions[($i - 1)]; $field_value = $fields_values[($i - 1)]; - $field_hidden = $fields_hidden_checked[($i - 1)]; + $field_hidden = (isset($fields_hidden_checked[($i - 1)]) === true) ? $fields_hidden_checked[($i - 1)] : ''; if (!empty($field_description)) { diff --git a/pandora_console/godmode/alerts/alert_list.list.php b/pandora_console/godmode/alerts/alert_list.list.php index 5d71895ecd..fe0790f71b 100644 --- a/pandora_console/godmode/alerts/alert_list.list.php +++ b/pandora_console/godmode/alerts/alert_list.list.php @@ -253,7 +253,7 @@ if (is_metaconsole() === true) { echo '
'; } -if (!$id_cluster) { +if (isset($id_cluster) === false) { ui_toggle( $form_filter, ''.__('Alert control filter').'', @@ -1115,7 +1115,7 @@ if (isset($dont_display_alert_create_bttn)) { } } -if ($display_create && (check_acl($config['id_user'], 0, 'LW') || check_acl($config['id_user'], $template_group, 'LM')) && !$id_cluster) { +if ($display_create && (check_acl($config['id_user'], 0, 'LW') || check_acl($config['id_user'], $template_group, 'LM')) && isset($id_cluster) === false) { echo '
'; $actionButtons = html_print_submit_button( __('Create'), diff --git a/pandora_console/godmode/category/category.php b/pandora_console/godmode/category/category.php index 46095b6efb..02a221fee8 100755 --- a/pandora_console/godmode/category/category.php +++ b/pandora_console/godmode/category/category.php @@ -242,6 +242,7 @@ if (empty($result) === false) { html_print_table($table); $tablePagination = ui_pagination($total_categories, $url, $offset, 0, true, 'offset', false); } else { + $tablePagination = ''; // No categories available or selected. ui_print_info_message(['no_close' => true, 'message' => __('No categories found') ]); } diff --git a/pandora_console/godmode/extensions.php b/pandora_console/godmode/extensions.php index 3ff09273c6..3db36f71a9 100644 --- a/pandora_console/godmode/extensions.php +++ b/pandora_console/godmode/extensions.php @@ -195,13 +195,13 @@ foreach ($extensions as $file => $extension) { $data[] = ''.$file.''; // Get version of this extensions - if ($config['extensions'][$file]['operation_menu']) { + if (isset($config['extensions'][$file]['operation_menu']) === true) { $data[] = $config['extensions'][$file]['operation_menu']['version']; - } else if ($config['extensions'][$file]['godmode_menu']) { + } else if (isset($config['extensions'][$file]['godmode_menu']) === true) { $data[] = $config['extensions'][$file]['godmode_menu']['version']; - } else if ($config['extensions'][$file]['extension_ope_tab']) { + } else if (isset($config['extensions'][$file]['extension_ope_tab']) === true) { $data[] = $config['extensions'][$file]['extension_ope_tab']['version']; - } else if ($config['extensions'][$file]['extension_god_tab']) { + } else if (isset($config['extensions'][$file]['extension_god_tab']) === true) { $data[] = $config['extensions'][$file]['extension_god_tab']['version']; } else { $data[] = __('N/A'); @@ -216,7 +216,7 @@ foreach ($extensions as $file => $extension) { $data[] = $config['extensions'][$file]['godmode_menu']['version']; } else if (isset($config['extensions'][$file]['extension_ope_tab'])) { $data[] = $config['extensions'][$file]['extension_ope_tab']['version']; - } else if ($config['extensions'][$file]['extension_god_tab']) { + } else if (isset($config['extensions'][$file]['extension_god_tab']) === true) { $data[] = $config['extensions'][$file]['extension_god_tab']['version']; } else { $data[] = __('N/A'); diff --git a/pandora_console/godmode/groups/configure_group.php b/pandora_console/godmode/groups/configure_group.php index f7fa7a76b7..3376f42804 100644 --- a/pandora_console/godmode/groups/configure_group.php +++ b/pandora_console/godmode/groups/configure_group.php @@ -234,7 +234,7 @@ $table->data[1][0] = html_print_label_input_block( if ((bool) $config['enterprise_installed'] === true) { $table->data[1][1] .= html_print_label_input_block( - __('Group Password'), + __('Group Password').ui_print_help_tip(__('If a group is password protected, it will only accept XML from those software agents that have a group password configured with the same name. Do not use spaces or symbols.'), true), html_print_input_password('group_pass', $group_pass, '', 16, 255, true) ); } @@ -250,7 +250,7 @@ $table->data[2][1] = html_print_label_input_block( ); $table->data[3][0] = html_print_label_input_block( - __('Custom ID'), + __('Custom ID').ui_print_help_tip(__('It is an external ID used for integrations. Do not use spaces or symbols.'), true), html_print_input_text('custom_id', $custom_id, '', 16, 255, true) ); diff --git a/pandora_console/godmode/groups/group_list.php b/pandora_console/godmode/groups/group_list.php index f1b40867d9..6aad60e71d 100644 --- a/pandora_console/godmode/groups/group_list.php +++ b/pandora_console/godmode/groups/group_list.php @@ -1205,9 +1205,9 @@ $tab = 'group_edition'; '; $output .= '
'; @@ -58,9 +66,11 @@ if ($files !== false) { } } -if ($files64 !== false) { - foreach ($files64 as $key => $file) { - $output .= ''; +if (isset($files64) === true) { + if ($files64 !== false) { + foreach ($files64 as $key => $file) { + $output .= ''; + } } } diff --git a/pandora_server/DEBIAN/control b/pandora_server/DEBIAN/control index a9ee10dc18..f9be42317e 100644 --- a/pandora_server/DEBIAN/control +++ b/pandora_server/DEBIAN/control @@ -1,5 +1,5 @@ package: pandorafms-server -Version: 7.0NG.775-240221 +Version: 7.0NG.775-240227 Architecture: all Priority: optional Section: admin diff --git a/pandora_server/DEBIAN/make_deb_package.sh b/pandora_server/DEBIAN/make_deb_package.sh index b393f9f116..f16c410ee6 100644 --- a/pandora_server/DEBIAN/make_deb_package.sh +++ b/pandora_server/DEBIAN/make_deb_package.sh @@ -14,7 +14,7 @@ # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. -pandora_version="7.0NG.775-240221" +pandora_version="7.0NG.775-240227" package_cpan=0 package_pandora=1 diff --git a/pandora_server/lib/PandoraFMS/Config.pm b/pandora_server/lib/PandoraFMS/Config.pm index f6a4170360..6853324266 100644 --- a/pandora_server/lib/PandoraFMS/Config.pm +++ b/pandora_server/lib/PandoraFMS/Config.pm @@ -46,7 +46,7 @@ our @EXPORT = qw( # version: Defines actual version of Pandora Server for this module only my $pandora_version = "7.0NG.775"; -my $pandora_build = "240221"; +my $pandora_build = "240227"; our $VERSION = $pandora_version." ".$pandora_build; # Setup hash diff --git a/pandora_server/lib/PandoraFMS/DataServer.pm b/pandora_server/lib/PandoraFMS/DataServer.pm index 8a72ef7605..cb2c5afc4c 100644 --- a/pandora_server/lib/PandoraFMS/DataServer.pm +++ b/pandora_server/lib/PandoraFMS/DataServer.pm @@ -407,19 +407,7 @@ sub process_xml_data ($$$$$) { # Modify the timestamp with the timezone_offset logger($pa_config, "Applied a timezone offset of $timestamp to agent " . $data->{'agent_name'}, 10); - - # Calculate the start date to add the offset - my $utimestamp = 0; - eval { - if ($timestamp =~ /(\d+)[\/|\-](\d+)[\/|\-](\d+) +(\d+):(\d+):(\d+)/) { - $utimestamp = strftime("%s", $6, $5, $4, $3, $2 -1 , $1 - 1900); - } - }; - - # Apply the offset if there were no errors - if (! $@ && $utimestamp != 0) { - $timestamp = strftime ("%Y-%m-%d %H:%M:%S", localtime($utimestamp + ($timezone_offset * 3600))); - } + $timestamp = apply_timezone_offset($timestamp, $timezone_offset); } # Check some variables @@ -667,6 +655,11 @@ sub process_xml_data ($$$$$) { # Single data if (! defined ($module_data->{'datalist'})) { my $data_timestamp = get_tag_value ($module_data, 'timestamp', $timestamp); + if ($pa_config->{'use_xml_timestamp'} eq '0' && defined($timestamp)) { + $data_timestamp = $timestamp; + } + $data_timestamp = apply_timezone_offset($data_timestamp, $timezone_offset); + process_module_data ($pa_config, $module_data, $server_id, $agent, $module_name, $module_type, $interval, $data_timestamp, $dbh, $new_agent); next; } @@ -684,10 +677,10 @@ sub process_xml_data ($$$$$) { $module_data->{'data'} = $data->{'value'}; my $data_timestamp = get_tag_value ($data, 'timestamp', $timestamp); - if ($pa_config->{'use_xml_timestamp'} eq '0' && defined($timestamp)) { $data_timestamp = $timestamp; } + $data_timestamp = apply_timezone_offset($data_timestamp, $timezone_offset); process_module_data ($pa_config, $module_data, $server_id, $agent, $module_name, $module_type, $interval, $data_timestamp, $dbh, $new_agent); diff --git a/pandora_server/lib/PandoraFMS/PluginTools.pm b/pandora_server/lib/PandoraFMS/PluginTools.pm index 8856a7f915..a621790a38 100644 --- a/pandora_server/lib/PandoraFMS/PluginTools.pm +++ b/pandora_server/lib/PandoraFMS/PluginTools.pm @@ -34,7 +34,7 @@ our @ISA = qw(Exporter); # version: Defines actual version of Pandora Server for this module only my $pandora_version = "7.0NG.775"; -my $pandora_build = "240221"; +my $pandora_build = "240227"; our $VERSION = $pandora_version." ".$pandora_build; our %EXPORT_TAGS = ( 'all' => [ qw() ] ); diff --git a/pandora_server/lib/PandoraFMS/Tools.pm b/pandora_server/lib/PandoraFMS/Tools.pm index 37d9ece692..1c8bd087c2 100755 --- a/pandora_server/lib/PandoraFMS/Tools.pm +++ b/pandora_server/lib/PandoraFMS/Tools.pm @@ -182,6 +182,7 @@ our @EXPORT = qw( check_cron_element cron_check p_pretty_json + apply_timezone_offset ); # ID of the different servers @@ -2995,6 +2996,33 @@ sub p_pretty_json { return $output; } + +################################################################################ +# Apply a timezone offset to the given timestamp. +################################################################################ +sub apply_timezone_offset { + my ($timestamp, $timezone_offset) = @_; + + # Nothing to be done. + return $timestamp if (!defined($timezone_offset) || $timezone_offset == 0); + + # Convert the timestamp to seconds. + my $utimestamp = 0; + eval { + if ($timestamp =~ /(\d+)[\/|\-](\d+)[\/|\-](\d+) +(\d+):(\d+):(\d+)/) { + $utimestamp = strftime("%s", $6, $5, $4, $3, $2 -1 , $1 - 1900); + } + }; + + # Something went wrong. + return $timestamp if ($@); + + # Apply the offset and convert back to timestamp. + $timestamp = strftime ("%Y-%m-%d %H:%M:%S", localtime($utimestamp + ($timezone_offset * 3600))); + + return $timestamp; +} + 1; __END__ diff --git a/pandora_server/pandora_server.redhat.spec b/pandora_server/pandora_server.redhat.spec index de2b710cfc..99b49a7b32 100644 --- a/pandora_server/pandora_server.redhat.spec +++ b/pandora_server/pandora_server.redhat.spec @@ -7,7 +7,7 @@ %define debug_package %{nil} %define name pandorafms_server %define version 7.0NG.775 -%define release 240221 +%define release 240227 Summary: Pandora FMS Server Name: %{name} diff --git a/pandora_server/pandora_server.spec b/pandora_server/pandora_server.spec index dba23ea4db..173fa201c2 100644 --- a/pandora_server/pandora_server.spec +++ b/pandora_server/pandora_server.spec @@ -4,7 +4,7 @@ %global __os_install_post %{nil} %define name pandorafms_server %define version 7.0NG.775 -%define release 240221 +%define release 240227 Summary: Pandora FMS Server Name: %{name} diff --git a/pandora_server/pandora_server_installer b/pandora_server/pandora_server_installer index 6973401c56..31b4517e22 100755 --- a/pandora_server/pandora_server_installer +++ b/pandora_server/pandora_server_installer @@ -9,7 +9,7 @@ # ********************************************************************** PI_VERSION="7.0NG.775" -PI_BUILD="240221" +PI_BUILD="240227" MODE=$1 if [ $# -gt 1 ]; then diff --git a/pandora_server/util/pandora_db.pl b/pandora_server/util/pandora_db.pl index 9feb4d3982..b1e26bd473 100755 --- a/pandora_server/util/pandora_db.pl +++ b/pandora_server/util/pandora_db.pl @@ -38,7 +38,7 @@ use PandoraFMS::Config; use PandoraFMS::DB; # version: define current version -my $version = "7.0NG.775 Build 240221"; +my $version = "7.0NG.775 Build 240227"; # Pandora server configuration my %conf; diff --git a/pandora_server/util/pandora_ha.pl b/pandora_server/util/pandora_ha.pl index 3bc15d6a55..28ae0df795 100755 --- a/pandora_server/util/pandora_ha.pl +++ b/pandora_server/util/pandora_ha.pl @@ -442,16 +442,6 @@ sub ha_database_connect_pandora($) { # Select a new master database. my ($dbh, $utimestamp, $max_utimestamp) = (undef, undef, -1); - my @disabled_nodes = get_disabled_nodes($conf); - - # If there are disabled nodes ignore them from the HA_DB_Hosts. - if(scalar @disabled_nodes ne 0){ - @HA_DB_Hosts = grep { my $item = $_; !grep { $_ eq $item } @disabled_nodes } @HA_DB_Hosts; - - my $data = join(",", @disabled_nodes); - log_message($conf, 'LOG', "Ignoring disabled hosts: " . $data); - } - foreach my $ha_dbhost (@HA_DB_Hosts) { # Retry each database ha_connect_retries times. @@ -478,6 +468,13 @@ sub ha_database_connect_pandora($) { # No luck. Try the next database. next unless defined($dbh); + # Check if database is disabled. + if (defined(get_db_value($dbh, 'SELECT `id` FROM `tdatabase` WHERE `host` = "' . $ha_dbhost . '" AND disabled = 1'))) + { + log_message($conf, 'LOG', "Ignoring disabled host: " . $ha_dbhost); + db_disconnect($dbh); + next; + } eval { # Get the most recent utimestamp from the database. $utimestamp = get_db_value($dbh, 'SELECT UNIX_TIMESTAMP(MAX(keepalive)) FROM tserver'); @@ -542,36 +539,6 @@ sub ha_restart_pandora($) { `$config->{'pandora_service_cmd'} $control_command 2>/dev/null`; } -############################################################################### -# Get ip of the disabled nodes. -############################################################################### -sub get_disabled_nodes($) { - my ($conf) = @_; - - my $dbh = db_connect('mysql', - $conf->{'dbname'}, - $conf->{'dbhost'}, - $conf->{'dbport'}, - $conf->{'ha_dbuser'}, - $conf->{'ha_dbpass'}); - - my $disabled_nodes = get_db_value($dbh, "SELECT value FROM tconfig WHERE token = 'ha_disabled_nodes'"); - - if(!defined($disabled_nodes) || $disabled_nodes eq ""){ - $disabled_nodes = ','; - } - - my @disabled_nodes = split(',', $disabled_nodes); - - if(scalar @disabled_nodes ne 0){ - $disabled_nodes = join(",", @disabled_nodes); - @disabled_nodes = get_db_rows($dbh, "SELECT host FROM tdatabase WHERE id IN ($disabled_nodes)"); - @disabled_nodes = map { $_->{host} } @disabled_nodes; - } - - return @disabled_nodes; -} - ############################################################################### # Main (Pacemaker) ############################################################################### @@ -743,6 +710,9 @@ sub ha_main_pandora($) { # Execute resync actions. enterprise_hook('pandoraha_resync_dbs', [$conf, $dbh, $DB_Host, \@HA_DB_Hosts]); + # Update and push HA databases info to Metaconsole or nodes. + enterprise_hook('pandoraha_update_and_push_databases_info', [$conf, $dbh]); + # Synchronize nodes. enterprise_hook('pandoraha_sync_node', [$conf, $dbh]); }; diff --git a/pandora_server/util/pandora_manage.pl b/pandora_server/util/pandora_manage.pl index 50540e43ab..3200b71f46 100755 --- a/pandora_server/util/pandora_manage.pl +++ b/pandora_server/util/pandora_manage.pl @@ -36,7 +36,7 @@ use Encode::Locale; Encode::Locale::decode_argv; # version: define current version -my $version = "7.0NG.775 Build 240221"; +my $version = "7.0NG.775 Build 240227"; # save program name for logging my $progname = basename($0);