false, 'text' => ''.html_print_image( 'images/custom_columns.png', true, [ 'title' => __('Custom fields'), 'class' => 'invert_filter', ] ).'', 'operation' => true, ]; $buttons['view'] = [ 'active' => false, 'text' => ''.html_print_image( 'images/list.png', true, [ 'title' => __('View'), 'class' => 'invert_filter', ] ).'', 'operation' => true, ]; switch ($section) { case 'fields': $buttons['fields']['active'] = true; $subpage = ' » '.__('Custom fields'); break; default: $buttons['view']['active'] = true; break; } // Header. ui_print_standard_header( __('Monitor detail').$subpage, 'images/agent.png', false, '', true, $buttons, [ [ 'link' => '', 'label' => __('Monitoring'), ], [ 'link' => '', 'label' => __('Views'), ], ] ); if ($section == 'fields') { include_once $config['homedir'].'/godmode/agentes/status_monitor_custom_fields.php'; exit(); } } else { $section = (string) get_parameter('sec', 'estado'); ui_meta_print_header(__('Monitor view')); } $recursion = get_parameter_switch('recursion', false); if ($recursion === false) { $recursion = get_parameter('recursion', false); } $ag_freestring = (string) get_parameter('ag_freestring'); $moduletype = (string) get_parameter('moduletype'); $datatype = (string) get_parameter('datatype'); $ag_modulename = (string) get_parameter('ag_modulename'); $refr = (int) get_parameter('refr', 0); $offset = (int) get_parameter('offset', 0); $status = (int) get_parameter('status', 4); $modulegroup = (int) get_parameter('modulegroup', -1); $tag_filter = (int) get_parameter('tag_filter', 0); $min_hours_status = (string) get_parameter('min_hours_status', ''); // Sort functionality. $sortField = get_parameter('sort_field'); $sort = get_parameter('sort', 'none'); // When the previous page was a visualmap and show only one module. $id_module = (int) get_parameter('id_module', 0); $ag_custom_fields = (array) get_parameter('ag_custom_fields', []); $module_option = (int) get_parameter('module_option', 1); $not_condition = (string) get_parameter('not_condition', ''); $is_none = 'All'; if ($not_condition !== '') { $is_none = 'None'; $not_condition = 'NOT'; } // If option not_condition is enabled, the conditions of the queries are reversed. $condition_query = '='; if ($not_condition !== '') { $condition_query = '!='; } $autosearch = false; // It is validated if it receives parameters different from those it has by default. if ($ag_freestring !== '' || $moduletype !== '' || $datatype !== '' || $ag_modulename !== '' || $refr !== 0 || $offset !== 0 || $status !== 4 || $modulegroup !== -1 || $tag_filter !== 0 || $sortField !== '' || $sort !== 'none' || $id_module !== 0 || $module_option !== 1 || $min_hours_status !== '' ) { $autosearch = true; } $is_metaconsole = is_metaconsole(); if (!$is_metaconsole) { $ag_group = (int) get_parameter('ag_group', 0); } else { $ag_group = get_parameter('ag_group', 0); $ag_group_metaconsole = $ag_group; } $ag_custom_fields_params = ''; if (!empty($ag_custom_fields)) { foreach ($ag_custom_fields as $id => $value) { if (!empty($value)) { $ag_custom_fields_params .= '&ag_custom_fields['.$id.']='.$value; } } } if ($id_module) { $status = -1; $ag_modulename = modules_get_agentmodule_name($id_module); $ag_freestring = modules_get_agentmodule_agent_alias($id_module); } enterprise_hook('open_meta_frame'); // Get Groups and profiles from user. $user_groups = implode(',', array_keys(users_get_groups(false, 'AR', false))); // Begin Build SQL sentences. $sql_from = ' FROM tagente_modulo INNER JOIN tagente ON tagente_modulo.id_agente = tagente.id_agente LEFT JOIN tagent_secondary_group tasg ON tagente.id_agente = tasg.id_agent INNER JOIN tagente_estado ON tagente_estado.id_agente_modulo = tagente_modulo.id_agente_modulo INNER JOIN tmodule ON tmodule.id_module = tagente_modulo.id_modulo INNER JOIN ttipo_modulo ON tagente_modulo.id_tipo_modulo = ttipo_modulo.id_tipo LEFT JOIN ttag_module ON tagente_modulo.id_agente_modulo = ttag_module.id_agente_modulo'; $sql_conditions = ' WHERE tagente.disabled = 0'; if (is_numeric($ag_group)) { $id_ag_group = 0; } else { $id_ag_group = db_get_value('id_grupo', 'tgrupo', 'nombre', $ag_group); } // Agent group selector. if (!$is_metaconsole) { if ($ag_group > 0 && check_acl($config['id_user'], $ag_group, 'AR')) { if ($recursion) { $all_groups = groups_get_children_ids($ag_group, true); // User has explicit permission on group 1 ? $sql_conditions_group = sprintf( ' AND (tagente.id_grupo IN (%s) OR tasg.id_group IN (%s)) ', implode(',', $all_groups), implode(',', $all_groups) ); } else { $sql_conditions_group = sprintf( ' AND (tagente.id_grupo '.$condition_query.' %d OR tasg.id_group '.$condition_query.' %d)', $ag_group, $ag_group ); } } else if ($user_groups != '') { // User has explicit permission on group 1 ? $sql_conditions_group = ' AND ( tagente.id_grupo IN ('.$user_groups.') OR tasg.id_group IN ('.$user_groups.') )'; } } else { if (((int) $ag_group !== 0) && (check_acl($config['id_user'], $id_ag_group, 'AR'))) { if ($recursion) { $all_groups = groups_get_children_ids($ag_group, true); // User has explicit permission on group 1 ? $sql_conditions_group = sprintf( ' AND (tagente.id_grupo IN (%s) OR tasg.id_group IN (%s)) ', implode(',', $all_groups), implode(',', $all_groups) ); } else { $sql_conditions_group = sprintf( ' AND (tagente.id_grupo '.$not_condition.' IN (%s) OR tasg.id_group '.$not_condition.' IN (%s))', $ag_group, $ag_group ); } } else if ($user_groups != '') { // User has explicit permission on group 1 ? $sql_conditions_group = ' AND ( tagente.id_grupo IN ('.$user_groups.') OR tasg.id_group IN ('.$user_groups.') )'; } } // Module group. if ($is_metaconsole) { if ($modulegroup != '-1') { $sql_conditions .= sprintf(' AND tagente_modulo.id_module_group '.$not_condition.' IN (%s)', $modulegroup); } } else if ($modulegroup > -1) { $sql_conditions .= sprintf(' AND tagente_modulo.id_module_group '.$condition_query.' \'%d\'', $modulegroup); } // Module name selector. if ($ag_modulename != '') { $sql_conditions .= " AND tagente_modulo.nombre $not_condition LIKE '%".$ag_modulename."%'"; } if ($id_module) { $sql_conditions .= sprintf(' AND tagente_modulo.id_agente_modulo = \'%d\'', $id_module); } if ($module_option !== 0) { if ($module_option == 1) { // Only enabled. $sql_conditions .= sprintf(' AND tagente_modulo.disabled '.$condition_query.' 0'); } else if ($module_option == 2) { // Only disabled. $sql_conditions .= sprintf(' AND tagente_modulo.disabled '.$condition_query.' 1'); } } if ($datatype != '') { $sql_conditions .= sprintf(' AND ttipo_modulo.id_tipo '.$condition_query.' '.$datatype); } if ($moduletype != '') { $sql_conditions .= sprintf(' AND tagente_modulo.id_modulo '.$condition_query.' '.$moduletype.''); } // Freestring selector. if ($ag_freestring != '') { $sql_conditions .= ' AND (tagente.nombre '.$not_condition.' LIKE \'%%'.$ag_freestring.'%%\' OR tagente.alias '.$not_condition.' LIKE \'%%'.$ag_freestring.'%%\' OR tagente_modulo.nombre '.$not_condition.' LIKE \'%%'.$ag_freestring.'%%\' OR tagente_modulo.descripcion '.$not_condition.' LIKE \'%%'.$ag_freestring.'%%\')'; } // Status selector. if ($status == AGENT_MODULE_STATUS_NORMAL) { // Normal. $sql_conditions .= ' AND tagente_estado.estado '.$condition_query.' 0 AND (utimestamp > 0 OR (tagente_modulo.id_tipo_modulo IN(21,22,23,100))) '; } else if ($status == AGENT_MODULE_STATUS_CRITICAL_BAD) { // Critical. $sql_conditions .= ' AND tagente_estado.estado '.$condition_query.' 1 AND utimestamp > 0'; } else if ($status == AGENT_MODULE_STATUS_WARNING) { // Warning. $sql_conditions .= ' AND tagente_estado.estado '.$condition_query.' 2 AND utimestamp > 0'; } else if ($status == AGENT_MODULE_STATUS_NOT_NORMAL) { // Not normal. $sql_conditions .= ' AND tagente_estado.estado <> 0'; } else if ($status == AGENT_MODULE_STATUS_UNKNOWN) { // Unknown. $sql_conditions .= ' AND tagente_estado.estado '.$condition_query.' 3 AND tagente_estado.utimestamp <> 0'; } else if ($status == AGENT_MODULE_STATUS_NOT_INIT) { // Not init. $sql_conditions .= ' AND tagente_estado.utimestamp '.$condition_query.' 0 AND tagente_modulo.id_tipo_modulo NOT IN (21,22,23,100)'; } $min_hours_condition = '<'; if ($not_condition !== '') { $min_hours_condition = '>'; } if (!empty($min_hours_status)) { $date = new DateTime(null, new DateTimeZone($config['timezone'])); $current_timestamp = $date->getTimestamp(); $max_time = ($current_timestamp - ((int) $min_hours_status * 3600)); $sql_conditions .= sprintf(' AND tagente_estado.last_status_change '.$min_hours_condition.' %d', $max_time); } // Filter by agent custom fields. $sql_conditions_custom_fields = ''; if (!empty($ag_custom_fields)) { $cf_filter = []; foreach ($ag_custom_fields as $field_id => $value) { if (!empty($value)) { $cf_filter[] = '(tagent_custom_data.id_field '.$condition_query.' '.$field_id.' AND tagent_custom_data.description '.$not_condition.' LIKE \'%'.$value.'%\')'; } } if (!empty($cf_filter)) { $sql_conditions_custom_fields = ' AND tagente.id_agente '.$not_condition.' IN ( SELECT tagent_custom_data.id_agent FROM tagent_custom_data WHERE '.implode(' AND ', $cf_filter).')'; } } // Filter by tag. if ($tag_filter !== 0) { if ($is_metaconsole) { $sql_conditions .= ' AND tagente_modulo.id_agente_modulo IN ( SELECT ttag_module.id_agente_modulo FROM ttag_module WHERE ttag_module.id_tag '.$not_condition.' IN ('.$tag_filter.'))'; } else { $sql_conditions .= ' AND tagente_modulo.id_agente_modulo IN ( SELECT ttag_module.id_agente_modulo FROM ttag_module WHERE ttag_module.id_tag '.$condition_query.' '.$tag_filter.')'; } } // Apply the module ACL with tags. $sql_conditions_tags = ''; if (!users_is_admin()) { $sql_conditions_tags = tags_get_acl_tags( $config['id_user'], ($recursion) ? $all_groups : $ag_group, 'AR', 'module_condition', 'AND', 'tagente_modulo', true, [], false ); if (is_numeric($sql_conditions_tags)) { $sql_conditions_tags = ' AND 1 = 0'; } } // Two modes of filter. All the filters and only ACLs filter. $sql_conditions_all = $sql_conditions.$sql_conditions_group.$sql_conditions_tags.$sql_conditions_custom_fields; // Get count to paginate. if (!defined('METACONSOLE')) { $count = db_get_sql('SELECT COUNT(DISTINCT tagente_modulo.id_agente_modulo)'.$sql_from.$sql_conditions_all); } // Get limit_sql depend of the metaconsole or standard mode. if ($is_metaconsole) { // Offset will be used to get the subset of modules. $inferior_limit = $offset; $superior_limit = ($config['block_size'] + $offset); // Offset reset to get all elements. $offset = 0; if (!isset($config['meta_num_elements'])) { $config['meta_num_elements'] = 100; } $limit_sql = $config['meta_num_elements']; } else { $limit_sql = $config['block_size']; } // End Build SQL sentences. // // Start Build Search Form. // $table = new StdClass(); $table->width = '100%'; $table->cellspacing = 0; $table->cellpadding = 0; $table->class = 'databox filters'; $table->style[0] = 'font-weight: bold;'; $table->style[1] = 'font-weight: bold;'; $table->style[2] = 'font-weight: bold;'; $table->style[3] = 'font-weight: bold;'; $table->style[4] = 'font-weight: bold;'; $table->data[0][0] = __('Group'); $table->data[0][1] = '
'; $table->data[0][1] .= html_print_select_groups( $config['id_user'], 'AR', true, 'ag_group', $ag_group, '', '', '0', true, false, false, '', false, '', false, false, 'id_grupo', false, false, false, false, false, false, $not_condition ); $table->data[0][1] .= '
'; $table->data[0][1] .= html_print_input( [ 'type' => 'checkbox', 'name' => 'recursion', 'return' => true, 'checked' => $recursion, 'value' => 1, ] ); $table->data[0][1] .= __('Recursion'); $table->data[0][1] .= '
'; $fields = []; $fields[AGENT_MODULE_STATUS_NORMAL] = __('Normal'); $fields[AGENT_MODULE_STATUS_WARNING] = __('Warning'); $fields[AGENT_MODULE_STATUS_CRITICAL_BAD] = __('Critical'); $fields[AGENT_MODULE_STATUS_UNKNOWN] = __('Unknown'); $fields[AGENT_MODULE_STATUS_NOT_NORMAL] = __('Not normal'); // Default. $fields[AGENT_MODULE_STATUS_NOT_INIT] = __('Not init'); $table->data[0][2] = __('Monitor status'); $table->data[0][3] = html_print_select( $fields, 'status', $status, '', __($is_none), -1, true, false, true, '', false, 'width: 150px;' ); $rows_select = []; $table->data[0][4] = __('Module group'); $rows_select[0] = __('Not assigned'); if (!$is_metaconsole) { $rows = db_get_all_rows_sql( 'SELECT * FROM tmodule_group ORDER BY name' ); $rows = io_safe_output($rows); if (!empty($rows)) { foreach ($rows as $module_group) { $rows_select[$module_group['id_mg']] = $module_group['name']; } } } else { $rows_select = modules_get_modulegroups(); } $table->data[0][5] = html_print_select($rows_select, 'modulegroup', $modulegroup, '', __($is_none), -1, true, false, true, '', false, 'width: 120px;'); $table->data[1][0] = __('Module name'); $table->data[1][1] = html_print_autocomplete_modules( 'ag_modulename', $ag_modulename, false, true, '', [], true ); $table->data[1][2] = __('Search'); $table->data[1][3] = html_print_input_text('ag_freestring', $ag_freestring, '', 20, 30, true); $table->data[1][4] = __('Tags').ui_print_help_tip(__('Only it is show tags in use.'), true); $tags = []; $tags = tags_get_user_tags(); if (empty($tags)) { $table->data[1][5] = __('No tags'); } else { $table->data[1][5] = html_print_select( $tags, 'tag_filter', $tag_filter, '', __($is_none), '', true, false, true, '', false, 'width: 150px;' ); } $table2 = new StdClass(); $table2->width = '100%'; $table2->class = 'filters'; $table2->style = []; $table2->style[0] = 'font-weight: bold;'; $table2->style[1] = 'font-weight: bold;'; $network_available = db_get_sql( 'SELECT count(*) FROM tserver WHERE server_type = 1' ); // POSTGRESQL AND ORACLE COMPATIBLE. $wmi_available = db_get_sql( 'SELECT count(*) FROM tserver WHERE server_type = 6' ); // POSTGRESQL AND ORACLE COMPATIBLE. $plugin_available = db_get_sql( 'SELECT count(*) FROM tserver WHERE server_type = 4' ); // POSTGRESQL AND ORACLE COMPATIBLE. $prediction_available = db_get_sql( 'SELECT count(*) FROM tserver WHERE server_type = 5' ); // POSTGRESQL AND ORACLE COMPATIBLE. $wux_available = db_get_sql( 'SELECT count(*) FROM tserver WHERE server_type = 17' ); // POSTGRESQL AND ORACLE COMPATIBLE. // Development mode to use all servers. if ($develop_bypass) { $network_available = 1; $wmi_available = 1; $plugin_available = 1; $prediction_available = 1; } $typemodules = []; $typemodules[1] = __('Data server module'); if ($network_available || $is_metaconsole) { $typemodules[2] = __('Network server module'); } if ($plugin_available || $is_metaconsole) { $typemodules[4] = __('Plugin server module'); } if ($wmi_available || $is_metaconsole) { $typemodules[6] = __('WMI server module'); } if ($prediction_available || $is_metaconsole) { $typemodules[5] = __('Prediction server module'); } if (enterprise_installed()) { $typemodules[7] = __('Web server module'); if ($wux_available || $is_metaconsole) { $typemodules[8] = __('Wux server module'); } } $table2->data[0][0] = ''.__('Server type').''; $table2->data[0][1] = html_print_select($typemodules, 'moduletype', $moduletype, '', __($is_none), '', true, false, true, '', false, 'width: 150px;'); $monitor_options = [ 0 => __('All'), 1 => __('Only enabled'), 2 => __('Only disabled'), ]; $table2->data[0][2] = ''.__('Show monitors...').''; $table2->data[0][3] = html_print_select($monitor_options, 'module_option', $module_option, '', '', '', true, false, true, '', false, 'width: 150px;'); $min_hours_val = empty($min_hours_status) ? '' : (int) $min_hours_status; $table2->data[0][4] = ''.__('Min. hours in current status').''; $table2->data[0][5] = html_print_input_text('min_hours_status', $min_hours_val, '', 12, 20, true); $table2->data[1][0] = 'data[1][0] .= '>'.__('Data type').''; $table2->data[1][1] .= '
'; switch ($moduletype) { case 1: $sql = sprintf( 'SELECT id_tipo, descripcion FROM ttipo_modulo WHERE categoria '.$not_condition.' IN (6,7,8,0,1,2,-1) order by descripcion ' ); break; case 2: $sql = sprintf( 'SELECT id_tipo, descripcion FROM ttipo_modulo WHERE categoria '.$not_condition.' between 3 and 5 ' ); break; case 4: $sql = sprintf( 'SELECT id_tipo, descripcion FROM ttipo_modulo WHERE categoria '.$not_condition.' between 0 and 2 ' ); break; case 6: $sql = sprintf( 'SELECT id_tipo, descripcion FROM ttipo_modulo WHERE categoria '.$not_condition.' between 0 and 2 ' ); break; case 7: $sql = sprintf( 'SELECT id_tipo, descripcion FROM ttipo_modulo WHERE categoria '.$condition_query.' 9' ); break; case 5: $sql = sprintf( 'SELECT id_tipo, descripcion FROM ttipo_modulo WHERE categoria '.$condition_query.' 0' ); break; case 8: $sql = sprintf( 'SELECT id_tipo, descripcion FROM ttipo_modulo WHERE nombre '.$condition_query.' \'web_analysis\'' ); break; case '': $sql = sprintf( 'SELECT id_tipo, descripcion FROM ttipo_modulo' ); break; default: // Nothing. break; } $a = db_get_all_rows_sql($sql); $table2->data[1][1] .= ''; $table2->data[1][1] .= '
'; $check_not_condition = ''; if ($not_condition !== '') { $check_not_condition = true; } $table2->data[1][2] .= __('Not condition').' '.ui_print_help_tip(__('If you check this option, those elements that do NOT meet any of the requirements will be shown'), true); $table2->data[1][3] = html_print_div( [ 'class' => 'w120px mrgn_5px mrgn_lft_0px mrgn_right_0px', 'content' => html_print_input( [ 'type' => 'switch', 'name' => 'not_condition', 'return' => false, 'checked' => $check_not_condition, 'value' => 'NOT', 'id' => 'not_condition_switch', 'onclick' => 'changeNotConditionStatus(this)', ] ), ], true ); $custom_fields = db_get_all_fields_in_table('tagent_custom_fields'); if ($custom_fields === false) { $custom_fields = []; } $div_custom_fields = '
'; foreach ($custom_fields as $custom_field) { $custom_field_value = ''; if (empty($ag_custom_fields) === false) { $custom_field_value = $ag_custom_fields[$custom_field['id_field']]; if (empty($custom_field_value) === true) { $custom_field_value = ''; } } $div_custom_fields .= '
'; $div_custom_fields .= '
'; $div_custom_fields .= ''.$custom_field['name'].''; $div_custom_fields .= '
'; $div_custom_fields .= '
'; $div_custom_fields .= html_print_input_text( 'ag_custom_fields['.$custom_field['id_field'].']', $custom_field_value, '', 0, 300, true, false, false, '', 'div-input' ); $div_custom_fields .= '
'; $div_custom_fields .= '
'; } $div_custom_fields .= '
'; $filters = '
'; $table2->colspan[2][0] = 7; $table2->cellstyle[2][0] = 'padding-left: 10px;'; $table2->data[2][0] = ui_toggle( $div_custom_fields, __('Agent custom fields'), '', '', true, true, '', 'white-box-content', 'white_table_graph' ); $table->colspan[3][0] = 7; $table->cellstyle[3][0] = 'padding-left: 10px;padding-bottom: 0px;'; $table->data[3][0] = ui_toggle( html_print_table( $table2, true ), __('Advanced options'), '', '', true, true, '', 'white-box-content', 'white_table_graph' ); $table->colspan[4][0] = 7; $table->cellstyle[4][0] = 'padding-top: 0px;'; $table->data[4][0] = html_print_submit_button( __('Show'), 'uptbutton', false, 'class="sub search mgn_tp_0 right"', true ); $filters .= html_print_table($table, true); $filters .= '
'; if (is_metaconsole() === true) { ui_toggle($filters, __('Show filters'), '', '', false); } else { echo $filters; } unset($table); // End Build Search Form. // // Sort functionality. $selected = true; $selectAgentNameUp = false; $selectAgentNameDown = false; $selectDataTypeUp = false; $selectDataTypeDown = false; $selectTypeUp = false; $selectTypeDown = false; $selectModuleNameUp = false; $selectModuleNameDown = false; $selectIntervalUp = false; $selectIntervalDown = false; $selectStatusUp = false; $selectStatusDown = false; $selectDataUp = false; $selectDataDown = false; $selectTimestampUp = false; $selectTimestampDown = false; $order = null; switch ($sortField) { case 'agent_alias': $fieldForSorting = 'agent_alias'; switch ($sort) { case 'up': $selectAgentNameUp = $selected; $order = [ 'field' => 'tagente.alias', 'order' => 'ASC', ]; break; case 'down': $selectAgentNameDown = $selected; $order = [ 'field' => 'tagente.alias', 'order' => 'DESC', ]; break; } break; case 'type': $fieldForSorting = 'module_type'; switch ($sort) { case 'up': $selectDataTypeUp = $selected; $order = [ 'field' => 'tagente_modulo.id_tipo_modulo', 'order' => 'ASC', ]; break; case 'down': $selectDataTypeDown = $selected; $order = [ 'field' => 'tagente_modulo.id_tipo_modulo', 'order' => 'DESC', ]; break; } break; case 'moduletype': $fieldForSorting = 'module_type'; switch ($sort) { case 'up': $selectTypeUp = $selected; $order = [ 'field' => 'tagente_modulo.id_modulo', 'order' => 'ASC', ]; break; case 'down': $selectTypeDown = $selected; $order = [ 'field' => 'tagente_modulo.id_modulo', 'order' => 'DESC', ]; break; } break; case 'module_name': $fieldForSorting = 'module_name'; switch ($sort) { case 'up': $selectModuleNameUp = $selected; $order = [ 'field' => 'tagente_modulo.nombre', 'order' => 'ASC', ]; break; case 'down': $selectModuleNameDown = $selected; $order = [ 'field' => 'tagente_modulo.nombre', 'order' => 'DESC', ]; break; } break; case 'interval': $fieldForSorting = 'module_interval'; switch ($sort) { case 'up': $selectIntervalUp = $selected; $order = [ 'field' => 'tagente_modulo.module_interval', 'order' => 'ASC', ]; break; case 'down': $selectIntervalDown = $selected; $order = [ 'field' => 'tagente_modulo.module_interval', 'order' => 'DESC', ]; break; } break; case 'status': $fieldForSorting = 'estado'; switch ($sort) { case 'up': $selectStatusUp = $selected; $order = [ 'field' => 'tagente_estado.estado', 'order' => 'ASC', ]; break; case 'down': $selectStatusDown = $selected; $order = [ 'field' => 'tagente_estado.estado', 'order' => 'DESC', ]; break; } break; case 'last_status_change': $fieldForSorting = 'last_status_change'; switch ($sort) { case 'up': $selectStatusUp = $selected; $order = [ 'field' => 'tagente_estado.last_status_change', 'order' => 'ASC', ]; break; case 'down': $selectStatusDown = $selected; $order = [ 'field' => 'tagente_estado.last_status_change', 'order' => 'DESC', ]; break; } break; case 'timestamp': $fieldForSorting = 'utimestamp'; switch ($sort) { case 'up': $selectTimestampUp = $selected; $order = [ 'field' => 'tagente_estado.utimestamp', 'order' => 'ASC', ]; break; case 'down': $selectTimestampDown = $selected; $order = [ 'field' => 'tagente_estado.utimestamp', 'order' => 'DESC', ]; break; } break; case 'data': $fieldForSorting = 'datos'; switch ($sort) { case 'up': $selectDataUp = $selected; $order = [ 'field' => 'tagente_estado.datos', 'order' => 'ASC', ]; break; case 'down': $selectDataDown = $selected; $order = [ 'field' => 'tagente_estado.datos', 'order' => 'DESC', ]; break; } break; default: $fieldForSorting = 'agent_alias'; $selectAgentNameUp = $selected; $selectAgentNameDown = false; $selectDataTypeUp = false; $selectDataTypeDown = false; $selectTypeUp = false; $selectTypeDown = false; $selectModuleNameUp = false; $selectModuleNameDown = false; $selectIntervalUp = false; $selectIntervalDown = false; $selectStatusUp = false; $selectStatusDown = false; $selectDataUp = false; $selectDataDown = false; $selectTimestampUp = false; $selectTimestampDown = false; $order = [ 'field' => 'tagente.alias', 'order' => 'ASC', ]; break; } $sql = 'SELECT (SELECT GROUP_CONCAT(ttag.name SEPARATOR \',\') FROM ttag WHERE ttag.id_tag IN ( SELECT ttag_module.id_tag FROM ttag_module WHERE ttag_module.id_agente_modulo = tagente_modulo.id_agente_modulo)) AS tags, tagente_modulo.id_agente_modulo, tagente_modulo.id_modulo, tagente.intervalo AS agent_interval, tagente.alias AS agent_alias, tagente.nombre AS agent_name, tagente_modulo.nombre AS module_name, tagente_modulo.history_data, tagente_modulo.flag AS flag, tagente.id_grupo AS id_group, tagente.id_agente AS id_agent, tagente_modulo.id_tipo_modulo AS module_type, tagente_modulo.module_interval, tagente_modulo.tcp_send, tagente_modulo.ip_target, tagente_modulo.snmp_community, tagente_modulo.snmp_oid, tagente_estado.datos, tagente_estado.estado, tagente_estado.last_status_change, tagente_modulo.min_warning, tagente_modulo.max_warning, tagente_modulo.str_warning, tagente_modulo.unit, tagente_modulo.min_critical, tagente_modulo.max_critical, tagente_modulo.str_critical, tagente_modulo.extended_info, tagente_modulo.critical_inverse, tagente_modulo.warning_inverse, tagente_modulo.critical_instructions, tagente_modulo.warning_instructions, tagente_modulo.unknown_instructions, tagente_estado.utimestamp AS utimestamp'.$sql_from.$sql_conditions_all.' GROUP BY tagente_modulo.id_agente_modulo ORDER BY '.$order['field'].' '.$order['order'].' LIMIT '.$offset.','.$limit_sql; // We do not show the modules until the user searches with the filter. if ($autosearch) { if (! defined('METACONSOLE')) { $result = db_get_all_rows_sql($sql); if ($result === false) { $result = []; } else { ui_pagination($count, false, $offset, 0, false, 'offset', true); } } else { // For each server defined and not disabled. $servers = db_get_all_rows_sql( 'SELECT * FROM tmetaconsole_setup WHERE disabled = 0' ); if ($servers === false) { $servers = []; } $result = []; $count_modules = 0; foreach ($servers as $server) { // If connection was good then retrieve all data server. if (metaconsole_connect($server) == NOERR) { $connection = true; } else { $connection = false; } $result_server = db_get_all_rows_sql($sql); if (!empty($result_server)) { // Create HASH login info. $pwd = $server['auth_token']; $auth_serialized = json_decode($pwd, true); if (is_array($auth_serialized)) { $pwd = $auth_serialized['auth_token']; $api_password = $auth_serialized['api_password']; $console_user = $auth_serialized['console_user']; $console_password = $auth_serialized['console_password']; } $user = $config['id_user']; $user_rot13 = str_rot13($config['id_user']); $hashdata = $user.$pwd; $hashdata = md5($hashdata); $url_hash = '&'.'loginhash=auto&'.'loginhash_data='.$hashdata.'&'.'loginhash_user='.$user_rot13; foreach ($result_server as $result_element_key => $result_element_value) { $result_server[$result_element_key]['server_id'] = $server['id']; $result_server[$result_element_key]['server_name'] = $server['server_name']; $result_server[$result_element_key]['server_url'] = $server['server_url'].'/'; $result_server[$result_element_key]['hashdata'] = $hashdata; $result_server[$result_element_key]['user'] = $config['id_user']; $result_server[$result_element_key]['groups_in_server'] = agents_get_all_groups_agent( $result_element_value['id_agent'], $result_element_value['id_group'] ); $count_modules++; } $result = array_merge($result, $result_server); } usort($result, arrayOutputSorting($sort, $fieldForSorting)); metaconsole_restore_db(); } if ($count_modules > $config['block_size']) { ui_pagination($count_modules, false, $offset); } // Get number of elements of the pagination. $result = ui_meta_get_subset_array($result, $inferior_limit, $superior_limit); } } if (($config['dbtype'] == 'oracle') && ($result !== false)) { for ($i = 0; $i < count($result); $i++) { unset($result[$i]['rnum']); } } // Urls to sort the table. $url_agent_name = 'index.php?sec='.$section.'&sec2=operation/agentes/status_monitor'; $url_type = 'index.php?sec='.$section.'&sec2=operation/agentes/status_monitor'; $url_module_name = 'index.php?sec='.$section.'&sec2=operation/agentes/status_monitor'; $url_server_type = 'index.php?sec='.$section.'&sec2=operation/agentes/status_monitor'; $url_interval = 'index.php?sec='.$section.'&sec2=operation/agentes/status_monitor'; $url_status = 'index.php?sec='.$section.'&sec2=operation/agentes/status_monitor'; $url_status = 'index.php?sec='.$section.'&sec2=operation/agentes/status_monitor'; $url_data = 'index.php?sec='.$section.'&sec2=operation/agentes/status_monitor'; $url_timestamp_up = 'index.php?sec='.$section.'&sec2=operation/agentes/status_monitor'; $url_timestamp_down = 'index.php?sec='.$section.'&sec2=operation/agentes/status_monitor'; $url_agent_name .= '&refr='.$refr.'&datatype='.$datatype.'&moduletype='.$moduletype.'&modulegroup='.$modulegroup.'&offset='.$offset.'&ag_group='.$ag_group.'&ag_freestring='.$ag_freestring.'&ag_modulename='.$ag_modulename.'&status='.$status.$ag_custom_fields_params; $url_type .= '&datatype='.$datatype.'&moduletype='.$moduletype.'&refr='.$refr.'&modulegroup='.$modulegroup.'&offset='.$offset.'&ag_group='.$ag_group.'&ag_freestring='.$ag_freestring.'&ag_modulename='.$ag_modulename.'&status='.$status.$ag_custom_fields_params; $url_module_name .= '&datatype='.$datatype.'&moduletype='.$moduletype.'&refr='.$refr.'&modulegroup='.$modulegroup.'&offset='.$offset.'&ag_group='.$ag_group.'&ag_freestring='.$ag_freestring.'&ag_modulename='.$ag_modulename.'&status='.$status.$ag_custom_fields_params; $url_server_type .= '&datatype='.$datatype.'&moduletype='.$moduletype.'&refr='.$refr.'&modulegroup='.$modulegroup.'&offset='.$offset.'&ag_group='.$ag_group.'&ag_freestring='.$ag_freestring.'&ag_modulename='.$ag_modulename.'&status='.$status.$ag_custom_fields_params; $url_interval .= '&datatype='.$datatype.'&moduletype='.$moduletype.'&refr='.$refr.'&modulegroup='.$modulegroup.'&offset='.$offset.'&ag_group='.$ag_group.'&ag_freestring='.$ag_freestring.'&ag_modulename='.$ag_modulename.'&status='.$status.$ag_custom_fields_params; $url_status .= '&datatype='.$datatype.'&moduletype='.$moduletype.'&refr='.$refr.'&modulegroup='.$modulegroup.'&offset='.$offset.'&ag_group='.$ag_group.'&ag_freestring='.$ag_freestring.'&ag_modulename='.$ag_modulename.'&status='.$status.$ag_custom_fields_params; $url_status .= '&datatype='.$datatype.'&moduletype='.$moduletype.'&refr='.$refr.'&modulegroup='.$modulegroup.'&offset='.$offset.'&ag_group='.$ag_group.'&ag_freestring='.$ag_freestring.'&ag_modulename='.$ag_modulename.'&status='.$status.$ag_custom_fields_params; $url_data .= '&datatype='.$datatype.'&moduletype='.$moduletype.'&refr='.$refr.'&modulegroup='.$modulegroup.'&offset='.$offset.'&ag_group='.$ag_group.'&ag_freestring='.$ag_freestring.'&ag_modulename='.$ag_modulename.'&status='.$status.$ag_custom_fields_params; $url_timestamp_up .= '&datatype='.$datatype.'&moduletype='.$moduletype.'&refr='.$refr.'&offset='.$offset.'&ag_group='.$ag_group.'&ag_freestring='.$ag_freestring.'&ag_modulename='.$ag_modulename.'&status='.$status.$ag_custom_fields_params; $url_timestamp_down .= '&datatype='.$datatype.'&moduletype='.$moduletype.'&refr='.$refr.'&modulegroup='.$modulegroup.'&offset='.$offset.'&ag_group='.$ag_group.'&ag_freestring='.$ag_freestring.'&ag_modulename='.$ag_modulename.'&status='.$status.$ag_custom_fields_params; // Holy god... $url_agent_name .= '&recursion='.$recursion; $url_type .= '&recursion='.$recursion; $url_module_name .= '&recursion='.$recursion; $url_server_type .= '&recursion='.$recursion; $url_interval .= '&recursion='.$recursion; $url_status .= '&recursion='.$recursion; $url_status .= '&recursion='.$recursion; $url_data .= '&recursion='.$recursion; $url_timestamp_up .= '&recursion='.$recursion; $url_timestamp_down .= '&recursion='.$recursion; $url_agent_name .= '&sort_field=agent_alias&sort='; $url_type .= '&sort_field=type&sort='; $url_module_name .= '&sort_field=module_name&sort='; $url_server_type .= '&sort_field=moduletype&sort='; $url_interval .= '&sort_field=interval&sort='; $url_status .= '&sort_field=status&sort='; $url_status .= '&sort_field=last_status_change&sort='; $url_data .= '&sort_field=data&sort='; $url_timestamp_up .= '&sort_field=timestamp&sort=up'; $url_timestamp_down .= '&sort_field=timestamp&sort=down'; // Start Build List Result. if (!empty($result)) { $table = new StdClass(); $table->cellpadding = 0; $table->cellspacing = 0; $table->width = '100%'; $table->class = 'info_table'; $table->head = []; $table->data = []; $table->size = []; $table->align = []; $show_fields = explode(',', $config['status_monitor_fields']); if (in_array('policy', $show_fields)) { if ($isFunctionPolicies !== ENTERPRISE_NOT_HOOK) { $table->head[0] = ''.__('P.').''; } } if (in_array('agent', $show_fields) || is_metaconsole()) { $table->head[1] = __('Agent'); $table->head[1] .= ui_get_sorting_arrows($url_agent_name.'up', $url_agent_name.'down', $selectAgentNameUp, $selectAgentNameDown); } if (in_array('data_type', $show_fields) || is_metaconsole()) { $table->head[2] = __('Data Type'); $table->head[2] .= ui_get_sorting_arrows($url_type.'up', $url_type.'down', $selectDataTypeUp, $selectDataTypeDown); $table->align[2] = 'left'; } if (in_array('module_name', $show_fields) || is_metaconsole()) { $table->head[3] = __('Module name'); $table->head[3] .= ui_get_sorting_arrows($url_module_name.'up', $url_module_name.'down', $selectModuleNameUp, $selectModuleNameDown); } if (in_array('server_type', $show_fields) || is_metaconsole()) { $table->head[4] = __('Server type'); $table->head[4] .= ui_get_sorting_arrows($url_server_type.'up', $url_server_type.'down', $selectTypeUp, $selectTypeDown); } if (in_array('interval', $show_fields) || is_metaconsole()) { $table->head[5] = __('Interval'); $table->head[5] .= ui_get_sorting_arrows($url_interval.'up', $url_interval.'down', $selectIntervalUp, $selectIntervalDown); $table->align[5] = 'left'; } if (in_array('status', $show_fields) || is_metaconsole()) { $table->head[6] = __('Status'); $table->head[6] .= ui_get_sorting_arrows($url_status.'up', $url_status.'down', $selectStatusUp, $selectStatusDown); $table->align[6] = 'left'; } if (in_array('last_status_change', $show_fields)) { $table->head[7] = __('Last status change'); $table->head[7] .= ui_get_sorting_arrows($url_status.'up', $url_status.'down', $selectStatusUp, $selectStatusDown); $table->align[7] = 'left'; } if (in_array('graph', $show_fields) || is_metaconsole()) { $table->head[8] = __('Graph'); $table->align[8] = 'left'; } if (in_array('warn', $show_fields) || is_metaconsole()) { $table->head[9] = __('Warn'); $table->align[9] = 'left'; } if (in_array('data', $show_fields) || is_metaconsole()) { $table->head[10] = __('Data'); $table->align[10] = 'left'; if (is_metaconsole()) { $table->head[10] .= ui_get_sorting_arrows($url_data.'up', $url_data.'down', $selectDataUp, $selectDataDown); } } if (in_array('timestamp', $show_fields) || is_metaconsole()) { $table->head[11] = __('Timestamp'); $table->head[11] .= ui_get_sorting_arrows($url_timestamp_up, $url_timestamp_down, $selectTimestampUp, $selectTimestampDown); $table->align[11] = 'left'; } $id_type_web_content_string = db_get_value( 'id_tipo', 'ttipo_modulo', 'nombre', 'web_content_string' ); foreach ($result as $row) { // Avoid unset, null and false value. if (empty($row['server_name'])) { $row['server_name'] = ''; } $is_web_content_string = (bool) db_get_value_filter( 'id_agente_modulo', 'tagente_modulo', [ 'id_agente_modulo' => $row['id_agente_modulo'], 'id_tipo_modulo' => $id_type_web_content_string, ] ); // Fixed the goliat sends the strings from web. // Without HTML entities. if ($is_web_content_string) { $row['datos'] = io_safe_input($row['datos']); } // Fixed the data from Selenium Plugin. if ($row['datos'] != strip_tags($row['datos'])) { $row['datos'] = io_safe_input($row['datos']); } $data = []; if (in_array('policy', $show_fields) || is_metaconsole()) { if ($isFunctionPolicies !== ENTERPRISE_NOT_HOOK) { if (is_metaconsole()) { $node = metaconsole_get_connection_by_id($row['server_id']); if (metaconsole_load_external_db($node) !== NOERR) { // Restore the default connection. metaconsole_restore_db(); $errors++; break; } } $policyInfo = policies_info_module_policy($row['id_agente_modulo']); if ($policyInfo === false) { $data[0] = ''; } else { $linked = policies_is_module_linked($row['id_agente_modulo']); $adopt = false; if (policies_is_module_adopt($row['id_agente_modulo'])) { $adopt = true; } if ($linked) { if ($adopt) { $img = 'images/policies_brick.png'; $title = __('(Adopt) ').$policyInfo['name_policy']; } else { $img = 'images/policies_mc.png'; $title = $policyInfo['name_policy']; } } else { if ($adopt) { $img = 'images/policies_not_brick.png'; $title = __('(Unlinked) (Adopt) ').$policyInfo['name_policy']; } else { $img = 'images/unlinkpolicy.png'; $title = __('(Unlinked) ').$policyInfo['name_policy']; } } if (is_metaconsole()) { $data[0] = ''.html_print_image($img, true, ['title' => $title]).''; } else { $data[0] = ''.html_print_image($img, true, ['title' => $title]).''; } } if (is_metaconsole()) { metaconsole_restore_db(); } } } if (in_array('agent', $show_fields) || is_metaconsole()) { $agent_alias = !empty($row['agent_alias']) ? $row['agent_alias'] : $row['agent_name']; // TODO: Calculate hash access before to use it more simply like other sections. I.E. Events view if (defined('METACONSOLE')) { $agent_link = ''; $agent_alias = ui_print_truncate_text( $agent_alias, 'agent_small', false, true, true, '[…]', 'font-size:7.5pt;' ); if (can_user_access_node()) { $data[1] = $agent_link.''.$agent_alias.''; } else { $data[1] = $agent_alias; } } else { $data[1] = ''; $data[1] .= ui_print_truncate_text($agent_alias, 'agent_medium', false, true, false, '[…]', 'font-size:7.5pt;'); $data[1] .= ''; } } if (in_array('data_type', $show_fields) || is_metaconsole()) { $data[2] = html_print_image('images/'.modules_show_icon_type($row['module_type']), true, ['class' => 'invert_filter']); $agent_groups = is_metaconsole() ? $row['groups_in_server'] : agents_get_all_groups_agent($row['id_agent'], $row['id_group']); if (check_acl_one_of_groups($config['id_user'], $agent_groups, 'AW')) { $show_edit_icon = true; if (defined('METACONSOLE')) { if (!can_user_access_node()) { $show_edit_icon = false; } $url_edit_module = $row['server_url'].'index.php?'.'sec=gagente&'.'sec2=godmode/agentes/configurar_agente&'.'id_agente='.$row['id_agent'].'&'.'tab=module&'.'id_agent_module='.$row['id_agente_modulo'].'&'.'edit_module=1'.'&loginhash=auto&loginhash_data='.$row['hashdata'].'&loginhash_user='.str_rot13($row['user']); } else { $url_edit_module = 'index.php?'.'sec=gagente&'.'sec2=godmode/agentes/configurar_agente&'.'id_agente='.$row['id_agent'].'&'.'tab=module&'.'id_agent_module='.$row['id_agente_modulo'].'&'.'edit_module=1'; } if ($show_edit_icon) { $table->cellclass[][2] = 'action_buttons'; $data[2] .= ''.html_print_image( 'images/config.png', true, [ 'alt' => '0', 'border' => '', 'title' => __('Edit'), ] ).''; } } } if (in_array('module_name', $show_fields) || is_metaconsole()) { $data[3] = ui_print_truncate_text($row['module_name'], 'module_small', false, true, true); if ($row['extended_info'] != '') { $data[3] .= ui_print_help_tip($row['extended_info'], true, '/images/default_list.png'); } if ($row['tags'] != '') { $data[3] .= html_print_image( '/images/tag_red.png', true, [ 'title' => $row['tags'], 'class' => 'tag_row', ] ); } } if (in_array('server_type', $show_fields) || is_metaconsole()) { $data[4] = servers_show_type($row['id_modulo']); } if (in_array('module_name', $show_fields) || is_metaconsole()) { $data[3] = ui_print_truncate_text($row['module_name'], 'module_small', false, true, true); if ($row['extended_info'] != '') { $data[3] .= ui_print_help_tip($row['extended_info'], true, '/images/default_list.png'); } if ($row['tags'] != '') { $data[3] .= html_print_image( '/images/tag_red.png', true, [ 'title' => $row['tags'], 'class' => 'tag_row invert_filter', ] ); } } if (in_array('server_type', $show_fields) || is_metaconsole()) { $data[4] = servers_show_type($row['id_modulo']); } if (in_array('interval', $show_fields) || is_metaconsole()) { $data[5] = ($row['module_interval'] == 0) ? human_time_description_raw($row['agent_interval']) : human_time_description_raw($row['module_interval']); } if (in_array('status', $show_fields) || is_metaconsole()) { if ($row['utimestamp'] == 0 && (($row['module_type'] < 21 || $row['module_type'] > 23) && $row['module_type'] != 100) ) { $data[6] = ui_print_status_image( STATUS_MODULE_NO_DATA, __('NOT INIT'), true ); } else if ($row['estado'] == 0) { if (is_numeric($row['datos'])) { $data[6] = ui_print_status_image( STATUS_MODULE_OK, __('NORMAL').': '.remove_right_zeros(number_format($row['datos'], $config['graph_precision'], $config['decimal_separator'], $config['thousand_separator'])), true ); } else { $data[6] = ui_print_status_image( STATUS_MODULE_OK, __('NORMAL').': '.htmlspecialchars($row['datos']), true ); } } else if ($row['estado'] == 1) { if (is_numeric($row['datos'])) { $data[6] = ui_print_status_image( STATUS_MODULE_CRITICAL, __('CRITICAL').': '.remove_right_zeros( number_format( $row['datos'], $config['graph_precision'], $config['decimal_separator'], $config['thousand_separator'] ) ), true ); } else { $data[6] = ui_print_status_image( STATUS_MODULE_CRITICAL, __('CRITICAL').': '.htmlspecialchars($row['datos']), true ); } } else if ($row['estado'] == 2) { if (is_numeric($row['datos'])) { $data[6] = ui_print_status_image( STATUS_MODULE_WARNING, __('WARNING').': '.remove_right_zeros( number_format( $row['datos'], $config['graph_precision'], $config['decimal_separator'], $config['thousand_separator'] ) ), true ); } else { $data[6] = ui_print_status_image( STATUS_MODULE_WARNING, __('WARNING').': '.htmlspecialchars($row['datos']), true ); } } else if ($row['estado'] == 3) { if (is_numeric($row['datos'])) { $data[6] = ui_print_status_image( STATUS_MODULE_UNKNOWN, __('UNKNOWN').': '.remove_right_zeros( number_format( $row['datos'], $config['graph_precision'], $config['decimal_separator'], $config['thousand_separator'] ) ), true ); } else { $data[6] = ui_print_status_image( STATUS_MODULE_UNKNOWN, __('UNKNOWN').': '.htmlspecialchars($row['datos']), true ); } } else if ($row['estado'] == 4) { if (is_numeric($row['datos'])) { $data[6] = ui_print_status_image( STATUS_MODULE_NO_DATA, __('NO DATA').': '.remove_right_zeros( number_format( $row['datos'], $config['graph_precision'], $config['decimal_separator'], $config['thousand_separator'] ) ), true ); } else { $data[6] = ui_print_status_image( STATUS_MODULE_NO_DATA, __('NO DATA').': '.htmlspecialchars($row['datos']), true ); } } else { $last_status = modules_get_agentmodule_last_status( $row['id_agente_modulo'] ); switch ($last_status) { case 0: if (is_numeric($row['datos'])) { $data[6] = ui_print_status_image( STATUS_MODULE_UNKNOWN, __('UNKNOWN').' - '.__('Last status').' '.__('NORMAL').': '.remove_right_zeros(number_format($row['datos'], $config['graph_precision'], $config['decimal_separator'], $config['thousand_separator'])), true ); } else { $data[6] = ui_print_status_image( STATUS_MODULE_UNKNOWN, __('UNKNOWN').' - '.__('Last status').' '.__('NORMAL').': '.htmlspecialchars($row['datos']), true ); } break; case 1: if (is_numeric($row['datos'])) { $data[6] = ui_print_status_image( STATUS_MODULE_UNKNOWN, __('UNKNOWN').' - '.__('Last status').' '.__('CRITICAL').': '.remove_right_zeros(number_format($row['datos'], $config['graph_precision'], $config['decimal_separator'], $config['thousand_separator'])), true ); } else { $data[6] = ui_print_status_image( STATUS_MODULE_UNKNOWN, __('UNKNOWN').' - '.__('Last status').' '.__('CRITICAL').': '.htmlspecialchars($row['datos']), true ); } break; case 2: if (is_numeric($row['datos'])) { $data[6] = ui_print_status_image( STATUS_MODULE_UNKNOWN, __('UNKNOWN').' - '.__('Last status').' '.__('WARNING').': '.remove_right_zeros(number_format($row['datos'], $config['graph_precision'], $config['decimal_separator'], $config['thousand_separator'])), true ); } else { $data[6] = ui_print_status_image( STATUS_MODULE_UNKNOWN, __('UNKNOWN').' - '.__('Last status').' '.__('WARNING').': '.htmlspecialchars($row['datos']), true ); } break; } } } if (in_array('last_status_change', $show_fields) || is_metaconsole()) { $data[7] = ($row['last_status_change'] > 0) ? human_time_comparation($row['last_status_change']) : __('N/A'); } if (in_array('graph', $show_fields) || is_metaconsole()) { $data[8] = ''; $acl_graphs = false; // Avoid the check on the metaconsole. Too slow to show/hide an icon depending on the permissions. if (!is_metaconsole()) { $agent_groups = agents_get_all_groups_agent($row['id_agent'], $row['id_group']); $acl_graphs = check_acl_one_of_groups($config['id_user'], $agent_groups, 'RR'); } else { $acl_graphs = true; } if ($row['history_data'] == 1 && $acl_graphs) { $tresholds = true; if (empty((float) $module['min_warning']) === true && empty((float) $module['max_warning']) === true && empty($module['warning_inverse']) === true && empty((float) $module['min_critical']) === true && empty((float) $module['max_critical']) === true && empty($module['critical_inverse']) === true ) { $tresholds = false; } $graph_type = return_graphtype($row['module_type']); $url = ui_get_full_url('operation/agentes/stat_win.php', false, false, false); $handle = dechex(crc32($row['id_agente_modulo'].$row['module_name'])); $win_handle = 'day_'.$handle; $graph_params = [ 'type' => $graph_type, 'period' => SECONDS_1DAY, 'id' => $row['id_agente_modulo'], 'refresh' => SECONDS_10MINUTES, ]; if ($tresholds === true || $graph_type === 'boolean') { $graph_params['histogram'] = 1; } if (is_metaconsole() && isset($row['server_id'])) { // Set the server id. $graph_params['server'] = $row['server_id']; } $graph_params_str = http_build_query($graph_params); $link = 'winopeng_var(\''.$url.'?'.$graph_params_str.'\',\''.$win_handle.'\', 800, 480)'; $data[8] = get_module_realtime_link_graph($row); if ($tresholds === true || $graph_type === 'boolean') { $data[8] .= ''.html_print_image( 'images/histograma.png', true, [ 'border' => '0', 'alt' => '', 'class' => 'invert_filter', ] ).''; } if (!is_snapshot_data($row['datos'])) { if ($tresholds === true || $graph_type === 'boolean') { unset($graph_params['histogram']); } $graph_params_str = http_build_query($graph_params); $link = 'winopeng_var(\''.$url.'?'.$graph_params_str.'\',\''.$win_handle.'\', 800, 480)'; $data[8] .= ''.html_print_image('images/chart.png', true, ['border' => '0', 'alt' => '', 'class' => 'invert_filter']).''; } $data[8] .= ''.html_print_image( 'images/binary.png', true, [ 'border' => '0', 'alt' => '', 'class' => 'invert_filter', ] ).''; $data[8] .= ''.$row['module_name'].''; } } if (in_array('warn', $show_fields) || is_metaconsole()) { $data[9] = ui_print_module_warn_value( $row['max_warning'], $row['min_warning'], $row['str_warning'], $row['max_critical'], $row['min_critical'], $row['str_critical'], $row['warning_inverse'], $row['critical_inverse'] ); if (is_numeric($row['datos']) && !modules_is_string_type($row['module_type'])) { if ($config['render_proc']) { switch ($row['module_type']) { case 2: case 6: case 9: case 18: case 21: case 31: if ($row['datos'] >= 1) { $salida = $config['render_proc_ok']; } else { $salida = $config['render_proc_fail']; } break; default: switch ($row['module_type']) { case 15: $value = db_get_value('snmp_oid', 'tagente_modulo', 'id_agente_modulo', $row['id_agente_modulo']); if ($value == '.1.3.6.1.2.1.1.3.0' || $value == '.1.3.6.1.2.1.25.1.1.0') { $salida = human_milliseconds_to_string($row['datos']); } else { $salida = remove_right_zeros(number_format($row['datos'], $config['graph_precision'], $config['decimal_separator'], $config['thousand_separator'])); } break; default: $salida = remove_right_zeros(number_format($row['datos'], $config['graph_precision'], $config['decimal_separator'], $config['thousand_separator'])); break; } break; } } else { switch ($row['module_type']) { case 15: $value = db_get_value('snmp_oid', 'tagente_modulo', 'id_agente_modulo', $row['id_agente_modulo']); if ($value == '.1.3.6.1.2.1.1.3.0' || $value == '.1.3.6.1.2.1.25.1.1.0') { $salida = human_milliseconds_to_string($row['datos']); } else { $salida = remove_right_zeros(number_format($row['datos'], $config['graph_precision'], $config['decimal_separator'], $config['thousand_separator'])); } break; default: $salida = remove_right_zeros(number_format($row['datos'], $config['graph_precision'], $config['decimal_separator'], $config['thousand_separator'])); break; } } // Show units ONLY in numeric data types. if (isset($row['unit'])) { $data_macro = modules_get_unit_macro($row['datos'], $row['unit']); if ($data_macro) { $salida = $data_macro; } else { $salida .= ' '.''.io_safe_output($row['unit']).''; if (strlen($salida) > $config['agent_size_text_small']) { $salida = ui_print_truncate_text($salida, 'agent_small', true, true, false, '[…]', 'font-size:7.5pt;'); // Clean tag . $text_aux = explode(' $row['id_agente_modulo'], 'interval' => $row['current_interval'], 'module_name' => $row['module_name'], 'id_node' => $row['server_id'], ] ); $salida = ui_get_snapshot_image($link, $is_snapshot).'  '; } else { $sub_string = substr(io_safe_output($row['datos']), 0, 12); if ($module_value == $sub_string) { if ($module_value == 0 && !$sub_string) { $salida = 0; } else { $data_macro = modules_get_unit_macro($row['datos'], $row['unit']); if ($data_macro) { $salida = $data_macro; } else { $salida = $row['datos']; } } } else { // Fixed the goliat sends the strings from web. // Without HTML entities. if ($is_web_content_string) { $sub_string = substr($row['datos'], 0, 12); } else { // Fixed the data from Selenium Plugin. if ($module_value != strip_tags($module_value)) { $module_value = io_safe_input($module_value); $sub_string = substr($row['datos'], 0, 12); } else { $sub_string = substr(io_safe_output($row['datos']), 0, 12); } } if ($module_value == $sub_string) { $salida = $module_value; } else { $salida = ''.'".''.$sub_string.' '."".html_print_image('images/rosette.png', true).''; } } } } } if (in_array('data', $show_fields) || is_metaconsole()) { $data[10] = $salida; } if (in_array('timestamp', $show_fields) || is_metaconsole()) { if ($row['module_interval'] > 0) { $interval = $row['module_interval']; } else { $interval = $row['agent_interval']; } if ($row['estado'] == 3) { $option = [ 'html_attr' => 'class="redb"', 'style' => 'font-size:7pt;', ]; } else { $option = ['style' => 'font-size:7pt;']; } $data[11] = ui_print_timestamp($row['utimestamp'], true, $option); } array_push($table->data, $data); } html_print_table($table); if ($count_modules > $config['block_size']) { ui_pagination($count_modules, false, $offset, 0, false, 'offset', true, 'pagination-bottom'); } } else { if ($first_interaction) { ui_print_info_message(['no_close' => true, 'message' => __('This group doesn\'t have any monitor')]); } else { ui_print_info_message(['no_close' => true, 'message' => __('Sorry no search parameters')]); } } // End Build List Result. echo "
"; enterprise_hook('close_meta_frame'); ui_require_javascript_file('pandora_modules'); ?>