diff --git a/pandora_agents/pc/pandora_agent_installer b/pandora_agents/pc/pandora_agent_installer index 7d8de1134d..bcfee3eb00 100644 --- a/pandora_agents/pc/pandora_agent_installer +++ b/pandora_agents/pc/pandora_agent_installer @@ -467,7 +467,7 @@ fi # Script banner at start echo " " -echo "Pandora FMS Agent UNIX Installer $PI_VERSION $PI_BUILD (c) 2008-2015 ArticaST" +echo "Pandora FMS Agent UNIX Installer $PI_VERSION $PI_BUILD (c) 2008-2024 PandoraFMS" echo "This program is licensed under GPL2 Terms. http://pandorafms.com" echo " " diff --git a/pandora_agents/unix/DEBIAN/control b/pandora_agents/unix/DEBIAN/control index 1287148b3e..acf998e94c 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-240208 +Version: 7.0NG.775-240222 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 61a0c0035c..a3cb485e4b 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-240208" +pandora_version="7.0NG.775-240222" 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 d1bb48301f..0947982db3 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 => '240208'; +use constant AGENT_BUILD => '240222'; # 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 a7cd427ca0..31dcaffaeb 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 240208 +%define release 240222 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 3d6d98c4d1..2e29ba964f 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 240208 +%define release 240222 %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 f78b231c24..7f53a67a6b 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 240208 +%define release 240222 %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 47d7340d8c..d018c4679f 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 240208 +%define release 240222 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 d0526d36eb..f7cc2a290d 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 240208 +%define release 240222 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 5d1d1cfe8a..a275fcfa5c 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="240208" +PI_BUILD="240222" OS_NAME=`uname -s` FORCE=0 @@ -579,7 +579,7 @@ fi # Script banner at start echo " " -echo "Pandora FMS Agent UNIX Installer $PI_VERSION $PI_BUILD (c) 2008-2015 ArticaST" +echo "Pandora FMS Agent UNIX Installer $PI_VERSION $PI_BUILD (c) 2008-2024 PandoraFMS" echo "This program is licensed under GPL2 Terms. http://pandorafms.com" echo " " diff --git a/pandora_agents/win32/installer/pandora.mpi b/pandora_agents/win32/installer/pandora.mpi index f284a8bf09..70c7ecb53b 100644 --- a/pandora_agents/win32/installer/pandora.mpi +++ b/pandora_agents/win32/installer/pandora.mpi @@ -186,7 +186,7 @@ UpgradeApplicationID {} Version -{240208} +{240222} ViewReadme {Yes} diff --git a/pandora_agents/win32/pandora.cc b/pandora_agents/win32/pandora.cc index 5a55cac837..fa9c417123 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 240208") +#define PANDORA_VERSION ("7.0NG.775 Build 240222") string pandora_path; string pandora_dir; diff --git a/pandora_agents/win32/versioninfo.rc b/pandora_agents/win32/versioninfo.rc index 76c9ee9077..16ec5fe61c 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 240208))" + VALUE "ProductVersion", "(7.0NG.775(Build 240222))" VALUE "FileVersion", "1.0.0.0" END END diff --git a/pandora_console/DEBIAN/control b/pandora_console/DEBIAN/control index e1fcf78907..de7e2de6f5 100644 --- a/pandora_console/DEBIAN/control +++ b/pandora_console/DEBIAN/control @@ -1,5 +1,5 @@ package: pandorafms-console -Version: 7.0NG.775-240208 +Version: 7.0NG.775-240222 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 29ad26f2cc..705993798a 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-240208" +pandora_version="7.0NG.775-240222" package_pear=0 package_pandora=1 diff --git a/pandora_console/extensions/quick_shell.php b/pandora_console/extensions/quick_shell.php index 9ea79ba364..a3f5872f84 100644 --- a/pandora_console/extensions/quick_shell.php +++ b/pandora_console/extensions/quick_shell.php @@ -394,7 +394,7 @@ function quickShellSettings() __('Address'), html_print_input_text( 'gotty_addr', - $config['gotty_addr'], + ($config['gotty_addr'] ?? ''), '', 30, 100, @@ -443,9 +443,8 @@ function quickShellSettings() html_print_checkbox_switch( 'gotty_ssh_use_ssl', 1, - $config['gotty_ssh_use_ssl'], - true, - $disable_agentaccess + ($config['gotty_ssh_use_ssl'] ?? false), + true ) ); @@ -497,7 +496,7 @@ function quickShellSettings() html_print_checkbox_switch( 'gotty_telnet_use_ssl', 1, - $config['gotty_telnet_use_ssl'], + ($config['gotty_telnet_use_ssl'] ?? false), true ) ); diff --git a/pandora_console/extensions/realtime_graphs/ajax.php b/pandora_console/extensions/realtime_graphs/ajax.php index 8b633171ab..1482540f91 100644 --- a/pandora_console/extensions/realtime_graphs/ajax.php +++ b/pandora_console/extensions/realtime_graphs/ajax.php @@ -128,6 +128,6 @@ if (empty($data)) { } echo '{ - "label": "'.htmlspecialchars($graph_title, ENT_QUOTES).'", - "data": [["'.time().'", '.htmlspecialchars($data, ENT_QUOTES).']] + "label": "'.htmlspecialchars(($graph_title ?? ''), ENT_QUOTES).'", + "data": [["'.time().'", '.htmlspecialchars(($data ?? ''), ENT_QUOTES).']] }'; diff --git a/pandora_console/extensions/resource_exportation.php b/pandora_console/extensions/resource_exportation.php deleted file mode 100755 index 476b7ef1bf..0000000000 --- a/pandora_console/extensions/resource_exportation.php +++ /dev/null @@ -1,497 +0,0 @@ -'."\n"; - echo "\n"; - echo '\n"; - if (isset($report['description'])) { - echo '\n"; - } - - $group = db_get_value('nombre', 'tgrupo', 'id_grupo', $report['id_group']); - echo '\n"; - $items = db_get_all_rows_field_filter( - 'treport_content', - 'id_report', - $report['id_report'] - ); - foreach ($items as $item) { - echo "\n"; - echo ''.io_safe_output($item['type'])."\n"; - echo ''.io_safe_output($item['description'])."\n"; - echo ''.io_safe_output($item['period'])."\n"; - if ($item['id_agent'] != 0) { - $agent = db_get_value('alias', 'tagente', 'id_agente', $item['id_agent']); - } - - if ($item['id_agent_module'] != 0) { - $module = db_get_value('nombre', 'tagente_modulo', 'id_agente_modulo', $item['id_agent_module']); - $id_agent = db_get_value('id_agente', 'tagente_modulo', 'id_agente_modulo', $item['id_agent_module']); - $agent = db_get_value('alias', 'tagente', 'id_agente', $item['id_agent']); - - echo '\n"; - } - - if (isset($agent)) { - echo '\n"; - } - - $agent = null; - switch (io_safe_output($item['type'])) { - case 2: - case 'custom_graph': - case 'automatic_custom_graph': - $graph = db_get_value('name', 'tgraph', 'id_graph', $item['id_gs']); - echo '\n"; - break; - - case 3: - case 'SLA': - echo ''.$item['only_display_wrong']."\n"; - echo ''.$item['monday']."\n"; - echo ''.$item['tuesday']."\n"; - echo ''.$item['wednesday']."\n"; - echo ''.$item['thursday']."\n"; - echo ''.$item['friday']."\n"; - echo ''.$item['saturday']."\n"; - echo ''.$item['sunday']."\n"; - echo ''.$item['time_from']."\n"; - echo ''.$item['time_to']."\n"; - - $slas = db_get_all_rows_field_filter('treport_content_sla_combined', 'id_report_content', $item['id_rc']); - if ($slas === false) { - $slas = []; - } - - foreach ($slas as $sla) { - $module = db_get_value('nombre', 'tagente_modulo', 'id_agente_modulo', $sla['id_agent_module']); - $id_agent = db_get_value('id_agente', 'tagente_modulo', 'id_agente_modulo', $sla['id_agent_module']); - $agent = db_get_value('alias', 'tagente', 'id_agente', $item['id_agent']); - echo ''; - echo '\n"; - echo '\n"; - echo ''.$sla['sla_max']."\n"; - echo ''.$sla['sla_min']."\n"; - echo ''.$sla['sla_limit']."\n"; - echo ''; - } - break; - - case 'text': - echo '\n"; - break; - - case 'sql': - echo '\n"; - if (!empty($item['external_source'])) { - echo '\n"; - } else { - $sql = db_get_value('sql', 'treport_custom_sql', 'id', $item['treport_custom_sql_id']); - echo ''.io_safe_output($sql)."\n"; - } - break; - - case 'sql_graph_pie': - case 'sql_graph_vbar': - case 'sql_graph_hbar': - echo ''.io_safe_output($item['header_definition'])."\n"; - if (!empty($item['external_source'])) { - echo ''.io_safe_output($item['external_source'])."\n"; - } else { - $sql = db_get_value('sql', 'treport_custom_sql', 'id', $item['treport_custom_sql_id']); - echo ''.io_safe_output($sql)."\n"; - } - break; - - case 'event_report_group': - $group = db_get_value('nombre', 'tgrupo', 'id_grupo', $item['id_agent']); - echo '\n"; - break; - - case 'url': - echo ''; - break; - - case 'database_serialized': - echo ''; - echo ''; - echo ''; - break; - - case 1: - case 'simple_graph': - case 'simple_baseline_graph': - case 6: - case 'monitor_report': - case 7: - case 'avg_value': - case 8: - case 'max_value': - case 9: - case 'min_value': - case 10: - case 'sumatory': - case 'agent_detailed_event': - case 'event_report_agent': - case 'event_report_module': - case 'alert_report_module': - case 'alert_report_agent': - case 'alert_report_group': - default: - // Do nothing. - break; - } - - echo "\n"; - } - - echo "\n"; -} - - -function output_xml_visual_console($id) -{ - $visual_map = db_get_row('tlayout', 'id', $id); - - echo ''."\n"; - echo "\n"; - echo '\n"; - if ($visual_map['id_group'] != 0) { - $group = db_get_value('nombre', 'tgrupo', 'id_grupo', $visual_map['id_group']); - echo '\n"; - } - - echo '\n"; - echo ''.io_safe_output($visual_map['height'])."\n"; - echo ''.io_safe_output($visual_map['width'])."\n"; - $items = db_get_all_rows_field_filter('tlayout_data', 'id_layout', $visual_map['id']); - if ($items === false) { - $items = []; - } - - foreach ($items as $item) { - echo "\n"; - echo ''.$item['id']."\n"; - // OLD ID USE FOR parent item - $agent = ''; - if ($item['id_agent'] != 0) { - $agent = db_get_value('nombre', 'tagente', 'id_agente', $item['id_agent']); - } - - if (!empty($item['label'])) { - echo '\n"; - } - - echo ''.$item['pos_x']."\n"; - echo ''.$item['pos_y']."\n"; - echo ''.$item['type']."\n"; - if ($item['width'] != 0) { - echo ''.$item['width']."\n"; - } - - if ($item['height'] != 0) { - echo ''.$item['height']."\n"; - } - - if (!empty($item['image'])) { - echo ''.$item['image']."\n"; - } - - if ($item['period'] != 0) { - echo ''.$item['period']."\n"; - } - - if (isset($item['id_agente_modulo'])) { - if ($item['id_agente_modulo'] != 0) { - $module = db_get_value('nombre', 'tagente_modulo', 'id_agente_modulo', $item['id_agente_modulo']); - $id_agent = db_get_value('id_agente', 'tagente_modulo', 'id_agente_modulo', $item['id_agente_modulo']); - $agent = db_get_value('nombre', 'tagente', 'id_agente', $id_agent); - - echo '\n"; - } - } - - if (!empty($agent)) { - echo '\n"; - } - - if ($item['id_layout_linked'] != 0) { - echo ''.$item['id_layout_linked']."\n"; - } - - if ($item['parent_item'] != 0) { - echo ''.$item['parent_item']."\n"; - } - - if (!empty($item['clock_animation'])) { - echo ''.$item['clock_animation']."\n"; - } - - if (!empty($item['fill_color'])) { - echo ''.$item['fill_color']."\n"; - } - - if (!empty($item['type_graph'])) { - echo ''.$item['type_graph']."\n"; - } - - if (!empty($item['time_format'])) { - echo ''.$item['time_format']."\n"; - } - - if (!empty($item['timezone'])) { - echo ''.$item['timezone']."\n"; - } - - if (!empty($item['border_width'])) { - echo ''.$item['border_width']."\n"; - } - - if (!empty($item['border_color'])) { - echo ''.$item['border_color']."\n"; - } - - echo "\n"; - } - - echo "\n"; -} - - -function get_name_xml_resource($hook_enterprise) -{ - global $config; - - $type = get_parameter('type'); - $id = (int) get_parameter('id'); - - switch ($type) { - case 'report': - $name = db_get_value('name', 'treport', 'id_report', $id); - break; - - case 'visual_console': - $name = db_get_value('name', 'tlayout', 'id', $id); - break; - - default: - if ($hook_enterprise === true) { - return enterprise_get_name_xml_resource($type, $id); - } - break; - } - - $file = io_safe_output($name).'.ptr'; - - return $file; -} - - -function get_xml_resource() -{ - global $config; - - $hook_enterprise = enterprise_include('extensions/resource_exportation/functions.php'); -} - - -function resource_exportation_extension_main() -{ - global $config; - - check_login(); - - if (! check_acl($config['id_user'], 0, 'PM') && ! is_user_admin($config['id_user'])) { - db_pandora_audit( - AUDIT_LOG_ACL_VIOLATION, - 'Trying to access Setup Management' - ); - include 'general/noaccess.php'; - return; - } - - $hook_enterprise = enterprise_include('extensions/resource_exportation/functions.php'); - - ui_print_standard_header( - __('Resource exportation'), - 'images/extensions.png', - false, - '', - true, - [], - [ - [ - 'link' => '', - 'label' => __('Resources'), - ], - [ - 'link' => '', - 'label' => __('Resource exporting'), - ], - ] - ); - - ui_print_warning_message( - __('This extension makes exportation of resource template more easy.').'
'.__('You can export resource templates in .ptr format.') - ); - - $table = new stdClass(); - $table->class = 'databox filter-table-adv'; - $table->id = 'resource_exportation_table'; - $table->style = []; - $table->style[0] = 'width: 30%'; - $table->style[1] = 'vertical-align: bottom;'; - $table->data = []; - $table->data[0][] = html_print_label_input_block( - __('Report'), - html_print_div( - [ - 'class' => 'flex-content-left', - 'content' => html_print_select_from_sql('SELECT id_report, name FROM treport', 'report', '', '', '', 0, true), - ], - true - ) - ); - $table->data[0][] = html_print_button(__('Export'), '', false, 'export_to_ptr("report");', '', true); - - $table->data[1][] = html_print_label_input_block( - __('Visual console'), - html_print_div( - [ - 'class' => 'flex-content-left', - 'content' => html_print_select_from_sql('SELECT id, name FROM tlayout', 'visual_console', '', '', '', 0, true), - ], - true - ) - ); - $table->data[1][] = html_print_button(__('Export'), '', false, 'export_to_ptr("visual_console");', '', true); - - if ($hook_enterprise === true) { - add_rows_for_enterprise($table->data); - } - - html_print_table($table); - - ?> - - $name) { - $values['id_report'] = $id; - $result = (bool) db_process_sql_insert('treport_content', $values); - - ui_print_result_message( - $result, - sprintf( - __("Success add '%s' item in report '%s'."), - $values['type'], - $name - ), - sprintf( - __("Error create '%s' item in report '%s'."), - $values['type'], - $name - ) - ); - } -} - - -function process_upload_xml_report($xml, $group_filter=0) -{ - foreach ($xml->xpath('/report') as $reportElement) { - $values = []; - - if (isset($reportElement->name)) { - $values['name'] = $reportElement->name; - - $posible_name = $values['name']; - $exist = true; - $loops = 30; - // Loops to exit or tries. - while ($exist && $loops > 0) { - $exist = (bool) db_get_row_filter( - 'treport', - ['name' => io_safe_input($posible_name)] - ); - - if ($exist) { - $loops--; - $posible_name = $values['name'].' ('.(30 - $loops).')'; - } - } - - if ($exist) { - ui_print_error_message( - sprintf( - __("Error create '%s' report, the name exist and there aren't free name."), - $reportElement->name - ) - ); - break; - } else if ($loops != 30) { - ui_print_warning_message( - sprintf( - __("Warning create '%s' report, the name exist, the report have a name %s."), - $reportElement->name, - $posible_name - ) - ); - } - - $values['name'] = io_safe_input($posible_name); - } else { - ui_print_error_message(__("Error the report haven't name.")); - break; - } - - if (isset($reportElement->group) === true - && empty($reportElement->group) === false - ) { - $id_group = db_get_value( - 'id_grupo', - 'tgrupo', - 'nombre', - $reportElement->group - ); - if ($id_group === false) { - ui_print_error_message(__("Error the report haven't group.")); - break; - } - } - - if (isset($reportElement->description) === true) { - $values['description'] = $reportElement->description; - } - - $id_report = db_process_sql_insert('treport', $values); - - ui_print_result_message( - $id_report, - sprintf(__("Success create '%s' report."), $posible_name), - sprintf(__("Error create '%s' report."), $posible_name) - ); - - if ($id_report) { - db_pandora_audit( - AUDIT_LOG_REPORT_MANAGEMENT, - 'Create report '.$id_report, - false, - false - ); - } else { - db_pandora_audit( - AUDIT_LOG_REPORT_MANAGEMENT, - 'Fail to create report', - false, - false - ); - break; - } - - foreach ($reportElement->item as $item) { - $item = (array) $item; - - $values = []; - $values['id_report'] = $id_report; - if (isset($item['description']) === true) { - $values['description'] = io_safe_input($item['description']); - } - - if (isset($item['period']) === true) { - $values['period'] = io_safe_input($item['period']); - } - - if (isset($item['type']) === true) { - $values['type'] = io_safe_input($item['type']); - } - - $agents_item = []; - if (isset($item['agent']) === true) { - $agents = agents_get_agents( - ['id_grupo' => $group_filter], - [ - 'id_agente', - 'alias', - ] - ); - - $agent_clean = str_replace( - [ - '[', - ']', - ], - '', - io_safe_output($item['agent']) - ); - $regular_expresion = ($agent_clean != $item['agent']); - - foreach ($agents as $agent) { - if ($regular_expresion) { - if ((bool) preg_match('/'.$agent_clean.'/', io_safe_output($agent['alias']))) { - $agents_item[$agent['id_agente']]['name'] = $agent['alias']; - } - } else { - if ($agent_clean == io_safe_output($agent['alias'])) { - $agents_item[$agent['id_agente']]['name'] = $agent['alias']; - } - } - } - } - - if (isset($item['module']) === true) { - $module_clean = str_replace(['[', ']'], '', $item['module']); - $regular_expresion = ($module_clean != $item['module']); - - foreach ($agents_item as $id => $agent) { - $modules = db_get_all_rows_filter( - 'tagente_modulo', - ['id_agente' => $id], - [ - 'id_agente_modulo', - 'nombre', - ] - ); - - $agents_item[$id]['modules'] = []; - - foreach ($modules as $module) { - if ($regular_expresion) { - if ((bool) preg_match('/'.$module_clean.'/', io_safe_output($module['nombre']))) { - $agents_item[$id]['modules'][$module['id_agente_modulo']]['name'] = $module['nombre']; - } - } else { - if ($module_clean == io_safe_output($module['nombre'])) { - $agents_item[$id]['modules'][$module['id_agente_modulo']]['name'] = $module['nombre']; - } - } - } - } - } - - switch ($item['type']) { - case 2: - case 'custom_graph': - case 'automatic_custom_graph': - $group = db_get_value('id_grupo', 'tgrupo', 'nombre', io_safe_input($item['graph'])); - $values['id_gs'] = $group; - break; - - case 3: - case 'SLA': - if (isset($item['only_display_wrong'])) { - $values['only_display_wrong'] = (string) $item['only_display_wrong']; - } - - if (isset($item['monday'])) { - $values['monday'] = (string) $item['monday']; - } - - if (isset($item['tuesday'])) { - $values['tuesday'] = (string) $item['tuesday']; - } - - if (isset($item['wednesday'])) { - $values['wednesday'] = (string) $item['wednesday']; - } - - if (isset($item['thursday'])) { - $values['thursday'] = (string) $item['thursday']; - } - - if (isset($item['friday'])) { - $values['friday'] = (string) $item['friday']; - } - - if (isset($item['saturday'])) { - $values['saturday'] = (string) $item['saturday']; - } - - if (isset($item['sunday'])) { - $values['sunday'] = (string) $item['sunday']; - } - - if (isset($item['time_from'])) { - $values['time_from'] = (string) $item['time_from']; - } - - if (isset($item['time_to'])) { - $values['time_to'] = (string) $item['time_to']; - } - - $slas = []; - if (!isset($item['sla'])) { - $item['sla'] = []; - } - - foreach ($item['sla'] as $sla_xml) { - if (isset($sla_xml->agent)) { - $agents = agents_get_agents(['id_grupo' => $group_filter], ['id_agente', 'nombre']); - - $agent_clean = str_replace(['[', ']'], '', $sla_xml->agent); - $regular_expresion = ($agent_clean != $sla_xml->agent); - - foreach ($agents as $agent) { - $id_agent = false; - if ($regular_expresion) { - if ((bool) preg_match('/'.$agent_clean.'/', io_safe_output($agent['nombre']))) { - $id_agent = $agent['id_agente']; - } else { - if ($agent_clean == io_safe_output($agent['nombre'])) { - $id_agent = $agent['id_agente']; - } - } - } - - if ($id_agent) { - if (isset($sla_xml->module)) { - $module_clean = str_replace(['[', ']'], '', $sla_xml->module); - $regular_expresion = ($module_clean != $sla_xml->module); - - $modules = db_get_all_rows_filter( - 'tagente_modulo', - ['id_agente' => $id_agent], - [ - 'id_agente_modulo', - 'nombre', - ] - ); - - foreach ($modules as $module) { - if ($regular_expresion) { - if ((bool) preg_match('/'.$module_clean.'/', io_safe_output($module['nombre']))) { - $slas[] = [ - 'id_agent_module' => $module['id_agente_modulo'], - 'sla_max' => (string) $sla_xml->sla_max, - 'sla_min' => (string) $sla_xml->sla_min, - 'sla_limit' => (string) $sla_xml->sla_limit, - ]; - } - } else { - if ($module_clean == io_safe_output($module['nombre'])) { - $slas[] = [ - 'id_agent_module' => $module['id_agente_modulo'], - 'sla_max' => (string) $sla_xml->sla_max, - 'sla_min' => (string) $sla_xml->sla_min, - 'sla_limit' => (string) $sla_xml->sla_limit, - ]; - } - } - } - } - } - } - } - } - break; - - case 'text': - $values['text'] = io_safe_input($item['text']); - break; - - case 'sql': - $values['header_definition'] = io_safe_input($item['header_definition']); - $values['external_source'] = io_safe_input($item['sql']); - break; - - case 'sql_graph_pie': - case 'sql_graph_vbar': - case 'sql_graph_hbar': - $values['header_definition'] = io_safe_input($item['header_definition']); - $values['external_source'] = io_safe_input($item['sql']); - break; - - case 'event_report_group': - $values['id_agent'] = db_get_value('id_grupo', 'tgrupo', 'nombre', io_safe_input($item->group)); - break; - - case 'url': - $values['external_source'] = io_safe_input($item['url']); - break; - - case 'database_serialized': - $values['header_definition'] = io_safe_input($item['header_definition']); - $values['line_separator'] = io_safe_input($item['line_separator']); - $values['column_separator'] = io_safe_input($item['column_separator']); - break; - - case 1: - case 'simple_graph': - case 'simple_baseline_graph': - case 6: - case 'monitor_report': - case 7: - case 'avg_value': - case 8: - case 'max_value': - case 9: - case 'min_value': - case 10: - case 'sumatory': - case 'event_report_module': - case 'alert_report_module': - case 'alert_report_agent': - case 'alert_report_group': - case 'agent_detailed_event': - case 'event_report_agent': - default: - // Do nothing. - break; - } - - if (empty($agents_item) === true) { - $id_content = db_process_sql_insert('treport_content', $values); - ui_print_result_message( - $id_content, - sprintf(__("Success add '%s' content."), $values['type']), - sprintf(__("Error add '%s' action."), $values['type']) - ); - - if ($item['type'] == 'SLA') { - foreach ($slas as $sla) { - $sla['id_report_content'] = $id_content; - $result = db_process_sql_insert('treport_content_sla_combined', $sla); - ui_print_result_message( - $result, - sprintf(__("Success add '%s' SLA."), $sla['id_agent_module']), - sprintf(__("Error add '%s' SLA."), $sla['id_agent_module']) - ); - } - } - } else { - foreach ($agents_item as $id_agent => $agent) { - if (empty($agent['modules'])) { - $values['id_agent'] = $id_agent; - $id_content = db_process_sql_insert('treport_content', $values); - ui_print_result_message( - $id_content, - sprintf(__("Success add '%s' content."), $values['type']), - sprintf(__("Error add '%s' action."), $values['type']) - ); - } else { - foreach ($agent['modules'] as $id_module => $module) { - $values['id_agent_module'] = $id_module; - $values['id_agent'] = $id_agent; - - $id_content = db_process_sql_insert('treport_content', $values); - ui_print_result_message( - $id_content, - sprintf(__("Success add '%s' content."), $values['type']), - sprintf(__("Error add '%s' action."), $values['type']) - ); - } - } - } - } - } - } -} - - -function process_upload_xml_visualmap($xml, $filter_group=0) -{ - global $config; - - foreach ($xml->xpath('/visual_map') as $visual_map) { - if (isset($visual_map->name)) { - $values['name'] = (string) $visual_map->name; - } else { - ui_print_error_message( - __("Error create '%s' visual map, lost tag name.") - ); - break; - } - - $values['id_group'] = 0; - if (isset($visual_map->group)) { - $id_group = db_get_value('id_grupo', 'tgrupo', 'nombre', io_safe_input($visual_map->group)); - if ($id_group !== false) { - $values['id_group'] = $id_group; - } - } - - if (isset($visual_map->background)) { - $values['background'] = (string) $visual_map->background; - } - - $values['width'] = 0; - if (isset($visual_map->width)) { - $values['width'] = (string) $visual_map->width; - } - - $values['height'] = 0; - if (isset($visual_map->height)) { - $values['height'] = (string) $visual_map->height; - } - - $posible_name = $values['name']; - $exist = true; - $loops = 30; - // Loops to exit or tries - while ($exist && $loops > 0) { - $exist = (bool) db_get_row_filter('tlayout', ['name' => io_safe_input($posible_name)]); - - if ($exist) { - $loops--; - $posible_name = $values['name'].' ('.(30 - $loops).')'; - } - } - - if ($exist) { - ui_print_error_message( - sprintf( - __("Error create '%s' visual map, the name exist and there aren't free name."), - $values['name'] - ) - ); - continue; - } else if ($loops != 30) { - ui_print_error_message( - sprintf( - __("Warning create '%s' visual map, the name exist, the report have a name %s."), - $values['name'], - $posible_name - ) - ); - } - - $values['name'] = io_safe_input($posible_name); - $id_visual_map = db_process_sql_insert('tlayout', $values); - - ui_print_result_message( - (bool) $id_visual_map, - sprintf(__("Success create '%s' visual map."), $posible_name), - sprintf(__("Error create '%s' visual map."), $posible_name) - ); - - if ($id_visual_map !== false) { - db_pandora_audit( - AUDIT_LOG_VISUAL_CONSOLE_MANAGEMENT, - sprintf('Create Visual Console #%s', $id_visual_map), - $config['id_user'] - ); - } else { - break; - } - - $relation_other_ids = []; - - foreach ($visual_map->item as $item) { - $no_agents = true; - - if (isset($item->agent)) { - $agent_clean = str_replace(['[', ']'], '', $item->agent); - $regular_expresion = ($agent_clean != $item->agent); - - $agents = agents_get_agents(['id_grupo' => $filter_group], ['id_agente', 'nombre']); - if ($agents === false) { - $agents = []; - } - - $temp = []; - foreach ($agents as $agent) { - $temp[$agent['id_agente']] = $agent['nombre']; - } - - $agents = $temp; - - $agents_in_item = []; - foreach ($agents as $id => $agent) { - if ($regular_expresion) { - if ((bool) preg_match('/'.$agent_clean.'/', io_safe_output($agent))) { - $agents_in_item[$id]['name'] = $agent; - $no_agents = false; - } - } else { - if ($agent_clean == io_safe_output($agent)) { - $agents_in_item[$id]['name'] = $agent; - $no_agents = false; - break; - } - } - } - } - - $no_modules = true; - if (isset($item->module)) { - $module_clean = str_replace(['[', ']'], '', $item->module); - $regular_expresion = ($module_clean != $item->module); - - foreach ($agents_in_item as $id => $agent) { - $modules = db_get_all_rows_filter( - 'tagente_modulo', - ['id_agente' => $id], - [ - 'id_agente_modulo', - 'nombre', - ] - ); - - $modules_in_item = []; - foreach ($modules as $module) { - if ($regular_expresion) { - if ((bool) preg_match('/'.$module_clean.'/', io_safe_output($module['nombre']))) { - $modules_in_item[$module['id_agente_modulo']] = $module['nombre']; - $no_modules = false; - } - } else { - if ($module_clean == io_safe_output($module['nombre'])) { - $modules_in_item[$module['id_agente_modulo']] = $module['nombre']; - $no_modules = false; - break; - } - } - } - - $agents_in_item[$id]['modules'] = $modules_in_item; - } - } - - $values = []; - - $values['id_layout'] = $id_visual_map; - if (isset($item->label)) { - $values['label'] = io_safe_input($item->label); - } - - if (isset($item->x)) { - $values['pos_x'] = (string) $item->x; - } - - if (isset($item->y)) { - $values['pos_y'] = (string) $item->y; - } - - if (isset($item->height)) { - $values['height'] = (string) $item->height; - } - - if (isset($item->width)) { - $values['width'] = (string) $item->width; - } - - if (isset($item->image)) { - $values['image'] = (string) $item->image; - } - - if (isset($item->period)) { - $values['period'] = (string) $item->period; - } - - if (isset($item->parent_item)) { - // Hack for link the items use the OTHER_ID - // and have too OTHER_ID - // then $relation_other_ids[OTHER_ID] have the item_id in DB. - $values['parent_item'] = (string) $relation_other_ids[(string) $item->parent_item]; - } - - if (isset($item->map_linked)) { - $values['id_layout_linked'] = (string) $item->map_linked; - } - - if (isset($item->type)) { - $values['type'] = (string) $item->type; - } - - if (isset($item->clock_animation)) { - $values['clock_animation'] = (string) $item->clock_animation; - } - - if (isset($item->fill_color)) { - $values['fill_color'] = (string) $item->fill_color; - } - - if (isset($item->type_graph)) { - $values['type_graph'] = (string) $item->type_graph; - } - - if (isset($item->time_format)) { - $values['time_format'] = (string) $item->time_format; - } - - if (isset($item->timezone)) { - $values['timezone'] = (string) $item->timezone; - } - - if (isset($item->border_width)) { - $values['border_width'] = (string) $item->border_width; - } - - if (isset($item->border_color)) { - $values['border_color'] = (string) $item->border_color; - } - - if ($no_agents) { - $id_item = db_process_sql_insert('tlayout_data', $values); - - ui_print_result_message( - (bool) $id_item, - sprintf(__("Success create item type '%d' visual map."), $values['type']), - sprintf(__("Error create item type '%d' visual map."), $values['type']) - ); - - if ($id_item !== false) { - db_pandora_audit( - AUDIT_LOG_VISUAL_CONSOLE_MANAGEMENT, - sprintf('Create Item %s in Visual Console #%s', $id_item, $values['id_layout']), - $config['id_user'] - ); - } - } else { - foreach ($agents_in_item as $id => $agent) { - if ($no_modules) { - $values['id_agent'] = $id; - - $id_item = db_process_sql_insert('tlayout_data', $values); - - if (isset($item->other_id) === true) { - $relation_other_ids[(string) $item->other_id] = $id_item; - } - - ui_print_result_message( - (bool) $id_item, - sprintf(__("Success create item for agent '%s' visual map."), $agent['name']), - sprintf(__("Error create item for agent '%s' visual map."), $agent['name']) - ); - - if ($id_item !== false) { - db_pandora_audit( - AUDIT_LOG_VISUAL_CONSOLE_MANAGEMENT, - sprintf('Create Item %s in Visual Console #%s', $id_item, $values['id_layout']), - $config['id_user'] - ); - } - } else { - // TODO: Review this else. - foreach ($agent['modules'] as $id_module => $module) { - $values['id_agent'] = $id; - $values['id_agente_modulo'] = $id_module; - - db_process_sql_insert('tlayout_data', $values); - - ui_print_result_message( - (bool) $id_item, - sprintf(__("Success create item for agent '%s' visual map."), $agent['name']), - sprintf(__("Error create item for agent '%s' visual map."), $agent['name']) - ); - - if ($id_item !== false) { - db_pandora_audit( - AUDIT_LOG_VISUAL_CONSOLE_MANAGEMENT, - sprintf('Create Item %s in Visual Console #%s', $id_item, $values['id_layout']), - $config['id_user'] - ); - } - } - } - } - } - } - } -} - - -function process_upload_xml_component($xml) -{ - // Extract components. - $components = []; - foreach ($xml->xpath('/component') as $componentElement) { - $name = io_safe_input((string) $componentElement->name); - $id_os = (int) $componentElement->id_os; - $os_version = io_safe_input((string) $componentElement->os_version); - $data = io_safe_input((string) $componentElement->data); - $type = (int) $componentElement->type; - $group = (int) $componentElement->group; - $description = io_safe_input((string) $componentElement->description); - $module_interval = (int) $componentElement->module_interval; - $max = (float) $componentElement->max; - $min = (float) $componentElement->min; - $tcp_send = io_safe_input((string) $componentElement->tcp_send); - $tcp_rcv_text = io_safe_input((string) $componentElement->tcp_rcv_text); - $tcp_port = (int) $componentElement->tcp_port; - $snmp_oid = io_safe_input((string) $componentElement->snmp_oid); - $snmp_community = io_safe_input((string) $componentElement->snmp_community); - $id_module_group = (int) $componentElement->id_module_group; - $module_source = (int) $componentElement->module_source; - $plugin = (int) $componentElement->plugin; - $plugin_username = io_safe_input((string) $componentElement->plugin_username); - $plugin_password = io_safe_input((string) $componentElement->plugin_password); - $plugin_parameters = io_safe_input((string) $componentElement->plugin_parameters); - $max_timeout = (int) $componentElement->max_timeout; - $max_retries = (int) $componentElement->max_retries; - $historical_data = (int) $componentElement->historical_data; - $dynamic_interval = (int) $componentElement->dynamic_interval; - $dynamic_min = (int) $componentElement->dynamic_min; - $dynamic_max = (int) $componentElement->dynamic_max; - $dynamic_two_tailed = (int) $componentElement->dynamic_two_tailed; - $min_war = (float) $componentElement->min_war; - $max_war = (float) $componentElement->max_war; - $str_war = (string) $componentElement->str_war; - $min_cri = (float) $componentElement->min_cri; - $max_cri = (float) $componentElement->max_cri; - $str_cri = (string) $componentElement->str_cri; - $ff_treshold = (int) $componentElement->ff_treshold; - $snmp_version = (int) $componentElement->snmp_version; - $auth_user = io_safe_input((string) $componentElement->auth_user); - $auth_password = io_safe_input((string) $componentElement->auth_password); - $auth_method = io_safe_input((string) $componentElement->auth_method); - $privacy_method = io_safe_input((string) $componentElement->privacy_method); - $privacy_pass = io_safe_input((string) $componentElement->privacy_pass); - $security_level = io_safe_input((string) $componentElement->security_level); - $wmi_query = io_safe_input((string) $componentElement->wmi_query); - $key_string = io_safe_input((string) $componentElement->key_string); - $field_number = (int) $componentElement->field_number; - $namespace = io_safe_input((string) $componentElement->namespace); - $wmi_user = io_safe_input((string) $componentElement->wmi_user); - $wmi_password = io_safe_input((string) $componentElement->wmi_password); - $post_process = io_safe_input((float) $componentElement->post_process); - - $idComponent = false; - switch ((int) $componentElement->module_source) { - case 1: - // Local component. - $values = [ - 'description' => $description, - 'id_network_component_group' => $group, - 'os_version' => $os_version, - ]; - $return = enterprise_hook('local_components_create_local_component', [$name, $data, $id_os, $values]); - if ($return !== ENTERPRISE_NOT_HOOK) { - $idComponent = $return; - } - break; - - case 2: - // Network component - // for modules - // 15 = remote_snmp, 16 = remote_snmp_inc, - // 17 = remote_snmp_string, 18 = remote_snmp_proc. - $custom_string_1 = ''; - $custom_string_2 = ''; - $custom_string_3 = ''; - if ($type >= 15 && $type <= 18) { - // New support for snmp v3. - $tcp_send = $snmp_version; - $plugin_user = $auth_user; - $plugin_pass = $auth_password; - $plugin_parameters = $auth_method; - $custom_string_1 = $privacy_method; - $custom_string_2 = $privacy_pass; - $custom_string_3 = $security_level; - } - - $idComponent = network_components_create_network_component( - $name, - $type, - $group, - [ - 'description' => $description, - 'module_interval' => $module_interval, - 'max' => $max, - 'min' => $min, - 'tcp_send' => $tcp_send, - 'tcp_rcv' => $tcp_rcv_text, - 'tcp_port' => $tcp_port, - 'snmp_oid' => $snmp_oid, - 'snmp_community' => $snmp_community, - 'id_module_group' => $id_module_group, - 'id_modulo' => $module_source, - 'id_plugin' => $plugin, - 'plugin_user' => $plugin_username, - 'plugin_pass' => $plugin_password, - 'plugin_parameter' => $plugin_parameters, - 'max_timeout' => $max_timeout, - 'max_retries' => $max_retries, - 'history_data' => $historical_data, - 'dynamic_interval' => $dynamic_interval, - 'dynamic_min' => $dynamic_min, - 'dynamic_max' => $dynamic_max, - 'dynamic_two_tailed' => $dynamic_two_tailed, - 'min_warning' => $min_war, - 'max_warning' => $max_war, - 'str_warning' => $str_war, - 'min_critical' => $min_cri, - 'max_critical' => $max_cri, - 'str_critical' => $str_cri, - 'min_ff_event' => $ff_treshold, - 'custom_string_1' => $custom_string_1, - 'custom_string_2' => $custom_string_2, - 'custom_string_3' => $custom_string_3, - 'post_process' => $post_process, - ] - ); - if ((bool) $idComponent === true) { - $components[] = $idComponent; - } - break; - - case 4: - // Plugin component. - $idComponent = network_components_create_network_component( - $name, - $type, - $group, - [ - 'description' => $description, - 'module_interval' => $module_interval, - 'max' => $max, - 'min' => $min, - 'tcp_send' => $tcp_send, - 'tcp_rcv' => $tcp_rcv_text, - 'tcp_port' => $tcp_port, - 'snmp_oid' => $snmp_oid, - 'snmp_community' => $snmp_community, - 'id_module_group' => $id_module_group, - 'id_modulo' => $module_source, - 'id_plugin' => $plugin, - 'plugin_user' => $plugin_username, - 'plugin_pass' => $plugin_password, - 'plugin_parameter' => $plugin_parameters, - 'max_timeout' => $max_timeout, - 'max_retries' => $max_retries, - 'history_data' => $historical_data, - 'dynamic_interval' => $dynamic_interval, - 'dynamic_min' => $dynamic_min, - 'dynamic_max' => $dynamic_max, - 'dynamic_two_tailed' => $dynamic_two_tailed, - 'min_warning' => $min_war, - 'max_warning' => $max_war, - 'str_warning' => $str_war, - 'min_critical' => $min_cri, - 'max_critical' => $max_cri, - 'str_critical' => $str_cri, - 'min_ff_event' => $ff_treshold, - 'custom_string_1' => $custom_string_1, - 'custom_string_2' => $custom_string_2, - 'custom_string_3' => $custom_string_3, - 'post_process' => $post_process, - ] - ); - if ((bool) $idComponent === true) { - $components[] = $idComponent; - } - break; - - case 6: - // WMI component. - $idComponent = network_components_create_network_component( - $name, - $type, - $group, - [ - 'description' => $description, - 'module_interval' => $module_interval, - 'max' => $max, - 'min' => $min, - 'tcp_send' => $namespace, - // work around - 'tcp_rcv' => $tcp_rcv_text, - 'tcp_port' => $field_number, - // work around - 'snmp_oid' => $wmi_query, - // work around - 'snmp_community' => $key_string, - // work around - 'id_module_group' => $id_module_group, - 'id_modulo' => $module_source, - 'id_plugin' => $plugin, - 'plugin_user' => $wmi_user, - // work around - 'plugin_pass' => $wmi_password, - // work around - 'plugin_parameter' => $plugin_parameters, - 'max_timeout' => $max_timeout, - 'max_retries' => $max_retries, - 'history_data' => $historical_data, - 'dynamic_interval' => $dynamic_interval, - 'dynamic_min' => $dynamic_min, - 'dynamic_max' => $dynamic_max, - 'dynamic_two_tailed' => $dynamic_two_tailed, - 'min_warning' => $min_war, - 'max_warning' => $max_war, - 'str_warning' => $str_war, - 'min_critical' => $min_cri, - 'max_critical' => $max_cri, - 'str_critical' => $str_cri, - 'min_ff_event' => $ff_treshold, - 'custom_string_1' => $custom_string_1, - 'custom_string_2' => $custom_string_2, - 'custom_string_3' => $custom_string_3, - 'post_process' => $post_process, - ] - ); - if ((bool) $idComponent === true) { - $components[] = $idComponent; - } - break; - - case 5: - // Prediction component. - case 7: - // Web component. - default: - // Do nothing. - break; - } - - ui_print_result_message( - (bool) $idComponent, - sprintf(__("Success create '%s' component."), $name), - sprintf(__("Error create '%s' component."), $name) - ); - } - - // Extract the template. - $templateElement = $xml->xpath('//template'); - if (empty($templateElement) === false) { - $templateElement = $templateElement[0]; - - $templateName = (string) $templateElement->name; - $templateDescription = (string) $templateElement->description; - - $idTemplate = db_process_sql_insert('tnetwork_profile', ['name' => $templateName, 'description' => $templateDescription]); - - $result = false; - if ((bool) $idTemplate) { - foreach ($components as $idComponent) { - db_process_sql_insert('tnetwork_profile_component', ['id_nc' => $idComponent, 'id_np' => $idTemplate]); - } - } - } -} - - -function process_upload_xml($xml) -{ - $hook_enterprise = enterprise_include('extensions/resource_registration/functions.php'); - - // Extract component. - process_upload_xml_component($xml); - - $group_filter = get_parameter('group'); - - // Extract visual map. - process_upload_xml_visualmap($xml, $group_filter); - - // Extract policies. - if ($hook_enterprise === true) { - $centralized_management = is_management_allowed(); - if ($centralized_management === true) { - process_upload_xml_policy($xml, $group_filter); - } - } - - // Extract reports. - process_upload_xml_report($xml, $group_filter); -} - - -function resource_registration_extension_main() -{ - global $config; - - if (! check_acl($config['id_user'], 0, 'PM') && ! is_user_admin($config['id_user'])) { - db_pandora_audit( - AUDIT_LOG_ACL_VIOLATION, - 'Trying to access Setup Management' - ); - include 'general/noaccess.php'; - return; - } - - include_once $config['homedir'].'/include/functions_network_components.php'; - include_once $config['homedir'].'/include/functions_db.php'; - enterprise_include_once('include/functions_local_components.php'); - - ui_print_standard_header( - __('Resource registration'), - 'images/extensions.png', - false, - '', - true, - [], - [ - [ - 'link' => '', - 'label' => __('Resources'), - ], - [ - 'link' => '', - 'label' => __('Resource registration'), - ], - ] - ); - - if (extension_loaded('libxml') === false) { - ui_print_error_message(_('Error, please install the PHP libXML in the system.')); - - return; - } - - if (is_management_allowed() === false) { - if (is_metaconsole() === false) { - $url = ''.__('metaconsole').''; - } else { - $url = __('any node'); - } - - ui_print_warning_message( - __( - 'This node is configured with centralized mode. Go to %s to create a policy.', - $url - ) - ); - - return; - } - - ui_print_warning_message( - __('This extension makes registering resource templates easier.').'
'.__('Here you can upload a resource template in .ptr format.').'
'.__('Please refer to our documentation for more information on how to obtain and use %s resources.', get_product_name()).' '.'

'.__('You can get more resurces in our Public Resource Library') - ); - - $table = new stdClass(); - $table->class = 'databox filter-table-adv'; - $table->id = 'resource_registration_table'; - - $table->data = []; - - $table->data[0][] = html_print_label_input_block( - __('File to upload'), - html_print_input_file('resource_upload', true) - ); - - $table->data[0][] = html_print_label_input_block( - __('Group filter'), - html_print_select_groups(false, 'AW', true, 'group', '', '', __('All'), 0, true) - ); - - // Upload form. - echo '
'; - html_print_table($table); - html_print_action_buttons( - html_print_submit_button( - __('Upload'), - 'upload', - false, - [ 'icon' => 'wand' ], - true - ), - ['type' => 'form_action'] - ); - echo '
'; - /* - echo ''; - echo ''; - echo "'; - echo ''; - echo "'; - echo '
"; - echo ''.__('Group filter: ').''; - html_print_select_groups(false, 'AW', true, 'group'); - echo '"; - echo '
';*/ - - if (isset($_FILES['resource_upload']['tmp_name']) === false) { - return; - } - - $xml = simplexml_load_file($_FILES['resource_upload']['tmp_name'], null, LIBXML_NOCDATA); - - if ($xml === false) { - ui_print_error_message( - __('Error uploading resource. Check if the selected file is a valid resource template in .ptr format') - ); - } else { - process_upload_xml($xml); - } -} - - -extensions_add_godmode_menu_option(__('Resource registration'), 'PM', 'gagente', '', 'v1r1'); -extensions_add_godmode_function('resource_registration_extension_main'); diff --git a/pandora_console/extras/delete_files/delete_files.txt b/pandora_console/extras/delete_files/delete_files.txt index f3eada8070..b3fbea46dd 100644 --- a/pandora_console/extras/delete_files/delete_files.txt +++ b/pandora_console/extras/delete_files/delete_files.txt @@ -1736,3 +1736,5 @@ extensions/files_repo/sql/files_repo.oracle.sql extensions/files_repo/sql/files_repo.postgreSQL.sql extensions/files_repo/sql/files_repo.sql extensions/files_repo +extensions/resource_exportation.php +extensions/resource_registration.php diff --git a/pandora_console/extras/discovery/DiscoveryApplicationsMigrateCodes.ini b/pandora_console/extras/discovery/DiscoveryApplicationsMigrateCodes.ini index d05611a6b5..ea136c996c 100644 --- a/pandora_console/extras/discovery/DiscoveryApplicationsMigrateCodes.ini +++ b/pandora_console/extras/discovery/DiscoveryApplicationsMigrateCodes.ini @@ -1,5 +1,5 @@ pandorafms.vmware=248788e0fb2cd4e11623e4a52ee7d05b -pandorafms.mysql=fadb4750d18285c0eca34f47c6aa3cfe +pandorafms.mysql=ca7dd8b80a1a03a25eb0fb077818ad63 pandorafms.mssql=1cc215409741d19080269ffba112810e pandorafms.oracle=abdfd7280f76276f696115cabdac731e pandorafms.db2=122f2abff0ec1d668c35ee0911483021 diff --git a/pandora_console/extras/mr/68.sql b/pandora_console/extras/mr/68.sql index 67ce78c9bc..b41f6c3e6c 100644 --- a/pandora_console/extras/mr/68.sql +++ b/pandora_console/extras/mr/68.sql @@ -40,9 +40,6 @@ CREATE TABLE IF NOT EXISTS `tmerge_queries` ( ALTER TABLE `tmerge_queries` CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci; --- Update version for plugin oracle -UPDATE `tdiscovery_apps` SET `version` = '1.2' WHERE `short_name` = 'pandorafms.oracle'; - ALTER TABLE `tevent_sound` MODIFY COLUMN `name` text NULL; ALTER TABLE `tevent_sound` MODIFY COLUMN `sound` text NULL; ALTER TABLE `treport_content` MODIFY COLUMN `use_prefix_notation` tinyint unsigned NOT NULL DEFAULT 1; @@ -56,7 +53,50 @@ ADD COLUMN `id_agent_data` int not null default 0 AFTER `script_type`; ALTER TABLE `tusuario` CHANGE COLUMN `metaconsole_data_section` `metaconsole_data_section` TEXT NOT NULL DEFAULT '' ; ALTER TABLE `tmensajes` ADD COLUMN `icon_notification` VARCHAR(250) NULL DEFAULT NULL AFTER `url`; +ALTER TABLE `tagente_modulo` ADD COLUMN `disabled_by_safe_mode` TINYINT UNSIGNED NOT NULL DEFAULT 0; + UPDATE `tncm_template` SET `vendors` = CONCAT('["', TRIM(BOTH '"' FROM TRIM(BOTH ']' FROM TRIM(BOTH '[' FROM vendors))), '"]'), `models` = CONCAT('["', TRIM(BOTH '"' FROM TRIM(BOTH ']' FROM TRIM(BOTH '[' FROM models))), '"]'); UPDATE `tncm_agent_data_template` SET `vendors` = CONCAT('["', TRIM(BOTH '"' FROM TRIM(BOTH ']' FROM TRIM(BOTH '[' FROM vendors))), '"]'), `models` = CONCAT('["', TRIM(BOTH '"' FROM TRIM(BOTH ']' FROM TRIM(BOTH '[' FROM models))), '"]'); +-- Update version for plugin oracle +UPDATE `tdiscovery_apps` SET `version` = '1.2' WHERE `short_name` = 'pandorafms.oracle'; +-- Update version for plugin mysql +UPDATE `tdiscovery_apps` SET `version` = '1.1' WHERE `short_name` = 'pandorafms.mysql'; + + +SET @widget_id = NULL; +SELECT @widget_id := `id` FROM `twidget` WHERE `unique_name` = 'GisMap'; +INSERT IGNORE INTO `twidget` (`id`,`class_name`,`unique_name`,`description`,`options`,`page`) VALUES (@widget_id,'GisMap','GisMap','Gis map','','GisMap.php'); + +SET @class_name = 'ITSMIncidences'; +SET @unique_name = 'ITSMIncidences'; +SET @description = 'Pandora ITSM tickets'; +SET @page = 'ITSMIncidences.php'; +SET @widget_id = NULL; +SELECT @widget_id := `id` FROM `twidget` WHERE `unique_name` = @unique_name; +INSERT IGNORE INTO `twidget` (`id`,`class_name`,`unique_name`,`description`,`options`,`page`) VALUES (@widget_id,@class_name,@unique_name,@description,'',@page); + +-- Create SNMPv3 credentials for recon tasks and update them +SET @creds_name = 'Recon-SNMP-creds-'; +INSERT IGNORE INTO `tcredential_store` (`identifier`, `id_group`, `product`, `extra_1`) + SELECT + CONCAT(@creds_name,`id_rt`) AS `identifier`, + `id_group`, + 'SNMP' AS `product`, + CONCAT( + '{', + '"community":"',`snmp_community`,'",', + '"version":"',`snmp_version`,'",', + '"securityLevelV3":"',`snmp_security_level`,'",', + '"authUserV3":"',`snmp_auth_user`,'",', + '"authMethodV3":"',`snmp_auth_method`,'",', + '"authPassV3":"',`snmp_auth_pass`,'",', + '"privacyMethodV3":"',`snmp_privacy_method`,'",', + '"privacyPassV3":"',`snmp_privacy_pass`,'"', + '}' + ) AS `extra1` + FROM `trecon_task` WHERE `snmp_version` = 3 AND `snmp_enabled` = 1 +; +UPDATE `trecon_task` SET `auth_strings` = IF(`auth_strings` = '',CONCAT(@creds_name,`id_rt`),CONCAT(@creds_name,`id_rt`,',',`auth_strings`)) WHERE `snmp_version` = 3 AND `snmp_enabled` = 1; + COMMIT; \ No newline at end of file diff --git a/pandora_console/general/header.php b/pandora_console/general/header.php index 35b994fead..e2573bd859 100644 --- a/pandora_console/general/header.php +++ b/pandora_console/general/header.php @@ -54,7 +54,7 @@ echo sprintf('
', $menuTypeClass); // ======= Servers List =============================================== if ((bool) check_acl($config['id_user'], 0, 'AW') !== false) { $servers = []; - $servers['all'] = (int) db_get_value('COUNT(id_server)', 'tserver'); + $servers['all'] = (int) count((servers_get_info() ?? [])); if ($servers['all'] != 0) { $servers['up'] = (int) servers_check_status(); $servers['down'] = ($servers['all'] - $servers['up']); diff --git a/pandora_console/godmode/agentes/agent_manager.php b/pandora_console/godmode/agentes/agent_manager.php index 283610e06a..18722508e9 100644 --- a/pandora_console/godmode/agentes/agent_manager.php +++ b/pandora_console/godmode/agentes/agent_manager.php @@ -357,7 +357,18 @@ if ($new_agent === false) { $tableAgent->data['caption_name'][0] = __('Agent name'); $tableAgent->rowclass['name'] = 'w540px'; $tableAgent->cellstyle['name'][0] = 'width: 100%;'; - $tableAgent->data['name'][0] = html_print_input_text('agente', $nombre_agente, '', 76, 100, true, false, false, '', 'w100p'); + $tableAgent->data['name'][0] = html_print_input_text( + 'agente', + $nombre_agente, + '', + 76, + 100, + true, + true, + false, + '', + 'w100p' + ); $tableAgent->data['name'][0] .= html_print_div( [ 'class' => 'moduleIdBox', @@ -365,6 +376,29 @@ if ($new_agent === false) { ], true ); + + // Other than Linux, Solaris, AIX, BSD, HPUX, MacOs, and Windows. + if ($id_os !== LINUX && $id_os !== SOLARIS && $id_os !== AIX + && $id_os !== BSD && $id_os !== HPUX && $id_os !== MACOS + && $id_os !== WINDOWS + ) { + $tableAgent->data['name'][0] .= html_print_anchor( + [ + 'content' => html_print_image( + 'images/edit.svg', + true, + [ + 'border' => 0, + 'title' => __('Edit agent name'), + 'class' => 'main_menu_icon invert_filter after_input_icon forced_title clickable', + 'onclick' => 'editAgent()', + ] + ), + ], + true + ); + } + // Agent options for QR code. $agent_options_update = 'agent_options_update'; } @@ -674,6 +708,19 @@ if (enterprise_installed()) { } } + if ($id_os === '1') { + $modules = $agent_plugin->getModules(); + foreach ($modules as $key => $row) { + if (preg_match('/Syslog/', $row['raw']) === 1) { + if ($row['disabled'] === 1) { + $enable_log_collector = 0; + } else { + $enable_log_collector = 1; + } + } + } + } + if ($id_os === '9') { $modules = $agent_plugin->getModules(); foreach ($modules as $key => $row) { @@ -1478,7 +1525,6 @@ ui_require_jquery_file('bgiframe'); 128 ); } - $("#text-agente").prop('readonly', true); $("#text-direccion").on('change',function(e){ @@ -1525,6 +1571,39 @@ ui_require_jquery_file('bgiframe'); } } + function editAgent() { + $(`#text-agente`).attr(`readonly`, false); + const title = ''; + const text = ''; + const id = uniqId(); + $("body").append('
'); + $("#" + id).empty(); + $("#" + id).append(text); + $("#" + id).dialog({ + height: 150, + width: 528, + opacity: 1, + modal: true, + position: { + my: "center", + at: "center", + of: window, + collision: "fit" + }, + title: title, + closeOnEscape: true, + buttons: [{ + text: "OK", + click: function() { + $(this).dialog("close"); + } + }], + open: function(event, ui) { + $(".ui-dialog-titlebar-close").hide(); + }, + }).show(); + } + function check_unique_ip() { const direccion = $('#text-direccion').val(); diff --git a/pandora_console/godmode/agentes/configurar_agente.php b/pandora_console/godmode/agentes/configurar_agente.php index c2e3a2f4f6..c6b5f2b691 100644 --- a/pandora_console/godmode/agentes/configurar_agente.php +++ b/pandora_console/godmode/agentes/configurar_agente.php @@ -949,6 +949,13 @@ if ($update_agent) { $mssg_warning = 0; $id_agente = (int) get_parameter_post('id_agente'); $nombre_agente = str_replace('`', '‘', (string) get_parameter_post('agente', '')); + $repeated_name = db_get_row_sql( + sprintf( + 'SELECT nombre FROM tagente WHERE id_agente <> %s AND nombre like "%s"', + $id_agente, + $nombre_agente + ) + ); $alias_safe_output = strip_tags(io_safe_output(get_parameter('alias', ''))); $alias = io_safe_input(trim(preg_replace('/[\/\\\|%#&$]/', '', $alias_safe_output))); $alias_as_name = (int) get_parameter_post('alias_as_name', 0); @@ -1077,14 +1084,17 @@ if ($update_agent) { } } + // Verify if there is another agent with the same name but different ID. + if (empty($repeated_name) === false) { + ui_print_error_message(__('Agent with repeated name')); + } + if ($mssg_warning) { ui_print_warning_message(__('The ip or dns name entered cannot be resolved')); } - // Verify if there is another agent with the same name but different ID. if ($alias == '') { ui_print_error_message(__('No agent alias specified')); - // If there is an agent with the same name, but a different ID. } $old_group = agents_get_agent_group($id_agente); @@ -1139,13 +1149,16 @@ if ($update_agent) { 'ignore_unknown' => $ignore_unknown, ]; + if (empty($repeated_name) === true) { + $values['nombre'] = $nombre_agente; + } + if ($config['metaconsole_agent_cache'] == 1) { $values['update_module_count'] = 1; // Force an update of the agent cache. } - $result = db_process_sql_update('tagente', $values, ['id_agente' => $id_agente]); - + $result = (bool) db_process_sql_update('tagente', $values, ['id_agente' => $id_agente]); if ($result === false && $update_custom_result == false) { ui_print_error_message( __('There was a problem updating the agent') @@ -1299,8 +1312,11 @@ if ($update_agent) { } $modules = $agent->getModules(); + foreach ($modules as $key => $row) { - if (preg_match('/PandoraAgent_log/', $row['raw']) === 1) { + if (preg_match('/PandoraAgent_log/', $row['raw']) === 1 + || ($id_os === 1 && preg_match('/Syslog/', $row['raw']) === 1) + ) { if ($enable_log_collector === 1) { if ($row['disabled'] === 1) { $agent->enableModule($row['module_name'], $row); diff --git a/pandora_console/godmode/agentes/modificar_agente.php b/pandora_console/godmode/agentes/modificar_agente.php index a7ee6bf4c0..b0f071c1b4 100644 --- a/pandora_console/godmode/agentes/modificar_agente.php +++ b/pandora_console/godmode/agentes/modificar_agente.php @@ -697,7 +697,7 @@ if ($agents !== false) { $tableAgents->head = []; $tableAgents->data = []; // Header. - $tableAgents->head[0] = ''.__('Agent name').''; + $tableAgents->head[0] = ''.__('Agent alias').''; $tableAgents->head[0] .= ui_get_sorting_arrows($url_up_agente, $url_down_agente, $selectNameUp, $selectNameDown); $tableAgents->head[1] = ''.__('R').''; $tableAgents->head[1] .= ui_get_sorting_arrows($url_up_remote, $url_down_remote, $selectRemoteUp, $selectRemoteDown); diff --git a/pandora_console/godmode/agentes/module_manager_editor.php b/pandora_console/godmode/agentes/module_manager_editor.php index 130f31c79d..543d241fc9 100644 --- a/pandora_console/godmode/agentes/module_manager_editor.php +++ b/pandora_console/godmode/agentes/module_manager_editor.php @@ -150,7 +150,7 @@ if (is_ajax()) { $component = db_get_row('tlocal_component', 'id', $id_component); foreach ($component as $index => $element) { $component[$index] = html_entity_decode( - $element, + (isset($element) === true) ? $element : '', ENT_QUOTES, 'UTF-8' ); diff --git a/pandora_console/godmode/agentes/module_manager_editor_common.php b/pandora_console/godmode/agentes/module_manager_editor_common.php index 47c843f2d9..a9d809d29f 100644 --- a/pandora_console/godmode/agentes/module_manager_editor_common.php +++ b/pandora_console/godmode/agentes/module_manager_editor_common.php @@ -505,7 +505,7 @@ $tableBasicThresholds->data['caption_switch_warning_inverse_string'][0] = html_p $tableBasicThresholds->data['caption_warning_threshold'][0] .= '('.__('Str.').')'; $tableBasicThresholds->data['warning_threshold'][0] .= html_print_input_text( 'str_warning', - str_replace('"', '', $str_warning), + str_replace('"', '', (isset($str_warning) === true) ? $str_warning : ''), '', 10, 1024, @@ -602,7 +602,7 @@ $tableBasicThresholds->data['switch_critical_threshold'][0] .= html_print_div( $tableBasicThresholds->data['caption_critical_threshold'][0] .= '('.__('Str.').')'; $tableBasicThresholds->data['critical_threshold'][0] .= html_print_input_text( 'str_critical', - str_replace('"', '', $str_critical), + str_replace('"', '', (isset($str_critical) === true) ? $str_critical : ''), '', 10, 1024, diff --git a/pandora_console/godmode/agentes/module_manager_editor_plugin.php b/pandora_console/godmode/agentes/module_manager_editor_plugin.php index 9b5d98c27d..affa225969 100644 --- a/pandora_console/godmode/agentes/module_manager_editor_plugin.php +++ b/pandora_console/godmode/agentes/module_manager_editor_plugin.php @@ -60,7 +60,12 @@ $data[1] = html_print_select_from_sql( $disabledBecauseInPolicy ); // Store the macros in base64 into a hidden control to move between pages -$data[1] .= html_print_input_hidden('macros', base64_encode($macros), true); +$data[1] .= html_print_input_hidden( + 'macros', + (isset($macros) === true) ? base64_encode($macros) : '', + true +); + $table_simple->colspan['plugin_1'][2] = 2; if (!empty($id_plugin)) { @@ -159,12 +164,13 @@ foreach ($password_fields as $k => $p) { return; } - const moduleId = ; - + const moduleId = 0) ? $module['id'] : $id_agent_module; ?>; + const isPolicy = 0) ? '1' : '0'; ?>; + load_plugin_description($("#id_plugin").val()); - - load_plugin_macros_fields('simple-macro', moduleId); - + + load_plugin_macros_fields('simple-macro', moduleId, isPolicy); + forced_title_callback(); $('select#id_plugin').select2('close'); diff --git a/pandora_console/godmode/groups/group_list.php b/pandora_console/godmode/groups/group_list.php index 66717bc35b..f1b40867d9 100644 --- a/pandora_console/godmode/groups/group_list.php +++ b/pandora_console/godmode/groups/group_list.php @@ -560,13 +560,13 @@ if ($is_management_allowed === true && $update_group === true) { } } +$id_group = (int) get_parameter('id_group'); + // Delete group. if ($is_management_allowed === true && $delete_group === true - && ((bool) check_acl($config['id_user'], 0, 'PM') === true) + && ((bool) check_acl($config['id_user'], $id_group, 'PM') === true) ) { - $id_group = (int) get_parameter('id_group'); - $usedGroup = groups_check_used($id_group); if (!$usedGroup['return']) { @@ -880,6 +880,28 @@ if ($tab == 'tree') { echo "
"; + if (users_can_manage_group_all('AR') === false) { + $user_groups_acl = users_get_groups(false, 'AR'); + $groups_acl = implode('","', $user_groups_acl); + if (empty($groups_acl) === true) { + $is_management_allowed = false; + } + } + + html_print_div( + [ + 'content' => ui_print_info_message( + [ + 'no_close' => true, + 'message' => __('There are no defined groups'), + ], + '', + true + ), + 'class' => 'invisible', + 'id' => 'message-tree-info', + ] + ); } else { /* * Group list view. @@ -1246,7 +1268,7 @@ $tab = 'group_edition'; treeController.init({ recipient: $("div#tree-controller-recipient"), page: parameters['page'], - emptyMessage: "", + emptyMessage: $("#message-tree-info").html(), foundMessage: "", tree: data.tree, baseURL: "", diff --git a/pandora_console/godmode/massive/massive_edit_agents.php b/pandora_console/godmode/massive/massive_edit_agents.php index 82698266a1..9a57ef9d53 100755 --- a/pandora_console/godmode/massive/massive_edit_agents.php +++ b/pandora_console/godmode/massive/massive_edit_agents.php @@ -319,9 +319,8 @@ if ($update_agents) { $secondary_groups_removed ); - $agents_values = agents_get_agent((int) $array_id[1]); + $agents_values = db_get_row_filter('tagente', ['id_agente' => (int) $array_id[1]]); $node->disconnect(); - if (empty($values) === false) { update_agents_in_metaconsole( (int) $array_id[1], diff --git a/pandora_console/godmode/massive/massive_edit_modules.php b/pandora_console/godmode/massive/massive_edit_modules.php index 79cd0233da..2b8990c065 100755 --- a/pandora_console/godmode/massive/massive_edit_modules.php +++ b/pandora_console/godmode/massive/massive_edit_modules.php @@ -1500,7 +1500,7 @@ $table->data[39][0] = html_print_label_input_block( '', '', true - ).html_print_input_hidden('macros', base64_encode($macros), true) + ).html_print_input_hidden('macros', base64_encode(($macros ?? '')), true) ); require_once $config['homedir'].'/include/class/CredentialStore.class.php'; diff --git a/pandora_console/godmode/menu.php b/pandora_console/godmode/menu.php index 3505e7cf2c..68d789cd74 100644 --- a/pandora_console/godmode/menu.php +++ b/pandora_console/godmode/menu.php @@ -208,6 +208,9 @@ if ($access_console_node === true) { $sub['godmode/setup/os']['text'] = __('Operating systems'); $sub['godmode/setup/os']['id'] = 'edit_OS'; + + $sub['godmode/resources/resources_export_import']['text'] = __('Resources export/import'); + $sub['godmode/resources/resources_export_import']['id'] = 'resources_export_import'; } if ((bool) check_acl($config['id_user'], 0, 'AW') === true) { diff --git a/pandora_console/godmode/reporting/reporting_builder.item_editor.php b/pandora_console/godmode/reporting/reporting_builder.item_editor.php index 74d9f07527..b30f1d6c43 100755 --- a/pandora_console/godmode/reporting/reporting_builder.item_editor.php +++ b/pandora_console/godmode/reporting/reporting_builder.item_editor.php @@ -5941,6 +5941,7 @@ ui_require_javascript_file('pandora'); ?> \ No newline at end of file diff --git a/pandora_console/godmode/servers/servers.build_table.php b/pandora_console/godmode/servers/servers.build_table.php index 23a284caf9..1589f33fc9 100644 --- a/pandora_console/godmode/servers/servers.build_table.php +++ b/pandora_console/godmode/servers/servers.build_table.php @@ -115,7 +115,7 @@ foreach ($servers as $server) { $table->cellclass[] = [ 3 => 'progress_bar', - 8 => 'table_action_buttons', + 9 => 'table_action_buttons', ]; $data[0] = ''.strip_tags($server['name']).''; diff --git a/pandora_console/godmode/setup/os.builder.php b/pandora_console/godmode/setup/os.builder.php index 6313aa3edd..4f7b77099b 100644 --- a/pandora_console/godmode/setup/os.builder.php +++ b/pandora_console/godmode/setup/os.builder.php @@ -48,7 +48,7 @@ if ($idOS > 0) { } else { $name = io_safe_input(strip_tags(trim(io_safe_output((string) get_parameter('name'))))); $description = io_safe_input(strip_tags(io_safe_output((string) get_parameter('description')))); - $icon = get_parameter('icon', 0); + $icon = get_parameter('icon', 'os@svg.svg'); } $icon_upload = get_parameter('icon_upload', null); @@ -246,7 +246,7 @@ $iconData[] = html_print_select( 'icon', $icon, 'show_icon_OS();', - __('None'), + '', 0, true ); @@ -356,6 +356,8 @@ function get_list_os_icons_dir() } } + $return['os@svg.svg'] = __('None'); + return $return; } diff --git a/pandora_console/godmode/setup/os.php b/pandora_console/godmode/setup/os.php index dcfe95ecdb..403232c868 100644 --- a/pandora_console/godmode/setup/os.php +++ b/pandora_console/godmode/setup/os.php @@ -88,6 +88,14 @@ switch ($tab) { break; case 'manage_os': + $id_os = get_parameter('id_os', ''); + if ($id_os !== '') { + $headerTitle = __('Edit OS'); + } else { + $headerTitle = __('Create OS'); + } + break; + case 'list': if ($action === 'edit') { $headerTitle = __('Edit OS'); diff --git a/pandora_console/godmode/tag/tag.php b/pandora_console/godmode/tag/tag.php index 220c6c244c..1bef19495e 100644 --- a/pandora_console/godmode/tag/tag.php +++ b/pandora_console/godmode/tag/tag.php @@ -386,7 +386,7 @@ if (empty($result) === false) { $data[4] = $output; $phone_large = io_safe_output($tag['phone']); - $phone_small = substr($phone_large, 0, 24); + $phone_small = substr(($phone_large ?? ''), 0, 24); if ($phone_large == $phone_small) { $output = $phone_large; } else { diff --git a/pandora_console/godmode/users/configure_user.php b/pandora_console/godmode/users/configure_user.php index 668216d330..4269405476 100644 --- a/pandora_console/godmode/users/configure_user.php +++ b/pandora_console/godmode/users/configure_user.php @@ -1581,7 +1581,7 @@ $autorefresh_list_out['operation/events/events'] = 'Events'; if (isset($autorefresh_list) === false || empty($autorefresh_list) === true || empty($autorefresh_list[0]) === true) { $select = db_process_sql("SELECT autorefresh_white_list FROM tusuario WHERE id_user = '".$id."'"); - $autorefresh_list = json_decode($select[0]['autorefresh_white_list']); + $autorefresh_list = json_decode(($select[0]['autorefresh_white_list'] ?? '')); if ($autorefresh_list === null || $autorefresh_list === 0) { $autorefresh_list = []; $autorefresh_list[0] = __('None'); diff --git a/pandora_console/godmode/wizards/Applications.class.php b/pandora_console/godmode/wizards/Applications.class.php index f92a8cf0d6..680630f86b 100644 --- a/pandora_console/godmode/wizards/Applications.class.php +++ b/pandora_console/godmode/wizards/Applications.class.php @@ -37,6 +37,20 @@ class Applications extends Wizard */ public $mode; + /** + * Task properties. + * + * @var array + */ + public $task; + + /** + * Class of styles. + * + * @var string + */ + public $class; + /** * Constructor. diff --git a/pandora_console/godmode/wizards/Custom.class.php b/pandora_console/godmode/wizards/Custom.class.php index 516b8d1e80..f721e76aa7 100644 --- a/pandora_console/godmode/wizards/Custom.class.php +++ b/pandora_console/godmode/wizards/Custom.class.php @@ -37,6 +37,20 @@ class Custom extends Wizard */ public $mode; + /** + * Task properties. + * + * @var array + */ + public $task; + + /** + * Class of styles. + * + * @var string + */ + public $class; + /** * Constructor. diff --git a/pandora_console/godmode/wizards/DiscoveryTaskList.class.php b/pandora_console/godmode/wizards/DiscoveryTaskList.class.php index d088e8c84f..1023a00704 100644 --- a/pandora_console/godmode/wizards/DiscoveryTaskList.class.php +++ b/pandora_console/godmode/wizards/DiscoveryTaskList.class.php @@ -47,6 +47,13 @@ ui_require_javascript_file('simTree'); class DiscoveryTaskList extends HTML { + /** + * Task properties. + * + * @var array + */ + public $task; + /** * Constructor. @@ -1418,7 +1425,7 @@ class DiscoveryTaskList extends HTML $table = new StdClasS(); $table->class = 'databox data'; $table->width = '75%'; - $table->styleTable = 'margin: 2em auto 0;border: 1px solid #ddd;background: white;'; + $table->styleTable = 'margin: 2em auto 0;border: 1px solid #ddd;background: white; overflow-wrap: anywhere'; $table->rowid = []; $table->data = []; @@ -1426,7 +1433,7 @@ class DiscoveryTaskList extends HTML $tableErrors = new StdClasS(); $tableErrors->class = 'databox data'; $tableErrors->width = '75%'; - $tableErrors->styleTable = 'margin: 2em auto 0;border: 1px solid #ddd;background: white;'; + $tableErrors->styleTable = 'margin: 2em auto 0;border: 1px solid #ddd;background: white; overflow-wrap: anywhere'; $tableErrors->rowid = []; $tableErrors->data = []; diff --git a/pandora_console/godmode/wizards/HostDevices.class.php b/pandora_console/godmode/wizards/HostDevices.class.php index 4f0043f038..e24d352500 100755 --- a/pandora_console/godmode/wizards/HostDevices.class.php +++ b/pandora_console/godmode/wizards/HostDevices.class.php @@ -450,6 +450,35 @@ class HostDevices extends Wizard if (isset($this->task['id_rt']) === false) { // Create. + $default_templates = [ + io_safe_input('Linux System'), + io_safe_input('Windows System'), + io_safe_input('Windows Hardware'), + io_safe_input('Network Management'), + ]; + + $default_templates_ids = db_get_all_rows_sql( + 'SELECT id_np + FROM tnetwork_profile + WHERE name IN ('.implode( + ',', + array_map( + function ($template) { + return "'".$template."'"; + }, + $default_templates + ) + ).') + ORDER BY name' + ); + + if ($default_templates_ids !== false) { + $this->task['id_network_profile'] = implode( + ',', + array_column($default_templates_ids, 'id_np'), + ); + } + $this->task['id_rt'] = db_process_sql_insert( 'trecon_task', $this->task @@ -1100,16 +1129,13 @@ class HostDevices extends Wizard 'arguments' => [ 'name' => 'id_network_profile[]', 'type' => 'select_from_sql', - 'sql' => 'SELECT tn.id_np, tn.name - FROM tnetwork_profile tn - LEFT JOIN `tnetwork_profile_pen` tp - ON tp.id_np = tn.id_np - WHERE tp.id_np IS NULL - ORDER BY tn.name', + 'sql' => 'SELECT id_np, name + FROM tnetwork_profile + ORDER BY name', 'return' => true, 'selected' => explode( ',', - $this->task['id_network_profile'] + (isset($this->task['id_network_profile']) === true) ? $this->task['id_network_profile'] : '' ), 'nothing_value' => 0, 'nothing' => __('None'), @@ -1273,114 +1299,86 @@ class HostDevices extends Wizard ], ]; - // SNMP Options pack v3. - $form['inputs'][] = [ - 'hidden' => 1, - 'block_id' => 'snmp_options_v3', - 'class' => 'indented', - 'block_content' => [ - [ - 'label' => ''.__('Context').'', - 'arguments' => [ - 'name' => 'snmp_context', - 'type' => 'text', - 'value' => $this->task['snmp_community'], - 'size' => 15, - 'return' => true, + $show_snmp_auth = false; + if (isset($this->task['snmp_enabled']) && $this->task['snmp_enabled'] > 0 + && isset($this->task['snmp_version']) && $this->task['snmp_version'] == 3 + ) { + $show_snmp_auth = true; + } - ], - ], - [ - 'label' => ''.__('Auth user').'', - 'arguments' => [ - 'name' => 'snmp_auth_user', - 'type' => 'text', - 'value' => $this->task['snmp_auth_user'], - 'size' => 15, - 'return' => true, - - ], - ], - [ - 'label' => ''.__('Security level').'', - 'arguments' => [ - 'name' => 'snmp_security_level', - 'type' => 'select', - 'fields' => [ - 'noAuthNoPriv' => __('Not auth and not privacy method'), - 'authNoPriv' => __('Auth and not privacy method'), - 'authPriv' => __('Auth and privacy method'), - ], - 'selected' => $this->task['snmp_security_level'], - 'size' => 15, - 'return' => true, - - ], - ], - [ - 'label' => ''.__('Auth method').'', - 'arguments' => [ - 'name' => 'snmp_auth_method', - 'type' => 'select', - 'fields' => [ - 'MD5' => __('MD5'), - 'SHA' => __('SHA'), - ], - 'selected' => $this->task['snmp_auth_method'], - 'size' => 15, - 'return' => true, - - ], - ], - [ - 'label' => ''.__('Auth password').''.ui_print_help_tip( - __( - 'The pass length must be eight character minimum.' - ), - true - ), - 'arguments' => [ - 'name' => 'snmp_auth_pass', - 'type' => 'password', - 'value' => $this->task['snmp_auth_pass'], - 'size' => 15, - 'return' => true, - - ], - ], - [ - 'label' => ''.__('Privacy method').'', - 'arguments' => [ - 'name' => 'snmp_privacy_method', - 'type' => 'select', - 'fields' => [ - 'DES' => __('DES'), - 'AES' => __('AES'), - ], - 'selected' => $this->task['snmp_privacy_method'], - 'size' => 15, - 'return' => true, - - ], - ], - [ - 'label' => ''.__('Privacy pass').''.ui_print_help_tip( - __( - 'The pass length must be eight character minimum.' - ), - true - ), - 'arguments' => [ - 'name' => 'snmp_privacy_pass', - 'type' => 'password', - 'value' => $this->task['snmp_privacy_pass'], - 'size' => 15, - 'return' => true, - - ], - ], + include_once $config['homedir'].'/include/class/CredentialStore.class.php'; + $all_snmp_keys = CredentialStore::getAll( + [ + 'cs.*', + 'tg.nombre as `group`', ], - ]; + ['product' => 'SNMP'] + ); + + if (is_array($all_snmp_keys) === true) { + // Improve usage and decode output. + $snmp_available_keys = array_reduce( + $all_snmp_keys, + function ($carry, $item) { + $item['extra_1'] = io_output_password($item['extra_1']); + + $extra1 = json_decode($item['extra_1'], true); + if ($extra1 !== null && $extra1['version'] == 3) { + $carry[$item['identifier']] = $item['identifier']; + } + + return $carry; + }, + [] + ); + } + + if (check_acl($config['id_user'], 0, 'UM')) { + $link_to_cs = ''; + $link_to_cs .= __('No credentials available').', '; + $link_to_cs .= strtolower(__('Manage credentials')).''; + } else { + $link_to_cs = __('No credentials available'); + } + + if (count($snmp_available_keys) > 0) { + $form['inputs'][] = [ + 'block_id' => 'auth_block_snmp', + 'class' => 'indented', + 'hidden' => !$show_snmp_auth, + 'block_content' => [ + [ + 'label' => __('Credentials to try with'), + 'arguments' => [ + 'type' => 'select', + 'name' => 'auth_strings[]', + 'fields' => $snmp_available_keys, + 'selected' => explode( + ',', + $this->task['auth_strings'] + ), + + 'multiple' => true, + 'class' => 'select_multiple', + ], + ], + ], + ]; + } else { + $form['inputs'][] = [ + 'block_id' => 'auth_block_snmp', + 'class' => 'indented', + 'hidden' => !$show_snmp_auth, + 'block_content' => [ + [ + 'label' => __('Credentials to try with'), + 'extra' => $link_to_cs, + ], + ], + ]; + } // Input: Enforce os detection. $form['inputs'][] = [ @@ -1453,14 +1451,12 @@ class HostDevices extends Wizard // AUTH CONFIGURATION. $show_auth = false; - if ((isset($this->task['wmi_enabled']) && $this->task['wmi_enabled'] > 0) - || (isset($this->task['rcmd_enabled']) && $this->task['rcmd_enabled'] > 0) - ) { + if (isset($this->task['wmi_enabled']) && $this->task['wmi_enabled'] > 0) { $show_auth = true; } include_once $config['homedir'].'/include/class/CredentialStore.class.php'; - $available_keys = CredentialStore::getKeys('WMI'); + $wmi_available_keys = CredentialStore::getKeys('WMI'); if (check_acl($config['id_user'], 0, 'UM')) { $link_to_cs = ''; - array_map('self::printBigButtonElement', $list_data); + array_map(['Wizard', 'printBigButtonElement'], $list_data); echo ''; if ($return === true) { diff --git a/pandora_console/images/export.svg b/pandora_console/images/export.svg new file mode 100644 index 0000000000..7d26fc3fed --- /dev/null +++ b/pandora_console/images/export.svg @@ -0,0 +1,18 @@ + + + E1DA0B54-BDFA-427E-9BFB-1315DFA5936F + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/pandora_console/images/export_to.svg b/pandora_console/images/export_to.svg new file mode 100644 index 0000000000..d5b9beac66 --- /dev/null +++ b/pandora_console/images/export_to.svg @@ -0,0 +1,25 @@ + + + 868E520D-AB8E-4FB9-B511-A43C58B7C144 + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/pandora_console/images/import.svg b/pandora_console/images/import.svg new file mode 100644 index 0000000000..18a77c8c0d --- /dev/null +++ b/pandora_console/images/import.svg @@ -0,0 +1,18 @@ + + + 6AE8E7E7-D5F8-4670-BCBD-08A30E381B8F + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/pandora_console/images/import_to.svg b/pandora_console/images/import_to.svg new file mode 100644 index 0000000000..0dee1bb4a3 --- /dev/null +++ b/pandora_console/images/import_to.svg @@ -0,0 +1,24 @@ + + + A981FD90-8ED5-4170-8C6A-8F4DFD0DCCD4 + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/pandora_console/images/widgets/GisMap.png b/pandora_console/images/widgets/GisMap.png new file mode 100644 index 0000000000..0cbfbf37b6 Binary files /dev/null and b/pandora_console/images/widgets/GisMap.png differ diff --git a/pandora_console/include/ajax/dashboard.ajax.php b/pandora_console/include/ajax/dashboard.ajax.php index 40497a2ebc..b4bc158ecf 100644 --- a/pandora_console/include/ajax/dashboard.ajax.php +++ b/pandora_console/include/ajax/dashboard.ajax.php @@ -117,12 +117,25 @@ if ($method === 'draw') { $where_name = 'name LIKE "%'.$filter['free_search'].'%"'; } + if (is_user_admin($config['id_user']) === false) { + $group_list = \users_get_groups( + $config['id_ser'], + 'RR', + true + ); + } + $where_group = ''; if (empty($filter['group']) === false && $filter['group'] !== '0') { $where_group = sprintf('id_group = %s', $filter['group']); if (empty($where_name) === false) { $where_group = 'AND '.$where_group; } + } else if (empty($group_list) === false) { + $where_group = sprintf('id_group IN (%s)', implode(',', array_keys($group_list))); + if (empty($where_name) === false) { + $where_group = 'AND '.$where_group; + } } $where = ''; diff --git a/pandora_console/include/ajax/events.php b/pandora_console/include/ajax/events.php index 72e77e73dc..7264b33cad 100644 --- a/pandora_console/include/ajax/events.php +++ b/pandora_console/include/ajax/events.php @@ -2049,7 +2049,9 @@ if ($get_extended_event) { $js .= '});'; - $js .= '$("#link_comments").click(get_table_events_tabs(\''.base64_encode(json_encode($event)).'\',\''.base64_encode(json_encode($filter)).'\'));'; + $js .= '$("#link_comments").on("click", () => { + get_table_events_tabs(\''.base64_encode(json_encode($event)).'\',\''.base64_encode(json_encode($filter)).'\') + });'; if (events_has_extended_info($event['id_evento']) === true) { $js .= ' diff --git a/pandora_console/include/ajax/heatmap.ajax.php b/pandora_console/include/ajax/heatmap.ajax.php index 71020ad67f..83c7226388 100644 --- a/pandora_console/include/ajax/heatmap.ajax.php +++ b/pandora_console/include/ajax/heatmap.ajax.php @@ -250,6 +250,7 @@ if (is_ajax() === true) { if ($getInfo === true) { enterprise_include_once('include/functions_agents.php'); + include_once $config['homedir'].'/include/functions_graph.php'; $id = get_parameter('id', 0); $id_server = get_parameter('id_server', 0); if (empty($id_server) === false) { diff --git a/pandora_console/include/ajax/module.php b/pandora_console/include/ajax/module.php index 1418024c4d..0e723cafe8 100755 --- a/pandora_console/include/ajax/module.php +++ b/pandora_console/include/ajax/module.php @@ -41,6 +41,7 @@ if (check_login()) { $get_plugin_macros = get_parameter('get_plugin_macros'); $get_module_macros = get_parameter('get_module_macros'); + $is_policy = (bool) get_parameter('is_policy', 0); $search_modules = get_parameter('search_modules'); $get_module_detail = get_parameter('get_module_detail', 0); $get_module_autocomplete_input = (bool) get_parameter( @@ -104,12 +105,22 @@ if (check_login()) { $id_plugin = get_parameter('id_plugin', 0); if ($id_plugin !== 0) { - $id_module_plugin = db_get_value( - 'id_plugin', - 'tagente_modulo', - 'id_agente_modulo', - $get_module_macros - ); + if ($is_policy === true) { + $id_module_plugin = db_get_value( + 'id_plugin', + 'tpolicy_modules', + 'id', + $get_module_macros + ); + } else { + $id_module_plugin = db_get_value( + 'id_plugin', + 'tagente_modulo', + 'id_agente_modulo', + $get_module_macros + ); + } + if ($id_plugin !== $id_module_plugin) { $get_plugin_macros = true; $get_module_macros = 0; @@ -145,12 +156,21 @@ if (check_login()) { $module_id = $get_module_macros; - $module_macros = db_get_value( - 'macros', - 'tagente_modulo', - 'id_agente_modulo', - $module_id - ); + if ($is_policy === true) { + $module_macros = db_get_value( + 'macros', + 'tpolicy_modules', + 'id', + $module_id + ); + } else { + $module_macros = db_get_value( + 'macros', + 'tagente_modulo', + 'id_agente_modulo', + $module_id + ); + } $macros = []; $macros['base64'] = base64_encode($module_macros); diff --git a/pandora_console/include/ajax/resources.ajax.php b/pandora_console/include/ajax/resources.ajax.php new file mode 100644 index 0000000000..0e34d756c0 --- /dev/null +++ b/pandora_console/include/ajax/resources.ajax.php @@ -0,0 +1,115 @@ +getOnePrdData($type); + if (empty($data) === false) { + $sql = sprintf( + 'SELECT %s FROM %s', + reset($data['items']['value']).', '.reset($data['items']['show']), + $data['items']['table'] + ); + $result = html_print_label_input_block( + $data['label'], + io_safe_output( + html_print_select_from_sql( + $sql, + 'select_value', + '', + '', + '', + 0, + true, + false, + true, + false, + false, + false, + GENERIC_SIZE_TEXT, + 'w90p', + ), + ), + [ + 'div_style' => 'display: flex; flex-direction: column; width: 50%', + 'div_id' => 'resource_type', + ], + ); + } + + echo $result; + return; + } + + if ($exportPrd === true) { + $type = (string) get_parameter('type', ''); + $value = (int) get_parameter('value', 0); + $name = (string) get_parameter('name', ''); + $filename = (string) get_parameter('filename', ''); + + try { + $data = $prd->exportPrd($type, $value, $name); + } catch (\Exception $e) { + $data = ''; + } + + $return = []; + + if (empty($data) === false) { + $filename_download = date('YmdHis').'-'.$type.'-'.$name.'.prd'; + $file = $config['attachment_store'].'/'.$filename; + + $file_pointer = fopen($file, 'a'); + if ($file_pointer !== false) { + $write = fwrite($file_pointer, $data); + + if ($write === false) { + $return['error'] = -2; + unlink($config['attachment_store'].'/'.$filename); + } else { + $return['name'] = $filename; + $return['name_download'] = $filename_download; + } + + fclose($file_pointer); + } else { + $return['error'] = -1; + } + } + + echo json_encode($return); + + return; + } + + if ($deleteFile === true) { + $filename = (string) get_parameter('filename', ''); + + unlink($config['attachment_store'].'/'.$filename); + } +} diff --git a/pandora_console/include/ajax/task_to_perform.php b/pandora_console/include/ajax/task_to_perform.php index e63ea55015..b943ee29a5 100644 --- a/pandora_console/include/ajax/task_to_perform.php +++ b/pandora_console/include/ajax/task_to_perform.php @@ -129,7 +129,12 @@ if ($check_connectivity) { if ($create_net_scan) { $ip_target = get_parameter('ip_target', '192.168.10.0/24'); - $id_net_scan = create_net_scan($ip_target); + $snmp_version = get_parameter('snmp_version', '1'); + $snmp_communities = get_parameter('snmp_communities', 'public'); + $wmi_credentials = get_parameter('wmi_credentials', []); + $rcmd_credentials = get_parameter('rcmd_credentials', []); + + $id_net_scan = create_net_scan($ip_target, $snmp_version, $snmp_communities, $wmi_credentials, $rcmd_credentials); if ($id_net_scan > 0) { $id_recon_server = db_get_row_filter('tserver', ['server_type' => SERVER_TYPE_DISCOVERY], 'id_server')['id_server']; ui_print_success_message(__('Basic net created and scan in progress. Click here to view the data. Please note that it may take a few seconds to see data if your server is busy')); diff --git a/pandora_console/include/api.php b/pandora_console/include/api.php index b29dd06bd3..4836f98c64 100644 --- a/pandora_console/include/api.php +++ b/pandora_console/include/api.php @@ -380,5 +380,7 @@ if (session_status() !== PHP_SESSION_DISABLED) { // Could give a warning if no session file is created. Ignore. @session_destroy(); header_remove('Set-Cookie'); - setcookie(session_name(), $_COOKIE[session_name()], (time() - 4800), '/'); + if (isset($_COOKIE[session_name()]) === true) { + setcookie(session_name(), $_COOKIE[session_name()], (time() - 4800), '/'); + } } diff --git a/pandora_console/include/auth/mysql.php b/pandora_console/include/auth/mysql.php index 3141272352..149621081f 100644 --- a/pandora_console/include/auth/mysql.php +++ b/pandora_console/include/auth/mysql.php @@ -172,12 +172,12 @@ function process_user_login_local($login, $pass, $api=false, $passAlreadyEncrypt $credentials_check = $pass === $row['password']; } else { // Perform password check whether it is MD5-hashed (old hashing) or Bcrypt-hashed. - if (strlen($row['password']) === 32) { + if (strlen(($row['password'] ?? '')) === 32) { // MD5. $credentials_check = $row !== false && $row['password'] !== md5('') && $row['password'] == md5($pass); } else { // Bcrypt. - $credentials_check = password_verify($pass, $row['password']); + $credentials_check = password_verify($pass, ($row['password'] ?? '')); } } @@ -572,10 +572,10 @@ function get_user_info($user) * * @return array An array of user information */ -function get_users($order='fullname', $filter=false, $fields=false) +function get_users($order='fullname', $filter=[], $fields=false) { if (is_array($order) === true) { - $filter['order'] = $order['field'].' '.$order['order']; + $filter['order'] = (string) $order['field'].' '.(string) $order['order']; } else { if ($order !== 'registered' || $order !== 'last_connect' || $order !== 'fullname') { $order = 'fullname'; diff --git a/pandora_console/include/class/AuditLog.class.php b/pandora_console/include/class/AuditLog.class.php index ceb98875a1..a4988e8042 100644 --- a/pandora_console/include/class/AuditLog.class.php +++ b/pandora_console/include/class/AuditLog.class.php @@ -53,6 +53,48 @@ class AuditLog extends HTML */ private $ajaxController; + /** + * TableId + * + * @var integer + */ + public $tableId; + + /** + * FilterIp + * + * @var array + */ + public $filterIp; + + /** + * FilterPeriod + * + * @var integer + */ + public $filterPeriod; + + /** + * FilterText + * + * @var string + */ + public $filterText; + + /** + * FilterType + * + * @var string + */ + public $filterType; + + /** + * FilterUser + * + * @var string + */ + public $filterUser; + /** * Class constructor diff --git a/pandora_console/include/class/CalendarManager.class.php b/pandora_console/include/class/CalendarManager.class.php index 560fb6f4ad..b5ef6456a7 100644 --- a/pandora_console/include/class/CalendarManager.class.php +++ b/pandora_console/include/class/CalendarManager.class.php @@ -66,6 +66,13 @@ class CalendarManager */ private $message; + /** + * Access + * + * @var string + */ + public $access; + /** * Allowed methods to be called using AJAX request. * diff --git a/pandora_console/include/class/ConsoleSupervisor.php b/pandora_console/include/class/ConsoleSupervisor.php index 08fc1922cd..8f57ec9138 100644 --- a/pandora_console/include/class/ConsoleSupervisor.php +++ b/pandora_console/include/class/ConsoleSupervisor.php @@ -1510,17 +1510,42 @@ class ConsoleSupervisor { global $config; + $types_sql = sprintf( + ' AND ( + `server_type` != %d AND + `server_type` != %d + )', + SERVER_TYPE_AUTOPROVISION, + SERVER_TYPE_MIGRATION + ); + if (is_metaconsole() === true && isset($config['ndbh']) === false) { + $types_sql = sprintf( + ' AND ( + `server_type` = %d OR + `server_type` = %d OR + `server_type` = %d OR + `server_type` = %d + )', + SERVER_TYPE_AUTOPROVISION, + SERVER_TYPE_EVENT, + SERVER_TYPE_MIGRATION, + SERVER_TYPE_PREDICTION + ); + } + $servers = db_get_all_rows_sql( - 'SELECT - id_server, - name, - server_type, - server_keepalive, - status, - unix_timestamp() - unix_timestamp(keepalive) as downtime - FROM tserver - WHERE - unix_timestamp() - unix_timestamp(keepalive) > server_keepalive' + sprintf( + 'SELECT id_server, + `name`, + server_type, + server_keepalive, + `status`, + unix_timestamp() - unix_timestamp(keepalive) as downtime + FROM tserver + WHERE unix_timestamp() - unix_timestamp(keepalive) > server_keepalive + %s', + $types_sql + ) ); if ($servers === false) { diff --git a/pandora_console/include/class/CredentialStore.class.php b/pandora_console/include/class/CredentialStore.class.php index dd3f484d5e..5169af1009 100644 --- a/pandora_console/include/class/CredentialStore.class.php +++ b/pandora_console/include/class/CredentialStore.class.php @@ -850,7 +850,7 @@ class CredentialStore extends Wizard 'privilege' => 'AR', 'type' => 'select_groups', 'nothing' => false, - 'selected' => (defined($id_group_filter) ? $id_group_filter : 0), + 'selected' => ((isset($id_group_filter) === true) ? $id_group_filter : 0), 'return' => true, 'size' => '80%', ], diff --git a/pandora_console/include/class/Diagnostics.class.php b/pandora_console/include/class/Diagnostics.class.php index 3f2c4cad22..714a6a707f 100644 --- a/pandora_console/include/class/Diagnostics.class.php +++ b/pandora_console/include/class/Diagnostics.class.php @@ -54,6 +54,13 @@ class Diagnostics extends Wizard */ public $pdf; + /** + * Product name. + * + * @var string + */ + public $product_name; + /** * Constructor. diff --git a/pandora_console/include/class/ExternalTools.class.php b/pandora_console/include/class/ExternalTools.class.php index 7165a4fcbb..215a664cb2 100644 --- a/pandora_console/include/class/ExternalTools.class.php +++ b/pandora_console/include/class/ExternalTools.class.php @@ -38,6 +38,62 @@ require_once $config['homedir'].'/include/class/HTML.class.php'; class ExternalTools extends HTML { + /** + * Origin + * + * @var string + */ + public $origin; + + /** + * PathCustomComm + * + * @var string + */ + public $pathCustomComm; + + /** + * PathDig + * + * @var string + */ + public $pathDig; + + /** + * PathNmap + * + * @var string + */ + public $pathNmap; + + /** + * PathPing + * + * @var string + */ + public $pathPing; + + /** + * PathSnmpget + * + * @var string + */ + public $pathSnmpget; + + /** + * PathTraceroute + * + * @var string + */ + public $pathTraceroute; + + /** + * UpdatePaths + * + * @var string + */ + public $updatePaths; + /** * Constructor. diff --git a/pandora_console/include/class/NetworkMap.class.php b/pandora_console/include/class/NetworkMap.class.php index 184e830e9c..3a8b947926 100644 --- a/pandora_console/include/class/NetworkMap.class.php +++ b/pandora_console/include/class/NetworkMap.class.php @@ -706,7 +706,7 @@ class NetworkMap */ public function setNodes($nodes) { - $this->nodes = $nodes; + $this->nodes = (array) $nodes; } diff --git a/pandora_console/include/class/OrderInterpreter.class.php b/pandora_console/include/class/OrderInterpreter.class.php index d41fbbf837..b96ad6e510 100644 --- a/pandora_console/include/class/OrderInterpreter.class.php +++ b/pandora_console/include/class/OrderInterpreter.class.php @@ -52,6 +52,13 @@ class OrderInterpreter extends Wizard */ public $ajaxController; + /** + * Pages menu + * + * @var array + */ + public $pages_menu; + /** * Generates a JSON error. diff --git a/pandora_console/include/class/Prd.class.php b/pandora_console/include/class/Prd.class.php new file mode 100644 index 0000000000..564585a6fe --- /dev/null +++ b/pandora_console/include/class/Prd.class.php @@ -0,0 +1,3730 @@ +prdData = [ + 'visual_console' => [ + 'label' => __('Visual console'), + 'items' => [ + 'table' => 'tlayout', + 'value' => ['id'], + 'show' => ['name'], + 'data' => [ + [ + 'table' => 'tlayout_data', + 'ref' => ['id_layout'], + 'value' => ['id'], + ], + ], + ], + ], + 'custom_report' => [ + 'label' => __('Custom report'), + 'items' => [ + 'table' => 'treport', + 'value' => ['id_report'], + 'show' => ['name'], + 'data' => [ + [ + 'table' => 'treport_content', + 'ref' => ['id_report'], + 'value' => ['id_rc'], + 'data' => [ + [ + 'table' => 'treport_content_item', + 'ref' => ['id_report_content'], + 'value' => ['id'], + ], + [ + 'table' => 'treport_content_sla_combined', + 'ref' => ['id_report_content'], + 'value' => ['id'], + ], + ], + ], + ], + ], + ], + 'policy' => [ + 'label' => __('Policy'), + 'items' => [ + 'table' => 'tpolicies', + 'value' => ['id'], + 'show' => ['name'], + 'data' => [ + [ + 'table' => 'tpolicy_agents', + 'ref' => ['id_policy'], + 'value' => ['id'], + ], + [ + 'table' => 'tpolicy_modules', + 'ref' => ['id_policy'], + 'value' => ['id'], + 'data' => [ + [ + 'table' => 'ttag_policy_module', + 'ref' => ['id_policy_module'], + 'value' => [ + 'id_tag', + 'id_policy_module', + ], + ], + [ + 'table' => 'tpolicy_modules_synth', + 'ref' => ['id_agent_module_target'], + 'value' => ['id'], + ], + ], + ], + [ + 'table' => 'tpolicy_alerts', + 'ref' => ['id_policy'], + 'value' => ['id'], + 'data' => [ + [ + 'table' => 'tpolicy_alerts_actions', + 'ref' => ['id_policy_alert'], + 'value' => ['id'], + ], + ], + ], + [ + 'table' => 'tpolicy_collections', + 'ref' => ['id_policy'], + 'value' => ['id'], + ], + [ + 'table' => 'tpolicy_group_agents', + 'ref' => ['id_policy'], + 'value' => ['id'], + ], + [ + 'table' => 'tpolicy_groups', + 'ref' => ['id_policy'], + 'value' => ['id'], + ], + [ + 'table' => 'tpolicy_modules_inventory', + 'ref' => ['id_policy'], + 'value' => ['id'], + ], + [ + 'table' => 'tpolicy_plugins', + 'ref' => ['id_policy'], + 'value' => ['id'], + ], + ], + ], + ], + 'service' => [ + 'label' => __('Service'), + 'items' => [ + 'table' => 'tservice', + 'value' => ['id'], + 'show' => ['name'], + 'data' => [ + [ + 'table' => 'tservice_element', + 'ref' => ['id_service'], + 'value' => ['id'], + ], + ], + ], + ], + 'network_map' => [ + 'label' => __('Network map'), + 'items' => [ + 'table' => 'tmap', + 'value' => ['id'], + 'show' => ['name'], + 'data' => [ + [ + 'table' => 'titem', + 'ref' => ['id_map'], + 'value' => ['id'], + ], + [ + 'table' => 'trel_item', + 'ref' => ['id_map'], + 'value' => ['id'], + ], + ], + ], + ], + 'gis_map' => [ + 'label' => __('GIS map'), + 'items' => [ + 'table' => 'tgis_map', + 'value' => ['id_tgis_map'], + 'show' => ['map_name'], + 'data' => [ + [ + 'table' => 'tgis_map_layer', + 'ref' => ['tgis_map_id_tgis_map'], + 'value' => ['id_tmap_layer'], + 'data' => [ + [ + 'table' => 'tgis_map_layer_groups', + 'ref' => ['layer_id'], + 'value' => [ + 'layer_id', + 'group_id', + ], + ], + [ + 'table' => 'tgis_map_layer_has_tagente', + 'ref' => ['tgis_map_layer_id_tmap_layer'], + 'value' => [ + 'tgis_map_layer_id_tmap_layer', + 'tagente_id_agente', + ], + ], + ], + ], + [ + 'table' => 'tgis_map_has_tgis_map_con', + 'ref' => ['tgis_map_id_tgis_map'], + 'value' => [ + 'tgis_map_id_tgis_map', + 'tgis_map_con_id_tmap_con', + ], + ], + ], + ], + ], + 'custom_graph' => [ + 'label' => __('Custom graph'), + 'items' => [ + 'table' => 'tgraph', + 'value' => ['id_graph'], + 'show' => ['name'], + 'data' => [ + [ + 'table' => 'tgraph_source', + 'ref' => ['id_graph'], + 'value' => ['id_gs'], + ], + ], + ], + ], + 'dashboard' => [ + 'label' => __('Dashboard'), + 'items' => [ + 'table' => 'tdashboard', + 'value' => ['id'], + 'show' => ['name'], + 'data' => [ + [ + 'table' => 'twidget_dashboard', + 'ref' => ['id_dashboard'], + 'value' => ['id'], + ], + ], + ], + ], + ]; + + // Define variables for tables references + // Variables order is very important due to hierarchy. + $this->tgrupo = [ + 'table' => 'tgrupo', + 'id' => 'id_grupo', + 'columns' => ['nombre'], + 'autocreate_item' => 'agent_groups', + ]; + + $this->ttipoModulo = [ + 'table' => 'ttipo_modulo', + 'id' => 'id_tipo', + 'columns' => ['nombre'], + ]; + + $this->tmoduleGroup = [ + 'table' => 'tmodule_group', + 'id' => 'id_mg', + 'columns' => ['name'], + 'autocreate_item' => 'module_groups', + ]; + + $this->tconfigOs = [ + 'table' => 'tconfig_os', + 'id' => 'id_os', + 'columns' => ['name'], + 'autocreate_item' => 'operating_systems', + ]; + + $this->tcategory = [ + 'table' => 'tcategory', + 'id' => 'id', + 'columns' => ['name'], + 'autocreate_item' => 'categories', + ]; + + $this->ttag = [ + 'table' => 'ttag', + 'id' => 'id_tag', + 'columns' => ['name'], + 'autocreate_item' => 'tags', + ]; + + $this->tagente = [ + 'table' => 'tagente', + 'id' => 'id_agente', + 'columns' => ['nombre'], + ]; + + $this->tagenteModulo = [ + 'table' => 'tagente_modulo', + 'id' => 'id_agente_modulo', + 'columns' => ['nombre'], + 'join' => ['id_agente' => $this->tagente], + ]; + + $this->tplugin = [ + 'table' => 'tplugin', + 'id' => 'id', + 'columns' => ['name'], + ]; + + $this->tmoduleInventory = [ + 'table' => 'tmodule_inventory', + 'id' => 'id_module_inventory', + 'columns' => ['name'], + 'join' => ['id_os' => $this->tconfigOs], + ]; + + $this->tpolicies = [ + 'table' => 'tpolicies', + 'id' => 'id', + 'columns' => ['name'], + ]; + + $this->tpolicyModules = [ + 'table' => 'tpolicy_modules', + 'id' => 'id', + 'columns' => ['name'], + 'join' => ['id_policy' => $this->tpolicies], + ]; + + $this->talertActions = [ + 'table' => 'talert_actions', + 'id' => 'id', + 'columns' => ['name'], + ]; + + $this->talertTemplates = [ + 'table' => 'talert_templates', + 'id' => 'id', + 'columns' => ['name'], + ]; + + $this->tcollection = [ + 'table' => 'tcollection', + 'id' => 'id', + 'columns' => ['short_name'], + ]; + + $this->tgraph = [ + 'table' => 'tgraph', + 'id' => 'id_graph', + 'columns' => ['name'], + ]; + + $this->tservice = [ + 'table' => 'tservice', + 'id' => 'id', + 'columns' => ['name'], + ]; + + $this->tlayout = [ + 'table' => 'tlayout', + 'id' => 'id', + 'columns' => ['name'], + ]; + + $this->tlayoutData = [ + 'table' => 'tlayout_data', + 'id' => 'id', + 'columns' => [ + 'pos_x', + 'pos_y', + 'height', + 'width', + 'type', + ], + 'join' => ['id_layout' => $this->tlayout], + ]; + + $this->treportCustomSql = [ + 'table' => 'treport_custom_sql', + 'id' => 'id', + 'columns' => ['name'], + ]; + + $this->tserverExport = [ + 'table' => 'tserver_export', + 'id' => 'id', + 'columns' => ['name'], + ]; + + $this->treconTask = [ + 'table' => 'trecon_task', + 'id' => 'id_rt', + 'columns' => [ + 'name', + 'type', + ], + ]; + + $this->tmap = [ + 'table' => 'tmap', + 'id' => 'id', + 'columns' => ['name'], + ]; + + $this->titem = [ + 'table' => 'titem', + 'id' => 'id', + 'columns' => [ + 'id_map', + 'type', + 'source_data', + 'x', + 'y', + 'z', + ], + ]; + + $this->tgisMapConnection = [ + 'table' => 'tgis_map_connection', + 'id' => 'id_tmap_connection', + 'columns' => ['conection_name'], + ]; + + $this->tserver = [ + 'table' => 'tserver', + 'id' => 'id_server', + 'columns' => [ + 'name', + 'server_type', + ], + ]; + + $this->twidget = [ + 'table' => 'twidget', + 'id' => 'id', + 'columns' => ['unique_name'], + ]; + + $this->treport = [ + 'table' => 'treport', + 'id' => 'id_report', + 'columns' => ['name'], + ]; + + $this->tnetflowFilter = [ + 'table' => 'tnetflow_filter', + 'id' => 'id_sg', + 'columns' => [ + 'ip_dst', + 'ip_src', + 'dst_port', + 'src_port', + 'router_ip', + 'advanced_filter', + 'filter_args', + 'aggregate', + 'netflow_monitoring', + 'traffic_max', + 'traffic_critical', + 'traffic_warning', + 'netflow_monitoring_interval', + ], + ]; + + // Define references between tables fields. + $this->columnRefs = [ + 'tlayout' => [ + 'id_group' => ['ref' => $this->tgrupo], + ], + 'tlayout_data' => [ + 'id_agente_modulo' => ['ref' => $this->tagenteModulo], + 'id_agent' => ['ref' => $this->tagente], + 'id_layout_linked' => ['ref' => $this->tlayout], + 'parent_item' => ['ref' => $this->tlayoutData], + 'id_group' => ['ref' => $this->tgrupo], + 'id_custom_graph' => ['ref' => $this->tgraph], + 'element_group' => ['ref' => $this->tgrupo], + ], + 'treport' => [ + 'id_group' => ['ref' => $this->tgrupo], + 'id_group_edit' => ['ref' => $this->tgrupo], + ], + 'treport_content' => [ + 'id_gs' => ['ref' => $this->tgraph], + 'id_agent_module' => ['ref' => $this->tagenteModulo], + 'id_agent' => ['ref' => $this->tagente], + 'treport_custom_sql_id' => ['ref' => $this->treportCustomSql], + 'id_group' => ['ref' => $this->tgrupo], + 'id_module_group' => ['ref' => $this->tmoduleGroup], + 'ncm_agents' => ['ref' => ($this->tagente + ['array' => true])], + 'text' => [ + 'conditional_refs' => [ + [ + 'when' => ['type' => 'netflow_area'], + 'ref' => $this->tnetflowFilter, + ], + [ + 'when' => ['type' => 'netflow_data'], + 'ref' => $this->tnetflowFilter, + ], + [ + 'when' => ['type' => 'netflow_summary'], + 'ref' => $this->tnetflowFilter, + ], + [ + 'when' => ['type' => 'netflow_top_N'], + 'ref' => $this->tnetflowFilter, + ], + ], + ], + ], + 'treport_content_item' => [ + 'id_agent_module' => ['ref' => $this->tagenteModulo], + ], + 'treport_content_sla_combined' => [ + 'id_agent_module' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_report_content' => [ + 'table' => 'treport_content', + 'id' => 'id_rc', + 'when' => ['type' => 'SLA_services'], + ], + ], + 'ref' => $this->tservice, + ], + ], + 'ref' => $this->tagenteModulo, + ], + ], + 'tpolicies' => [ + 'id_group' => ['ref' => $this->tgrupo], + ], + 'tpolicy_agents' => [ + 'id_agent' => ['ref' => $this->tagente], + ], + 'tpolicy_alerts' => [ + 'id_policy_module' => ['ref' => $this->tpolicyModules], + 'id_alert_template' => ['ref' => $this->talertTemplates], + ], + 'tpolicy_alerts_actions' => [ + 'id_alert_action' => ['ref' => $this->talertActions], + ], + 'tpolicy_collections' => [ + 'id_collection' => ['ref' => $this->tcollection], + ], + 'tpolicy_group_agents' => [ + 'id_agent' => ['ref' => $this->tagente], + ], + 'tpolicy_groups' => [ + 'id_group' => ['ref' => $this->tgrupo], + ], + 'tpolicy_modules' => [ + 'id_tipo_modulo' => ['ref' => $this->ttipoModulo], + 'id_module_group' => ['ref' => $this->tmoduleGroup], + 'id_export' => ['ref' => $this->tserverExport], + 'id_plugin' => ['ref' => $this->tplugin], + 'id_category' => ['ref' => $this->tcategory], + ], + 'ttag_policy_module' => [ + 'id_tag' => ['ref' => $this->ttag], + ], + 'tpolicy_modules_synth' => [ + 'id_agent_module_source' => ['ref' => $this->tagenteModulo], + ], + 'tpolicy_modules_inventory' => [ + 'id_module_inventory' => ['ref' => $this->tmoduleInventory], + ], + 'tservice' => [ + 'id_group' => ['ref' => $this->tgrupo], + 'id_agent_module' => ['ref' => ($this->tagenteModulo + ['autocreate_item' => 'service_module'])], + 'sla_id_module' => ['ref' => ($this->tagenteModulo + ['autocreate_item' => 'service_sla_module'])], + 'sla_value_id_module' => ['ref' => ($this->tagenteModulo + ['autocreate_item' => 'service_sla_value_module'])], + 'id_template_alert_warning' => ['ref' => $this->talertTemplates], + 'id_template_alert_critical' => ['ref' => $this->talertTemplates], + 'id_template_alert_unknown' => ['ref' => $this->talertTemplates], + 'id_template_alert_critical_sla' => ['ref' => $this->talertTemplates], + ], + 'tservice_element' => [ + 'id_agente_modulo' => ['ref' => $this->tagenteModulo], + 'id_agent' => ['ref' => $this->tagente], + 'id_service_child' => ['ref' => $this->tservice], + ], + 'tmap' => [ + 'id_group' => ['ref' => $this->tgrupo], + 'source_data' => [ + 'conditional_refs' => [ + [ + 'when' => ['source' => '0'], + 'ref' => ($this->tgrupo + ['csv' => true, 'csv_separator' => ',']), + ], + [ + 'when' => ['source' => '1'], + 'ref' => $this->treconTask, + ], + ], + ], + 'id_group_map' => ['ref' => $this->tgrupo], + ], + 'titem' => [ + 'source_data' => [ + 'conditional_refs' => [ + [ + 'when' => ['type' => '0'], + 'ref' => $this->tagente, + ], + [ + 'when' => ['type' => '1'], + 'ref' => $this->tagenteModulo, + ], + ], + ], + ], + 'trel_item' => [ + 'id_parent' => ['ref' => $this->titem], + 'id_child' => ['ref' => $this->titem], + 'id_parent_source_data' => [ + 'conditional_refs' => [ + [ + 'when' => ['parent_type' => '0'], + 'ref' => $this->tagente, + ], + [ + 'when' => ['parent_type' => '1'], + 'ref' => $this->tagenteModulo, + ], + ], + ], + 'id_child_source_data' => [ + 'conditional_refs' => [ + [ + 'when' => ['child_type' => '0'], + 'ref' => $this->tagente, + ], + [ + 'when' => ['child_type' => '1'], + 'ref' => $this->tagenteModulo, + ], + ], + ], + ], + 'tgis_map' => [ + 'group_id' => ['ref' => $this->tgrupo], + ], + 'tgis_map_layer' => [ + 'tgrupo_id_grupo' => ['ref' => $this->tgrupo], + ], + 'tgis_map_layer_groups' => [ + 'group_id' => ['ref' => $this->tgrupo], + 'agent_id' => ['ref' => $this->tagente], + ], + 'tgis_map_layer_has_tagente' => [ + 'tagente_id_agente' => ['ref' => $this->tagente], + ], + 'tgis_map_has_tgis_map_con' => [ + 'tgis_map_con_id_tmap_con' => ['ref' => $this->tgisMapConnection], + ], + 'tgraph' => [ + 'id_group' => ['ref' => $this->tgrupo], + ], + 'tgraph_source' => [ + 'id_server' => ['ref' => $this->tserver], + 'id_agent_module' => ['ref' => $this->tagenteModulo], + ], + 'tdashboard' => [ + 'id_group' => ['ref' => $this->tgrupo], + ], + 'twidget_dashboard' => [ + 'id_widget' => ['ref' => $this->twidget], + ], + ]; + + // Define references between tables fields with JSON format. + $this->jsonRefs = [ + 'tservice_element' => [ + 'rules' => [ + 'group' => ['ref' => $this->tgrupo], + ], + ], + 'titem' => [ + 'style' => [ + 'id_group' => ['ref' => $this->tgrupo], + 'networkmap' => ['ref' => $this->tmap], + 'id_agent' => ['ref' => $this->tagente], + ], + ], + 'treport_content' => [ + 'external_source' => [ + 'module' => [ + 'ref' => ($this->tagenteModulo + ['array' => true, 'values_as_keys' => true]), + ], + 'id_agents' => ['ref' => ($this->tagente + ['array' => true])], + 'templates' => ['ref' => ($this->talertTemplates + ['array' => true])], + 'actions' => ['ref' => ($this->talertActions + ['array' => true])], + ], + ], + 'twidget_dashboard' => [ + 'options' => [ + 'id_group' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'single_graph'], + ], + ], + 'ref' => $this->tgrupo, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'wux_transaction'], + ], + ], + 'ref' => $this->tgrupo, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'inventory'], + ], + ], + 'ref' => $this->tgrupo, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'service_view'], + ], + ], + 'ref' => $this->tgrupo, + ], + ], + ], + 'agentId' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'single_graph'], + ], + ], + 'ref' => $this->tagente, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'wux_transaction'], + ], + ], + 'ref' => $this->tagente, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'AvgSumMaxMinModule'], + ], + ], + 'ref' => $this->tagente, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'BasicChart'], + ], + ], + 'ref' => $this->tagente, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'module_icon'], + ], + ], + 'ref' => $this->tagente, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'inventory'], + ], + ], + 'ref' => $this->tagente, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'graph_module_histogram'], + ], + ], + 'ref' => $this->tagente, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'module_table_value'], + ], + ], + 'ref' => $this->tagente, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'module_status'], + ], + ], + 'ref' => $this->tagente, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'module_value'], + ], + ], + 'ref' => $this->tagente, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'sla_percent'], + ], + ], + 'ref' => $this->tagente, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'wux_transaction_stats'], + ], + ], + 'ref' => $this->tagente, + ], + ], + ], + 'moduleId' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'single_graph'], + ], + ], + 'ref' => $this->tagenteModulo, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'AvgSumMaxMinModule'], + ], + ], + 'ref' => $this->tagenteModulo, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'BasicChart'], + ], + ], + 'ref' => $this->tagenteModulo, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'module_icon'], + ], + ], + 'ref' => $this->tagenteModulo, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'graph_module_histogram'], + ], + ], + 'ref' => $this->tagenteModulo, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'module_table_value'], + ], + ], + 'ref' => $this->tagenteModulo, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'module_status'], + ], + ], + 'ref' => $this->tagenteModulo, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'module_value'], + ], + ], + 'ref' => $this->tagenteModulo, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'sla_percent'], + ], + ], + 'ref' => $this->tagenteModulo, + ], + ], + ], + 'transactionId' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'wux_transaction'], + ], + ], + 'ref' => $this->tagenteModulo, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'wux_transaction_stats'], + ], + ], + 'ref' => $this->tagenteModulo, + ], + ], + ], + 'mGroup' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'agent_module'], + ], + ], + 'ref' => $this->tgrupo, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'service_level'], + ], + ], + 'ref' => $this->tgrupo, + ], + ], + ], + 'mModuleGroup' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'agent_module'], + ], + ], + 'ref' => $this->tmoduleGroup, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'service_level'], + ], + ], + 'ref' => $this->tmoduleGroup, + ], + ], + ], + 'mAgents' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'agent_module'], + ], + ], + 'ref' => ($this->tagente + ['csv' => true, 'csv_separator' => ',']), + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'service_level'], + ], + ], + 'ref' => ($this->tagente + ['csv' => true, 'csv_separator' => ',']), + ], + ], + ], + 'groups[0]' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'AgentHive'], + ], + ], + 'ref' => ($this->tgrupo + ['csv' => true, 'csv_separator' => ',']), + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'heatmap'], + ], + ], + 'ref' => ($this->tgrupo + ['csv' => true, 'csv_separator' => ',']), + ], + ], + ], + 'agentsBlockHistogram[0]' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'BlockHistogram'], + ], + ], + 'ref' => ($this->tagente + ['csv' => true, 'csv_separator' => ',']), + ], + ], + ], + 'moduleBlockHistogram' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'BlockHistogram'], + ], + ], + 'ref' => ($this->tagenteModulo + ['array' => true, 'values_as_keys' => true]), + ], + ], + ], + 'agentsColorModuleTabs[0]' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'ColorModuleTabs'], + ], + ], + 'ref' => ($this->tagente + ['csv' => true, 'csv_separator' => ',']), + ], + ], + ], + 'moduleColorModuleTabs' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'ColorModuleTabs'], + ], + ], + 'ref' => ($this->tagenteModulo + ['array' => true, 'values_as_keys' => true]), + ], + ], + ], + 'reportId' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'reports'], + ], + ], + 'ref' => $this->treport, + ], + ], + ], + 'agentsDataMatrix[0]' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'DataMatrix'], + ], + ], + 'ref' => ($this->tagente + ['csv' => true, 'csv_separator' => ',']), + ], + ], + ], + 'moduleDataMatrix' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'DataMatrix'], + ], + ], + 'ref' => ($this->tagenteModulo + ['array' => true, 'values_as_keys' => true]), + ], + ], + ], + 'id_graph' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'custom_graph'], + ], + ], + 'ref' => $this->tgraph, + ], + ], + ], + 'groupId' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'EventCardboard'], + ], + ], + 'ref' => ($this->tgrupo + ['array' => true]), + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'groups_status'], + ], + ], + 'ref' => $this->tgrupo, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'groups_status_map'], + ], + ], + 'ref' => ($this->tgrupo + ['csv' => true, 'csv_separator' => ',']), + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'system_group_status'], + ], + ], + 'ref' => ($this->tgrupo + ['array' => true]), + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'events_list'], + ], + ], + 'ref' => ($this->tgrupo + ['array' => true]), + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'tactical'], + ], + ], + 'ref' => ($this->tgrupo + ['array' => true]), + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'top_n_events_by_group'], + ], + ], + 'ref' => ($this->tgrupo + ['array' => true]), + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'top_n_events_by_module'], + ], + ], + 'ref' => ($this->tgrupo + ['array' => true]), + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'tree_view'], + ], + ], + 'ref' => $this->tgrupo, + ], + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'alerts_fired'], + ], + ], + 'ref' => $this->tgrupo, + ], + ], + ], + 'maps' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'maps_status'], + ], + ], + 'ref' => ($this->tlayout + ['array' => true]), + ], + ], + ], + 'idGroup' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'inventory'], + ], + ], + 'ref' => $this->tgrupo, + ], + ], + ], + 'agentsGroupedMeterGraphs[0]' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'GroupedMeterGraphs'], + ], + ], + 'ref' => ($this->tagente + ['csv' => true, 'csv_separator' => ',']), + ], + ], + ], + 'moduleGroupedMeterGraphs' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'GroupedMeterGraphs'], + ], + ], + 'ref' => ($this->tagenteModulo + ['array' => true, 'values_as_keys' => true]), + ], + ], + ], + 'tagsId' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'events_list'], + ], + ], + 'ref' => ($this->ttag + ['array' => true]), + ], + ], + ], + 'networkmapId' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'network_map'], + ], + ], + 'ref' => $this->tmap, + ], + ], + ], + 'group' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'security_hardening'], + ], + ], + 'ref' => $this->tgrupo, + ], + ], + ], + 'serviceId' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'service_map'], + ], + ], + 'ref' => $this->tservice, + ], + ], + ], + 'vcId' => [ + 'conditional_refs' => [ + [ + 'when' => [ + 'id_widget' => [ + 'table' => 'twidget', + 'id' => 'id', + 'when' => ['unique_name' => 'maps_made_by_user'], + ], + ], + 'ref' => $this->tlayout, + ], + ], + ], + ], + ], + ]; + + $this->currentItem = [ + 'table' => '', + 'value' => '', + 'last_autocreate' => '', + 'autocreate' => [], + 'parsed' => [], + ]; + + $this->itemsReferences = []; + } + + + /** + * Initialize result + * + * @return void + */ + private function initializeResult() + { + $this->result = [ + 'status' => true, + 'items' => [], + 'errors' => [], + 'info' => [], + ]; + } + + + /** + * Fills result with status. + * + * @param boolean $status Result status. + * + * @return void + */ + public function setResultStatus(bool $status) + { + $this->result['status'] = $status; + } + + + /** + * Fills result with item. + * + * @param string $table Item table. + * @param array $values Item values. + * + * @return void + */ + public function addResultItem(string $table, array $values) + { + $this->result['items'][] = [ + $table, + $values, + ]; + } + + + /** + * Fills result with info message. + * + * @param string $msg Info message. + * + * @return void + */ + public function addResultInfo(string $msg) + { + $this->result['info'][] = $msg; + } + + + /** + * Fills result with error message. + * + * @param string $msg Error message. + * + * @return void + */ + public function addResultError(string $msg) + { + $this->result['errors'][] = $msg; + } + + + /** + * Get current result status. + * + * @return boolean + */ + public function getResultStatus() + { + return $this->result['status']; + } + + + /** + * Get $prdData. + * + * @return array + */ + public function getPrdData(): array + { + return $this->prdData; + } + + + /** + * Get one $prdData. + * + * @param string $item Item to be searched in array. + * + * @return boolean|array + */ + public function getOnePrdData(string $item): bool|array + { + if (isset($this->prdData[$item]) === false) { + return false; + } + + return $this->prdData[$item]; + } + + + /** + * Recursive function to extract tables. + * + * @param array $prd_data PrdData. + * @param array $result Empty array. + * @param string $parent_table Parent level table name. + * + * @return void + */ + private function getTablesPrdData($prd_data, &$result=[], $parent_table='') + { + if (isset($prd_data['items']) === true) { + $result[] = $prd_data['items']['table']; + $this->crossed_refs[$prd_data['items']['table']] = [ + 'value' => $prd_data['items']['value'], + 'ref' => [], + 'parent_table' => $parent_table, + ]; + if ($prd_data['items']['data']) { + $this->getTablesPrdData($prd_data['items']['data'], $result, $prd_data['items']['table']); + } + } else { + foreach ($prd_data as $key => $value) { + $result[] = $value['table']; + $this->crossed_refs[$value['table']] = [ + 'value' => $value['value'], + 'ref' => isset($value['ref']) ? $value['ref'] : [], + 'parent_table' => $parent_table, + ]; + if (isset($value['data'])) { + $this->getTablesPrdData($value['data'], $result, $value['table']); + } + } + } + } + + + /** + * Get $columnRefs. + * + * @return array + */ + public function getColumnRefs(): array + { + return $this->columnRefs; + } + + + /** + * Get one $columnRefs. + * + * @param string $item Item to be searched in array. + * + * @return boolean|array + */ + public function getOneColumnRefs(string $item): bool|array + { + if (isset($this->columnRefs[$item]) === false) { + return false; + } + + return $this->columnRefs[$item]; + } + + + /** + * Get $jsonRefs. + * + * @return array + */ + public function getJsonRefs(): array + { + return $this->jsonRefs; + } + + + /** + * Get one $jsonRefs. + * + * @param string $item Item to be searched in array. + * + * @return boolean|array + */ + public function getOneJsonRefs(string $item): bool|array + { + if (isset($this->jsonRefs[$item]) === false) { + return false; + } + + return $this->jsonRefs[$item]; + } + + + /** + * Get types of prd. + * + * @return array + */ + public function getTypesPrd(): array + { + $result = []; + foreach ($this->prdData as $key => $value) { + $result[$key] = $value['label']; + } + + return $result; + } + + + /** + * Search value in database. + * + * @param array $columns Column. + * @param string $table Table. + * @param string $id Id. + * @param integer|string $value Value. + * + * @return mixed + */ + private function searchValue(array $columns, string $table, string $id, $value) + { + $sql_column = sprintf( + 'SELECT %s FROM %s WHERE %s="%s"', + implode( + ',', + $columns + ), + $table, + $id, + $value + ); + + $result = db_get_row_sql($sql_column); + if ($result !== false) { + $value = $result; + $new_array = []; + $new_array[$table] = $value; + $value = $new_array; + } + + return $value; + } + + + /** + * Function that checks if a value is a base64. + * + * @param string $string Value to be checked. + * + * @return boolean + */ + private function validateBase64(string $string): bool + { + // Check if the string is valid base64 by decoding it + $decoded = base64_decode($string, true); + + // Check if decoding was successful and if the decoded string matches the original + return ($decoded !== false && base64_encode($decoded) === $string); + } + + + /** + * Function that checks if a value is a json. + * + * @param string $json Value to be checked. + * + * @return boolean + */ + private function validateJSON(string $json): bool + { + try { + json_decode($json); + return (json_last_error() === JSON_ERROR_NONE); + } catch (Exception $e) { + return false; + } + } + + + /** + * Function to traverse the array based on the reference. + * + * @param mixed $data JSON Array. + * @param string $reference JSON key reference. + * + * @return mixed + */ + private function extractJsonArrayValue($data, $reference) + { + $keys = explode('.', $reference); + + foreach ($keys as $key) { + if (preg_match('/(.+)\[(\d+)\]/', $key, $matches)) { + // Handle array access + $data = $data[$matches[1]][$matches[2]]; + } else { + // Handle regular key access + $data = $data[$key]; + } + } + + return $data; + } + + + /** + * Function to update a value in the JSON based on the reference. + * + * @param mixed $data JSON Array. + * @param string $reference JSON key reference. + * @param mixed $newValue JSON new value. + * + * @return void + */ + private function updateJsonArrayValue(&$data, $reference, $newValue) + { + preg_match_all('/(\w+)|\[(\d+)\]/', $reference, $matches, PREG_SET_ORDER); + $keys = []; + foreach ($matches as $match) { + if (isset($match[2]) === true) { + $keys[] = (int) $match[2]; + } else { + $keys[] = $match[1]; + } + } + + $lastIndex = (count($keys) - 1); + $updated_data = &$data; + + for ($i = 0; $i < $lastIndex; $i++) { + $updated_data = &$updated_data[$keys[$i]]; + } + + $updated_data[$keys[$lastIndex]] = $newValue; + } + + + /** + * Get reference from value and return true if found. + * + * @param mixed $when_value Condition to build SQL. + * @param array $sql_tables SQL tables. + * @param array $sql_wheres SQL wheres. + * + * @return void + */ + private function recursiveWhenSQLBuildWhere($when_value, &$sql_tables, &$sql_wheres) + { + $rec_when = reset($when_value['when']); + if (is_array($rec_when) === true) { + $sql_tables[] = '`'.$rec_when['table'].'`'; + $sql_wheres[] = '`'.$when_value['table'].'`.`'.array_key_first($when_value['when']).'` = `'.$rec_when['table'].'`.`'.$rec_when['id'].'`'; + + $this->recursiveWhenSQLBuildWhere($rec_when, $sql_tables, $sql_wheres); + } else { + $sql_wheres[] = '`'.$when_value['table'].'`.`'.array_key_first($when_value['when']).'` = "'.$rec_when.'"'; + } + } + + + /** + * Evals conditional references. + * + * @param string $compare_value Value to compare. + * @param mixed $when Condition to check. + * + * @return boolean + */ + private function evalConditionalRef($compare_value, $when) + { + if (is_array($when) === true) { + $when_value = reset($when); + } else { + $when_value = $when; + } + + if ($compare_value == $when_value) { + return true; + } else { + if (is_array($when_value) === true) { + if (isset($when_value['table']) === true + && isset($when_value['id']) === true + && isset($when_value['when']) === true + ) { + if ($this->validateJSON($compare_value) === true) { + $json_value = json_decode($compare_value, true); + foreach ($when_value['when'] as $when_key => $w) { + if (isset($json_value[$when_value['table']][$when_key]) === true) { + $match_compare_value = $json_value[$when_value['table']][$when_key]; + return $this->evalConditionalRef($match_compare_value, $w); + } + } + } + + $sql_fields = []; + $sql_tables = []; + $sql_wheres = []; + + $sql_fields[] = '`'.$when_value['table'].'`.`'.$when_value['id'].'`'; + $sql_tables[] = '`'.$when_value['table'].'`'; + + $this->recursiveWhenSQLBuildWhere($when_value, $sql_tables, $sql_wheres); + + $sql = sprintf( + 'SELECT %s FROM %s WHERE %s', + implode(',', $sql_fields), + implode(',', $sql_tables), + implode(' AND ', $sql_wheres) + ); + + $sql_value = db_get_value_sql($sql); + + $crossed_ref = $this->getItemReference($when_value['table'], $when_value['id'], $compare_value); + if ($crossed_ref !== false) { + $compare_value = $crossed_ref; + } + + if ($compare_value == $sql_value) { + return true; + } + } + } + } + + return false; + } + + + /** + * Get reference from value and return true if found. + * + * @param string $table Table. + * @param string $column Table column. + * @param array $reference Reference to extract value. + * @param array $row Current row values. + * @param string $value Value to update. + * + * @return void + */ + private function getReferenceFromValue($table, $column, $reference, $row, &$value) + { + if (isset($reference['conditional_refs']) === true) { + // Conditional refs. + $conditional = $reference['conditional_refs']; + foreach ($conditional as $key => $condition) { + if (isset($condition['when']) === true + && isset($condition['ref']) === true + ) { + if (isset($row[array_key_first($condition['when'])]) === true) { + $compare_value = $row[array_key_first($condition['when'])]; + + if ($this->evalConditionalRef($compare_value, $condition['when']) === true + && empty($value) === false + ) { + $ref = $condition['ref']; + if (isset($ref['join']) === true) { + if (isset($ref['array']) === true + && $ref['array'] === true + ) { + if (is_array($value) === true) { + $value_arr = $value; + } else { + $value_arr = json_decode($value, true); + } + + if (is_array($value_arr)) { + $ref_arr = []; + foreach ($value_arr as $val) { + $join_array = $this->recursiveJoin( + $ref, + $val + ); + $ref_arr[] = [$ref['table'] => $join_array]; + } + + $value = $ref_arr; + } + } else if (isset($ref['csv']) === true + && $ref['csv'] === true + ) { + $csv_separator = ','; + if (isset($ref['csv_separator']) === true + && $ref['csv_separator'] === true + ) { + $csv_separator = $ref['csv_separator']; + } + + $value_arr = explode($csv_separator, $value); + $ref_arr = []; + foreach ($value_arr as $val) { + $join_array = $this->recursiveJoin( + $ref, + $val + ); + $val = [$ref['table'] => $join_array]; + $ref_arr[] = json_encode($val); + } + + $value = implode($csv_separator, $ref_arr); + } else { + $join_array = $this->recursiveJoin( + $ref, + $value + ); + $value = [$ref['table'] => $join_array]; + $value = json_encode($value); + } + } else { + if (isset($ref['array']) === true + && $ref['array'] === true + ) { + if (is_array($value) === true) { + $value_arr = $value; + } else { + $value_arr = json_decode($value, true); + } + + if (is_array($value_arr)) { + $ref_arr = []; + foreach ($value_arr as $val) { + $ref_val = $this->searchValue( + $ref['columns'], + $ref['table'], + $ref['id'], + $val + ); + if ($ref_val !== false) { + if (isset($ref['values_as_keys']) === true + && $ref['values_as_keys'] === true + ) { + $ref_arr[$ref_val] = $ref_val; + } else { + $ref_arr[] = $ref_val; + } + } + } + + $value = $ref_arr; + } + } else if (isset($ref['csv']) === true + && $ref['csv'] === true + ) { + $csv_separator = ','; + if (isset($ref['csv_separator']) === true + && $ref['csv_separator'] === true + ) { + $csv_separator = $ref['csv_separator']; + } + + $value_arr = explode($csv_separator, $value); + $ref_arr = []; + foreach ($value_arr as $val) { + $ref_val = $this->searchValue( + $ref['columns'], + $ref['table'], + $ref['id'], + $val + ); + if (is_array($ref_val) === true) { + $ref_val = json_encode($ref_val); + } + + $ref_arr[] = $ref_val; + } + + $value = implode($csv_separator, $ref_arr); + } else { + $value = $this->searchValue( + $ref['columns'], + $ref['table'], + $ref['id'], + $value + ); + } + } + + return; + } + } + } + } + } + + if (isset($reference['ref']) === true) { + $ref = $reference['ref']; + + if (isset($ref['join']) === true) { + if (isset($ref['array']) === true + && $ref['array'] === true + ) { + if (is_array($value) === true) { + $value_arr = $value; + } else { + $value_arr = json_decode($value, true); + } + + if (is_array($value_arr)) { + $ref_arr = []; + foreach ($value_arr as $val) { + $join_array = $this->recursiveJoin( + $ref, + $val + ); + $ref_arr[] = [$ref['table'] => $join_array]; + } + + $value = $ref_arr; + } + } else if (isset($ref['csv']) === true + && $ref['csv'] === true + ) { + $csv_separator = ','; + if (isset($ref['csv_separator']) === true + && $ref['csv_separator'] === true + ) { + $csv_separator = $ref['csv_separator']; + } + + $value_arr = explode($csv_separator, $value); + $ref_arr = []; + foreach ($value_arr as $val) { + $join_array = $this->recursiveJoin( + $ref, + $val + ); + $val = [$ref['table'] => $join_array]; + $ref_arr[] = json_encode($val); + } + + $value = implode($csv_separator, $ref_arr); + } else { + $join_array = $this->recursiveJoin( + $ref, + $value + ); + $value = [$ref['table'] => $join_array]; + $value = json_encode($value); + } + } else { + if (isset($ref['array']) === true + && $ref['array'] === true + ) { + if (is_array($value) === true) { + $value_arr = $value; + } else { + $value_arr = json_decode($value, true); + } + + if (is_array($value_arr)) { + $ref_arr = []; + foreach ($value_arr as $val) { + $ref_val = $this->searchValue( + $ref['columns'], + $ref['table'], + $ref['id'], + $val + ); + if ($ref_val !== false) { + if (isset($ref['values_as_keys']) === true + && $ref['values_as_keys'] === true + ) { + $ref_arr[$ref_val] = $ref_val; + } else { + $ref_arr[] = $ref_val; + } + } + } + + $value = $ref_arr; + } + } else if (isset($ref['csv']) === true + && $ref['csv'] === true + ) { + $csv_separator = ','; + if (isset($ref['csv_separator']) === true + && $ref['csv_separator'] === true + ) { + $csv_separator = $ref['csv_separator']; + } + + $value_arr = explode($csv_separator, $value); + $ref_arr = []; + foreach ($value_arr as $val) { + $ref_val = $this->searchValue( + $ref['columns'], + $ref['table'], + $ref['id'], + $val + ); + if (is_array($ref_val) === true) { + $ref_val = json_encode($ref_val); + } + + $ref_arr[] = $ref_val; + } + + $value = implode($csv_separator, $ref_arr); + } else { + $value = $this->searchValue( + $ref['columns'], + $ref['table'], + $ref['id'], + $value + ); + } + } + } + } + + + /** + * Get value from reference and return true if found. + * + * @param string $table Table. + * @param string $column Table column. + * @param array $reference Reference to extract value. + * @param string $value Value to update. + * + * @return boolean + */ + private function getValueFromReference($table, $column, $reference, &$value) + { + if (isset($reference['conditional_refs']) === true) { + // Conditional refs. + $prd_item = false; + $conditional = $reference['conditional_refs']; + foreach ($conditional as $key => $condition) { + if (isset($condition['when']) === true + && isset($condition['ref']) === true + ) { + if (isset($this->currentItem['parsed'][array_key_first($condition['when'])]) === true) { + $compare_value = $this->currentItem['parsed'][array_key_first($condition['when'])]; + + if ($this->evalConditionalRef($compare_value, $condition['when']) === true + && empty($value) === false + ) { + if (isset($condition['ref']['array']) === true + && $condition['ref']['array'] === true + ) { + if (is_array($value) === true) { + $value_arr = $value; + } else { + $value_arr = json_decode($value, true); + } + + if (is_array($value_arr)) { + $ref_arr = []; + foreach ($value_arr as $val) { + $ref_val = $this->findPrdItem( + $condition['ref'], + is_array($val) ? json_encode($val) : $val + ); + + if ($ref_val === false && $ref_val != $val) { + if ($this->evalAutocreateItem($condition['ref'], is_array($val) ? json_encode($val) : $val, $column) === false) { + return false; + } + } + + if ($ref_val !== false) { + if (isset($ref['values_as_keys']) === true + && $ref['values_as_keys'] === true + ) { + $ref_arr[$ref_val] = $ref_val; + } else { + $ref_arr[] = $ref_val; + } + } + } + + $value = $ref_arr; + } + } else if (isset($condition['ref']['csv']) === true + && $condition['ref']['csv'] === true + ) { + $csv_separator = ','; + if (isset($condition['ref']['csv_separator']) === true + && $condition['ref']['csv_separator'] === true + ) { + $csv_separator = $condition['ref']['csv_separator']; + } + + $value_arr = explode($csv_separator, $value); + $ref_arr = []; + foreach ($value_arr as $val) { + $ref_val = $this->findPrdItem( + $condition['ref'], + $val + ); + + if ($ref_val === false && $ref_val != $val) { + if ($this->evalAutocreateItem($condition['ref'], $val, $column) === false) { + return false; + } + } + + $ref_arr[] = $ref_val; + } + + $value = implode($csv_separator, $ref_arr); + } else { + $prd_item = $this->findPrdItem( + $condition['ref'], + is_array($value) ? json_encode($value) : $value + ); + + if ($prd_item === false && $prd_item != $value) { + if ($this->evalAutocreateItem($condition['ref'], is_array($value) ? json_encode($value) : $value, $column) === false) { + return false; + } + } + + $value = $prd_item; + } + + return true; + } + } + } + } + } + + if (isset($reference['ref']) === true) { + $ref = $reference['ref']; + if (isset($ref['array']) === true + && $ref['array'] === true + ) { + if (is_array($value) === true) { + $value_arr = $value; + } else { + $value_arr = json_decode($value, true); + } + + if (is_array($value_arr)) { + $ref_arr = []; + foreach ($value_arr as $val) { + $ref_val = $this->findPrdItem( + $ref, + is_array($val) ? json_encode($val) : $val + ); + + if ($ref_val === false && $ref_val != $val) { + if ($this->evalAutocreateItem($ref, is_array($val) ? json_encode($val) : $val, $column) === false) { + return false; + } + } + + if ($ref_val !== false) { + if (isset($ref['values_as_keys']) === true + && $ref['values_as_keys'] === true + ) { + $ref_arr[$ref_val] = $ref_val; + } else { + $ref_arr[] = $ref_val; + } + } + } + + $value = $ref_arr; + } + } else if (isset($ref['csv']) === true + && $ref['csv'] === true + ) { + $csv_separator = ','; + if (isset($ref['csv_separator']) === true + && $ref['csv_separator'] === true + ) { + $csv_separator = $ref['csv_separator']; + } + + $value_arr = explode($csv_separator, $value); + $ref_arr = []; + foreach ($value_arr as $val) { + $ref_val = $this->findPrdItem( + $ref, + $val + ); + + if ($ref_val === false && $ref_val != $val) { + if ($this->evalAutocreateItem($ref, $val, $column) === false) { + return false; + } + } + + $ref_arr[] = $ref_val; + } + + $value = implode($csv_separator, $ref_arr); + } else { + $prd_item = $this->findPrdItem( + $ref, + is_array($value) ? json_encode($value) : $value + ); + + if ($prd_item === false && $prd_item != $value) { + if ($this->evalAutocreateItem($ref, is_array($value) ? json_encode($value) : $value, $column) === false) { + return false; + } + } + + $value = $prd_item; + } + + return true; + } + + if (isset($reference['fixed_value']) === true) { + $value = $reference['fixed_value']; + return true; + } + + return true; + } + + + /** + * Converts a resource into a string. + * + * @param string $type Item type. + * @param mixed $id Item value. + * @param string $name Item name. + * + * @return string + */ + public function exportPrd(string $type, mixed $id, string $name) :string + { + $result = ''; + + $prd_data = $this->getOnePrdData($type); + if (empty($prd_data) === false) { + $result .= '[prd_data]'.LINE_BREAK.LINE_BREAK; + $result .= 'type="'.$type.'"'.LINE_BREAK; + $result .= 'name="'.io_safe_output($name).'"'.LINE_BREAK.LINE_BREAK; + + $prd_export_tables = []; + $this->recursiveExportPrd([$prd_data['items']], $id, $prd_export_tables); + + foreach ($prd_export_tables as $table => $rows) { + $result .= '['.$table.']'.LINE_BREAK.LINE_BREAK; + + foreach ($rows as $index => $row) { + foreach ($row as $field => $value) { + // Scape double quotes in all values. + $value = str_replace('"', '\"', $value); + $result .= $field.'['.$index.']="'.$value.'"'.LINE_BREAK; + } + + $result .= LINE_BREAK; + } + } + } + + return $result; + } + + + /** + * Recursive function to traverse all data + * + * @param mixed $data Data. + * @param mixed $id Id value for search. + * @param mixed $result Result. + * + * @return void + */ + private function recursiveExportPrd($data, $id, &$result=[]) + { + foreach ($data as $key => $element) { + if (!isset($result[$element['table']])) { + $result[$element['table']] = []; + } + + $columns_ref = $this->getOneColumnRefs($element['table']); + $json_ref = $this->getOneJsonRefs($element['table']); + + $sql_field = reset($element['value']); + if (isset($element['ref'])) { + $sql_field = reset($element['ref']); + } + + $sql = sprintf( + 'SELECT * FROM %s WHERE %s = "%s"', + $element['table'], + $sql_field, + $id, + ); + + if (empty($id) === false && empty($element['table']) === false + && empty(reset($element['value'])) === false + ) { + $rows = db_get_all_rows_sql($sql); + } else { + $rows = []; + } + + foreach ($rows as $row) { + if (count($element['value']) > 1) { + $primary_key = ''; + foreach ($element['value'] as $value) { + $primary_key .= $row[$value].'-'; + } + + $primary_key = substr($primary_key, 0, -1); + } else { + $primary_key = $row[reset($element['value'])]; + } + + foreach ($row as $column => $value) { + $isBase64 = false; + if (isset($columns_ref[$column]) === true + && empty($value) === false + ) { + if (is_string($value) === true && $this->validateBase64($value) === true) { + $value = base64_decode($value); + $isBase64 = true; + } + + // The column is inside column refs. + $this->getReferenceFromValue( + $element['table'], + $column, + $columns_ref[$column], + $row, + $value + ); + } else if (isset($json_ref[$column]) === true + && empty($value) === false + ) { + // Json ref. + $array_value = json_decode($value, true); + foreach ($json_ref[$column] as $json_key => $ref) { + $json_value = $this->extractJsonArrayValue($array_value, $json_key); + if (isset($json_value) === true) { + $isBase64 = false; + if (is_string($json_value) === true && $this->validateBase64($json_value) === true) { + $json_value = base64_decode($json_value); + $isBase64 = true; + } + + $this->getReferenceFromValue( + $element['table'], + $column, + $ref, + $row, + $json_value + ); + if ($isBase64 === true) { + if (is_array($json_value) === true) { + $json_value = json_encode($json_value); + } + + $json_value = base64_encode($json_value); + } + + $this->updateJsonArrayValue($array_value, $json_key, $json_value); + } + } + + $isBase64 = false; + $value = json_encode($array_value); + } + + if (is_array($value) === true) { + $value = json_encode($value); + } + + if ($isBase64 === true) { + $value = base64_encode($value); + } + + if (!isset($result[$element['table']][$primary_key])) { + $result[$element['table']][$primary_key] = []; + } + + $result[$element['table']][$primary_key][$column] = $value; + } + + if (isset($element['data']) === true) { + $this->recursiveExportPrd($element['data'], $primary_key, $result); + } + } + } + } + + + /** + * Recursive function to traverse all join data + * + * @param array $data Data. + * @param mixed $value Value for search. + * + * @return array + */ + private function recursiveJoin(array $data, $value):array + { + $result = []; + if (empty($data['join']) === false) { + $sql = sprintf( + 'SELECT %s, %s FROM %s WHERE %s="%s"', + implode( + ',', + $data['columns'] + ), + array_key_first($data['join']), + $data['table'], + $data['id'], + $value + ); + + $result = db_get_row_sql($sql); + $join = reset($data['join']); + $result_deep = $this->recursiveJoin($join, $result[array_key_first($data['join'])]); + + $result[array_key_first($data['join'])] = $result_deep; + } else { + $sql = sprintf( + 'SELECT %s FROM %s WHERE %s="%s"', + implode( + ',', + $data['columns'] + ), + $data['table'], + $data['id'], + $value + ); + + $result_sql = db_get_row_sql($sql); + $result[$data['table']] = $result_sql; + } + + return $result; + } + + + /** + * Function to fill current item. + * + * @param string|integer $id Id. + * @param string $table Table. + * @param array $data Array with data. + * + * @return void + */ + private function fillCurrentItem($id, string $table, array $data) + { + $this->currentItem['table'] = $table; + $this->currentItem['id'] = $id; + $this->currentItem['value'] = ''; + $this->currentItem['last_autocreate'] = ''; + $this->currentItem['autocreate'] = []; + $this->currentItem['parsed'] = []; + foreach ($data as $column => $value) { + $this->currentItem['parsed'][$column] = $value[$id]; + } + } + + + /** + * Converts a resource into a string. + * + * @param array $data_file Array with import data. + * + * @return array + */ + public function importPrd($data_file): array + { + global $config; + + $this->initializeResult(); + + if (empty($data_file['prd_data']) === false) { + $type = $data_file['prd_data']['type']; + $name = io_safe_input($data_file['prd_data']['name']); + unset($data_file['prd_data']); + + $prd_data = $this->getOnePrdData($type); + if ($prd_data !== false) { + // Begin transaction. + $db = $config['dbconnection']; + $db->begin_transaction(); + + try { + $tables = []; + $this->crossed_refs = []; + $tables_id = []; + $this->getTablesPrdData($prd_data, $tables); + foreach ($tables as $table) { + if (isset($data_file[$table]) === false) { + continue; + } + + $internal_array = $data_file[$table]; + + $column_refs = $this->getOneColumnRefs($table); + $json_refs = $this->getOneJsonRefs($table); + + $ids = reset($internal_array); + foreach ($ids as $id => $i) { + $create_item = true; + $this->fillCurrentItem($id, $table, $internal_array); + foreach ($this->currentItem['parsed'] as $column => $value) { + if (isset($column_refs[$column]) === true + && empty($value) === false + ) { + $isBase64 = false; + if (is_string($value) === true && $this->validateBase64($value)) { + $value = base64_decode($value); + $isBase64 = true; + } + + $create_item = $this->getValueFromReference( + $table, + $column, + $column_refs[$column], + $value + ); + + if (is_array($value) === true) { + $value = json_encode($value); + } + + if ($isBase64 === true) { + $value = base64_encode($value); + } + } else if (isset($json_refs[$column]) === true + && empty($value) === false + ) { + $array_value = json_decode($value, true); + foreach ($json_refs[$column] as $json_key => $json_ref) { + $json_value = $this->extractJsonArrayValue($array_value, $json_key); + if (isset($json_value) === true) { + $isBase64 = false; + if (is_string($json_value) === true && $this->validateBase64($json_value) === true) { + $json_value = base64_decode($json_value); + $isBase64 = true; + } + + if ($this->getValueFromReference( + $table, + $column, + $json_refs[$column][$json_key], + $json_value + ) === true + ) { + if ($isBase64 === true) { + if (is_array($json_value) === true) { + $json_value = json_encode($json_value); + } + + $json_value = base64_encode($json_value); + } + + $this->updateJsonArrayValue($array_value, $json_key, $json_value); + } else { + $create_item = false; + break; + } + } + } + + $value = json_encode($array_value); + } + + if ($create_item === false) { + break; + } + + $this->currentItem['parsed'][$column] = $value; + } + + if ($create_item === true) { + if ($this->createItem($table) === false) { + $this->setResultStatus(false); + break; + } + } else { + $this->addResultInfo( + sprintf( + 'Skipped item creation at least one reference not found: table => %s, item => %s', + $table, + $id + ) + ); + } + } + + if ($this->getResultStatus() === false) { + break; + } + } + } catch (\Throwable $th) { + $this->setResultStatus(false); + $this->addResultError('Unexpected error: '.$th->getMessage()); + } + } else { + $this->setResultStatus(false); + $this->addResultError('[prd_data] => "type" not valid to import: '.$type); + } + } else { + $this->setResultStatus(false); + $this->addResultError('[prd_data] not found in PRD file.'); + } + + if (isset($db)) { + if ($this->getResultStatus() === true) { + $db->commit(); + } else { + $db->rollback(); + } + } + + return $this->result; + } + + + /** + * Finds value in database. + * + * @param array $ref Reference. + * @param mixed $value Value. + * + * @return mixed + */ + private function findPrdItem($ref, $value) + { + $result = false; + $array_value = json_decode($value, true); + if (isset($ref['join']) === true) { + $result = $this->inverseRecursiveJoin( + $ref, + $array_value + ); + } else { + if (empty($array_value) === false + && empty($array_value[$ref['table']]) === false + ) { + $where = ''; + foreach ($ref['columns'] as $column_name) { + if (isset($array_value[$ref['table']][$column_name])) { + $where .= sprintf( + "%s = '%s' AND ", + $column_name, + $array_value[$ref['table']][$column_name] + ); + } + } + + $where = rtrim($where, 'AND '); + $sql_column = sprintf( + 'SELECT %s FROM %s WHERE %s', + $ref['id'], + $ref['table'], + $where, + ); + + $result = db_get_value_sql($sql_column); + } else { + // Empty json. + $result = $value; + } + } + + return $result; + } + + + /** + * Recursive function to traverse all join data + * + * @param array $ref Data. + * @param mixed $value Value for search. + * + * @return mixed + */ + private function inverseRecursiveJoin($ref, $value) + { + $result = ''; + if (empty($ref['join']) === false) { + $result = $this->inverseRecursiveJoin( + $ref['join'], + $value[$ref['table']][array_key_first($ref['join'])] + ); + + if (empty($result) === false) { + $where = ''; + foreach ($ref['columns'] as $column_name) { + if (isset($value[$ref['table']][$column_name]) === true) { + $where .= sprintf( + "%s = '%s' AND ", + $column_name, + $value[$ref['table']][$column_name] + ); + } + } + + $where .= ' '.array_key_first($ref['join']).' = "'.reset($result).'"'; + $where = rtrim($where, 'AND '); + + $sql = sprintf( + 'SELECT %s FROM %s WHERE %s', + $ref['id'], + $ref['table'], + $where + ); + + $result = db_get_value_sql($sql); + } + } else { + $key = array_key_first($ref); + $where = ''; + foreach ($ref[$key]['columns'] as $column_name) { + if (isset($value[$ref[$key]['table']][$column_name]) === true) { + $where .= sprintf( + "%s = '%s' AND ", + $column_name, + $value[$ref[$key]['table']][$column_name] + ); + } + } + + if (empty($where) === false) { + $where = rtrim($where, 'AND '); + + $sql = sprintf( + 'SELECT %s FROM %s WHERE %s', + $ref[$key]['id'], + $ref[$key]['table'], + $where + ); + + $result = db_get_row_sql($sql); + } + } + + return $result; + } + + + /** + * Eval autocreate Item. + * + * @param array $ref References. + * @param string $value Current value. + * @param string $column Table column. + * + * @return boolean + */ + private function evalAutocreateItem(array $ref, string $value='', string $column='') + { + if (isset($ref['autocreate_item']) === true) { + $this->autocreateItem( + $ref, + $column, + $value, + $ref['autocreate_item'] + ); + } else { + return false; + } + + return true; + } + + + /** + * Autocreate Item. + * + * @param array $ref References. + * @param string $field Field. + * @param string $autocreate_key Key. + * + * @return void + */ + private function autocreateItem(array $ref, string $field='', $ref_value, string $autocreate_key='') + { + $current_item = $this->currentItem['parsed'][$field]; + $current_item = json_decode($current_item, true); + + switch ($autocreate_key) { + case 'service_module': + $autocreate_globals = [ + 'service_module' => [ + 'id_agent' => $this->findPrdItem( + $this->tagente, + json_encode($current_item['tagente_modulo']['id_agente']) + ), + 'interval' => 300, + 'status' => AGENT_MODULE_STATUS_NO_DATA, + ], + ]; + + $autocreate_pre_items = [ + 'service_module' => [ + [ + 'table' => 'tagente_modulo', + 'id' => ['id_agente_modulo'], + 'fields' => [ + 'id_agente' => $autocreate_globals[$autocreate_key]['id_agent'], + 'nombre' => $this->currentItem['parsed']['name'].'_service', + 'flag' => 1, + 'module_interval' => $autocreate_globals[$autocreate_key]['interval'], + 'prediction_module' => 2, + 'id_modulo' => MODULE_PREDICTION, + 'id_tipo_modulo' => MODULE_TYPE_GENERIC_DATA, + 'min_warning' => $this->currentItem['parsed']['warning'], + 'min_critical' => $this->currentItem['parsed']['critical'], + ], + ], + [ + 'table' => 'tagente_estado', + 'id' => ['id_agente_estado'], + 'fields' => [ + 'id_agente_modulo' => &$this->currentItem['last_autocreate'], + 'datos' => '', + 'timestamp' => '0000-00-00 00:00:00', + 'estado' => $autocreate_globals[$autocreate_key]['status'], + 'known_status' => $autocreate_globals[$autocreate_key]['status'], + 'id_agente' => $autocreate_globals[$autocreate_key]['id_agent'], + 'utimestamp' => 0, + 'status_changes' => 0, + 'last_status' => $autocreate_globals[$autocreate_key]['status'], + 'last_known_status' => $autocreate_globals[$autocreate_key]['status'], + 'current_interval' => 0, + ], + ], + ], + ]; + + $autocreate_post_updates = [ + 'service_module' => [ + [ + 'table' => 'tagente_modulo', + 'fields' => [ + 'custom_integer_1' => &$this->currentItem['value'], + ], + 'conditions' => [ + 'id_agente_modulo' => &$this->currentItem['parsed'][$field], + ], + ], + [ + 'table' => 'tagente', + 'fields' => ['update_module_count' => '1'], + 'conditions' => [ + 'id_agente' => $autocreate_globals[$autocreate_key]['id_agent'], + ], + ], + ], + ]; + break; + + case 'service_sla_module': + $autocreate_globals = [ + 'service_sla_module' => [ + 'id_agent' => $this->findPrdItem( + $this->tagente, + json_encode($current_item['tagente_modulo']['id_agente']) + ), + 'interval' => 300, + 'status' => AGENT_MODULE_STATUS_NO_DATA, + ], + ]; + + $autocreate_pre_items = [ + 'service_sla_module' => [ + [ + 'table' => 'tagente_modulo', + 'id' => ['id_agente_modulo'], + 'fields' => [ + 'id_agente' => $autocreate_globals[$autocreate_key]['id_agent'], + 'nombre' => $this->currentItem['parsed']['name'].'_SLA_service', + 'flag' => 1, + 'module_interval' => $autocreate_globals[$autocreate_key]['interval'], + 'prediction_module' => 2, + 'id_modulo' => MODULE_PREDICTION, + 'id_tipo_modulo' => MODULE_TYPE_GENERIC_PROC, + ], + ], + [ + 'table' => 'tagente_estado', + 'id' => ['id_agente_estado'], + 'fields' => [ + 'id_agente_modulo' => &$this->currentItem['last_autocreate'], + 'datos' => '', + 'timestamp' => '0000-00-00 00:00:00', + 'estado' => $autocreate_globals[$autocreate_key]['status'], + 'known_status' => $autocreate_globals[$autocreate_key]['status'], + 'id_agente' => $autocreate_globals[$autocreate_key]['id_agent'], + 'utimestamp' => 0, + 'status_changes' => 0, + 'last_status' => $autocreate_globals[$autocreate_key]['status'], + 'last_known_status' => $autocreate_globals[$autocreate_key]['status'], + 'current_interval' => 0, + ], + ], + ], + ]; + + $autocreate_post_updates = [ + 'service_sla_module' => [ + [ + 'table' => 'tagente_modulo', + 'fields' => [ + 'custom_integer_1' => &$this->currentItem['value'], + ], + 'conditions' => [ + 'id_agente_modulo' => &$this->currentItem['parsed'][$field], + ], + ], + [ + 'table' => 'tagente', + 'fields' => ['update_module_count' => '1'], + 'conditions' => [ + 'id_agente' => $autocreate_globals[$autocreate_key]['id_agent'], + ], + ], + ], + ]; + break; + + case 'service_sla_value_module': + $autocreate_globals = [ + 'service_sla_value_module' => [ + 'id_agent' => $this->findPrdItem( + $this->tagente, + json_encode($current_item['tagente_modulo']['id_agente']) + ), + 'interval' => 300, + 'status' => AGENT_MODULE_STATUS_NO_DATA, + ], + ]; + + $autocreate_pre_items = [ + 'service_sla_value_module' => [ + [ + 'table' => 'tagente_modulo', + 'id' => ['id_agente_modulo'], + 'fields' => [ + 'id_agente' => $autocreate_globals[$autocreate_key]['id_agent'], + 'nombre' => $this->currentItem['parsed']['name'].'_SLA_Value_service', + 'flag' => 1, + 'module_interval' => $autocreate_globals[$autocreate_key]['interval'], + 'prediction_module' => 2, + 'id_modulo' => MODULE_PREDICTION, + 'id_tipo_modulo' => MODULE_TYPE_GENERIC_DATA, + 'min_critical' => $this->currentItem['parsed']['sla_limit'], + ], + ], + [ + 'table' => 'tagente_estado', + 'id' => ['id_agente_estado'], + 'fields' => [ + 'id_agente_modulo' => &$this->currentItem['last_autocreate'], + 'datos' => '', + 'timestamp' => '0000-00-00 00:00:00', + 'estado' => $autocreate_globals[$autocreate_key]['status'], + 'known_status' => $autocreate_globals[$autocreate_key]['status'], + 'id_agente' => $autocreate_globals[$autocreate_key]['id_agent'], + 'utimestamp' => 0, + 'status_changes' => 0, + 'last_status' => $autocreate_globals[$autocreate_key]['status'], + 'last_known_status' => $autocreate_globals[$autocreate_key]['status'], + 'current_interval' => 0, + ], + ], + ], + ]; + + $autocreate_post_updates = [ + 'service_sla_value_module' => [ + [ + 'table' => 'tagente_modulo', + 'fields' => [ + 'custom_integer_1' => &$this->currentItem['value'], + ], + 'conditions' => [ + 'id_agente_modulo' => &$this->currentItem['parsed'][$field], + ], + ], + [ + 'table' => 'tagente', + 'fields' => ['update_module_count' => '1'], + 'conditions' => [ + 'id_agente' => $autocreate_globals[$autocreate_key]['id_agent'], + ], + ], + ], + ]; + break; + + case 'agent_groups': + $autocreate_pre_items = [ + 'agent_groups' => [ + [ + 'table' => 'tgrupo', + 'id' => ['id_grupo'], + 'fields' => ['nombre' => json_decode($ref_value, true)['tgrupo']['nombre']], + ], + ], + ]; + break; + + case 'module_groups': + $autocreate_pre_items = [ + 'module_groups' => [ + [ + 'table' => 'tmodule_group', + 'id' => ['id_mg'], + 'fields' => ['name' => json_decode($ref_value, true)['tmodule_group']['name']], + ], + ], + ]; + break; + + case 'operating_systems': + $autocreate_pre_items = [ + 'operating_systems' => [ + [ + 'table' => 'tconfig_os', + 'id' => ['id_os'], + 'fields' => ['name' => json_decode($ref_value, true)['tconfig_os']['name']], + ], + ], + ]; + break; + + case 'categories': + $autocreate_pre_items = [ + 'categories' => [ + [ + 'table' => 'tcategory', + 'id' => ['id'], + 'fields' => ['name' => json_decode($ref_value, true)['tcategory']['name']], + ], + ], + ]; + break; + + case 'tags': + $autocreate_pre_items = [ + 'tags' => [ + [ + 'table' => 'ttag', + 'id' => ['id_tag'], + 'fields' => ['name' => json_decode($ref_value, true)['ttag']['name']], + ], + ], + ]; + break; + + default: + // Empty. + break; + } + + $this->currentItem['autocreate'][$field]['ref'] = $ref; + $this->currentItem['autocreate'][$field]['pre_items'] + = (isset($autocreate_pre_items[$autocreate_key]) === true + ? $autocreate_pre_items[$autocreate_key] + : [] + ); + $this->currentItem['autocreate'][$field]['post_updates'] + = (isset($autocreate_post_updates[$autocreate_key]) === true + ? $autocreate_post_updates[$autocreate_key] + : [] + ); + } + + + /** + * Function to add an old ID reference. + * + * @param string $table Table. + * @param array $fields Table fields. + * @param string $old_value Old value. + * @param string $current_value Current value. + * + * @return void + */ + private function addItemReference(string $table, array $fields, string $old_value, string $current_value) + { + if (count($fields) > 1) { + $old_value = explode('-', $old_value); + $current_value = explode('-', $current_value); + } else { + $old_value = [$old_value]; + $current_value = [$current_value]; + } + + if (!isset($this->itemsReferences[$table])) { + $this->itemsReferences[$table] = []; + } + + foreach ($fields as $k => $field) { + if (!isset($this->itemsReferences[$table][$field])) { + $this->itemsReferences[$table][$field] = []; + } + + $this->itemsReferences[$table][$field][$old_value[$k]] = $current_value[$k]; + } + } + + + /** + * Function to get an old ID reference. + * + * @param string $table Table. + * @param string $field Table field. + * @param string $old_value Old value. + * + * @return mixed + */ + private function getItemReference(string $table, string $field, string $old_value) + { + if (isset($this->itemsReferences[$table][$field][$old_value]) === true) { + return $this->itemsReferences[$table][$field][$old_value]; + } + + return false; + } + + + /** + * Function to create item in database. + * + * @param string $table Table. + * + * @return mixed + */ + private function createItem(string $table) + { + $id = $this->crossed_refs[$table]['value']; + + // Remove primary keys not references + foreach ($id as $id_column) { + if (in_array($id_column, $this->crossed_refs[$table]['ref']) === false + && isset($this->columnRefs[$table][$id_column]) === false + ) { + unset($this->currentItem['parsed'][$id_column]); + } + } + + // Update current item crossed references. + if (isset($this->crossed_refs[$table]) === true + && empty($this->crossed_refs[$table]['ref']) === false + ) { + $parent_table = $this->crossed_refs[$table]['parent_table']; + foreach ($this->crossed_refs[$table]['ref'] as $k => $f) { + $itemReference = $this->getItemReference( + $parent_table, + $this->crossed_refs[$parent_table]['value'][$k], + $this->currentItem['parsed'][$f] + ); + + if ($itemReference === false) { + $this->addResultError( + sprintf( + 'Failed when trying to create item (crossed references): table => %s, item => %s', + $table, + $this->currentItem['id'] + ) + ); + return false; + } + + $this->currentItem['parsed'][$f] = $itemReference; + } + } + + foreach ($this->currentItem['autocreate'] as $field => $values) { + if (isset($values['pre_items']) === true) { + foreach ($values['pre_items'] as $insert) { + // Run each INSERT and store each value in $this->currentItem['last_autocreate'] overwriting. + foreach ($insert['fields'] as $insert_f => $insert_v) { + if ($insert_v === false) { + $this->addResultError( + sprintf( + 'Failed when trying to autocreate unexisting item (dependent item not found in pre inserts): table => %s, item => %s, field => %s', + $this->currentItem['table'], + $this->currentItem['id'], + $field + ) + ); + return false; + } + } + + $insert_query = db_process_sql_insert( + $insert['table'], + $insert['fields'], + false + ); + + $last_autocreate = db_get_all_rows_filter( + $insert['table'], + $insert['fields'], + $insert['id'] + ); + + if ($insert_query === false || $last_autocreate === false) { + $this->addResultError( + sprintf( + 'Failed when trying to autocreate unexisting item: table => %s, item => %s, field => %s', + $this->currentItem['table'], + $this->currentItem['id'], + $field + ) + ); + return false; + } + + $last_autocreate = end($last_autocreate); + + $this->addResultItem($insert['table'], $last_autocreate); + + $this->currentItem['last_autocreate'] = implode('-', array_values($last_autocreate)); + } + } + + $this->currentItem['parsed'][$field] = $this->findPrdItem( + $values['ref'], + $this->currentItem['parsed'][$field] + ); + } + + // Create item itself with INSERT query and store its value in $this->currentItem['value']. + $sql_fields = []; + foreach ($this->currentItem['parsed'] as $f => $v) { + $sql_fields['`'.$f.'`'] = $v; + } + + $insert_query = db_process_sql_insert( + $table, + $sql_fields, + false + ); + + $insert = db_get_all_rows_filter( + $table, + $sql_fields, + $id + ); + + if ($insert_query === false || $insert === false) { + $this->addResultError( + sprintf( + 'Failed when trying to create item: table => %s, item => %s', + $table, + $this->currentItem['id'] + ) + ); + return false; + } + + $insert = end($insert); + + $this->addResultItem($table, $insert); + + $this->currentItem['value'] = implode('-', array_values($insert)); + + if (isset($this->crossed_refs[$table]) === true) { + $this->addItemReference( + $table, + $this->crossed_refs[$table]['value'], + $this->currentItem['id'], + $this->currentItem['value'] + ); + } + + foreach ($this->currentItem['autocreate'] as $field => $values) { + if (isset($values['post_updates']) === true) { + foreach ($values['post_updates'] as $update) { + // Run each UPDATE query. + foreach ($update['fields'] as $update_f => $update_v) { + if ($update_v === false) { + $this->addResultError( + sprintf( + 'Failed when trying to autocreate unexisting item (dependent item not found in post updates): table => %s, item => %s, field => %s', + $this->currentItem['table'], + $this->currentItem['id'], + $field, + ) + ); + return false; + } + } + + $update = db_process_sql_update( + $update['table'], + $update['fields'], + $update['conditions'], + 'AND', + false + ); + + if ($update === false) { + $this->addResultError( + sprintf( + 'Failed when trying to create item (post updates): table => %s, item => %s', + $table, + $this->currentItem['id'] + ) + ); + return false; + } + } + } + } + + return true; + } + + +} diff --git a/pandora_console/include/class/SatelliteAgent.class.php b/pandora_console/include/class/SatelliteAgent.class.php index a40b3ecc7a..5dc149ffb4 100644 --- a/pandora_console/include/class/SatelliteAgent.class.php +++ b/pandora_console/include/class/SatelliteAgent.class.php @@ -67,6 +67,34 @@ class SatelliteAgent extends HTML */ private $ajaxController; + /** + * Satellite_name + * + * @var string + */ + public $satellite_name; + + /** + * Satellite_server + * + * @var string + */ + public $satellite_server; + + /** + * TableId + * + * @var integer + */ + public $tableId; + + /** + * Satellite_config + * + * @var string + */ + public $satellite_config; + /** * Class constructor diff --git a/pandora_console/include/class/Tree.class.php b/pandora_console/include/class/Tree.class.php index ed515dee87..7e75594a66 100644 --- a/pandora_console/include/class/Tree.class.php +++ b/pandora_console/include/class/Tree.class.php @@ -107,7 +107,7 @@ class Tree $userGroupsACL = users_get_groups(false, $this->access); - $this->userGroupsACL = empty($userGroupsACL) ? false : $userGroupsACL; + $this->userGroupsACL = empty($userGroupsACL) ? [0] : $userGroupsACL; $this->userGroups = $this->userGroupsACL; $this->userGroupsArray = array_keys($this->userGroups); diff --git a/pandora_console/include/class/WelcomeWindow.class.php b/pandora_console/include/class/WelcomeWindow.class.php index 4a157540c5..5a80bed577 100644 --- a/pandora_console/include/class/WelcomeWindow.class.php +++ b/pandora_console/include/class/WelcomeWindow.class.php @@ -848,13 +848,22 @@ class WelcomeWindow extends Wizard