diff --git a/pandora_console/images/status_sets/default/module_unknown_ball.png b/pandora_console/images/status_sets/default/module_unknown_ball.png index 7d0e20ea74..4d0ff8b35a 100755 Binary files a/pandora_console/images/status_sets/default/module_unknown_ball.png and b/pandora_console/images/status_sets/default/module_unknown_ball.png differ diff --git a/pandora_console/images/tree/branch.png b/pandora_console/images/tree/branch.png new file mode 100644 index 0000000000..dac28141c7 Binary files /dev/null and b/pandora_console/images/tree/branch.png differ diff --git a/pandora_console/images/tree/closed.png b/pandora_console/images/tree/closed.png new file mode 100644 index 0000000000..a0beb9bfd9 Binary files /dev/null and b/pandora_console/images/tree/closed.png differ diff --git a/pandora_console/images/tree/expanded.png b/pandora_console/images/tree/expanded.png new file mode 100644 index 0000000000..a5249e42b4 Binary files /dev/null and b/pandora_console/images/tree/expanded.png differ diff --git a/pandora_console/images/tree/first_closed.png b/pandora_console/images/tree/first_closed.png new file mode 100644 index 0000000000..7a3673c7c2 Binary files /dev/null and b/pandora_console/images/tree/first_closed.png differ diff --git a/pandora_console/images/tree/first_expanded.png b/pandora_console/images/tree/first_expanded.png new file mode 100644 index 0000000000..ef8d30aaa0 Binary files /dev/null and b/pandora_console/images/tree/first_expanded.png differ diff --git a/pandora_console/images/tree/first_leaf.png b/pandora_console/images/tree/first_leaf.png new file mode 100644 index 0000000000..e85d78d93a Binary files /dev/null and b/pandora_console/images/tree/first_leaf.png differ diff --git a/pandora_console/images/tree/last_closed.png b/pandora_console/images/tree/last_closed.png new file mode 100644 index 0000000000..4e07936700 Binary files /dev/null and b/pandora_console/images/tree/last_closed.png differ diff --git a/pandora_console/images/tree/last_expanded.png b/pandora_console/images/tree/last_expanded.png new file mode 100644 index 0000000000..8411630167 Binary files /dev/null and b/pandora_console/images/tree/last_expanded.png differ diff --git a/pandora_console/images/tree/last_leaf.png b/pandora_console/images/tree/last_leaf.png new file mode 100644 index 0000000000..5e75cc5343 Binary files /dev/null and b/pandora_console/images/tree/last_leaf.png differ diff --git a/pandora_console/images/tree/leaf.png b/pandora_console/images/tree/leaf.png new file mode 100644 index 0000000000..52ffb066cb Binary files /dev/null and b/pandora_console/images/tree/leaf.png differ diff --git a/pandora_console/images/tree/no_branch.png b/pandora_console/images/tree/no_branch.png new file mode 100644 index 0000000000..8e97d8b10a Binary files /dev/null and b/pandora_console/images/tree/no_branch.png differ diff --git a/pandora_console/images/tree/one_closed.png b/pandora_console/images/tree/one_closed.png new file mode 100755 index 0000000000..db9d336b17 Binary files /dev/null and b/pandora_console/images/tree/one_closed.png differ diff --git a/pandora_console/images/tree/one_expanded.png b/pandora_console/images/tree/one_expanded.png new file mode 100755 index 0000000000..577c4bf6ce Binary files /dev/null and b/pandora_console/images/tree/one_expanded.png differ diff --git a/pandora_console/include/ajax/module.php b/pandora_console/include/ajax/module.php index db2ab3e94d..2ff6afe878 100755 --- a/pandora_console/include/ajax/module.php +++ b/pandora_console/include/ajax/module.php @@ -67,25 +67,15 @@ if ($search_modules) { if ($get_module_detail) { - - ui_include_time_picker(); - - ui_require_jquery_file("ui.datepicker-" . get_user_language(), - "include/javascript/i18n/"); - - ui_require_jquery_file ("ui-timepicker-addon"); // This script is included manually to be included after jquery and avoid error - echo ''; - ui_require_jquery_file("ui.datepicker-" . get_user_language(), - "include/javascript/i18n/"); + ui_include_time_picker(); + ui_require_jquery_file("ui.datepicker-" . get_user_language(), "include/javascript/i18n/"); - $module_id = get_parameter ('id_module'); - $period = get_parameter ("period", 86400); + $module_id = (int) get_parameter('id_module'); + $period = (int) get_parameter("period", 86400); $group = agents_get_agentmodule_group ($module_id); - $agentId = get_parameter("id_agent"); - $server_name = get_parameter('server_name'); + $agentId = (int) get_parameter("id_agent"); + $server_name = (string) get_parameter('server_name'); if (defined ('METACONSOLE')) { $server = metaconsole_get_connection ($server_name); diff --git a/pandora_console/include/ajax/tree.ajax.php b/pandora_console/include/ajax/tree.ajax.php new file mode 100644 index 0000000000..6c44b591fb --- /dev/null +++ b/pandora_console/include/ajax/tree.ajax.php @@ -0,0 +1,131 @@ + '', 'statusAgent' => AGENT_STATUS_ALL)); + $id = (int)get_parameter('id', 0); + $childrenMethod = get_parameter('childrenMethod', 'on_demand'); + $countModuleStatusMethod = get_parameter('countModuleStatusMethod', 'on_demand'); + $countAgentStatusMethod = get_parameter('countAgentStatusMethod', 'live'); + + if (class_exists('TreeEnterprise')) { + $tree = new TreeEnterprise($type, + $id, + $childrenMethod, + $countModuleStatusMethod, + $countAgentStatusMethod + ); + } + else { + $tree = new Tree($type, + $id, + $childrenMethod, + $countModuleStatusMethod, + $countAgentStatusMethod + ); + } + + $tree->setFilter(array( + 'statusAgent' => $filter['statusAgent'], + 'searchAgent' => $filter['searchAgent']) + ); + echo json_encode(array('success' => 1, 'tree' => $tree->getArray())); + return; + } + + if ($getGroupStatus) { + $id = (int)get_parameter('id', 0); + $type = get_parameter('type', 'group'); + $id = 0; + + $status = array(); + + switch ($type) { + case 'group': + $data = reporting_get_group_stats($id); + + $status['unknown'] = $data['agents_unknown']; + $status['critical'] = $data['agent_critical']; + $status['warning'] = $data['agent_warning']; + $status['not_init'] = $data['agent_not_init']; + $status['ok'] = $data['agent_ok']; + $status['total'] = $data['total_agents']; + $status['status'] = $data['status']; + $status['alert_fired'] = $data['alert_fired']; + + echo json_encode($status); + break; + } + return; + } + + if ($get_detail) { + require_once($config['homedir']."/include/functions_treeview.php"); + + // Clean the output + ob_clean(); + + $id = (int) get_parameter('id'); + $type = (string) get_parameter('type'); + + $server = array(); + if (defined ('METACONSOLE')) { + $server_name = (string) get_parameter('server'); + $server = metaconsole_get_connection($server_name); + metaconsole_connect($server); + } + + switch ($type) { + case 'agent': + treeview_printTable($id, $server); + break; + case 'module': + treeview_printModuleTable($id, $server); + break; + case 'alert': + treeview_printAlertsTable($id, $server); + break; + default: + // Nothing + break; + } + + if (!empty($server) && defined ('METACONSOLE')) { + metaconsole_restore_db(); + } + + return; + } + + return; +} +?> \ No newline at end of file diff --git a/pandora_console/include/class/Tree.class.php b/pandora_console/include/class/Tree.class.php new file mode 100644 index 0000000000..d28910ba58 --- /dev/null +++ b/pandora_console/include/class/Tree.class.php @@ -0,0 +1,1522 @@ +type = $type; + $this->root = $root; + $this->childrenMethod = $childrenMethod; + $this->countModuleStatusMethod = $countModuleStatusMethod; + $this->countAgentStatusMethod = $countAgentStatusMethod; + + $userGroups = users_get_groups(); + + if (empty($userGroups)) + $this->userGroups = false; + else + $this->userGroups = $userGroups; + + global $config; + include_once($config['homedir']."/include/functions_servers.php"); + } + + public function setType($type) { + $this->type = $type; + } + + public function setFilter($filter) { + $this->filter = $filter; + } + + protected function processModule (&$module) { + global $config; + + $module['type'] = 'module'; + $module['id'] = (int) $module['id_agente_modulo']; + $module['name'] = $module['nombre']; + $module['id_module_type'] = (int) $module['id_tipo_modulo']; + $module['server_type'] = (int) $module['id_modulo']; + // $module['icon'] = modules_get_type_icon($module['id_tipo_modulo']); + + if (!isset($module['value'])) + $module['value'] = modules_get_last_value($module['id']); + + // Status + switch ($module['status']) { + case AGENT_MODULE_STATUS_CRITICAL_ALERT: + $module['alert'] = 1; + case AGENT_MODULE_STATUS_CRITICAL_BAD: + $statusType = STATUS_MODULE_CRITICAL_BALL; + $statusTitle = __('CRITICAL'); + $module['statusText'] = "critical"; + break; + case AGENT_MODULE_STATUS_WARNING_ALERT: + $module['alert'] = 1; + case AGENT_MODULE_STATUS_WARNING: + $statusType = STATUS_MODULE_WARNING_BALL; + $statusTitle = __('WARNING'); + $module['statusText'] = "warning"; + break; + case AGENT_MODULE_STATUS_UNKNOWN: + $statusType = STATUS_MODULE_UNKNOWN_BALL; + $statusTitle = __('UNKNOWN'); + $module['statusText'] = "unknown"; + break; + case AGENT_MODULE_STATUS_NO_DATA: + case AGENT_MODULE_STATUS_NOT_INIT: + $statusType = STATUS_MODULE_NO_DATA_BALL; + $statusTitle = __('NO DATA'); + $module['statusText'] = "not_init"; + break; + case AGENT_MODULE_STATUS_NORMAL_ALERT: + $module['alert'] = 1; + case AGENT_MODULE_STATUS_NORMAL: + default: + $statusType = STATUS_MODULE_OK_BALL; + $statusTitle = __('NORMAL'); + $module['statusText'] = "ok"; + break; + } + + if ($statusType !== STATUS_MODULE_UNKNOWN_BALL + && $statusType !== STATUS_MODULE_NO_DATA_BALL) { + if (is_numeric($module["value"])) { + $statusTitle .= " : " . format_for_graph($module["value"]); + } + else { + $statusTitle .= " : " . substr(io_safe_output($module["value"]),0,42); + } + } + + $module['statusImageHTML'] = ui_print_status_image($statusType, $statusTitle, true); + + // HTML of the server type image + $module['serverTypeHTML'] = servers_show_type($module['server_type']); + + // Link to the Module graph + $graphType = return_graphtype($module['id']); + $winHandle = dechex(crc32($module['id'] . $module['name'])); + + $moduleGraphURL = $config['homeurl'] . + "/operation/agentes/stat_win.php?" . + "type=$graphType&" . + "period=86400&" . + "id=" . $module['id'] . "&" . + "label=" . rawurlencode(urlencode(base64_encode($module['name']))) . "&" . + "refresh=600"; + + $module['moduleGraph'] = array( + 'url' => $moduleGraphURL, + 'handle' => $winHandle + ); + } + + protected function processModules ($modules_aux, &$modules) { + $counters = false; + + if (!empty($modules_aux)) { + $counters = array( + 'critical' => 0, + 'warning' => 0, + 'ok' => 0, + 'not_init' => 0, + 'unknown' => 0, + 'alerts' => 0 + ); + + foreach ($modules_aux as $module) { + $this->processModule($module); + $modules[] = $module; + + if (isset($counters[$module['statusText']])) + $counters[$module['statusText']]++; + if ($module['alert']) + $counters['alerts']++; + } + } + return $counters; + } + + protected function getModules ($parent = 0, $filter = array()) { + $modules = array(); + + $modules_aux = agents_get_modules($parent, + array('id_agente_modulo', 'nombre', 'id_tipo_modulo', 'id_modulo'), $filter); + + if (empty($modules_aux)) + $modules_aux = array(); + + // Process the modules + $this->processModules($modules_aux, $modules); + + return $modules; + } + + protected function processAgent (&$agent, $modulesFilter = array(), $searchChildren = true) { + $agent['type'] = 'agent'; + $agent['id'] = (int) $agent['id_agente']; + $agent['name'] = $agent['nombre']; + + // Counters + if (empty($agent['counters'])) { + $agent['counters'] = array(); + + if (isset($agent['unknown_count'])) + $agent['counters']['unknown'] = $agent['unknown_count']; + else + $agent['counters']['unknown'] = agents_monitor_unknown($agent['id']); + + if (isset($agent['critical_count'])) + $agent['counters']['critical'] = $agent['critical_count']; + else + $agent['counters']['critical'] = agents_monitor_critical($agent['id']); + + if (isset($agent['warning_count'])) + $agent['counters']['warning'] = $agent['warning_count']; + else + $agent['counters']['warning'] = agents_monitor_warning($agent['id']); + + if (isset($agent['notinit_count'])) + $agent['counters']['not_init'] = $agent['notinit_count']; + else + $agent['counters']['not_init'] = agents_monitor_notinit($agent['id']); + + if (isset($agent['normal_count'])) + $agent['counters']['ok'] = $agent['normal_count']; + else + $agent['counters']['ok'] = agents_monitor_ok($agent['id']); + + if (isset($agent['total_count'])) + $agent['counters']['total'] = $agent['total_count']; + else + $agent['counters']['total'] = agents_monitor_total($agent['id']); + + if (isset($agent['fired_count'])) + $agent['counters']['alerts'] = $agent['fired_count']; + else + $agent['counters']['alerts'] = agents_get_alerts_fired($agent['id']); + } + + // Status image + $agent['statusImageHTML'] = agents_tree_view_status_img_ball( + $agent['counters']['critical'], + $agent['counters']['warning'], + $agent['counters']['unknown'], + $agent['counters']['total'], + $agent['counters']['not_init']); + + // Alerts fired image + $agent["alertImageHTML"] = agents_tree_view_alert_img_ball($agent['counters']['alerts']); + + // Status + $agent['statusRaw'] = agents_get_status($agent['id']); + switch ($agent['statusRaw']) { + case AGENT_STATUS_NORMAL: + $agent['status'] = "ok"; + break; + case AGENT_STATUS_WARNING: + $agent['status'] = "warning"; + break; + case AGENT_STATUS_CRITICAL: + $agent['status'] = "critical"; + break; + case AGENT_STATUS_UNKNOWN: + $agent['status'] = "unknown"; + break; + case AGENT_STATUS_NOT_INIT: + $agent['status'] = "not_init"; + break; + default: + $agent['status'] = "none"; + break; + } + + // Children + if (empty($agent['children'])) { + $agent['children'] = array(); + if ($agent['counters']['total'] > 0) { + switch ($this->childrenMethod) { + case 'on_demand': + $agent['searchChildren'] = 1; + break; + case 'live': + $agent['searchChildren'] = 0; + + if ($searchChildren) + $agent['children'] = $this->getModules($agent['id'], $modulesFilter); + break; + } + } + else { + switch ($this->childrenMethod) { + case 'on_demand': + $agent['searchChildren'] = 0; + break; + case 'live': + $agent['searchChildren'] = 0; + break; + } + } + } + } + + protected function processAgents (&$agents, $modulesFilter = array()) { + if (!empty($agents)) { + foreach ($agents as $iterator => $agent) { + $this->processAgent($agents[$iterator], $modulesFilter); + } + } + } + + protected function getAgents ($parent = 0, $parentType = '') { + // Agent name filter + $agent_search = ""; + if (!empty($this->filter['searchAgent'])) { + $agent_search = " AND ta.nombre LIKE '%".$this->filter['searchAgent']."%' "; + } + + // Module name filter + $module_search = ""; + if (!empty($this->filter['searchModule'])) { + $module_search = " AND tam.nombre LIKE '%".$this->filter['searchModule']."%' "; + } + + switch ($parentType) { + case 'group': + // ACL Groups + if (isset($this->userGroups) && $this->userGroups === false) + return array(); + + if (!empty($this->userGroups) && !empty($parent)) { + if (!isset($this->userGroups[$parent])) + return array(); + } + // TODO: Check ACL + + // Get the agents. The modules are optional (LEFT JOIN), like their status + $sql = "SELECT ta.id_agente, ta.nombre AS agent_name, ta.fired_count, + ta.normal_count, ta.warning_count, ta.critical_count, + ta.unknown_count, ta.notinit_count, ta.total_count, + tam.id_agente_modulo, tam.nombre AS module_name, + tam.id_tipo_modulo, tam.id_modulo, tae.estado, tae.datos + FROM tagente AS ta + LEFT JOIN tagente_modulo AS tam + LEFT JOIN tagente_estado AS tae + ON tam.id_agente_modulo IS NOT NULL + AND tam.id_agente_modulo = tae.id_agente_modulo + ON tam.disabled = 0 + AND ta.id_agente = tam.id_agente + $module_search + WHERE ta.id_grupo = $parent + AND ta.disabled = 0 + $agent_search + ORDER BY ta.nombre ASC, ta.id_agente ASC, tam.nombre ASC, tam.id_agente_modulo ASC"; + $data = db_process_sql($sql); + break; + case 'tag': + $groups_clause = ""; + if (!empty($this->acltags)) { + $i = 0; + $groups = array(); + foreach ($this->acltags as $group_id => $tags) { + if (!empty($tags)) { + $tags_arr = explode(',', $tags); + + if (in_array($id_tag, $tags_arr)) + $groups[] = $group_id; + } + } + if (!empty($groups)) { + $groups_str = implode(",", $groups); + $groups_clause = " AND ta.id_grupo IN ($groups_str)"; + } + } + + // Get the agents. The modules are required (INNER JOIN), although their status + $sql = "SELECT ta.id_agente, ta.nombre AS agent_name, ta.fired_count, + ta.normal_count, ta.warning_count, ta.critical_count, + ta.unknown_count, ta.notinit_count, ta.total_count, + tam.id_agente_modulo, tam.nombre AS module_name, + tam.id_tipo_modulo, tam.id_modulo, tae.estado, tae.datos + FROM tagente AS ta + INNER JOIN tagente_modulo AS tam + ON tam.disabled = 0 + AND ta.id_agente = tam.id_agente + $module_search + INNER JOIN ttag_module AS ttm + ON ttm.id_tag = $parent + AND tam.id_agente_modulo = ttm.id_agente_modulo + LEFT JOIN tagente_estado AS tae + ON tam.id_agente_modulo = tae.id_agente_modulo + WHERE ta.disabled = 0 + $groups_clause + $agent_search + ORDER BY ta.nombre ASC, ta.id_agente ASC, tam.nombre ASC, tam.id_agente_modulo ASC"; + $data = db_process_sql($sql); + break; + default: + return array(); + break; + } + + if (empty($data)) + return array(); + + $agents = array(); + $actual_agent = array(); + foreach ($data as $key => $value) { + + if (empty($actual_agent) || $actual_agent['id_agente'] != (int)$value['id_agente']) { + if (!empty($actual_agent)) { + $this->processAgent($actual_agent, array(), false); + $agents[] = $actual_agent; + } + + $actual_agent = array(); + $actual_agent['id_agente'] = (int) $value['id_agente']; + $actual_agent['nombre'] = $value['agent_name']; + + $actual_agent['children'] = array(); + + // Initialize counters + $actual_agent['counters'] = array(); + $actual_agent['counters']['total'] = 0; + $actual_agent['counters']['alerts'] = 0; + $actual_agent['counters']['critical'] = 0; + $actual_agent['counters']['warning'] = 0; + $actual_agent['counters']['unknown'] = 0; + $actual_agent['counters']['not_init'] = 0; + $actual_agent['counters']['ok'] = 0; + + // $actual_agent['counters'] = array(); + // $actual_agent['counters']['total'] = (int) $value['total_count']; + // $actual_agent['counters']['alerts'] = (int) $value['fired_count_count']; + // $actual_agent['counters']['critical'] = (int) $value['critical_count']; + // $actual_agent['counters']['warning'] = (int) $value['warning_count']; + // $actual_agent['counters']['unknown'] = (int) $value['unknown_count']; + // $actual_agent['counters']['not_init'] = (int) $value['notinit_count']; + // $actual_agent['counters']['ok'] = (int) $value['normal_count']; + } + + if (empty($value['id_agente_modulo'])) + continue; + + $module = array(); + $module['id_agente_modulo'] = (int) $value['id_agente_modulo']; + $module['nombre'] = $value['module_name']; + $module['id_tipo_modulo'] = (int) $value['id_tipo_modulo']; + $module['server_type'] = (int) $value['id_modulo']; + $module['status'] = (int) $value['estado']; + $module['value'] = $value['data']; + + $this->processModule($module); + + $actual_agent['children'][] = $module; + $actual_agent['counters']['total']++; + + if (isset($actual_agent['counters'][$module['statusText']])) + $actual_agent['counters'][$module['statusText']]++; + + if ($module['alert']) + $actual_agent['counters']['alerts']++; + } + if (!empty($actual_agent)) { + $this->processAgent($actual_agent, array(), false); + $agents[] = $actual_agent; + } + + return $agents; + } + + protected function getGroupsRecursive($parent, $limit = null, $get_agents = true) { + $filter = array(); + $filter['parent'] = $parent; + + // if (!empty($this->filter['search'])) { + // $filter['nombre'] = "%" . $this->filter['search'] . "%"; + // } + // ACL groups + if (isset($this->userGroups) && $this->userGroups === false) + return array(); + + if (!empty($this->userGroups)) + $filter['id_grupo'] = array_keys($this->userGroups); + + // First filter by name and father + $groups = db_get_all_rows_filter('tgrupo', $filter, array('id_grupo', 'nombre', 'icon')); + if (empty($groups)) + $groups = array(); + + // Filter by status + // $filter_status = AGENT_STATUS_ALL; + // if (!empty($this->filter['status'])) { + // $filter_status = $this->filter['status']; + // } + + foreach ($groups as $iterator => $group) { + // Counters + $group_stats = reporting_get_group_stats($group['id_grupo']); + + $groups[$iterator]['counters'] = array(); + if (!empty($group_stats)) { + $groups[$iterator]['counters']['unknown'] = $group_stats['agents_unknown']; + $groups[$iterator]['counters']['critical'] = $group_stats['agent_critical']; + $groups[$iterator]['counters']['warning'] = $group_stats['agent_warning']; + $groups[$iterator]['counters']['not_init'] = $group_stats['agent_not_init']; + $groups[$iterator]['counters']['ok'] = $group_stats['agent_ok']; + $groups[$iterator]['counters']['total'] = $group_stats['total_agents']; + } + + $groups[$iterator]['status'] = $group_stats['status']; + $groups[$iterator]['icon'] = !empty($group['icon']) ? $group['icon'] . '.png' : 'without_group.png'; + + // // Filter by status + // if ($filter_status != AGENT_STATUS_ALL) { + // $remove_group = true; + // switch ($filter_status) { + // case AGENT_STATUS_NORMAL: + // if ($groups[$iterator]['status'] === "ok") + // $remove_group = false; + // break; + // case AGENT_STATUS_WARNING: + // if ($groups[$iterator]['status'] === "warning") + // $remove_group = false; + // break; + // case AGENT_STATUS_CRITICAL: + // if ($groups[$iterator]['status'] === "critical") + // $remove_group = false; + // break; + // case AGENT_STATUS_UNKNOWN: + // if ($groups[$iterator]['status'] === "unknown") + // $remove_group = false; + // break; + // case AGENT_STATUS_NOT_INIT: + // if ($groups[$iterator]['status'] === "not_init") + // $remove_group = false; + // break; + // } + + // if ($remove_group) { + // unset($groups[$iterator]); + // continue; + // } + // } + + if (is_null($limit)) { + $groups[$iterator]['children'] = + $this->getGroupsRecursive($group['id_grupo']); + } + else if ($limit >= 1) { + $groups[$iterator]['children'] = + $this->getGroupsRecursive($group['id_grupo'], ($limit - 1)); + } + + switch ($this->countAgentStatusMethod) { + case 'on_demand': + $groups[$iterator]['searchCounters'] = 1; + break; + case 'live': + $groups[$iterator]['searchCounters'] = 0; + break; + } + switch ($this->childrenMethod) { + case 'on_demand': + // if (!empty($groups[$iterator]['children'])) { + // $groups[$iterator]['searchChildren'] = 1; + // } + // else { + // $groups[$iterator]['searchChildren'] = 0; + // } + $groups[$iterator]['searchChildren'] = 0; + break; + case 'live': + $groups[$iterator]['searchChildren'] = 0; + break; + } + + $groups[$iterator]['type'] = 'group'; + $groups[$iterator]['name'] = $groups[$iterator]['nombre']; + $groups[$iterator]['id'] = $groups[$iterator]['id_grupo']; + } + + if (!empty($parent) && $get_agents) { + $agents = $this->getAgents($parent, 'group'); + + if (!empty($agents)) + $groups = array_merge($groups, $agents); + } + + return $groups; + } + + public function getData() { + switch ($this->type) { + case 'os': + $this->getDataOS(); + break; + case 'group': + $this->getDataGroup(); + break; + case 'module_group': + $this->getDataModuleGroup(); + break; + case 'module': + $this->getDataModules(); + break; + case 'tag': + $this->getDataTag(); + break; + default: + $this->getDataExtended(); + } + } + + protected function getDataExtended () { + // Override this method to add new types + } + + private function getDataGroup() { + global $config; + + // Get the parent + if (empty($this->root)) + $parent = 0; + else + $parent = $this->root; + + // Get all groups + if (empty($parent)) { + require_once($config['homedir']."/include/functions_groups.php"); + + // Return all the children groups + function __searchChildren(&$groups, $id) { + $children = array(); + foreach ($groups as $key => $group) { + if (isset($group['_parent_id_']) && $group['_parent_id_'] == $id) { + $children[] = __getProcessedItem($key, $groups); + } + } + return $children; + } + + function __getProcessedItem($itemKey, &$items) { + if (!isset($items[$itemKey])) { + return false; + } + else { + $item = $items[$itemKey]; + unset($items[$itemKey]); + } + + $processed_item = array(); + $processed_item['id'] = $item['_id_']; + $processed_item['name'] = $item['_name_']; + $processed_item['searchChildren'] = 1; + + if (isset($item['_is_tag_']) && $item['_is_tag_']) { + $processed_item['type'] = 'tag'; + } + else { + $processed_item['type'] = 'group'; + $processed_item['parentID'] = $item['_parent_id_']; + $processed_item['iconHTML'] = $item['_iconImg_']; + } + + $counters = array(); + if (isset($item['_agents_unknown_'])) + $counters['unknown'] = $item['_agents_unknown_']; + if (isset($item['_agents_critical_'])) + $counters['critical'] = $item['_agents_critical_']; + if (isset($item['_agents_warning_'])) + $counters['warning'] = $item['_agents_warning_']; + if (isset($item['_agents_not_init_'])) + $counters['not_init'] = $item['_agents_not_init_']; + if (isset($item['_agents_ok_'])) + $counters['ok'] = $item['_agents_ok_']; + if (isset($item['_total_agents_'])) + $counters['total'] = $item['_total_agents_']; + if (isset($item['_monitors_alerts_fired_'])) + $counters['alerts'] = $item['_monitors_alerts_fired_']; + + $children = __searchChildren($items, $item['_id_']); + if (!empty($children)) { + $processed_item['children'] = $children; + + foreach ($children as $key => $child) { + if (isset($child['counters'])) { + foreach ($child['counters'] as $type => $value) { + if (isset($counters[$type])) + $counters[$type] += $value; + } + } + } + } + + if (!empty($counters)) + $processed_item['counters'] = $counters; + + return $processed_item; + } + + if (! defined ('METACONSOLE')) { + $items = group_get_data($config['id_user'], $this->strictACL, $this->acltags, false, 'tree'); + + // Build the group hierarchy + $processed_items = array(); + foreach ($items as $key => $item) { + if (empty($item['_parent_id_'])) + $processed_items[] = __getProcessedItem($key, $items); + } + $items = $processed_items; + } + else { + //enterprise_include_once("include/functions_metaconsole.php"); + $servers = metaconsole_get_servers(); + + $item_list = array(); + foreach ($servers as $server) { + if (metaconsole_connect($server) != NOERR) + continue; + + $items = group_get_data($config['id_user'], $this->strictACL, $this->acltags, false, 'tree'); + + // Build the group hierarchy + $processed_items = array(); + foreach ($items as $key => $item) { + if (empty($item['_parent_id_'])) + $processed_items[] = __getProcessedItem($key, $items); + } + $item_list[$server['id']] = $processed_items; + + metaconsole_restore_db(); + } + + function __getMergedItems($items) { + // This variable holds the result + $mergedItems = array(); + + foreach ($items as $key => $child) { + + $childrenAux = array(); + + // Store the item in a temporary element + $resultItem = $child; + // Remove the item + unset($items[$key]); + + // The 'id' parameter will be stored as 'server_id' => 'id' + $resultItem['id'] = array(); + $resultItem['id'][$child['server_id']] = $child['id']; + + // Initialize counters if any of it don't exist + if (!isset($resultItem['counters'])) + $resultItem['counters'] = array(); + if (!isset($resultItem['counters']['unknown'])) + $resultItem['counters']['unknown'] = 0; + if (!isset($resultItem['counters']['critical'])) + $resultItem['counters']['critical'] = 0; + if (!isset($resultItem['counters']['warning'])) + $resultItem['counters']['warning'] = 0; + if (!isset($resultItem['counters']['not_init'])) + $resultItem['counters']['not_init'] = 0; + if (!isset($resultItem['counters']['ok'])) + $resultItem['counters']['ok'] = 0; + if (!isset($resultItem['counters']['total'])) + $resultItem['counters']['total'] = 0; + if (!isset($resultItem['counters']['alerts'])) + $resultItem['counters']['alerts'] = 0; + + // Iterate over the list to search items that match the actual item + foreach ($items as $key2 => $child2) { + // Skip the actual or empty items + if (!isset($key) || !isset($key2) || $key == $key2) + continue; + + // Match with the name + if ($child['name'] == $child2['name'] && $child['type'] == $child2['type']) { + // Add the matched ids + $resultItem['id'][$child2['server_id']] = $child2['id']; + + // Add the matched counters + if (isset($child2['counters']) && !child2($item['counters'])) { + foreach ($child2['counters'] as $type => $value) { + if (isset($resultItem['counters'][$type])) + $resultItem['counters'][$type] += $value; + } + } + + // Add the matched children + if (isset($child2['children'])) + $childrenAux += $child2['children']; + + // Remove the item + unset($items[$key2]); + } + } + // Get the merged children (recursion) + if (!empty($childrenAux)) + $resultItem['children'] = __getMergedItems($childrenAux); + + // Add the resulting item + $mergedItems[] = $resultItem; + } + + return $mergedItems; + } + + $items = __getMergedItems($item_list); + + html_debug_print($items, true); + } + + if (empty($items)) + $items = array(); + + $this->tree = $items; + } + // Get the group agents + else { + if (! defined ('METACONSOLE')) { + $this->tree = $this->getAgents($parent, $this->type); + } + else { + function cmpSortAgentNames($a, $b) { + return strcmp($a["name"], $b["name"]); + } + + $agents = array(); + foreach ($parent as $server_id => $group_id) { + $server = metaconsole_get_servers($server_id); + + if (!empty($server)) { + if (metaconsole_connect($server) != NOERR) + continue; + + $agents += $this->tree = $this->getAgents($group_id, $this->type); + + metaconsole_restore_db(); + } + } + if (!empty($agents)) + usort($agents, "cmpSortAgentNames"); + + $this->tree = $agents; + } + } + } + + private function getDataModules() { + // ACL Group + if (isset($this->userGroups) && $this->userGroups === false) + return array(); + + $group_acl = ""; + if (!empty($this->userGroups)) { + $user_groups_str = implode(",", array_keys($this->userGroups)); + $group_acl = " AND ta.id_grupo IN ($user_groups_str) "; + } + + // Agent name filter + $agent_search = ""; + if (!empty($this->filter['searchAgent'])) { + $agent_search = " AND ta.nombre LIKE '%".$this->filter['searchAgent']."%' "; + } + + // Module name filter + $module_search = ""; + if (!empty($this->filter['searchModule'])) { + $module_search = " AND tam.nombre LIKE '%".$this->filter['searchModule']."%' "; + } + + $sql = "SELECT tam.id_agente_modulo, tam.nombre AS module_name, + tam.id_tipo_modulo, tam.id_modulo, + ta.id_agente, ta.nombre AS agent_name, ta.fired_count, + ta.normal_count, ta.warning_count, ta.critical_count, + ta.unknown_count, ta.notinit_count, ta.total_count, + tae.estado, tae.datos + FROM tagente_modulo AS tam + INNER JOIN tagente AS ta + ON ta.id_agente = tam.id_agente + AND ta.disabled = 0 + $agent_search + $group_acl + INNER JOIN tagente_estado AS tae + ON tae.id_agente_modulo = tam.id_agente_modulo + WHERE tam.disabled = 0 + $module_search + ORDER BY tam.nombre ASC, ta.nombre ASC"; + $data = db_process_sql($sql); + + if (empty($data)) { + $data = array(); + } + + $modules = array(); + $actual_module_root = array( + 'name' => '', + 'children' => array(), + 'counters' => array() + ); + foreach ($data as $key => $value) { + $agent = array(); + $agent['id_agente'] = (int) $value['id_agente']; + $agent['nombre'] = $value['agent_name']; + + $agent['counters'] = array(); + $agent['counters']['total'] = (int) $value['total_count']; + $agent['counters']['alerts'] = (int) $value['fired_count_count']; + $agent['counters']['critical'] = (int) $value['critical_count']; + $agent['counters']['warning'] = (int) $value['warning_count']; + $agent['counters']['unknown'] = (int) $value['unknown_count']; + $agent['counters']['not_init'] = (int) $value['notinit_count']; + $agent['counters']['ok'] = (int) $value['normal_count']; + + $this->processAgent($agent, array(), false); + + $module = array(); + $module['id_agente_modulo'] = (int) $value['id_agente_modulo']; + $module['nombre'] = $value['module_name']; + $module['id_tipo_modulo'] = (int) $value['id_tipo_modulo']; + $module['server_type'] = (int) $value['id_modulo']; + $module['status'] = (int) $value['estado']; + $module['value'] = $value['data']; + + $this->processModule($module); + + $agent['children'] = array($module); + + if ($actual_module_root['name'] == $module['name']) { + $actual_module_root['children'][] = $agent; + + // Increase counters + $actual_module_root['counters']['total']++; + + if (isset($actual_module_root['counters'][$agent['status']])) + $actual_module_root['counters'][$agent['status']]++; + } + else { + if (!empty($actual_module_root['name'])) + $modules[] = $actual_module_root; + + $actual_module_root = array(); + $actual_module_root['name'] = $module['name']; + $actual_module_root['children'] = array($agent); + + // Initialize counters + $actual_module_root['counters'] = array(); + $actual_module_root['counters']['total'] = 0; + $actual_module_root['counters']['alerts'] = 0; + $actual_module_root['counters']['critical'] = 0; + $actual_module_root['counters']['warning'] = 0; + $actual_module_root['counters']['unknown'] = 0; + $actual_module_root['counters']['not_init'] = 0; + $actual_module_root['counters']['ok'] = 0; + + // Increase counters + $actual_module_root['counters']['total']++; + + if (isset($actual_module_root['counters'][$agent['status']])) + $actual_module_root['counters'][$agent['status']]++; + } + } + if (!empty($actual_module_root['name'])) { + $modules[] = $actual_module_root; + } + + $this->tree = $modules; + } + + private function getDataModuleGroup() { + // ACL Group + if (isset($this->userGroups) && $this->userGroups === false) + return array(); + + $group_acl = ""; + if (!empty($this->userGroups)) { + $user_groups_str = implode(",", array_keys($this->userGroups)); + $group_acl = " AND ta.id_grupo IN ($user_groups_str) "; + } + + // Agent name filter + $agent_search = ""; + if (!empty($this->filter['searchAgent'])) { + $agent_search = " AND ta.nombre LIKE '%".$this->filter['searchAgent']."%' "; + } + + // Module name filter + $module_search = ""; + if (!empty($this->filter['searchModule'])) { + $module_search = " AND tam.nombre LIKE '%".$this->filter['searchModule']."%' "; + } + + $sql = "SELECT tam.id_agente_modulo, tam.nombre AS module_name, + tam.id_tipo_modulo, tam.id_modulo, + ta.id_agente, ta.nombre AS agent_name, ta.fired_count, + ta.normal_count, ta.warning_count, ta.critical_count, + ta.unknown_count, ta.notinit_count, ta.total_count, + tmg.id_mg, tmg.name AS module_group_name, + tae.estado, tae.datos + FROM tagente_modulo AS tam + INNER JOIN tagente AS ta + ON ta.id_agente = tam.id_agente + AND ta.disabled = 0 + $agent_search + $group_acl + INNER JOIN tagente_estado AS tae + ON tae.id_agente_modulo = tam.id_agente_modulo + LEFT JOIN tmodule_group AS tmg + ON tmg.id_mg = tam.id_module_group + WHERE tam.disabled = 0 + $module_search + ORDER BY tmg.name ASC, tmg.id_mg ASC, ta.nombre ASC, tam.nombre ASC"; + $data = db_process_sql($sql); + + if (empty($data)) { + $data = array(); + } + + $nodes = array(); + $actual_module_group_root = array( + 'id' => -1, + 'name' => '', + 'children' => array(), + 'counters' => array() + ); + $actual_agent = array(); + foreach ($data as $key => $value) { + + // Module + $module = array(); + $module['id_agente_modulo'] = (int) $value['id_agente_modulo']; + $module['nombre'] = $value['module_name']; + $module['id_tipo_modulo'] = (int) $value['id_tipo_modulo']; + $module['id_module_group'] = (int) $value['id_mg']; + $module['server_type'] = (int) $value['id_modulo']; + $module['status'] = (int) $value['estado']; + $module['value'] = $value['data']; + + $this->processModule($module); + + // Module group + if ($actual_module_group_root['id'] === $module['id_module_group']) { + // Agent + if (empty($actual_agent) || $actual_agent['id'] !== (int)$value['id_agente']) { + // Add the last agent to the agent module + if (!empty($actual_agent)) + $actual_module_group_root['children'][] = $actual_agent; + + // Create the new agent + $actual_agent = array(); + $actual_agent['id_agente'] = (int) $value['id_agente']; + $actual_agent['nombre'] = $value['agent_name']; + $actual_agent['children'] = array(); + + $actual_agent['counters'] = array(); + $actual_agent['counters']['total'] = (int) $value['total_count']; + $actual_agent['counters']['alerts'] = (int) $value['fired_count_count']; + $actual_agent['counters']['critical'] = (int) $value['critical_count']; + $actual_agent['counters']['warning'] = (int) $value['warning_count']; + $actual_agent['counters']['unknown'] = (int) $value['unknown_count']; + $actual_agent['counters']['not_init'] = (int) $value['notinit_count']; + $actual_agent['counters']['ok'] = (int) $value['normal_count']; + + $this->processAgent($actual_agent, array(), false); + + // Add the module to the agent + $actual_agent['children'][] = $module; + + // Increase counters + $actual_module_group_root['counters']['total']++; + + if (isset($actual_module_group_root['counters'][$actual_agent['status']])) + $actual_module_group_root['counters'][$actual_agent['status']]++; + } + else { + $actual_agent['children'][] = $module; + } + } + else { + // The first iteration doesn't enter here + if ($actual_module_group_root['id'] !== -1) { + // Add the agent to the module group + $actual_module_group_root['children'][] = $actual_agent; + // Add the module group to the branch + $nodes[] = $actual_module_group_root; + } + + // Create the new agent + $actual_agent = array(); + $actual_agent['id_agente'] = (int) $value['id_agente']; + $actual_agent['nombre'] = $value['agent_name']; + $actual_agent['children'] = array(); + + $actual_agent['counters'] = array(); + $actual_agent['counters']['total'] = (int) $value['total_count']; + $actual_agent['counters']['alerts'] = (int) $value['fired_count_count']; + $actual_agent['counters']['critical'] = (int) $value['critical_count']; + $actual_agent['counters']['warning'] = (int) $value['warning_count']; + $actual_agent['counters']['unknown'] = (int) $value['unknown_count']; + $actual_agent['counters']['not_init'] = (int) $value['notinit_count']; + $actual_agent['counters']['ok'] = (int) $value['normal_count']; + + $this->processAgent($actual_agent, array(), false); + + // Add the module to the agent + $actual_agent['children'][] = $module; + + // Create new module group + $actual_module_group_root = array(); + $actual_module_group_root['id'] = $module['id_module_group']; + $actual_module_group_root['type'] = $this->type; + + if (!empty($value['module_group_name'])) { + $actual_module_group_root['name'] = $value['module_group_name']; + } + else { + $actual_module_group_root['name'] = __('Not assigned'); + } + + // Initialize counters + $actual_module_group_root['counters'] = array(); + $actual_module_group_root['counters']['total'] = 0; + $actual_module_group_root['counters']['alerts'] = 0; + $actual_module_group_root['counters']['critical'] = 0; + $actual_module_group_root['counters']['warning'] = 0; + $actual_module_group_root['counters']['unknown'] = 0; + $actual_module_group_root['counters']['not_init'] = 0; + $actual_module_group_root['counters']['ok'] = 0; + + // Increase counters + $actual_module_group_root['counters']['total']++; + + if (isset($actual_module_group_root['counters'][$actual_agent['status']])) + $actual_module_group_root['counters'][$actual_agent['status']]++; + } + } + // If there is an agent and a module group opened and not saved + if ($actual_module_group_root['id'] !== -1) { + // Add the last agent to the module group + $actual_module_group_root['children'][] = $actual_agent; + // Add the last module group to the branch + $nodes[] = $actual_module_group_root; + } + + $this->tree = $nodes; + } + + private function getDataOS() { + // ACL Group + if (isset($this->userGroups) && $this->userGroups === false) + return array(); + + $group_acl = ""; + if (!empty($this->userGroups)) { + $user_groups_str = implode(",", array_keys($this->userGroups)); + $group_acl = " AND ta.id_grupo IN ($user_groups_str) "; + } + + // Agent name filter + $agent_search = ""; + if (!empty($this->filter['searchAgent'])) { + $agent_search = " AND ta.nombre LIKE '%".$this->filter['searchAgent']."%' "; + } + + // Module name filter + $module_search = ""; + if (!empty($this->filter['searchModule'])) { + $module_search = " AND tam.nombre LIKE '%".$this->filter['searchModule']."%' "; + } + + $sql = "SELECT tam.id_agente_modulo, tam.nombre AS module_name, + tam.id_tipo_modulo, tam.id_modulo, + ta.id_agente, ta.nombre AS agent_name, ta.fired_count, + ta.normal_count, ta.warning_count, ta.critical_count, + ta.unknown_count, ta.notinit_count, ta.total_count, + tos.id_os, tos.name AS os_name, tos.icon_name AS os_icon, + tae.estado, tae.datos + FROM tagente_modulo AS tam + INNER JOIN tagente AS ta + ON ta.id_agente = tam.id_agente + AND ta.disabled = 0 + $agent_search + $group_acl + INNER JOIN tagente_estado AS tae + ON tae.id_agente_modulo = tam.id_agente_modulo + LEFT JOIN tconfig_os AS tos + ON tos.id_os = ta.id_os + WHERE tam.disabled = 0 + $module_search + ORDER BY tos.icon_name ASC, tos.id_os ASC, ta.nombre ASC, tam.nombre"; + $data = db_process_sql($sql); + + if (empty($data)) { + $data = array(); + } + + $nodes = array(); + $actual_os_root = array( + 'id' => -1, + 'name' => '', + 'icon' => '', + 'children' => array(), + 'counters' => array() + ); + $actual_agent = array(); + foreach ($data as $key => $value) { + + // Module + $module = array(); + $module['id_agente_modulo'] = (int) $value['id_agente_modulo']; + $module['nombre'] = $value['module_name']; + $module['id_tipo_modulo'] = (int) $value['id_tipo_modulo']; + $module['server_type'] = (int) $value['id_modulo']; + $module['status'] = (int) $value['estado']; + $module['value'] = $value['datos']; + + $this->processModule($module); + + // OS item + if ($actual_os_root['id'] === (int)$value['id_os']) { + // Agent + if (empty($actual_agent) || $actual_agent['id'] !== (int)$value['id_agente']) { + // Add the last agent to the os item + if (!empty($actual_agent)) + $actual_os_root['children'][] = $actual_agent; + + // Create the new agent + $actual_agent = array(); + $actual_agent['id_agente'] = (int) $value['id_agente']; + $actual_agent['nombre'] = $value['agent_name']; + $actual_agent['children'] = array(); + + $actual_agent['counters'] = array(); + $actual_agent['counters']['total'] = (int) $value['total_count']; + $actual_agent['counters']['alerts'] = (int) $value['fired_count_count']; + $actual_agent['counters']['critical'] = (int) $value['critical_count']; + $actual_agent['counters']['warning'] = (int) $value['warning_count']; + $actual_agent['counters']['unknown'] = (int) $value['unknown_count']; + $actual_agent['counters']['not_init'] = (int) $value['notinit_count']; + $actual_agent['counters']['ok'] = (int) $value['normal_count']; + + $this->processAgent($actual_agent, array(), false); + + // Add the module to the agent + $actual_agent['children'][] = $module; + + // Increase counters + $actual_os_root['counters']['total']++; + + if (isset($actual_os_root['counters'][$actual_agent['status']])) + $actual_os_root['counters'][$actual_agent['status']]++; + } + else { + // Add the module to the agent + $actual_agent['children'][] = $module; + } + } + else { + // The first iteration doesn't enter here + if ($actual_os_root['id'] !== -1) { + // Add the agent to the os item + $actual_os_root['children'][] = $actual_agent; + // Add the os the branch + $nodes[] = $actual_os_root; + } + + // Create new os item + $actual_os_root = array(); + $actual_os_root['id'] = (int) $value['id_os']; + $actual_os_root['type'] = $this->type; + + if (!empty($actual_os_root['id'])) { + $actual_os_root['name'] = $value['os_name']; + $actual_os_root['icon'] = $value['os_icon']; + } + else { + $actual_os_root['name'] = __('None'); + $actual_os_root['icon'] = 'so_other.png'; + } + + // Create the new agent + $actual_agent = array(); + $actual_agent['id_agente'] = (int) $value['id_agente']; + $actual_agent['nombre'] = $value['agent_name']; + $actual_agent['children'] = array(); + + $actual_agent['counters'] = array(); + $actual_agent['counters']['total'] = (int) $value['total_count']; + $actual_agent['counters']['alerts'] = (int) $value['fired_count_count']; + $actual_agent['counters']['critical'] = (int) $value['critical_count']; + $actual_agent['counters']['warning'] = (int) $value['warning_count']; + $actual_agent['counters']['unknown'] = (int) $value['unknown_count']; + $actual_agent['counters']['not_init'] = (int) $value['notinit_count']; + $actual_agent['counters']['ok'] = (int) $value['normal_count']; + + $this->processAgent($actual_agent, array(), false); + + // Add the module to the agent + $actual_agent['children'][] = $module; + + // Initialize counters + $actual_os_root['counters'] = array(); + $actual_os_root['counters']['total'] = 0; + $actual_os_root['counters']['alerts'] = 0; + $actual_os_root['counters']['critical'] = 0; + $actual_os_root['counters']['warning'] = 0; + $actual_os_root['counters']['unknown'] = 0; + $actual_os_root['counters']['not_init'] = 0; + $actual_os_root['counters']['ok'] = 0; + + // Increase counters + $actual_os_root['counters']['total']++; + + if (isset($actual_os_root['counters'][$actual_agent['status']])) + $actual_os_root['counters'][$actual_agent['status']]++; + } + } + // If there is an agent and an os item opened and not saved + if ($actual_os_root['id'] !== -1) { + // Add the last agent to the os item + $actual_os_root['children'][] = $actual_agent; + // Add the last os to the branch + $nodes[] = $actual_os_root; + } + + $this->tree = $nodes; + } + + private function getDataTag() { + + // Get the parent + if (empty($this->root)) + $parent = 0; + else + $parent = $this->root; + + // Get all groups + if (empty($parent)) { + // ACL Group + if (isset($this->userGroups) && $this->userGroups === false) + return array(); + + $group_acl = ""; + if (!empty($this->userGroups)) { + $user_groups_str = implode(",", array_keys($this->userGroups)); + $group_acl = " AND ta.id_grupo IN ($user_groups_str) "; + } + + // Agent name filter + $agent_search = ""; + if (!empty($this->filter['searchAgent'])) { + $agent_search = " AND ta.nombre LIKE '%".$this->filter['searchAgent']."%' "; + } + + // Module name filter + $module_search = ""; + if (!empty($this->filter['searchModule'])) { + $module_search = " AND tam.nombre LIKE '%".$this->filter['searchModule']."%' "; + } + + $sql = "SELECT tam.id_agente_modulo, tam.nombre AS module_name, + tam.id_tipo_modulo, tam.id_modulo, + ta.id_agente, ta.nombre AS agent_name, ta.fired_count, + ta.normal_count, ta.warning_count, ta.critical_count, + ta.unknown_count, ta.notinit_count, ta.total_count, + tt.id_tag, tt.name AS tag_name, + tae.estado, tae.estado + FROM tagente_modulo AS tam + INNER JOIN tagente AS ta + ON ta.id_agente = tam.id_agente + AND ta.disabled = 0 + INNER JOIN tagente_estado AS tae + ON tae.id_agente_modulo = tam.id_agente_modulo + INNER JOIN ttag_module AS ttm + ON ttm.id_agente_modulo = tam.id_agente_modulo + INNER JOIN ttag AS tt + ON tt.id_tag = ttm.id_tag + WHERE tam.disabled = 0 + $agent_search + $module_search + $group_acl + ORDER BY tt.name ASC, tt.id_tag ASC, ta.nombre ASC, tam.nombre ASC"; + $data = db_process_sql($sql); + + if (empty($data)) { + $data = array(); + } + + $nodes = array(); + $actual_tag_root = array( + 'id' => null, + 'name' => '', + 'children' => array(), + 'counters' => array() + ); + $actual_agent = array(); + foreach ($data as $key => $value) { + + // Module + $module = array(); + $module['id_agente_modulo'] = (int) $value['id_agente_modulo']; + $module['nombre'] = $value['module_name']; + $module['id_tipo_modulo'] = (int) $value['id_tipo_modulo']; + $module['server_type'] = (int) $value['id_modulo']; + $module['status'] = (int) $value['estado']; + $module['value'] = $value['datos']; + + $this->processModule($module); + + // Tag + if ($actual_tag_root['id'] === (int)$value['id_tag']) { + // Agent + if (empty($actual_agent) || $actual_agent['id'] !== (int)$value['id_agente']) { + // Add the last agent to the tag + if (!empty($actual_agent)) + $actual_tag_root['children'][] = $actual_agent; + + // Create the new agent + $actual_agent = array(); + $actual_agent['id_agente'] = (int) $value['id_agente']; + $actual_agent['nombre'] = $value['agent_name']; + $actual_agent['children'] = array(); + + $this->processAgent($actual_agent, array(), false); + + // Add the module to the agent + $actual_agent['children'][] = $module; + + // Increase counters + $actual_tag_root['counters']['total']++; + + if (isset($actual_tag_root['counters'][$actual_agent['status']])) + $actual_tag_root['counters'][$actual_agent['status']]++; + } + else { + $actual_agent['children'][] = $module; + } + } + else { + // The first iteration doesn't enter here + if ($actual_tag_root['id'] !== null) { + // Add the agent to the tag + $actual_tag_root['children'][] = $actual_agent; + // Add the tag to the branch + $nodes[] = $actual_tag_root; + } + + // Create the new agent + $actual_agent = array(); + $actual_agent['id_agente'] = (int) $value['id_agente']; + $actual_agent['nombre'] = $value['agent_name']; + $actual_agent['children'] = array(); + + $this->processAgent($actual_agent, array(), false); + + // Add the module to the agent + $actual_agent['children'][] = $module; + + // Create new tag + $actual_tag_root = array(); + $actual_tag_root['id'] = (int) $value['id_tag']; + $actual_tag_root['name'] = $value['tag_name']; + $actual_tag_root['type'] = $this->type; + + // Initialize counters + $actual_tag_root['counters'] = array(); + $actual_tag_root['counters']['total'] = 0; + $actual_tag_root['counters']['alerts'] = 0; + $actual_tag_root['counters']['critical'] = 0; + $actual_tag_root['counters']['warning'] = 0; + $actual_tag_root['counters']['unknown'] = 0; + $actual_tag_root['counters']['not_init'] = 0; + $actual_tag_root['counters']['ok'] = 0; + + // Increase counters + $actual_tag_root['counters']['total']++; + + if (isset($actual_tag_root['counters'][$actual_agent['status']])) + $actual_tag_root['counters'][$actual_agent['status']]++; + } + } + // If there is an agent and a tag opened and not saved + if ($actual_tag_root['id'] !== null) { + // Add the last agent to the tag + $actual_tag_root['children'][] = $actual_agent; + // Add the last tag to the branch + $nodes[] = $actual_tag_root; + } + + $this->tree = $nodes; + } + else { + if (! defined ('METACONSOLE')) { + $this->tree = $this->getAgents($parent, $this->type); + } + else { + function cmpSortAgentNames($a, $b) { + return strcmp($a["name"], $b["name"]); + } + + $agents = array(); + foreach ($parent as $server_id => $tag_id) { + $server = metaconsole_get_servers($server_id); + + if (!empty($server)) { + if (metaconsole_connect($server) != NOERR) + continue; + + $agents += $this->tree = $this->getAgents($tag_id, $this->type); + + metaconsole_restore_db(); + } + } + if (!empty($agents)) + usort($agents, "cmpSortAgentNames"); + + $this->tree = $agents; + } + } + } + + public function getJSON() { + $this->getData(); + + return json_encode($this->tree); + } + + public function getArray() { + $this->getData(); + + return $this->tree; + } +} +?> diff --git a/pandora_console/include/constants.php b/pandora_console/include/constants.php old mode 100644 new mode 100755 index 3be630f662..d6ad8bca8f --- a/pandora_console/include/constants.php +++ b/pandora_console/include/constants.php @@ -19,25 +19,25 @@ */ /* Enterprise hook constant */ -define ('ENTERPRISE_NOT_HOOK', -1); +define ('ENTERPRISE_NOT_HOOK', -1); /**/ -define('DATE_FORMAT', 'Y/m/d'); -define('DATE_FORMAT_JS', 'yy/mm/d'); -define('TIME_FORMAT', 'H:i:s'); -define('TIME_FORMAT_JS', 'HH:mm:ss'); +define('DATE_FORMAT', 'Y/m/d'); +define('DATE_FORMAT_JS', 'yy/mm/d'); +define('TIME_FORMAT', 'H:i:s'); +define('TIME_FORMAT_JS', 'HH:mm:ss'); /* Events state constants */ -define ('EVENT_NEW', 0); -define ('EVENT_VALIDATE', 1); -define ('EVENT_PROCESS', 2); +define ('EVENT_NEW', 0); +define ('EVENT_VALIDATE', 1); +define ('EVENT_PROCESS', 2); /* Agents disabled status */ -define ('AGENT_ENABLED',0); -define ('AGENT_DISABLED',1); +define ('AGENT_ENABLED', 0); +define ('AGENT_DISABLED', 1); @@ -97,10 +97,10 @@ define('SECONDS_3YEARS', 93312000); /* Separator constats */ -define('SEPARATOR_COLUMN', ';'); -define('SEPARATOR_ROW', chr(10)); //chr(10) = '\n' -define('SEPARATOR_COLUMN_CSV', "#"); -define('SEPARATOR_ROW_CSV', "@\n"); +define('SEPARATOR_COLUMN', ';'); +define('SEPARATOR_ROW', chr(10)); //chr(10) = '\n' +define('SEPARATOR_COLUMN_CSV', "#"); +define('SEPARATOR_ROW_CSV', "@\n"); @@ -108,72 +108,72 @@ define('SEPARATOR_ROW_CSV', "@\n"); switch ($config["dbtype"]) { case "mysql": case "postgresql": - define ('BACKUP_DIR', 'attachment/backups'); - define ('BACKUP_FULLPATH', $config['homedir'] . '/' . BACKUP_DIR); + define ('BACKUP_DIR', 'attachment/backups'); + define ('BACKUP_FULLPATH', $config['homedir'] . '/' . BACKUP_DIR); break; case "oracle": - define ('BACKUP_DIR', 'DATA_PUMP_DIR'); - define ('BACKUP_FULLPATH', 'DATA_PUMP_DIR'); + define ('BACKUP_DIR', 'DATA_PUMP_DIR'); + define ('BACKUP_FULLPATH', 'DATA_PUMP_DIR'); break; } /* Color constants */ -define('COL_CRITICAL','#f85858'); -define('COL_WARNING','#ffea59'); -define('COL_WARNING_DARK','#FFB900'); -define('COL_NORMAL','#6EB432'); -define('COL_NOTINIT','#3BA0FF'); -define('COL_UNKNOWN','#AAAAAA'); -define('COL_ALERTFIRED','#FF8800'); -define('COL_MINOR','#F099A2'); -define('COL_MAJOR','#C97A4A'); -define('COL_INFORMATIONAL','#E4E4E4'); -define('COL_MAINTENANCE','#3BA0FF'); +define('COL_CRITICAL', '#f85858'); +define('COL_WARNING', '#ffea59'); +define('COL_WARNING_DARK', '#FFB900'); +define('COL_NORMAL', '#6EB432'); +define('COL_NOTINIT', '#3BA0FF'); +define('COL_UNKNOWN', '#AAAAAA'); +define('COL_ALERTFIRED', '#FF8800'); +define('COL_MINOR', '#F099A2'); +define('COL_MAJOR', '#C97A4A'); +define('COL_INFORMATIONAL', '#E4E4E4'); +define('COL_MAINTENANCE', '#3BA0FF'); -define('COL_GRAPH1', '#C397F2'); -define('COL_GRAPH2', '#FFE66C'); -define('COL_GRAPH3', '#92CCA3'); -define('COL_GRAPH4', '#EA6D5B'); -define('COL_GRAPH5', '#6BD8DD'); -define('COL_GRAPH6', '#F49B31'); -define('COL_GRAPH7', '#999999'); -define('COL_GRAPH8', '#F2B8C1'); -define('COL_GRAPH9', '#C4E8C1'); -define('COL_GRAPH10', '#C1DBE5'); -define('COL_GRAPH11', '#C9C1e0'); -define('COL_GRAPH12', '#F45B95'); -define('COL_GRAPH13', '#E83128'); +define('COL_GRAPH1', '#C397F2'); +define('COL_GRAPH2', '#FFE66C'); +define('COL_GRAPH3', '#92CCA3'); +define('COL_GRAPH4', '#EA6D5B'); +define('COL_GRAPH5', '#6BD8DD'); +define('COL_GRAPH6', '#F49B31'); +define('COL_GRAPH7', '#999999'); +define('COL_GRAPH8', '#F2B8C1'); +define('COL_GRAPH9', '#C4E8C1'); +define('COL_GRAPH10', '#C1DBE5'); +define('COL_GRAPH11', '#C9C1e0'); +define('COL_GRAPH12', '#F45B95'); +define('COL_GRAPH13', '#E83128'); /* The styles */ /* Size of text in characters for truncate */ -define('GENERIC_SIZE_TEXT', 25); +define('GENERIC_SIZE_TEXT', 25); /* Agent module status */ -define('AGENT_MODULE_STATUS_CRITICAL_BAD', 1); -define('AGENT_MODULE_STATUS_CRITICAL_ALERT', 100); -define('AGENT_MODULE_STATUS_NO_DATA', 4); -define('AGENT_MODULE_STATUS_NORMAL', 0); -define('AGENT_MODULE_STATUS_NORMAL_ALERT', 300); -define('AGENT_MODULE_STATUS_NOT_NORMAL', 6); -define('AGENT_MODULE_STATUS_WARNING', 2); -define('AGENT_MODULE_STATUS_WARNING_ALERT', 200); -define('AGENT_MODULE_STATUS_UNKNOWN', 3); -define('AGENT_MODULE_STATUS_NOT_INIT', 5); +define('AGENT_MODULE_STATUS_CRITICAL_BAD', 1); +define('AGENT_MODULE_STATUS_CRITICAL_ALERT', 100); +define('AGENT_MODULE_STATUS_NO_DATA', 4); +define('AGENT_MODULE_STATUS_NORMAL', 0); +define('AGENT_MODULE_STATUS_NORMAL_ALERT', 300); +define('AGENT_MODULE_STATUS_NOT_NORMAL', 6); +define('AGENT_MODULE_STATUS_WARNING', 2); +define('AGENT_MODULE_STATUS_WARNING_ALERT', 200); +define('AGENT_MODULE_STATUS_UNKNOWN', 3); +define('AGENT_MODULE_STATUS_NOT_INIT', 5); /* Agent status */ -define('AGENT_STATUS_ALL', -1); -define('AGENT_STATUS_CRITICAL', 1); -define('AGENT_STATUS_NORMAL', 0); -define('AGENT_STATUS_NOT_INIT', 5); -define('AGENT_STATUS_NOT_NORMAL', 6); -define('AGENT_STATUS_UNKNOWN', 3); -define('AGENT_STATUS_ALERT_FIRED', 4); -define('AGENT_STATUS_WARNING', 2); +define('AGENT_STATUS_ALL', -1); +define('AGENT_STATUS_CRITICAL', 1); +define('AGENT_STATUS_NORMAL', 0); +define('AGENT_STATUS_NOT_INIT', 5); +define('AGENT_STATUS_NOT_NORMAL', 6); +define('AGENT_STATUS_UNKNOWN', 3); +define('AGENT_STATUS_ALERT_FIRED', 4); +define('AGENT_STATUS_WARNING', 2); /* Visual maps contants */ @@ -260,6 +260,31 @@ define ('STATUS_SERVER_OK', 'server_ok.png'); define ('STATUS_SERVER_DOWN', 'server_down.png'); +/* Status images (ball) */ +//For modules +define ('STATUS_MODULE_OK_BALL', 'module_ok_ball.png'); +define ('STATUS_MODULE_CRITICAL_BALL', 'module_critical_ball.png'); +define ('STATUS_MODULE_WARNING_BALL', 'module_warning_ball.png'); +define ('STATUS_MODULE_NO_DATA_BALL', 'module_no_data_ball.png'); +define ('STATUS_MODULE_UNKNOWN_BALL', 'module_unknown_ball.png'); +//For agents +define ('STATUS_AGENT_CRITICAL_BALL', 'agent_critical_ball.png'); +define ('STATUS_AGENT_WARNING_BALL', 'agent_warning_ball.png'); +define ('STATUS_AGENT_DOWN_BALL', 'agent_down_ball.png'); +define ('STATUS_AGENT_UNKNOWN_BALL', 'agent_unknown_ball.png'); +define ('STATUS_AGENT_OK_BALL', 'agent_ok_ball.png'); +define ('STATUS_AGENT_NO_DATA_BALL', 'agent_no_data_ball.png'); +define ('STATUS_AGENT_NO_MONITORS_BALL', 'agent_no_monitors_ball.png'); +define ('STATUS_AGENT_NOT_INIT_BALL', 'agent_notinit_ball.png'); +//For alerts +define ('STATUS_ALERT_FIRED_BALL', 'alert_fired_ball.png'); +define ('STATUS_ALERT_NOT_FIRED_BALL', 'alert_not_fired_ball.png'); +define ('STATUS_ALERT_DISABLED_BALL', 'alert_disabled_ball.png'); +//For servers +define ('STATUS_SERVER_OK_BALL', 'server_ok_ball.png'); +define ('STATUS_SERVER_DOWN_BALL', 'server_down_ball.png'); + + /* Events criticity */ define ('EVENT_CRIT_MAINTENANCE', 0); diff --git a/pandora_console/include/functions_agents.php b/pandora_console/include/functions_agents.php index 144cf08a2a..22e1da590d 100644 --- a/pandora_console/include/functions_agents.php +++ b/pandora_console/include/functions_agents.php @@ -370,7 +370,8 @@ function agents_get_agents ($filter = false, $fields = false, $access = 'AR', $o $where = db_format_array_where_clause_sql ($filter, 'AND', ''); - $where_nogroup = db_format_array_where_clause_sql ($filter_nogroup, 'AND', ''); + $where_nogroup = db_format_array_where_clause_sql( + $filter_nogroup, 'AND', ''); if ($where_nogroup == '') { $where_nogroup = '1 = 1'; @@ -1861,7 +1862,7 @@ function agents_get_agent_group ($id_agent) { * @return mixed The incidents attached or false */ function agents_get_count_incidents ($id_agent) { - if (empty($id_agent)){ + if (empty($id_agent)) { return false; } @@ -2023,6 +2024,18 @@ function agents_tree_view_alert_img ($alert_fired) { } } +//Returns the alert ball image to display tree view + +function agents_tree_view_alert_img_ball ($alert_fired) { + + if ($alert_fired) { + return ui_print_status_image (STATUS_ALERT_FIRED_BALL, __('Alert fired'), true); + } + else { + return ui_print_status_image (STATUS_ALERT_NOT_FIRED_BALL, __('Alert not fired'), true); + } +} + //Returns the status image to display tree view function agents_tree_view_status_img ($critical, $warning, $unknown, $total, $notinit) { @@ -2043,7 +2056,33 @@ function agents_tree_view_status_img ($critical, $warning, $unknown, $total, $no __('At least one module is in UKNOWN status'), true); } else { - return ui_print_status_image (STATUS_AGENT_OK, __('All Monitors OK'), true); + return ui_print_status_image (STATUS_AGENT_OK, + __('All Monitors OK'), true); + } +} + +//Returns the status ball image to display tree view + +function agents_tree_view_status_img_ball ($critical, $warning, $unknown, $total, $notinit) { + if ($total == 0 || $total == $notinit) { + return ui_print_status_image (STATUS_AGENT_NO_MONITORS_BALL, + __('No Monitors'), true); + } + if ($critical > 0) { + return ui_print_status_image (STATUS_AGENT_CRITICAL_BALL, + __('At least one module in CRITICAL status'), true); + } + else if ($warning > 0) { + return ui_print_status_image (STATUS_AGENT_WARNING_BALL, + __('At least one module in WARNING status'), true); + } + else if ($unknown > 0) { + return ui_print_status_image (STATUS_AGENT_DOWN_BALL, + __('At least one module is in UKNOWN status'), true); + } + else { + return ui_print_status_image (STATUS_AGENT_OK_BALL, + __('All Monitors OK'), true); } } diff --git a/pandora_console/include/functions_groups.php b/pandora_console/include/functions_groups.php index f20fc25e3a..b49c293957 100644 --- a/pandora_console/include/functions_groups.php +++ b/pandora_console/include/functions_groups.php @@ -278,8 +278,12 @@ function groups_get_parents($parent, $onlyPropagate = false, $groups = null) { continue; } - if (($group['id_grupo'] == $parent) && ($group['propagate'] || !$onlyPropagate)) { - $return = $return + array($group['id_grupo'] => $group) + groups_get_parents($group['parent'], $onlyPropagate, $groups); + if (($group['id_grupo'] == $parent) + && ($group['propagate'] || !$onlyPropagate)) { + + $return = $return + + array($group['id_grupo'] => $group) + + groups_get_parents($group['parent'], $onlyPropagate, $groups); } } @@ -402,7 +406,10 @@ function groups_get_all($groupWithAgents = false) { global $config; if ($groupWithAgents) - $sql .= ' WHERE id_grupo IN (SELECT id_grupo FROM tagente GROUP BY id_grupo)'; + $sql .= ' WHERE id_grupo IN ( + SELECT id_grupo + FROM tagente + GROUP BY id_grupo)'; switch ($config['dbtype']) { case "mysql": @@ -1828,9 +1835,10 @@ function group_get_data ($id_user = false, $user_strict = false, $acltags, $retu if ($id_user == false) { $id_user = $config['id_user']; } - + $user_groups = array(); $user_tags = array(); + $groups_without_tags = array(); foreach ($acltags as $group => $tags) { if ($user_strict) { //Remove groups with tags if ($tags == '') { @@ -1852,34 +1860,31 @@ function group_get_data ($id_user = false, $user_strict = false, $acltags, $retu } else { $user_groups_ids = implode(',',array_keys($acltags)); } - - if ($user_groups_ids == '') { - $user_groups_ids == -1; - } - switch ($config["dbtype"]) { - case "mysql": - $list_groups = db_get_all_rows_sql(" - SELECT * - FROM tgrupo - WHERE id_grupo IN (" . $user_groups_ids . ") - ORDER BY nombre COLLATE utf8_general_ci ASC"); - - break; - case "postgresql": - $list_groups = db_get_all_rows_sql(" - SELECT * - FROM tgrupo - WHERE id_grupo IN (" . $user_groups_ids . ") - ORDER BY nombre ASC"); - break; - case "oracle": - $list_groups = db_get_all_rows_sql(" - SELECT * - FROM tgrupo - WHERE id_grupo IN (" . $user_groups_ids . ") - ORDER BY nombre COLLATE utf8_general_ci ASC"); - break; + if (!empty($user_groups_ids)) { + switch ($config["dbtype"]) { + case "mysql": + $list_groups = db_get_all_rows_sql(" + SELECT * + FROM tgrupo + WHERE id_grupo IN (" . $user_groups_ids . ") + ORDER BY nombre COLLATE utf8_general_ci ASC"); + break; + case "postgresql": + $list_groups = db_get_all_rows_sql(" + SELECT * + FROM tgrupo + WHERE id_grupo IN (" . $user_groups_ids . ") + ORDER BY nombre ASC"); + break; + case "oracle": + $list_groups = db_get_all_rows_sql(" + SELECT * + FROM tgrupo + WHERE id_grupo IN (" . $user_groups_ids . ") + ORDER BY nombre COLLATE utf8_general_ci ASC"); + break; + } } if ($list_groups == false) { @@ -1924,6 +1929,9 @@ function group_get_data ($id_user = false, $user_strict = false, $acltags, $retu $list[$i]['_name_'] = $item['nombre']; $list[$i]['_iconImg_'] = html_print_image ("images/groups_small/" . groups_get_icon($item['id_grupo']).".png", true, array ("style" => 'vertical-align: middle;')); + if ($mode == 'tree' && !empty($item['parent'])) + $list[$i]['_parent_id_'] = $item['parent']; + $list[$i]['_agents_unknown_'] = $group_stat[0]["unknown"]; $list[$i]['_monitors_alerts_fired_'] = $group_stat[0]["alerts_fired"]; $list[$i]['_total_agents_'] = $group_stat[0]["agents"]; @@ -1936,7 +1944,7 @@ function group_get_data ($id_user = false, $user_strict = false, $acltags, $retu $list[$i]['_monitors_not_init_'] = groups_monitor_not_init($id, $user_strict, $id); $list[$i]['_agents_not_init_'] = groups_agent_not_init ($id, $user_strict, $id); - if ($mode == 'tactical') { + if ($mode == 'tactical' || $mode == 'tree') { $list[$i]['_agents_ok_'] = $group_stat[0]["normal"]; $list[$i]['_agents_warning_'] = $group_stat[0]["warning"]; $list[$i]['_agents_critical_'] = $group_stat[0]["critical"]; @@ -1945,7 +1953,8 @@ function group_get_data ($id_user = false, $user_strict = false, $acltags, $retu $list[$i]["_monitor_alerts_fire_count_"] = $group_stat[0]["alerts_fired"]; $list[$i]["_total_checks_"] = $group_stat[0]["modules"]; $list[$i]["_total_alerts_"] = $group_stat[0]["alerts"]; - + } + if ($mode == 'tactical') { // Get total count of monitors for this group, except disabled. $list[$i]["_monitor_checks_"] = $list[$i]["_monitors_not_init_"] + $list[$i]["_monitors_unknown_"] + $list[$i]["_monitors_warning_"] + $list[$i]["_monitors_critical_"] + $list[$i]["_monitors_ok_"]; @@ -2002,7 +2011,7 @@ function group_get_data ($id_user = false, $user_strict = false, $acltags, $retu $list[0]['_monitors_not_init_'] += $list[$i]['_monitors_not_init_']; $list[0]['_agents_not_init_'] += $list[$i]['_agents_not_init_']; - if ($mode == 'tactical') { + if ($mode == 'tactical' || $mode == 'tree') { $list[0]['_agents_ok_'] += $group_stat[0]["normal"]; $list[0]['_agents_warning_'] += $group_stat[0]["warning"]; $list[0]['_agents_critical_'] += $group_stat[0]["critical"]; @@ -2010,7 +2019,7 @@ function group_get_data ($id_user = false, $user_strict = false, $acltags, $retu } } - if ($mode == 'group') { + if ($mode == 'group' || $mode == 'tree') { if (! defined ('METACONSOLE')) { if (($list[$i]['_agents_unknown_'] == 0) && ($list[$i]['_monitors_alerts_fired_'] == 0) && ($list[$i]['_total_agents_'] == 0) && ($list[$i]['_monitors_ok_'] == 0) && ($list[$i]['_monitors_critical_'] == 0) && ($list[$i]['_monitors_warning_'] == 0) && ($list[$i]['_monitors_unknown_'] == 0) && ($list[$i]['_monitors_not_init_'] == 0) && ($list[$i]['_agents_not_init_'] == 0)) { unset($list[$i]); @@ -2027,6 +2036,9 @@ function group_get_data ($id_user = false, $user_strict = false, $acltags, $retu $list[$i]['_name_'] = $item['nombre']; $list[$i]['_iconImg_'] = html_print_image ("images/groups_small/" . groups_get_icon($item['id_grupo']).".png", true, array ("style" => 'vertical-align: middle;')); + if ($mode == 'tree' && !empty($item['parent'])) + $list[$i]['_parent_id_'] = $item['parent']; + $list[$i]['_monitors_ok_'] = groups_monitor_ok($id, $user_strict, $id); $list[$i]['_monitors_critical_'] = groups_monitor_critical($id, $user_strict, $id); $list[$i]['_monitors_warning_'] = groups_monitor_warning($id, $user_strict, $id); @@ -2037,7 +2049,7 @@ function group_get_data ($id_user = false, $user_strict = false, $acltags, $retu $list[$i]['_monitors_not_init_'] = groups_monitor_not_init($id, $user_strict, $id); $list[$i]['_agents_not_init_'] = groups_agent_not_init ($id, $user_strict, $id); - if ($mode == 'tactical') { + if ($mode == 'tactical' || $mode == 'tree') { $list[$i]['_agents_ok_'] = groups_agent_ok ($id, $user_strict, $id); $list[$i]['_agents_warning_'] = groups_agent_warning ($id, $user_strict, $id); $list[$i]['_agents_critical_'] = groups_agent_critical ($id, $user_strict, $id); @@ -2103,7 +2115,7 @@ function group_get_data ($id_user = false, $user_strict = false, $acltags, $retu $list[0]['_monitors_not_init_'] = $list[$i]['_monitors_not_init_']; $list[0]['_agents_not_init_'] += $list[$i]['_agents_not_init_']; - if ($mode == 'tactical') { + if ($mode == 'tactical' || $mode == 'tree') { $list[0]['_agents_ok_'] += $list[$i]['_agents_ok_']; $list[0]['_agents_warning_'] += $list[$i]['_agents_warning_']; $list[0]['_agents_critical_'] += $list[$i]['_agents_critical_']; @@ -2111,7 +2123,7 @@ function group_get_data ($id_user = false, $user_strict = false, $acltags, $retu } } - if ($mode == 'group') { + if ($mode == 'group' || $mode == 'tree') { if (! defined ('METACONSOLE')) { if (($list[$i]['_agents_unknown_'] == 0) && ($list[$i]['_monitors_alerts_fired_'] == 0) && ($list[$i]['_total_agents_'] == 0) && ($list[$i]['_monitors_ok_'] == 0) && ($list[$i]['_monitors_critical_'] == 0) && ($list[$i]['_monitors_warning_'] == 0) && ($list[$i]['_monitors_unknown_'] == 0) && ($list[$i]['_monitors_not_init_'] == 0) && ($list[$i]['_agents_not_init_'] == 0)) { unset($list[$i]); @@ -2142,7 +2154,7 @@ function group_get_data ($id_user = false, $user_strict = false, $acltags, $retu $list[$i]['_monitors_warning_'] = tags_monitors_warning ($id, $acltags); $list[$i]['_monitors_alerts_fired_'] = tags_monitors_fired_alerts($id, $acltags); - if ($mode == 'tactical') { + if ($mode == 'tactical' || $mode == 'tree') { $list[$i]['_agents_ok_'] = tags_agent_ok ($id, $acltags); $list[$i]['_agents_warning_'] = tags_agent_warning ($id, $acltags); $list[$i]['_agents_critical_'] = tags_get_critical_agents ($id, $acltags); @@ -2160,7 +2172,7 @@ function group_get_data ($id_user = false, $user_strict = false, $acltags, $retu $list[0]['_monitors_unknown_'] += $list[$i]['_monitors_unknown_']; $list[0]['_monitors_not_init_'] = $list[$i]['_monitors_not_init_']; - if ($mode == 'tactical') { + if ($mode == 'tactical' || $mode == 'tree') { $list[0]['_agents_ok_'] += $list[$i]['_agents_ok_']; $list[0]['_agents_warning_'] += $list[$i]['_agents_warning_']; $list[0]['_agents_critical_'] += $list[$i]['_agents_critical_']; @@ -2168,7 +2180,7 @@ function group_get_data ($id_user = false, $user_strict = false, $acltags, $retu } } - if ($mode == 'group') { + if ($mode == 'group' || $mode == 'tree') { if (! defined ('METACONSOLE')) { if (($list[$i]['_agents_unknown_'] == 0) && ($list[$i]['_monitors_alerts_fired_'] == 0) && ($list[$i]['_total_agents_'] == 0) && ($list[$i]['_monitors_ok_'] == 0) && ($list[$i]['_monitors_critical_'] == 0) && ($list[$i]['_monitors_warning_'] == 0) && ($list[$i]['_monitors_unknown_'] == 0) && ($list[$i]['_monitors_not_init_'] == 0) && ($list[$i]['_agents_not_init_'] == 0)) { unset($list[$i]); @@ -2270,4 +2282,4 @@ function groups_get_group_deep ($id_group) { return $deep; } -?> \ No newline at end of file +?> diff --git a/pandora_console/include/functions_html.php b/pandora_console/include/functions_html.php index 101e75a6cf..0086ff0c8a 100644 --- a/pandora_console/include/functions_html.php +++ b/pandora_console/include/functions_html.php @@ -1766,24 +1766,17 @@ function html_print_image ($src, $return = false, $options = false, else { $options['class'] = 'forced_title'; } - - if (!isset ($options['id'])) { - $options['id'] = uniqid(); - } - - $params = array( - 'id' => 'forced_title_' . $options['id'], - 'class' => 'forced_title_layer', - 'content' => $options["title"], - 'hidden' => true); - $output = html_print_div($params, true) . $output; + + // New way to show the force_title (cleaner and better performance) + $output .= 'title="'.io_safe_input_html($options["title"]).'" '; + $output .= 'data-use_title_for_force_title="1" '; } //Valid attributes (invalid attributes get skipped) - $attrs = array ("height", "longdesc", "usemap","width","id", - "class","lang","xml:lang", "onclick", "ondblclick", + $attrs = array ("height", "longdesc", "usemap", "width", "id", + "class", "lang", "xml:lang", "onclick", "ondblclick", "onmousedown", "onmouseup", "onmouseover", "onmousemove", - "onmouseout", "onkeypress", "onkeydown", "onkeyup","pos_tree"); + "onmouseout", "onkeypress", "onkeydown", "onkeyup", "pos_tree"); foreach ($attrs as $attribute) { if (isset ($options[$attribute])) { diff --git a/pandora_console/include/functions_modules.php b/pandora_console/include/functions_modules.php old mode 100644 new mode 100755 index e5746032bb..5c757042f1 --- a/pandora_console/include/functions_modules.php +++ b/pandora_console/include/functions_modules.php @@ -875,7 +875,8 @@ function modules_is_string_type ($id_type) { * @return string The name of the icon. */ function modules_get_type_icon ($id_type) { - return (string) db_get_value ('icon', 'ttipo_modulo', 'id_tipo', (int) $id_type); + return (string) db_get_value ('icon', 'ttipo_modulo', 'id_tipo', + (int) $id_type); } /** diff --git a/pandora_console/include/functions_os.php b/pandora_console/include/functions_os.php index a54848ce45..8862b87db7 100755 --- a/pandora_console/include/functions_os.php +++ b/pandora_console/include/functions_os.php @@ -66,4 +66,12 @@ function os_get_name($id_os) { return db_get_value ('name', 'tconfig_os', 'id_os', (int) $id_os); } + +function os_get_os() { + $op_systems = db_get_all_rows_in_table('tconfig_os'); + if (empty($op_systems)) + $op_systems = array(); + + return $op_systems; +} ?> diff --git a/pandora_console/include/functions_reporting.php b/pandora_console/include/functions_reporting.php index c96f4e8808..8d58420a16 100644 --- a/pandora_console/include/functions_reporting.php +++ b/pandora_console/include/functions_reporting.php @@ -2022,6 +2022,32 @@ function reporting_get_group_stats ($id_group = 0, $access = 'AR') { $data["server_sanity"] = format_numeric (100 - $data["module_sanity"], 1); + + $data['alert_fired'] = 0; + if ($data["monitor_alerts_fired"] > 0) { + $data['alert_fired'] = 1; + } + + + if ($data["monitor_critical"] > 0) { + $data['status'] = 'critical'; + } + elseif ($data["monitor_warning"] > 0) { + $data['status'] = 'warning'; + } + elseif (($data["monitor_unknown"] > 0) || ($data["agents_unknown"] > 0)) { + $data['status'] = 'unknown'; + } + elseif ($data["monitor_ok"] > 0) { + $data['status'] = 'ok'; + } + elseif ($data["agent_not_init"] > 0) { + $data['status'] = 'not_init'; + } + else { + $data['status'] = 'none'; + } + return ($data); } diff --git a/pandora_console/include/functions_treeview.php b/pandora_console/include/functions_treeview.php index d518a3a00c..bb41341d0d 100755 --- a/pandora_console/include/functions_treeview.php +++ b/pandora_console/include/functions_treeview.php @@ -274,18 +274,11 @@ function treeview_printTable($id_agente, $server_data = array()) { $url_hash = metaconsole_get_servers_url_hash($server_data); } - require_once ("include/functions_agents.php"); + require_once ($config["homedir"] . "/include/functions_agents.php"); require_once ($config["homedir"] . '/include/functions_graph.php'); - include_graphs_dependencies(); require_once ($config['homedir'] . '/include/functions_groups.php'); require_once ($config['homedir'] . '/include/functions_gis.php'); - - $agent = db_get_row ("tagente", "id_agente", $id_agente); - - if ($agent === false) { - ui_print_error_message(__('There was a problem loading agent')); - return; - } + include_graphs_dependencies(); $is_extra = enterprise_hook('policies_is_agent_extra_policy', array($id_agente)); @@ -300,11 +293,21 @@ function treeview_printTable($id_agente, $server_data = array()) { return; } - echo '
'.__('Agent name').' | '; + $agent = db_get_row ("tagente", "id_agente", $id_agente); + if ($agent === false) { + ui_print_error_message(__('There was a problem loading agent')); + return; + } + + $table = new StdClass(); + $table->width = "100%"; + $table->style = array(); + $table->style['title'] = 'font-weight: bold;'; + $table->head = array(); + $table->data = array(); + + // Agent name if ($agent['disabled']) { $cellName = ""; } @@ -317,12 +320,13 @@ function treeview_printTable($id_agente, $server_data = array()) { if ($agent['disabled']) { $cellName .= ui_print_help_tip(__('Disabled'), true) . ""; } - - echo ''.$cellName.' | '; - + + $row = array(); + $row['title'] = __('Agent name'); + $row['data'] = $cellName; + $table->data['name'] = $row; + //Addresses - echo '|
'.__('IP Address').' | '; - echo '';
$ips = array();
$addresses = agents_get_addresses ($id_agente);
$address = agents_get_address($id_agente);
@@ -333,95 +337,115 @@ function treeview_printTable($id_agente, $server_data = array()) {
}
}
- echo $address;
-
if (!empty($addresses)) {
- ui_print_help_tip(__('Other IP addresses').': '.implode(' ',$addresses)); + $address .= ui_print_help_tip(__('Other IP addresses').': '.implode(' ',$addresses), true); } - echo ' | |
'.__('Interval').' | '; - echo ''.human_time_description_raw ($agent["intervalo"]).' | |
' . __('Description') . ' | '; - echo '' . $agent["comentarios"] . ' | |
' . __('Last contact') . " / " . __('Remote') . ' | '; - - ui_print_timestamp ($agent["ultimo_contacto"]); - - echo " / "; - + $last_contact = ui_print_timestamp($agent["ultimo_contacto"], true); + if ($agent["ultimo_contacto_remoto"] == "01-01-1970 00:00:00") { - echo __('Never'); + $last_remote_contact = __('Never'); } else { - ui_print_timestamp ($agent["ultimo_contacto_remoto"]); + $last_remote_contact = ui_print_timestamp ($agent["ultimo_contacto_remoto"], true); } - echo ' | |
'.__('Next agent contact').' | '; - echo '' . progress_bar($progress, 150, 20) . ' |
'.__('Agent Version'). ' | '; - $advanced .= ''.$agent["agent_version"].' | |
'.__('Position (Long, Lat)'). ' | '; - $advanced .= ''; - - if ($dataPositionAgent === false) { - $advanced .= __('There is no GIS data.'); - } - else { - $advanced .= ''; + if ($dataPositionAgent !== false) { + $position = ''; if ($dataPositionAgent['description'] != "") - $advanced .= $dataPositionAgent['description']; + $position .= $dataPositionAgent['description']; else - $advanced .= $dataPositionAgent['stored_longitude'].', '.$dataPositionAgent['stored_latitude']; - $advanced .= ""; + $position .= $dataPositionAgent['stored_longitude'].', '.$dataPositionAgent['stored_latitude']; + $position .= ""; + + $row = array(); + $row['title'] = __('Position (Long, Lat)'); + $row['data'] = $position; + $table->data['agent_position'] = $row; } - - $advanced .= ' | |
'.__('Url address').' | '; - $advanced .= '' . $agent["url_address"] . ' | |
'.__('Timezone Offset'). ' | '; - $advanced .= ''.$agent["timezone_offset"].' | |
'.$field['name'] . ui_print_help_tip (__('Custom field'), true).' | '; $custom_value = db_get_value_filter('description', 'tagent_custom_data', array('id_field' => $field['id_field'], 'id_agent' => $id_agente)); - if ($custom_value === false || $custom_value == '') { - $custom_value = '-'.__('empty').'-'; + if (!empty($custom_value)) { + $row = array(); + $row['title'] = $field['name'] . ui_print_help_tip (__('Custom field'), true); + $row['data'] = $custom_value; + $table->data['custom_field_'.$field['id_field']] = $row; } - $advanced .= ''.$custom_value.' |