Improved the agent search for the metaconsole
This commit is contained in:
parent
bcfd0237bb
commit
abc426bc4d
|
@ -169,6 +169,7 @@ elseif ($search_agents && ($config['metaconsole'] == 1) && defined('METACONSOLE'
|
|||
$id_group = (int) get_parameter('id_group', -1);
|
||||
$addedItems = html_entity_decode((string) get_parameter('add'));
|
||||
$addedItems = json_decode($addedItems);
|
||||
$all = (string)get_parameter('all', 'all');
|
||||
|
||||
if ($addedItems != null) {
|
||||
foreach ($addedItems as $item) {
|
||||
|
@ -176,6 +177,13 @@ elseif ($search_agents && ($config['metaconsole'] == 1) && defined('METACONSOLE'
|
|||
}
|
||||
}
|
||||
|
||||
$data = array();
|
||||
|
||||
$fields = array(
|
||||
'id_tagente AS id_agente', 'nombre',
|
||||
'direccion', 'id_tmetaconsole_setup AS id_server'
|
||||
);
|
||||
|
||||
$filter = array();
|
||||
|
||||
if ($id_group != -1) {
|
||||
|
@ -189,63 +197,92 @@ elseif ($search_agents && ($config['metaconsole'] == 1) && defined('METACONSOLE'
|
|||
}
|
||||
}
|
||||
|
||||
switch ($all) {
|
||||
case 'enabled':
|
||||
$filter['disabled'] = 0;
|
||||
break;
|
||||
}
|
||||
|
||||
if (!empty($id_agent)) {
|
||||
$filter['id_agente'] = $id_agent;
|
||||
}
|
||||
|
||||
if (!empty($string)) {
|
||||
$search_filters = array();
|
||||
|
||||
//Get agents for only the name.
|
||||
$filter_agents = $filter;
|
||||
switch ($config['dbtype']) {
|
||||
case "mysql":
|
||||
//Get agents for only the name.
|
||||
$search_filters[] = "(nombre COLLATE utf8_general_ci LIKE '%$string%')";
|
||||
//Get agents for only the address
|
||||
$search_filters[] = "(direccion LIKE '%$string%')";
|
||||
//Get agents for only the description
|
||||
$search_filters[] = "(comentarios LIKE '%$string%')";
|
||||
$filter_agents[] = '(nombre COLLATE utf8_general_ci LIKE "%'.$string.'%")';
|
||||
break;
|
||||
case "postgresql":
|
||||
//Get agents for only the name.
|
||||
$search_filters[] = "(nombre LIKE '%$string%')";
|
||||
//Get agents for only the address
|
||||
$search_filters[] = "(direccion LIKE '%$string%')";
|
||||
//Get agents for only the description
|
||||
$search_filters[] = "(comentarios LIKE '%$string%')";
|
||||
$filter_agents[] = '(nombre LIKE \'%'.$string.'%\')';
|
||||
break;
|
||||
case "oracle":
|
||||
//Get agents for only the name.
|
||||
$search_filters[] = "(UPPER(nombre) LIKE UPPER('%$string%')";
|
||||
//Get agents for only the address
|
||||
$search_filters[] = "(UPPER(direccion) LIKE UPPER('%$string%'))";
|
||||
//Get agents for only the description
|
||||
$search_filters[] = "(UPPER(comentarios) LIKE UPPER('%$string%'))";
|
||||
$filter_agents[] = '(UPPER(nombre) LIKE UPPER(\'%'.$string.'%\'))';
|
||||
break;
|
||||
}
|
||||
|
||||
$search_filters_str = implode($search_filters, ' OR ');
|
||||
|
||||
if (!empty($search_filters_str))
|
||||
$filter[] = "($search_filters_str)";
|
||||
}
|
||||
|
||||
$fields = array(
|
||||
'id_tagente AS id_agente', 'nombre',
|
||||
'direccion', 'id_tmetaconsole_setup AS id_server'
|
||||
);
|
||||
$agents = db_get_all_rows_filter('tmetaconsole_agent', $filter, $fields);
|
||||
|
||||
$data = array();
|
||||
|
||||
if ($agents !== false) {
|
||||
foreach ($agents as $agent) {
|
||||
$data[] = array('id' => $agent['id_agente'],
|
||||
'name' => io_safe_output($agent['nombre']),
|
||||
'ip' => io_safe_output($agent['direccion']),
|
||||
'filter' => 'description',
|
||||
'id_server' => $agent['id_server']);
|
||||
$agents = db_get_all_rows_filter('tmetaconsole_agent', $filter_agents, $fields);
|
||||
if ($agents !== false) {
|
||||
foreach ($agents as $agent) {
|
||||
$data[] = array('id' => $agent['id_agente'],
|
||||
'name' => io_safe_output($agent['nombre']),
|
||||
'ip' => io_safe_output($agent['direccion']),
|
||||
'id_server' => $agent['id_server'],
|
||||
'filter' => 'agent');
|
||||
}
|
||||
}
|
||||
|
||||
//Get agents for only the address
|
||||
$filter_address = $filter;
|
||||
switch ($config['dbtype']) {
|
||||
case "mysql":
|
||||
$filter_address[] = '(nombre COLLATE utf8_general_ci NOT LIKE "%'.$string.'%" AND direccion LIKE "%'.$string.'%")';
|
||||
break;
|
||||
case "postgresql":
|
||||
$filter_address[] = '(nombre NOT LIKE \'%'.$string.'%\' AND direccion LIKE \'%'.$string.'%\')';
|
||||
break;
|
||||
case "oracle":
|
||||
$filter_address[] = '(UPPER(nombre) NOT LIKE UPPER(\'%'.$string.'%\') AND UPPER(direccion) LIKE UPPER(\'%'.$string.'%\'))';
|
||||
break;
|
||||
}
|
||||
|
||||
$agents = db_get_all_rows_filter('tmetaconsole_agent', $filter_address, $fields);
|
||||
if ($agents !== false) {
|
||||
foreach ($agents as $agent) {
|
||||
$data[] = array('id' => $agent['id_agente'],
|
||||
'name' => io_safe_output($agent['nombre']),
|
||||
'ip' => io_safe_output($agent['direccion']),
|
||||
'id_server' => $agent['id_server'],
|
||||
'filter' => 'address');
|
||||
}
|
||||
}
|
||||
|
||||
//Get agents for only the description
|
||||
$filter_description = $filter;
|
||||
switch ($config['dbtype']) {
|
||||
case "mysql":
|
||||
$filter_description[] = '(nombre COLLATE utf8_general_ci NOT LIKE "%'.$string.'%" AND direccion NOT LIKE "%'.$string.'%" AND comentarios LIKE "%'.$string.'%")';
|
||||
break;
|
||||
case "postgresql":
|
||||
$filter_description[] = '(nombre NOT LIKE \'%'.$string.'%\' AND direccion NOT LIKE \'%'.$string.'%\' AND comentarios LIKE \'%'.$string.'%\')';
|
||||
break;
|
||||
case "oracle":
|
||||
$filter_description[] = '(UPPER(nombre) NOT LIKE UPPER(\'%'.$string.'%\') AND UPPER(direccion) NOT LIKE UPPER(\'%'.$string.'%\') AND UPPER(comentarios) LIKE UPPER(\'%'.$string.'%\'))';
|
||||
break;
|
||||
}
|
||||
|
||||
$agents = db_get_all_rows_filter('tmetaconsole_agent', $filter_description, $fields);
|
||||
if ($agents !== false) {
|
||||
foreach ($agents as $agent) {
|
||||
$data[] = array('id' => $agent['id_agente'],
|
||||
'name' => io_safe_output($agent['nombre']),
|
||||
'ip' => io_safe_output($agent['direccion']),
|
||||
'id_server' => $agent['id_server'],
|
||||
'filter' => 'description');
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
echo json_encode($data);
|
||||
|
|
Loading…
Reference in New Issue