2020-05-14 17:49:02 +02:00
|
|
|
<?php
|
2020-05-20 19:04:42 +02:00
|
|
|
// phpcs:disable Squiz.NamingConventions.ValidFunctionName.ScopeNotCamelCaps
|
2020-05-14 17:49:02 +02:00
|
|
|
/**
|
|
|
|
* Agent entity class.
|
|
|
|
*
|
|
|
|
* @category Class
|
|
|
|
* @package Pandora FMS
|
|
|
|
* @subpackage OpenSource
|
|
|
|
* @version 1.0.0
|
|
|
|
* @license See below
|
|
|
|
*
|
|
|
|
* ______ ___ _______ _______ ________
|
|
|
|
* | __ \.-----.--.--.--| |.-----.----.-----. | ___| | | __|
|
|
|
|
* | __/| _ | | _ || _ | _| _ | | ___| |__ |
|
|
|
|
* |___| |___._|__|__|_____||_____|__| |___._| |___| |__|_|__|_______|
|
|
|
|
*
|
|
|
|
* ============================================================================
|
|
|
|
* Copyright (c) 2005-2019 Artica Soluciones Tecnologicas
|
|
|
|
* Please see http://pandorafms.org for full contribution list
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* 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.
|
|
|
|
* ============================================================================
|
|
|
|
*/
|
|
|
|
|
|
|
|
// Begin.
|
|
|
|
namespace PandoraFMS;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* PandoraFMS agent entity.
|
|
|
|
*/
|
|
|
|
class Agent extends Entity
|
|
|
|
{
|
|
|
|
|
2020-05-20 19:04:42 +02:00
|
|
|
/**
|
|
|
|
* Agent's modules.
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
private $modules = [];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Flag to verify if modules has been loaded.
|
|
|
|
*
|
|
|
|
* @var boolean
|
|
|
|
*/
|
|
|
|
private $modulesLoaded = false;
|
|
|
|
|
2020-05-14 17:49:02 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Builds a PandoraFMS\Agent object from a agent id.
|
|
|
|
*
|
2020-06-26 15:48:58 +02:00
|
|
|
* @param integer $id_agent Agent Id.
|
|
|
|
* @param boolean $load_modules Load all modules of this agent.
|
|
|
|
* @param integer|null $id_node Metaconsole only. ID node.
|
2020-05-14 17:49:02 +02:00
|
|
|
*/
|
2020-06-26 15:48:58 +02:00
|
|
|
public function __construct(
|
|
|
|
?int $id_agent=null,
|
|
|
|
?bool $load_modules=false,
|
|
|
|
?int $id_node=null
|
|
|
|
) {
|
|
|
|
$table = 'tagente';
|
|
|
|
$filter = ['id_agente' => $id_agent];
|
|
|
|
if (is_metaconsole() === true
|
|
|
|
&& $id_node !== null
|
|
|
|
) {
|
|
|
|
$table = 'tmetaconsole_agent';
|
|
|
|
$filter = [
|
|
|
|
'id_agente' => $id_agent,
|
|
|
|
'id_tmetaconsole_setup' => (int) $id_node,
|
|
|
|
];
|
|
|
|
|
|
|
|
// Cannot load modules from metaconsole.
|
|
|
|
$load_modules = false;
|
|
|
|
}
|
|
|
|
|
2020-06-25 11:25:43 +02:00
|
|
|
if (is_numeric($id_agent) === true
|
|
|
|
&& $id_agent > 0
|
|
|
|
) {
|
2020-06-26 15:48:58 +02:00
|
|
|
parent::__construct($table, $filter);
|
2020-05-20 19:04:42 +02:00
|
|
|
if ($load_modules === true) {
|
|
|
|
$rows = \db_get_all_rows_filter(
|
|
|
|
'tagente_modulo',
|
2020-06-26 15:48:58 +02:00
|
|
|
$filter
|
2020-05-20 19:04:42 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
if (is_array($rows) === true) {
|
|
|
|
foreach ($rows as $row) {
|
|
|
|
$this->modules[] = Module::build($row);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->modulesLoaded = true;
|
|
|
|
}
|
2020-05-14 17:49:02 +02:00
|
|
|
} else {
|
|
|
|
// Create empty skel.
|
2020-06-26 15:48:58 +02:00
|
|
|
parent::__construct($table);
|
2020-05-20 19:04:42 +02:00
|
|
|
|
|
|
|
// New agent has no modules.
|
|
|
|
$this->modulesLoaded = true;
|
2020-05-14 17:49:02 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Customize certain fields.
|
|
|
|
$this->fields['group'] = new Group($this->fields['id_grupo']);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-05-20 19:04:42 +02:00
|
|
|
/**
|
|
|
|
* Overrides Entity method.
|
|
|
|
*
|
|
|
|
* @param integer $id_group Target group Id.
|
|
|
|
*
|
|
|
|
* @return integer|null Group Id or null.
|
|
|
|
*/
|
|
|
|
public function id_grupo(?int $id_group=null)
|
|
|
|
{
|
|
|
|
if ($id_group === null) {
|
|
|
|
return $this->fields['id_grupo'];
|
|
|
|
} else {
|
|
|
|
$this->fields['id_grupo'] = $id_group;
|
|
|
|
$this->fields['group'] = new Group($this->fields['id_grupo']);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Saves current definition to database.
|
2020-05-14 17:49:02 +02:00
|
|
|
*
|
|
|
|
* @param boolean $alias_as_name Use alias as agent name.
|
|
|
|
*
|
|
|
|
* @return mixed Affected rows of false in case of error.
|
|
|
|
* @throws \Exception On error.
|
|
|
|
*/
|
|
|
|
public function save(bool $alias_as_name=false)
|
|
|
|
{
|
|
|
|
if (empty($this->fields['nombre']) === true) {
|
|
|
|
if ($alias_as_name === true
|
|
|
|
&& (empty($this->fields['alias']) === true)
|
|
|
|
) {
|
|
|
|
throw new \Exception(
|
|
|
|
get_class($this).' error, nor "alias" nor "nombre" are set'
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
// Use alias instead.
|
|
|
|
$this->fields['nombre'] = $this->fields['alias'];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->fields['id_agente'] > 0) {
|
2020-05-20 19:04:42 +02:00
|
|
|
// Agent update.
|
2020-05-14 17:49:02 +02:00
|
|
|
$updates = $this->fields;
|
|
|
|
|
|
|
|
// Remove shortcuts from values.
|
|
|
|
unset($updates['group']);
|
|
|
|
|
2020-05-20 19:04:42 +02:00
|
|
|
$rs = \db_process_sql_update(
|
|
|
|
'tagente',
|
2020-05-14 17:49:02 +02:00
|
|
|
$updates,
|
2020-05-20 19:04:42 +02:00
|
|
|
['id_agente' => $this->fields['id_agente']]
|
2020-05-14 17:49:02 +02:00
|
|
|
);
|
2020-05-20 19:04:42 +02:00
|
|
|
|
|
|
|
if ($rs === false) {
|
|
|
|
global $config;
|
|
|
|
throw new \Exception(
|
|
|
|
__METHOD__.' error: '.$config['dbconnection']->error
|
|
|
|
);
|
|
|
|
}
|
2020-05-14 17:49:02 +02:00
|
|
|
} else {
|
2020-05-20 19:04:42 +02:00
|
|
|
// Agent creation.
|
2020-05-14 17:49:02 +02:00
|
|
|
$updates = $this->fields;
|
|
|
|
|
|
|
|
// Remove shortcuts from values.
|
|
|
|
unset($updates['group']);
|
|
|
|
|
|
|
|
// Clean null fields.
|
|
|
|
foreach ($updates as $k => $v) {
|
|
|
|
if ($v === null) {
|
|
|
|
unset($updates[$k]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-20 19:04:42 +02:00
|
|
|
$rs = \agents_create_agent(
|
2020-05-14 17:49:02 +02:00
|
|
|
$updates['nombre'],
|
|
|
|
$updates['id_grupo'],
|
|
|
|
$updates['intervalo'],
|
|
|
|
$updates['direccion'],
|
|
|
|
$updates,
|
|
|
|
$alias_as_name
|
|
|
|
);
|
2020-05-20 19:04:42 +02:00
|
|
|
|
|
|
|
if ($rs === false) {
|
|
|
|
global $config;
|
|
|
|
throw new \Exception(
|
|
|
|
__METHOD__.' error: '.$config['dbconnection']->error
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->fields['id_agente'] = $rs;
|
2020-05-14 17:49:02 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->fields['group']->id_grupo() === null) {
|
|
|
|
// Customize certain fields.
|
|
|
|
$this->fields['group'] = new Group($this->fields['id_grupo']);
|
|
|
|
}
|
|
|
|
|
2020-05-20 19:04:42 +02:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates a module in current agent.
|
|
|
|
*
|
|
|
|
* @param array $params Module definition (each db field).
|
|
|
|
*
|
|
|
|
* @return integer Id of new module.
|
|
|
|
* @throws \Exception On error.
|
|
|
|
*/
|
|
|
|
public function addModule(array $params)
|
|
|
|
{
|
|
|
|
$err = __METHOD__.' error: ';
|
|
|
|
|
|
|
|
if (empty($params['nombre']) === true) {
|
|
|
|
throw new \Exception(
|
|
|
|
$err.' module name is mandatory'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$params['id_agente'] = $this->fields['id_agente'];
|
|
|
|
|
|
|
|
$id_module = modules_create_agent_module(
|
|
|
|
$this->fields['id_agente'],
|
|
|
|
$params['nombre'],
|
|
|
|
$params
|
|
|
|
);
|
|
|
|
|
|
|
|
if ($id_module === false) {
|
|
|
|
global $config;
|
|
|
|
throw new \Exception(
|
|
|
|
$err.$config['dbconnection']->error
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $id_module;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Search for modules into this agent.
|
|
|
|
*
|
|
|
|
* @param array $filter Filters.
|
|
|
|
*
|
|
|
|
* @return PandoraFMS\Module Module found.
|
|
|
|
*/
|
|
|
|
public function searchModules(array $filter)
|
|
|
|
{
|
|
|
|
$filter['id_agente'] = $this->id_agente();
|
|
|
|
|
|
|
|
if ($this->modulesLoaded === true) {
|
|
|
|
// Search in $this->modules.
|
|
|
|
$results = [];
|
|
|
|
|
|
|
|
foreach ($this->modules as $module) {
|
|
|
|
$found = true;
|
|
|
|
foreach ($filter as $field => $value) {
|
|
|
|
if ($module->{$field}() !== $value) {
|
|
|
|
$found = false;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($found === true) {
|
|
|
|
$results[] = $module;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $results;
|
|
|
|
} else {
|
|
|
|
// Search in db.
|
|
|
|
return Module::search($filter);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Delete agent from db.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function delete()
|
|
|
|
{
|
|
|
|
// This function also mark modules for deletion.
|
|
|
|
\agents_delete_agent(
|
|
|
|
$this->fields['id_agente']
|
|
|
|
);
|
|
|
|
|
|
|
|
unset($this->fields);
|
|
|
|
unset($this->modules);
|
2020-05-14 17:49:02 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|