'agent_keepalive', 'id_agente' => $id_agent, 'id_tipo_modulo' => 100, 'descripcion' => __('Agent keepalive monitor'), 'id_modulo' => 1, 'min_warning' => 0, 'max_warning' => 1)); if ($id_agent_module === false) { process_sql_rollback (); return false; } $result = process_sql_insert ('tagente_estado', array ('id_agente_modulo' => $id_agent_module, 'datos' => '', 'timestamp' => 0, 'estado' => 0, 'id_agente' => $id_agent, 'last_try' => 0, 'utimestamp' => 0, 'current_interval' => 0, 'running_by' => 0, 'last_execution_try' => 0)); if ($result === false) { process_sql_rollback (); return false; } process_sql_commit (); pandora_audit ("Agent management", "New agent '$name' created"); return $id_agent; } /** * Get all the simple alerts of an agent. * * @param int Agent id * @param string Filter on "fired", "notfired" or "disabled". Any other value * will not do any filter. * @param array Extra filter options in an indexed array. See * format_array_to_where_clause_sql() * @param boolean $allModules * * @return array All simple alerts defined for an agent. Empty array if no * alerts found. */ function get_agent_alerts_simple ($id_agent = false, $filter = '', $options = false, $where = '', $allModules = false, $orderby = false, $idGroup = false, $count = false) { switch ($filter) { case "notfired": $filter = ' AND times_fired = 0 AND talert_template_modules.disabled = 0'; break; case "fired": $filter = ' AND times_fired > 0 AND talert_template_modules.disabled = 0'; break; case "disabled": $filter = ' AND talert_template_modules.disabled = 1'; break; case 'all_enabled': $filter = ' AND talert_template_modules.disabled = 0'; break; default: $filter = ''; } if (is_array ($options)) { $filter .= format_array_to_where_clause_sql ($options); } if (($id_agent === false) && ($idGroup !== false)) { if ($idGroup != 0) { //All group $subQuery = 'SELECT id_agente_modulo FROM tagente_modulo WHERE delete_pending = 0 AND id_agente IN (SELECT id_agente FROM tagente WHERE id_grupo = ' . $idGroup . ')'; } else { $subQuery = 'SELECT id_agente_modulo FROM tagente_modulo WHERE delete_pending = 0'; } } else if ($id_agent === false) { if ($allModules) $disabled = ''; else $disabled = 'WHERE disabled = 0'; $subQuery = 'SELECT id_agente_modulo FROM tagente_modulo ' . $disabled; } else { $id_agent = (array) $id_agent; $id_modules = array_keys (get_agent_modules ($id_agent, false, array('delete_pending' => 0))); if (empty ($id_modules)) return array (); $subQuery = implode (",", $id_modules); } $orderbyText = ''; if ($orderby !== false) { if (is_array($orderby)) { $orderbyText = sprintf("ORDER BY %s", $orderby['field'], $orderby['order']); } else { $orderbyText = sprintf("ORDER BY %s", $orderby); } } $selectText = 'talert_template_modules.*, t2.nombre AS agent_module_name, t3.nombre AS agent_name, t4.name AS template_name'; if ($count !== false) { $selectText = 'COUNT(talert_template_modules.id) AS count'; } $sql = sprintf ("SELECT %s FROM talert_template_modules INNER JOIN tagente_modulo AS t2 ON talert_template_modules.id_agent_module = t2.id_agente_modulo INNER JOIN tagente AS t3 ON t2.id_agente = t3.id_agente INNER JOIN talert_templates AS t4 ON talert_template_modules.id_alert_template = t4.id WHERE id_agent_module in (%s) %s %s %s", $selectText, $subQuery, $where, $filter, $orderbyText); $alerts = get_db_all_rows_sql ($sql); if ($alerts === false) return array (); if ($count !== false) { return $alerts[0]['count']; } else { return $alerts; } } /** * Get all the combined alerts of an agent. * * @param int $id_agent Agent id * @param string Special filter. Can be: "notfired", "fired" or "disabled". * @param array Extra filter options in an indexed array. See * format_array_to_where_clause_sql() * * @return array An array with all combined alerts defined for an agent. */ function get_agent_alerts_compound ($id_agent = false, $filter = '', $options = false, $idGroup = false, $count = false, $where = '') { switch ($filter) { case "notfired": $filter = ' AND times_fired = 0 AND disabled = 0'; break; case "fired": $filter = ' AND times_fired > 0 AND disabled = 0'; break; case "disabled": $filter = ' AND disabled = 1'; break; case 'all_enabled': $filter = ' AND disabled = 0'; break; default: $filter = ''; } if (is_array ($options)) { $filter .= format_array_to_where_clause_sql ($options); } if (($id_agent === false) && ($idGroup !== false)) { if ($idGroup != 0) { //All group $subQuery = 'SELECT id_agente FROM tagente WHERE id_grupo = ' . $idGroup; } else { $subQuery = 'SELECT id_agente FROM tagente'; } } else if ($id_agent === false) { $subQuery = 'SELECT id_agente FROM tagente WHERE disabled = 0'; } else { $id_agent = (array) $id_agent; $subQuery = implode (',', $id_agent); } $selectText = '*'; if ($count !== false) { $selectText = 'COUNT(id) AS count'; } $sql = sprintf ("SELECT %s FROM talert_compound WHERE id_agent IN (%s) %s %s", $selectText, $subQuery, $where, $filter); $alerts = get_db_all_rows_sql ($sql); if ($alerts === false) return array (); if ($count !== false) { return $alerts[0]['count']; } else { return $alerts; } } /** * Get a list of agents. * * By default, it will return all the agents where the user has reading access. * * @param array filter options in an indexed array. See * format_array_to_where_clause_sql() * @param array Fields to get. * @param string Access needed in the agents groups. * @param array $order The order of agents, by default is upward for field nombre. * * @return mixed An array with all alerts defined for an agent or false in case no allowed groups are specified. */ function get_agents ($filter = false, $fields = false, $access = 'AR', $order = array('field' => 'nombre', 'order' => 'ASC')) { if (! is_array ($filter)) { $filter = array (); } //Get user groups $groups = array_keys (get_user_groups (false, $access)); //If no group specified, get all user groups if (empty ($filter['id_grupo'])) { $filter['id_grupo'] = $groups; } elseif (! is_array ($filter['id_grupo'])) { //If group is specified but not allowed, return false if (! in_array ($filter['id_grupo'], $groups)) { return false; } $filter['id_grupo'] = (array) $filter['id_grupo']; //Make an array } else { //Check each group specified to the user groups, remove unwanted groups foreach ($filter['id_grupo'] as $key => $id_group) { if (! in_array ($id_group, $groups)) { unset ($filter['id_grupo'][$key]); } } //If no allowed groups are specified return false if (count ($filter['id_grupo']) == 0) { return false; } } if (in_array (0, $filter['id_grupo'])) { unset ($filter['id_grupo']); } if (!is_array ($fields)) { $fields = array (); $fields[0] = "id_agente"; $fields[1] = "nombre"; } $filter['order'] = $order['field'] . ' ' . $order['order']; return get_db_all_rows_filter ('tagente', $filter, $fields); } /** * Get all the alerts of an agent, simple and combined. * * @param int $id_agent Agent id * @param string Special filter. Can be: "notfired", "fired" or "disabled". * @param array Extra filter options in an indexed array. See * format_array_to_where_clause_sql() * * @return array An array with all alerts defined for an agent. */ function get_agent_alerts ($id_agent = false, $filter = false, $options = false) { $combined_alerts = get_agent_alerts_compound ($id_agent, $filter, $options); $simple_alerts = get_agent_alerts_simple ($id_agent, $filter, $options); return array ('simple' => $simple_alerts, 'compounds' => $combined_alerts); } /** * Copy the agents config from one agent to the other * * @param int Agent id * @param mixed Agent id or id's (array) to copy to * @param bool Whether to copy modules as well (defaults to $_REQUEST['copy_modules']) * @param bool Whether to copy alerts as well * @param array Which modules to copy. * @param array Which alerts to copy. Only will be used if target_modules is empty. * * @return bool True in case of good, false in case of bad */ function process_manage_config ($source_id_agent, $destiny_id_agents, $copy_modules = false, $copy_alerts = false, $target_modules = false, $target_alerts = false) { if (empty ($source_id_agent)) { echo '