2009-01-15 11:21:38 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
// Pandora FMS - the Flexible Monitoring System
|
|
|
|
// ============================================
|
|
|
|
// Copyright (c) 2008 Artica Soluciones Tecnologicas, http://www.artica.es
|
|
|
|
// Please see http://pandora.sourceforge.net for full contribution list
|
|
|
|
|
|
|
|
// This program is free software; you can redistribute it and/or
|
|
|
|
// modify it under the terms of the GNU Lesser General Public License (LGPL)
|
|
|
|
// as published by the Free Software Foundation for version 2.
|
|
|
|
//
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with this program; if not, write to the Free Software
|
|
|
|
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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.
|
2009-02-18 13:29:30 +01:00
|
|
|
* @param array Extra filter options in an indexed array. See
|
|
|
|
* format_array_to_where_clause_sql()
|
2009-01-15 11:21:38 +01:00
|
|
|
*
|
|
|
|
* @return array All simple alerts defined for an agent. Empty array if no
|
|
|
|
* alerts found.
|
|
|
|
*/
|
2009-02-18 13:29:30 +01:00
|
|
|
function get_agent_alerts_simple ($id_agent, $filter = '', $options = false) {
|
2009-01-15 11:21:38 +01:00
|
|
|
switch ($filter) {
|
|
|
|
case "notfired":
|
2009-02-11 17:55:04 +01:00
|
|
|
$filter = ' AND times_fired = 0 AND disabled = 0';
|
2009-01-15 11:21:38 +01:00
|
|
|
break;
|
|
|
|
case "fired":
|
2009-02-11 17:55:04 +01:00
|
|
|
$filter = ' AND times_fired > 0 AND disabled = 0';
|
2009-01-15 11:21:38 +01:00
|
|
|
break;
|
|
|
|
case "disabled":
|
2009-02-11 17:55:04 +01:00
|
|
|
$filter = ' AND disabled = 1';
|
2009-01-15 11:21:38 +01:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
$filter = '';
|
|
|
|
}
|
|
|
|
|
2009-02-18 13:29:30 +01:00
|
|
|
$id_agent = (array) $id_agent;
|
2009-01-15 11:21:38 +01:00
|
|
|
$id_modules = array_keys (get_agent_modules ($id_agent));
|
2009-01-19 15:42:34 +01:00
|
|
|
if (empty ($id_modules))
|
|
|
|
return array ();
|
2009-01-15 11:21:38 +01:00
|
|
|
|
2009-02-18 13:29:30 +01:00
|
|
|
if (is_array ($options)) {
|
|
|
|
$filter .= format_array_to_where_clause_sql ($options);
|
|
|
|
}
|
|
|
|
|
2009-01-15 11:21:38 +01:00
|
|
|
$sql = sprintf ("SELECT talert_template_modules.*
|
|
|
|
FROM talert_template_modules
|
2009-01-19 15:42:34 +01:00
|
|
|
WHERE id_agent_module in (%s)%s",
|
|
|
|
implode (",", $id_modules), $filter);
|
2009-01-15 11:21:38 +01:00
|
|
|
|
|
|
|
$alerts = get_db_all_rows_sql ($sql);
|
|
|
|
|
|
|
|
if ($alerts === false)
|
|
|
|
return array ();
|
|
|
|
return $alerts;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get all the combined alerts of an agent.
|
|
|
|
*
|
|
|
|
* @param int $id_agent Agent id
|
2009-02-18 13:29:30 +01:00
|
|
|
* @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()
|
2009-01-15 11:21:38 +01:00
|
|
|
*
|
|
|
|
* @return array An array with all combined alerts defined for an agent.
|
|
|
|
*/
|
2009-02-18 13:29:30 +01:00
|
|
|
function get_agent_alerts_compound ($id_agent, $filter = '', $options = false) {
|
2009-01-15 11:21:38 +01:00
|
|
|
switch ($filter) {
|
2009-02-11 17:55:04 +01:00
|
|
|
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;
|
|
|
|
default:
|
|
|
|
$filter = '';
|
2009-01-15 11:21:38 +01:00
|
|
|
}
|
2009-01-19 15:42:34 +01:00
|
|
|
|
2009-02-18 13:29:30 +01:00
|
|
|
if (is_array ($options)) {
|
|
|
|
$filter .= format_array_to_where_clause_sql ($options);
|
|
|
|
}
|
|
|
|
|
|
|
|
$id_agent = array ($id_agent);
|
|
|
|
|
2009-02-11 17:55:04 +01:00
|
|
|
$sql = sprintf ("SELECT * FROM talert_compound
|
2009-02-18 13:29:30 +01:00
|
|
|
WHERE id_agent in (%s)%s",
|
|
|
|
implode (',', $id_agent), $filter);
|
2009-01-19 15:42:34 +01:00
|
|
|
|
2009-01-15 11:21:38 +01:00
|
|
|
$alerts = get_db_all_rows_sql ($sql);
|
|
|
|
|
|
|
|
if ($alerts === false)
|
|
|
|
return array ();
|
|
|
|
return $alerts;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get all the alerts of an agent, simple and combined.
|
|
|
|
*
|
|
|
|
* @param int $id_agent Agent id
|
2009-02-18 13:29:30 +01:00
|
|
|
* @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()
|
2009-01-15 11:21:38 +01:00
|
|
|
*
|
|
|
|
* @return array An array with all alerts defined for an agent.
|
|
|
|
*/
|
2009-02-18 13:29:30 +01:00
|
|
|
function get_agent_alerts ($id_agent, $filter = false, $options = false) {
|
|
|
|
$simple_alerts = get_agent_alerts_simple ($id_agent, $filter, $options);
|
|
|
|
$combined_alerts = get_agent_alerts_compound ($id_agent, $filter, $options);
|
2009-01-15 11:21:38 +01:00
|
|
|
|
2009-02-11 17:55:04 +01:00
|
|
|
return array ('simple' => $simple_alerts, 'compounds' => $combined_alerts);
|
2009-01-15 11:21:38 +01:00
|
|
|
}
|
|
|
|
?>
|