'.html_print_image( 'images/eye_show.png', true, [ 'title' => __('View'), 'class' => 'invert_filter', ] ).''; $viewtab['operation'] = true; $viewtab['active'] = false; $onheader = ['view' => $viewtab]; // Header. ui_print_standard_header( __('Agents defined in %s', get_product_name()), 'images/agent.png', false, '', true, $onheader, [ [ 'link' => '', 'label' => __('Resources'), ], [ 'link' => '', 'label' => __('Manage agents'), ], ] ); 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 delete an agent', $url ) ); } // Perform actions. $agent_to_delete = (int) get_parameter('borrar_agente'); $enable_agent = (int) get_parameter('enable_agent'); $disable_agent = (int) get_parameter('disable_agent'); if ($disable_agent != 0) { $server_name = db_get_row_sql( 'select server_name from tagente where id_agente = '.$disable_agent ); } else if ($enable_agent != 0) { $server_name = db_get_row_sql( 'select server_name from tagente where id_agente = '.$enable_agent ); } $result = null; if ($agent_to_delete) { $id_agente = $agent_to_delete; if (check_acl_one_of_groups( $config['id_user'], agents_get_all_groups_agent($id_agente), 'AW' ) ) { $id_agentes[0] = $id_agente; $result = agents_delete_agent($id_agentes); } else { // NO permissions. db_pandora_audit( AUDIT_LOG_ACL_VIOLATION, "Trying to delete agent \'".agents_get_name($id_agente)."\'" ); include 'general/noaccess.php'; exit; } ui_print_result_message( $result, __('Success deleted agent.'), __('Could not be deleted.') ); if (enterprise_installed()) { // Check if the remote config file still exist. if (isset($config['remote_config'])) { enterprise_include_once( 'include/functions_config_agents.php' ); if (enterprise_hook( 'config_agents_has_remote_configuration', [$id_agente] ) ) { ui_print_error_message( __('Maybe the files conf or md5 could not be deleted') ); } } } } if ($enable_agent) { $result = db_process_sql_update( 'tagente', ['disabled' => 0], ['id_agente' => $enable_agent] ); $alias = io_safe_output(agents_get_alias($enable_agent)); if ($result) { // Update the agent from the metaconsole cache. enterprise_include_once('include/functions_agents.php'); $values = ['disabled' => 0]; enterprise_hook( 'agent_update_from_cache', [ $enable_agent, $values, $server_name, ] ); enterprise_hook( 'config_agents_update_config_token', [ $enable_agent, 'standby', 0, ] ); db_pandora_audit( AUDIT_LOG_AGENT_MANAGEMENT, 'Enable '.$alias ); } else { db_pandora_audit( AUDIT_LOG_AGENT_MANAGEMENT, 'Fail to enable '.$alias ); } ui_print_result_message( $result, __('Successfully enabled'), __('Could not be enabled') ); } if ($disable_agent) { $result = db_process_sql_update('tagente', ['disabled' => 1], ['id_agente' => $disable_agent]); $alias = io_safe_output(agents_get_alias($disable_agent)); if ($result) { // Update the agent from the metaconsole cache. enterprise_include_once('include/functions_agents.php'); $values = ['disabled' => 1]; enterprise_hook( 'agent_update_from_cache', [ $disable_agent, $values, $server_name, ] ); enterprise_hook( 'config_agents_update_config_token', [ $disable_agent, 'standby', 1, ] ); db_pandora_audit( AUDIT_LOG_AGENT_MANAGEMENT, 'Disable '.$alias ); } else { db_pandora_audit( AUDIT_LOG_AGENT_MANAGEMENT, 'Fail to disable '.$alias ); } ui_print_result_message( $result, __('Successfully disabled'), __('Could not be disabled') ); } echo ""; echo ""; echo ''; // Recursion checkbox. echo ''; echo ''; echo '
'; echo __('Group').' '; $own_info = get_user_info($config['id_user']); if (!$own_info['is_admin'] && !check_acl( $config['id_user'], 0, 'AR' ) && !check_acl($config['id_user'], 0, 'AW') ) { $return_all_group = false; } else { $return_all_group = true; } echo '
'; html_print_select_groups( false, 'AR', $return_all_group, 'ag_group', $ag_group, 'this.form.submit();', '', 0, false, false, true, '', false ); echo '
'; echo __('Recursion').' '; html_print_checkbox( 'recursion', 1, $recursion, false, false, 'this.form.submit()' ); echo ''; echo __('Show Agents').' '; $fields = [ 2 => __('Everyone'), 1 => __('Only disabled'), 0 => __('Only enabled'), ]; html_print_select( $fields, 'disabled', $disabled, 'this.form.submit()' ); echo ''; echo __('Operative System').' '; $pre_fields = db_get_all_rows_sql( 'select distinct(tagente.id_os),tconfig_os.name from tagente,tconfig_os where tagente.id_os = tconfig_os.id_os' ); $fields = []; foreach ($pre_fields as $key => $value) { $fields[$value['id_os']] = $value['name']; } html_print_select($fields, 'os', $os, 'this.form.submit()', 'All', 0); echo ''; echo __('Search').' '; html_print_input_text('search', $search, '', 12); echo ui_print_help_tip( __('Search filter by alias, name, description, IP address or custom fields content'), true ); echo ''; html_print_submit_button( __('Search'), 'srcbutton', false, [ 'icon' => 'search', 'mode' => 'mini', ] ); echo ''; echo ''; echo '
'; $selected = true; $selectNameUp = false; $selectNameDown = false; $selectOsUp = false; $selectOsDown = false; $selectGroupUp = false; $selectGroupDown = false; switch ($sortField) { case 'remote': switch ($sort) { case 'up': $selectRemoteUp = $selected; $order = [ 'field' => 'remote ', 'field2' => 'nombre ', 'order' => 'ASC', ]; break; case 'down': $selectRemoteDown = $selected; $order = [ 'field' => 'remote ', 'field2' => 'nombre ', 'order' => 'DESC', ]; break; default: // Default. break; } break; case 'name': switch ($sort) { case 'up': $selectNameUp = $selected; $order = [ 'field' => 'alias ', 'field2' => 'alias ', 'order' => 'ASC', ]; break; case 'down': $selectNameDown = $selected; $order = [ 'field' => 'alias ', 'field2' => 'alias ', 'order' => 'DESC', ]; break; default: // Default. break; } break; case 'os': switch ($sort) { case 'up': $selectOsUp = $selected; $order = [ 'field' => 'id_os', 'field2' => 'alias ', 'order' => 'ASC', ]; break; case 'down': $selectOsDown = $selected; $order = [ 'field' => 'id_os', 'field2' => 'alias ', 'order' => 'DESC', ]; break; default: // Default. break; } break; case 'group': switch ($sort) { case 'up': $selectGroupUp = $selected; $order = [ 'field' => 'id_grupo', 'field2' => 'alias ', 'order' => 'ASC', ]; break; case 'down': $selectGroupDown = $selected; $order = [ 'field' => 'id_grupo', 'field2' => 'alias ', 'order' => 'DESC', ]; break; default: // Default. break; } break; default: $selectNameUp = $selected; $selectNameDown = ''; $selectOsUp = ''; $selectOsDown = ''; $selectGroupUp = ''; $selectGroupDown = ''; $order = [ 'field' => 'alias ', 'field2' => 'alias ', 'order' => 'ASC', ]; break; } $search_sql = ''; if ($search != '') { $sql = sprintf( 'SELECT DISTINCT taddress_agent.id_agent FROM taddress INNER JOIN taddress_agent ON taddress.id_a = taddress_agent.id_a WHERE taddress.ip LIKE "%%%s%%"', $search ); $id = db_get_all_rows_sql($sql); if ($id != '') { $aux = $id[0]['id_agent']; $search_sql = sprintf( ' AND ( `nombre` LIKE "%%%s%%" OR tagente.id_agente = %d', $search, $aux ); $nagent_count = count($id); if ($nagent_count >= 2) { for ($i = 1; $i < $nagent_count; $i++) { $aux = $id[$i]['id_agent']; $search_sql .= sprintf( ' OR tagente.id_agente = %d', $aux ); } } $search_sql .= ')'; } else { $search_sql = sprintf( ' AND ( nombre LIKE "%%%s%%" OR alias LIKE "%%%s%%" OR comentarios LIKE "%%%s%%" OR EXISTS (SELECT * FROM tagent_custom_data WHERE id_agent = id_agente AND description LIKE "%%%s%%"))', $search, $search, $search, $search ); } } if ($disabled == 1) { $search_sql .= ' AND disabled = '.$disabled.$search_sql; } else { if ($disabled == 0) { $search_sql .= ' AND disabled = 0'.$search_sql; } } if ($os != 0) { $search_sql .= ' AND id_os = '.$os; } $user_groups_to_sql = ''; // Show only selected groups. if ($ag_group > 0) { $ag_groups = []; $ag_groups = (array) $ag_group; if ($recursion) { $ag_groups = groups_get_children_ids($ag_group, true); } $user_groups_to_sql = implode(',', $ag_groups); } else { // Concatenate AW and AD permisions to get all the possible groups where the user can manage. $user_groupsAW = users_get_groups($config['id_user'], 'AW'); $user_groupsAD = users_get_groups($config['id_user'], 'AD'); $user_groups = ($user_groupsAW + $user_groupsAD); $user_groups_to_sql = implode(',', array_keys($user_groups)); } $sql = sprintf( 'SELECT COUNT(DISTINCT(tagente.id_agente)) FROM tagente LEFT JOIN tagent_secondary_group tasg ON tagente.id_agente = tasg.id_agent WHERE (tagente.id_grupo IN (%s) OR tasg.id_group IN (%s)) %s', $user_groups_to_sql, $user_groups_to_sql, $search_sql ); $total_agents = db_get_sql($sql); $sql = sprintf( 'SELECT * FROM tagente LEFT JOIN tagent_secondary_group tasg ON tagente.id_agente = tasg.id_agent WHERE (tagente.id_grupo IN (%s) OR tasg.id_group IN (%s)) %s GROUP BY tagente.id_agente ORDER BY %s %s, %s %s LIMIT %d, %d', $user_groups_to_sql, $user_groups_to_sql, $search_sql, $order['field'], $order['order'], $order['field2'], $order['order'], $offset, $config['block_size'] ); $agents = db_get_all_rows_sql($sql); // Delete rnum row generated by oracle_recode_query() function. if (($config['dbtype'] == 'oracle') && ($agents !== false)) { for ($i = 0; $i < count($agents); $i++) { unset($agents[$i]['rnum']); } } // Prepare pagination. ui_pagination($total_agents, "index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&group_id=$ag_group&recursion=$recursion&search=$search&sort_field=$sortField&sort=$sort&disabled=$disabled&os=$os", $offset); if ($agents !== false) { // Urls to sort the table. if ($config['language'] == 'ja' || $config['language'] == 'zh_CN' || $own_info['language'] == 'ja' || $own_info['language'] == 'zh_CN' ) { // Adds a custom font size for Japanese and Chinese language. $custom_font_size = 'custom_font_size'; } $url_up_agente = 'index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&group_id='.$ag_group.'&recursion='.$recursion.'&search='.$search.'&os='.$os.'&offset='.$offset.'&sort_field=name&sort=up&disabled=$disabled'; $url_down_agente = 'index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&group_id='.$ag_group.'&recursion='.$recursion.'&search='.$search.'&os='.$os.'&offset='.$offset.'&sort_field=name&sort=down&disabled=$disabled'; $url_up_remote = 'index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&group_id='.$ag_group.'&recursion='.$recursion.'&search='.$search.'&os='.$os.'&offset='.$offset.'&sort_field=remote&sort=up&disabled=$disabled'; $url_down_remote = 'index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&group_id='.$ag_group.'&recursion='.$recursion.'&search='.$search.'&os='.$os.'&offset='.$offset.'&sort_field=remote&sort=down&disabled=$disabled'; $url_up_os = 'index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&group_id='.$ag_group.'&recursion='.$recursion.'&search='.$search.'&os='.$os.'&offset='.$offset.'&sort_field=os&sort=up&disabled=$disabled'; $url_down_os = 'index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&group_id='.$ag_group.'&recursion='.$recursion.'&search='.$search.'&os='.$os.'&offset='.$offset.'&sort_field=os&sort=down&disabled=$disabled'; $url_up_group = 'index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&group_id='.$ag_group.'&recursion='.$recursion.'&search='.$search.'&os='.$os.'&offset='.$offset.'&sort_field=group&sort=up&disabled=$disabled'; $url_down_group = 'index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&group_id='.$ag_group.'&recursion='.$recursion.'&search='.$search.'&os='.$os.'&offset='.$offset.'&sort_field=group&sort=down&disabled=$disabled'; echo ""; echo ''; echo ''; echo "'; echo ''; echo ''; echo ''; echo ''; echo "'; echo ''; $color = 1; $rowPair = true; $iterator = 0; foreach ($agents as $agent) { // Begin Update tagente.remote 0/1 with remote agent function return. if (enterprise_hook( 'config_agents_has_remote_configuration', [$agent['id_agente']] ) ) { db_process_sql_update( 'tagente', ['remote' => 1], 'id_agente = '.$agent['id_agente'].'' ); } else { db_process_sql_update('tagente', ['remote' => 0], 'id_agente = '.$agent['id_agente'].''); } // End Update tagente.remote 0/1 with remote agent function return. $all_groups = agents_get_all_groups_agent( $agent['id_agente'], $agent['id_grupo'] ); $check_aw = check_acl_one_of_groups( $config['id_user'], $all_groups, 'AW' ); $check_ad = check_acl_one_of_groups( $config['id_user'], $all_groups, 'AD' ); $cluster = db_get_row_sql('select id from tcluster where id_agent = '.$agent['id_agente']); // Do not show the agent if there is not enough permissions. if (!$check_aw && !$check_ad) { continue; } if ($color == 1) { $tdcolor = 'datos'; $color = 0; } else { $tdcolor = 'datos2'; $color = 1; } if ($rowPair) { $rowclass = 'rowPair'; } else { $rowclass = 'rowOdd'; } $rowPair = !$rowPair; $iterator++; // Agent name. echo "'; echo "'; // Operating System icon. echo "'; // Type agent (Networt, Software or Satellite). echo "'; // Group icon and name. echo "'; // Description. echo "'; // Action // When there is only one element in page it's necesary go back page. if ((count($agents) == 1) && ($offset >= $config['block_size'])) { $offsetArg = ($offset - $config['block_size']); } else { $offsetArg = $offset; } echo "'; } echo '
'.__('Agent name').ui_get_sorting_arrows($url_up_agente, $url_down_agente, $selectNameUp, $selectNameDown).'".__('R').ui_get_sorting_arrows($url_up_remote, $url_down_remote, $selectRemoteUp, $selectRemoteDown).''.__('OS').ui_get_sorting_arrows($url_up_os, $url_down_os, $selectOsUp, $selectOsDown).''.__('Type').''.__('Group').ui_get_sorting_arrows($url_up_group, $url_down_group, $selectGroupUp, $selectGroupDown).''.__('Description').'".__('Actions').'
"; if ($agent['disabled']) { echo ''; } echo ''; echo ''; if ($check_aw) { $main_tab = 'main'; } else { $main_tab = 'module'; } if ($agent['alias'] == '') { $agent['alias'] = $agent['nombre']; } if ($agent['id_os'] == CLUSTER_OS_ID) { if (enterprise_installed()) { $cluster = PandoraFMS\Enterprise\Cluster::loadFromAgentId( $agent['id_agente'] ); $url = 'index.php?sec=reporting&sec2='.ENTERPRISE_DIR; $url .= '/operation/cluster/cluster'; $url = ui_get_full_url( $url.'&op=update&id='.$cluster->id() ); echo ''.ui_print_truncate_text($agent['alias'], 'agent_medium').''; } } else { echo '".''.ui_print_truncate_text($agent['alias'], 'agent_medium').''.''; } echo ''; $in_planned_downtime = db_get_sql( 'SELECT executed FROM tplanned_downtime INNER JOIN tplanned_downtime_agents ON tplanned_downtime.id = tplanned_downtime_agents.id_downtime WHERE tplanned_downtime_agents.id_agent = '.$agent['id_agente'].' AND tplanned_downtime.executed = 1 AND tplanned_downtime.type_downtime <> "disable_agent_modules"' ); if ($agent['disabled']) { ui_print_help_tip(__('Disabled')); if (!$in_planned_downtime) { echo ''; } } if ($agent['quiet']) { echo ' '; html_print_image( 'images/dot_blue.png', false, [ 'border' => '0', 'title' => __('Quiet'), 'alt' => '', ] ); } if ($in_planned_downtime) { ui_print_help_tip( __('Agent in scheduled downtime'), false, 'images/minireloj-16.png' ); echo ''; } echo '
'; if ($check_aw) { if ($agent['id_os'] == CLUSTER_OS_ID) { if (enterprise_installed()) { $cluster = PandoraFMS\Enterprise\Cluster::loadFromAgentId( $agent['id_agente'] ); $url = 'index.php?sec=reporting&sec2='.ENTERPRISE_DIR; $url .= '/operation/cluster/cluster'; $url = ui_get_full_url( $url.'&op=update&id='.$cluster->id() ); echo ''.__('Edit').''; echo ' | '; } } else { echo ''.__('Edit').''; echo ' | '; } } if ($agent['id_os'] != 100) { echo ''.__('Modules').''; echo ' | '; } echo ''.__('Alerts').''; echo ' | '; if ($agent['id_os'] == CLUSTER_OS_ID) { if (enterprise_installed()) { $cluster = PandoraFMS\Enterprise\Cluster::loadFromAgentId( $agent['id_agente'] ); $url = 'index.php?sec=reporting&sec2='.ENTERPRISE_DIR; $url .= '/operation/cluster/cluster'; $url = ui_get_full_url( $url.'&op=view&id='.$cluster->id() ); echo ''.__('View').''; } } else { echo ''.__('View').''; } echo '
'; echo '
"; // Has remote configuration ? if (enterprise_installed()) { enterprise_include_once('include/functions_config_agents.php'); if (enterprise_hook('config_agents_has_remote_configuration', [$agent['id_agente']])) { echo ""; echo html_print_image( 'images/application_edit.png', true, [ 'align' => 'middle', 'title' => __('Edit remote config'), 'class' => 'invert_filter', ] ); echo ''; } } echo '"; ui_print_os_icon($agent['id_os'], false); echo '"; echo ui_print_type_agent_icon( $agent['id_os'], $agent['ultimo_contacto_remoto'], $agent['ultimo_contacto'], $agent['remote'], $agent['agent_version'] ); echo '".ui_print_group_icon($agent['id_grupo'], true).'".ui_print_truncate_text($agent['comentarios'], 'description', true, true, true, '[…]').'"; if ($agent['disabled']) { echo "'; } else { echo ' onClick="if (!confirm(\' '.__('You are going to enable a cluster agent. Are you sure?').'\')) return false;">'; } echo html_print_image('images/lightbulb_off.png', true, ['alt' => __('Enable agent'), 'title' => __('Enable agent'), 'class' => 'filter_none']).''; } else { echo "'; } else { echo ' onClick="if (!confirm(\' '.__('You are going to disable a cluster agent. Are you sure?').'\')) return false;">'; } echo html_print_image('images/lightbulb.png', true, ['alt' => __('Disable agent'), 'title' => __('Disable agent'), 'class' => 'invert_filter']).''; } if ($check_aw && is_management_allowed() === true) { echo "'; } else { echo ' onClick="if (!confirm(\' '.__('WARNING! - You are going to delete a cluster agent. Are you sure?').'\')) return false;">'; } echo html_print_image('images/cross.png', true, ['border' => '0', 'class' => 'invert_filter']).''; } echo '
'; ui_pagination($total_agents, "index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&group_id=$ag_group&recursion=$recursion&search=$search&sort_field=$sortField&sort=$sort&disabled=$disabled&os=$os", $offset); echo "
"; } else { ui_print_info_message(['no_close' => true, 'message' => __('There are no defined agents') ]); } if ((bool) check_acl($config['id_user'], 0, 'AW') === true) { // Create agent button. echo '
'; html_print_div( [ 'class' => 'action-buttons', 'content' => html_print_submit_button( __('Create agent'), 'crt-2', false, [ 'icon' => 'cog', 'mode' => 'secondary', ], true ), ] ); echo '
'; } echo '
'; ?>