2010-04-06 18:24:54 +02:00
< ? php
2021-11-04 16:28:15 +01:00
// Pandora FMS- http://pandorafms.com
2010-04-06 18:24:54 +02:00
// ==================================================
2020-11-27 13:52:35 +01:00
// Copyright (c) 2005-2021 Artica Soluciones Tecnologicas
2010-04-06 18:24:54 +02:00
// 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 Lesser General Public License
// as published by the Free Software Foundation; 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.
2011-05-30 19:04:34 +02:00
global $config ;
2015-06-11 12:08:02 +02:00
2019-01-30 16:18:44 +01:00
require_once $config [ 'homedir' ] . '/include/functions_agents.php' ;
require_once $config [ 'homedir' ] . '/include/functions_reporting.php' ;
enterprise_include_once ( 'include/functions_metaconsole.php' );
2010-04-06 18:24:54 +02:00
2015-06-11 12:08:02 +02:00
// Clean the possible blanks introduced by the included files
ob_clean ();
2010-04-06 18:24:54 +02:00
// Get list of agent + ip
// Params:
// * search_agents 1
2019-01-30 16:18:44 +01:00
// * id_agent
2010-04-06 18:24:54 +02:00
// * q
// * id_group
2019-01-30 16:18:44 +01:00
$search_agents = ( bool ) get_parameter ( 'search_agents' );
2021-04-12 18:17:09 +02:00
$get_agents_interfaces = ( bool ) get_parameter ( 'get_agents_interfaces' );
$id_agents = get_parameter ( 'id_agents' , []);
2012-03-12 17:23:50 +01:00
$get_agents_group = ( bool ) get_parameter ( 'get_agents_group' , false );
2012-12-11 18:39:48 +01:00
$force_local = ( bool ) get_parameter ( 'force_local' , false );
2023-01-25 17:22:54 +01:00
// Agent detail filter.
$load_filter_modal = get_parameter ( 'load_filter_modal' , 0 );
$save_filter_modal = get_parameter ( 'save_filter_modal' , 0 );
$get_agent_filters = get_parameter ( 'get_agent_filters' , 0 );
$save_agent_filter = get_parameter ( 'save_agent_filter' , 0 );
$update_agent_filter = get_parameter ( 'update_agent_filter' , 0 );
2023-02-28 17:06:31 +01:00
$delete_agent_filter = get_parameter ( 'delete_agent_filter' , 0 );
2023-01-25 17:22:54 +01:00
2019-01-30 16:18:44 +01:00
if ( https_is_running ()) {
header ( 'Content-type: application/json' );
2015-09-09 15:01:12 +02:00
}
2012-03-12 17:23:50 +01:00
2021-04-12 18:17:09 +02:00
if ( $get_agents_interfaces ) {
$agents_interfaces = agents_get_network_interfaces ( $id_agents );
// Include alias per agent.
foreach ( $agents_interfaces as $key => $value ) {
$agent_alias = agents_get_alias ( $key );
$agents_interfaces [ $key ][ 'agent_alias' ] = $agent_alias ;
}
echo json_encode ( $agents_interfaces );
return ;
}
2012-03-12 17:23:50 +01:00
if ( $get_agents_group ) {
2019-01-30 16:18:44 +01:00
$id_group = ( int ) get_parameter ( 'id_group' , - 1 );
$mode = ( string ) get_parameter ( 'mode' , 'json' );
$id_server = ( int ) get_parameter ( 'id_server' , 0 );
$serialized = ( bool ) get_parameter ( 'serialized' );
$return = [];
if ( $id_group != - 1 ) {
$filter = [];
if ( is_metaconsole () && ! empty ( $id_server )) {
$filter [ 'id_server' ] = $id_server ;
}
$return = agents_get_group_agents ( $id_group , $filter , 'none' , false , false , $serialized );
}
switch ( $mode ) {
case 'json' :
default :
echo json_encode ( $return );
break ;
}
return ;
2012-03-12 17:23:50 +01:00
}
2010-04-06 18:24:54 +02:00
2015-08-05 10:36:35 +02:00
if ( $search_agents && ( ! is_metaconsole () || $force_local )) {
2019-01-30 16:18:44 +01:00
$id_agent = ( int ) get_parameter ( 'id_agent' );
$string = ( string ) get_parameter ( 'q' );
2019-07-29 16:32:50 +02:00
$string = strtoupper ( $string );
2019-01-30 16:18:44 +01:00
// q is what autocomplete plugin gives
$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' );
2022-05-30 11:29:17 +02:00
$delete_offspring_agents = ( int ) get_parameter ( 'delete_offspring_agents' , 0 );
2019-01-30 16:18:44 +01:00
if ( $addedItems != null ) {
foreach ( $addedItems as $item ) {
echo $item . " | \n " ;
}
}
$filter = [];
if ( $id_group != - 1 ) {
if ( $id_group == 0 ) {
$user_groups = users_get_groups ( $config [ 'id_user' ], 'AR' , true );
$filter [ 'id_grupo' ] = array_keys ( $user_groups );
} else {
$filter [ 'id_grupo' ] = $id_group ;
}
}
if ( $all === 'enabled' ) {
$filter [ 'disabled' ] = 1 ;
} else {
$filter [ 'disabled' ] = 0 ;
}
$data = [];
2022-05-30 11:29:17 +02:00
// Get agents for only the alias.
2019-01-30 16:18:44 +01:00
$filter_alias = $filter ;
2022-05-30 11:29:17 +02:00
$filter_alias [] = '(UPPER(alias) LIKE "%' . $string . '%")' ;
2019-01-30 16:18:44 +01:00
$agents = agents_get_agents ( $filter_alias , [ 'id_agente' , 'nombre' , 'direccion' , 'alias' ]);
if ( $agents !== false ) {
foreach ( $agents as $agent ) {
$data [] = [
'id' => $agent [ 'id_agente' ],
'name' => io_safe_output ( $agent [ 'nombre' ]),
'alias' => io_safe_output ( $agent [ 'alias' ]),
'ip' => io_safe_output ( $agent [ 'direccion' ]),
'filter' => 'alias' ,
];
}
}
// Get agents for only the name.
$filter_agents = $filter ;
2022-05-30 11:29:17 +02:00
$filter_agents [] = '(UPPER(alias) NOT LIKE "%' . $string . '%" AND UPPER(nombre) LIKE "%' . $string . '%")' ;
2019-01-30 16:18:44 +01:00
$agents = agents_get_agents ( $filter_agents , [ 'id_agente' , 'nombre' , 'direccion' , 'alias' ]);
if ( $agents !== false ) {
foreach ( $agents as $agent ) {
$data [] = [
'id' => $agent [ 'id_agente' ],
'name' => io_safe_output ( $agent [ 'nombre' ]),
'alias' => io_safe_output ( $agent [ 'alias' ]),
'ip' => io_safe_output ( $agent [ 'direccion' ]),
'filter' => 'agent' ,
];
}
}
2022-05-30 11:29:17 +02:00
// Get agents for only the address.
2019-01-30 16:18:44 +01:00
$filter_address = $filter ;
2022-05-30 11:29:17 +02:00
$filter_address [] = '(UPPER(alias) NOT LIKE "%' . $string . '%" AND UPPER(nombre) NOT LIKE "%' . $string . '%" AND UPPER(direccion) LIKE "%' . $string . '%")' ;
2019-01-30 16:18:44 +01:00
$agents = agents_get_agents ( $filter_address , [ 'id_agente' , 'nombre' , 'direccion' , 'alias' ]);
if ( $agents !== false ) {
foreach ( $agents as $agent ) {
$data [] = [
'id' => $agent [ 'id_agente' ],
'name' => io_safe_output ( $agent [ 'nombre' ]),
'alias' => io_safe_output ( $agent [ 'alias' ]),
'ip' => io_safe_output ( $agent [ 'direccion' ]),
'filter' => 'address' ,
];
}
}
2022-05-30 11:29:17 +02:00
// Get agents for only the description.
2019-01-30 16:18:44 +01:00
$filter_description = $filter ;
2022-05-30 11:29:17 +02:00
$filter_description [] = '(UPPER(alias) NOT LIKE "%' . $string . '%" AND UPPER(nombre) NOT LIKE "%' . $string . '%" AND UPPER(direccion) NOT LIKE "%' . $string . '%" AND UPPER(comentarios) LIKE "%' . $string . '%")' ;
2019-01-30 16:18:44 +01:00
$agents = agents_get_agents ( $filter_description , [ 'id_agente' , 'nombre' , 'direccion' , 'alias' ]);
if ( $agents !== false ) {
foreach ( $agents as $agent ) {
$data [] = [
'id' => $agent [ 'id_agente' ],
'name' => io_safe_output ( $agent [ 'nombre' ]),
'alias' => io_safe_output ( $agent [ 'alias' ]),
'ip' => io_safe_output ( $agent [ 'direccion' ]),
'filter' => 'description' ,
];
}
}
2022-05-30 11:29:17 +02:00
if ( empty ( $data ) === false && $delete_offspring_agents !== 0 ) {
// Gets offspring and deletes them, including himself.
$agents_offspring = agents_get_offspring ( $delete_offspring_agents );
if ( empty ( $agents_offspring ) === false ) {
foreach ( $data as $key => $value ) {
if ( isset ( $agents_offspring [ $value [ 'id' ]]) === true ) {
unset ( $data [ $key ]);
}
}
}
}
2019-01-30 16:18:44 +01:00
echo json_encode ( $data );
return ;
} else if ( $search_agents && is_metaconsole ()) {
$id_agent = ( int ) get_parameter ( 'id_agent' );
$string = ( string ) get_parameter ( 'q' );
2020-10-20 18:30:53 +02:00
// Q is what autocomplete plugin gives.
2019-01-30 16:18:44 +01:00
$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 ) {
echo $item . " | \n " ;
}
}
$data = [];
$fields = [
'id_tagente AS id_agente' ,
'nombre' ,
'alias' ,
'direccion' ,
'id_tmetaconsole_setup AS id_server' ,
2020-10-20 18:30:53 +02:00
'server_name' ,
2019-01-30 16:18:44 +01:00
];
$filter = [];
if ( $id_group != - 1 ) {
if ( $id_group == 0 ) {
$user_groups = users_get_groups ( $config [ 'id_user' ], 'AR' , true );
$filter [ 'id_grupo' ] = array_keys ( $user_groups );
} else {
$filter [ 'id_grupo' ] = $id_group ;
}
}
switch ( $all ) {
case 'enabled' :
$filter [ 'disabled' ] = 0 ;
break ;
2020-10-20 18:30:53 +02:00
default :
// Not possible.
break ;
2019-01-30 16:18:44 +01:00
}
2020-10-20 18:30:53 +02:00
if ( empty ( $id_agent ) === false ) {
2019-01-30 16:18:44 +01:00
$filter [ 'id_agente' ] = $id_agent ;
}
2020-10-20 18:30:53 +02:00
if ( empty ( $string ) === false ) {
2019-01-30 16:18:44 +01:00
// Get agents for only the alias.
$filter_alias = $filter ;
2022-02-01 15:18:45 +01:00
$filter_alias [] = '(alias LIKE "%' . $string . '%")' ;
2020-10-20 18:30:53 +02:00
$agents = db_get_all_rows_filter (
'tmetaconsole_agent' ,
$filter_alias ,
$fields
);
2019-01-30 16:18:44 +01:00
if ( $agents !== false ) {
foreach ( $agents as $agent ) {
$data [] = [
'id' => $agent [ 'id_agente' ],
'name' => io_safe_output ( $agent [ 'nombre' ]),
2020-10-20 18:30:53 +02:00
'alias' => io_safe_output ( $agent [ 'alias' ]) . ' (' . io_safe_output ( $agent [ 'server_name' ]) . ')' ,
2019-01-30 16:18:44 +01:00
'ip' => io_safe_output ( $agent [ 'direccion' ]),
'id_server' => $agent [ 'id_server' ],
'filter' => 'alias' ,
];
}
}
// Get agents for only the name.
$filter_agents = $filter ;
2022-02-01 15:18:45 +01:00
$filter_agents [] = '(alias NOT LIKE "%' . $string . '%" AND nombre LIKE "%' . $string . '%")' ;
2020-10-20 18:30:53 +02:00
$agents = db_get_all_rows_filter (
'tmetaconsole_agent' ,
$filter_agents ,
$fields
);
2019-01-30 16:18:44 +01:00
if ( $agents !== false ) {
foreach ( $agents as $agent ) {
$data [] = [
'id' => $agent [ 'id_agente' ],
'name' => io_safe_output ( $agent [ 'nombre' ]),
2020-10-20 18:30:53 +02:00
'alias' => io_safe_output ( $agent [ 'alias' ]) . ' (' . io_safe_output ( $agent [ 'server_name' ]) . ')' ,
2019-01-30 16:18:44 +01:00
'ip' => io_safe_output ( $agent [ 'direccion' ]),
'id_server' => $agent [ 'id_server' ],
'filter' => 'agent' ,
];
}
}
2020-10-20 18:30:53 +02:00
// Get agents for only the address.
2019-01-30 16:18:44 +01:00
$filter_address = $filter ;
2022-02-01 15:18:45 +01:00
$filter_address [] = '(alias NOT LIKE "%' . $string . '%" AND nombre NOT LIKE "%' . $string . '%" AND direccion LIKE "%' . $string . '%")' ;
2020-10-20 18:30:53 +02:00
$agents = db_get_all_rows_filter (
'tmetaconsole_agent' ,
$filter_address ,
$fields
);
2019-01-30 16:18:44 +01:00
if ( $agents !== false ) {
foreach ( $agents as $agent ) {
$data [] = [
'id' => $agent [ 'id_agente' ],
'name' => io_safe_output ( $agent [ 'nombre' ]),
2020-10-20 18:30:53 +02:00
'alias' => io_safe_output ( $agent [ 'alias' ]) . ' (' . io_safe_output ( $agent [ 'server_name' ]) . ')' ,
2019-01-30 16:18:44 +01:00
'ip' => io_safe_output ( $agent [ 'direccion' ]),
'id_server' => $agent [ 'id_server' ],
'filter' => 'address' ,
];
}
}
2020-10-20 18:30:53 +02:00
// Get agents for only the description.
2019-01-30 16:18:44 +01:00
$filter_description = $filter ;
2022-02-01 15:18:45 +01:00
$filter_description [] = '(alias NOT LIKE "%' . $string . '%" AND nombre NOT LIKE "%' . $string . '%" AND direccion NOT LIKE "%' . $string . '%" AND comentarios LIKE "%' . $string . '%")' ;
2020-10-20 18:30:53 +02:00
$agents = db_get_all_rows_filter (
'tmetaconsole_agent' ,
$filter_description ,
$fields
);
2019-01-30 16:18:44 +01:00
if ( $agents !== false ) {
foreach ( $agents as $agent ) {
$data [] = [
'id' => $agent [ 'id_agente' ],
'name' => io_safe_output ( $agent [ 'nombre' ]),
2020-10-20 18:30:53 +02:00
'alias' => io_safe_output ( $agent [ 'alias' ]) . ' (' . io_safe_output ( $agent [ 'server_name' ]) . ')' ,
2019-01-30 16:18:44 +01:00
'ip' => io_safe_output ( $agent [ 'direccion' ]),
'id_server' => $agent [ 'id_server' ],
'filter' => 'description' ,
];
}
}
}
echo json_encode ( $data );
return ;
2012-03-05 Miguel de Dios <miguel.dedios@artica.es>
* extensions/update_manager/main.php, general/shortcut_bar.php,
godmode/reporting/reporting_builder.item_editor.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.preview.php, include/functions_api.php,
include/functions_html.php, include/htmlawed.php, include/pchart_graph.php,
operation/events/events_list.php, operation/netflow/nf_live_view.php:
cleaned source code style.
* godmode/menu.php, godmode/agentes/manage_config_remote.php: removed the
enterprise feature that have been wrong for years.
* general/header.php: changed to load the jquery-ui and jquery javascript
library to last version.
* extensions/insert_data.php, extensions/snmp_explorer.php,
godmode/agentes/agent_manager.php, include/ajax/agent.php,
include/javascript/pandora.js, operation/agentes/exportdata.php,
operation/events/events.php: changed the unknow plugin autocomplete for
the autocomple from jquery-ui.
* include/functions_ui.php: cleaned source code style and into the function
"ui_process_page_head" added the blacklist hardwrote for to use old jquery.
* include/styles/jquery-ui-1.8.17.custom.css,
include/javascript/jquery-1.7.1.min.js,
include/javascript/jquery.jquery-ui-1.8.17.custom.min.js: added the last
version of Jquery and Jquery-ui.
Merge from the branch "pandora_4.0"
* godmode/reporting/visual_console_builder.constans.php,
godmode/reporting/visual_console_builder.editor.js,
godmode/reporting/visual_console_builder.editor.php,
include/functions_visual_map.php,
include/ajax/visual_console_builder.ajax.php,
include/javascript/pandora_visual_console.js: changed the unknow
plugin autocomplete for the autocomple from jquery-ui and added function to
paint a Bubble Chart (http://en.wikipedia.org/wiki/Bubble_chart) with the
name "progress_bubble".
* images/percentile_item.disabled.png, images/percentile_item.png: added
images for button of percentile item (new item in visual map).
* include/styles/pandora.css: added the style for the new button percentile
item.
* include/functions_graph.php, include/graphs/fgraph.php,
include/graphs/functions_gd.php: cleaned source code style, and added the
params to set text and color in the function "progress_bar" and added
function to paint a Bubble Chart (http://en.wikipedia.org/wiki/Bubble_chart)
with the name "progress_bubble".
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@5693 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-03-05 18:56:56 +01:00
}
2015-06-11 12:08:02 +02:00
2023-01-25 17:22:54 +01:00
// Saves an event filter.
if ( $save_agent_filter ) {
$values = [];
$values [ 'id_name' ] = get_parameter ( 'id_name' );
$values [ 'group_id' ] = get_parameter ( 'group_id' );
$values [ 'recursion' ] = get_parameter ( 'recursion' );
$values [ 'status' ] = get_parameter ( 'status' );
$values [ 'search' ] = get_parameter ( 'search' );
$values [ 'id_os' ] = get_parameter ( 'id_os' );
$values [ 'policies' ] = json_encode ( get_parameter ( 'policies' ));
$values [ 'search_custom' ] = get_parameter ( 'search_custom' );
$values [ 'ag_custom_fields' ] = get_parameter ( 'ag_custom_fields' );
2023-02-28 17:06:31 +01:00
$values [ 'id_group_filter' ] = get_parameter ( 'id_group_filter' );
2023-01-25 17:22:54 +01:00
$exists = ( bool ) db_get_value_filter (
'id_filter' ,
'tagent_filter' ,
$values
);
if ( $exists === true ) {
echo 'duplicate' ;
} else {
$result = db_process_sql_insert ( 'tagent_filter' , $values );
if ( $result === false ) {
echo 'error' ;
} else {
echo $result ;
}
}
}
if ( $update_agent_filter ) {
$values = [];
$id = get_parameter ( 'id' );
$values [ 'group_id' ] = get_parameter ( 'group_id' );
$values [ 'recursion' ] = get_parameter ( 'recursion' );
$values [ 'status' ] = get_parameter ( 'status' );
$values [ 'search' ] = get_parameter ( 'search' );
$values [ 'id_os' ] = get_parameter ( 'id_os' );
$values [ 'policies' ] = json_encode ( get_parameter ( 'policies' ));
$values [ 'search_custom' ] = get_parameter ( 'search_custom' );
$values [ 'ag_custom_fields' ] = get_parameter ( 'ag_custom_fields' );
$result = db_process_sql_update (
'tagent_filter' ,
$values ,
[ 'id_filter' => $id ]
);
if ( $result === false ) {
echo 'error' ;
} else {
echo 'ok' ;
}
}
2023-02-28 17:06:31 +01:00
if ( $delete_agent_filter ) {
$id = get_parameter ( 'id' );
$user_groups = users_get_groups (
$config [ 'id_user' ],
'AW' ,
users_can_manage_group_all ( 'AW' ),
true
);
$sql = ' DELETE
FROM tagent_filter
WHERE id_filter = '.$id.' AND id_group_filter IN ( '.implode(' , ', array_keys($user_groups)).' ) ' ;
$agent_filters = db_process_sql ( $sql );
if ( $agent_filters === false ) {
echo 'error' ;
} else {
echo 'ok' ;
}
}
2023-01-25 17:22:54 +01:00
if ( $get_agent_filters ) {
2023-02-28 17:06:31 +01:00
$user_groups = users_get_groups (
$config [ 'id_user' ],
'AR' ,
users_can_manage_group_all ( 'AR' ),
true
);
$sql = ' SELECT id_filter , id_name
FROM tagent_filter
WHERE id_group_filter IN ( '.implode(' , ', array_keys($user_groups)).' ) ' ;
2023-01-25 17:22:54 +01:00
$agent_filters = db_get_all_rows_sql ( $sql );
$result = [];
if ( $agent_filters !== false ) {
foreach ( $agent_filters as $agent_filter ) {
$result [ $agent_filter [ 'id_filter' ]] = $agent_filter [ 'id_name' ];
}
}
echo io_json_mb_encode ( $result );
}
if (( int ) $load_filter_modal === 1 ) {
$user_groups = users_get_groups (
$config [ 'id_user' ],
'AR' ,
2023-02-28 17:06:31 +01:00
users_can_manage_group_all ( 'AR' ),
2023-01-25 17:22:54 +01:00
true
);
$sql = ' SELECT id_filter , id_name
FROM tagent_filter
WHERE id_group_filter IN ( '.implode(' , ', array_keys($user_groups)).' ) ' ;
2023-02-28 17:06:31 +01:00
$agent_filters = db_get_all_rows_sql ( $sql );
2023-01-25 17:22:54 +01:00
$filters = [];
2023-02-28 17:06:31 +01:00
foreach ( $agent_filters as $agent_filter ) {
$filters [ $agent_filter [ 'id_filter' ]] = $agent_filter [ 'id_name' ];
2023-01-25 17:22:54 +01:00
}
echo '<div id="load-filter-select" class="load-filter-modal">' ;
echo '<form method="post" id="form_load_filter" action="index.php?sec=view&sec2=operation/agentes/estado_agente&pure=">' ;
$table = new StdClass ;
$table -> id = 'load_filter_form' ;
$table -> width = '100%' ;
2023-03-03 14:16:06 +01:00
$table -> class = 'filter-table-adv' ;
2023-01-25 17:22:54 +01:00
$data = [];
$table -> rowid [ 3 ] = 'update_filter_row1' ;
2023-03-03 14:16:06 +01:00
$data [ 0 ] = html_print_label_input_block (
2023-01-25 17:22:54 +01:00
__ ( 'Load filter' ),
2023-03-03 14:16:06 +01:00
html_print_select (
$filters ,
'filter_id' ,
$current ,
'' ,
__ ( 'None' ),
0 ,
true ,
false ,
true ,
'' ,
false
)
2023-01-25 17:22:54 +01:00
);
2023-03-03 14:16:06 +01:00
2023-01-25 17:22:54 +01:00
$table -> data [] = $data ;
$table -> rowclass [] = '' ;
2023-03-03 14:16:06 +01:00
2023-01-25 17:22:54 +01:00
html_print_table ( $table );
2023-03-03 14:16:06 +01:00
html_print_div (
[
'class' => 'action-buttons' ,
'content' => html_print_submit_button (
__ ( 'Load filter' ),
'srcbutton' ,
false ,
[
'icon' => 'search' ,
'mode' => 'mini' ,
],
true
),
],
false
);
echo html_print_input_hidden ( 'load_filter' , 1 , true );
2023-01-25 17:22:54 +01:00
echo '</form>' ;
echo '</div>' ;
?>
< script type = " text/javascript " >
function show_filter () {
$ ( " #load-filter-select " ) . dialog ({
resizable : true ,
draggable : true ,
modal : false ,
closeOnEscape : true ,
width : 450
});
}
$ ( document ) . ready ( function () {
show_filter ();
});
</ script >
< ? php
return ;
}
if ( $save_filter_modal ) {
echo '<div id="save-filter-select">' ;
if ( check_acl ( $config [ 'id_user' ], 0 , 'AW' )) {
echo '<div id="#info_box"></div>' ;
$table = new StdClass ;
$table -> id = 'save_filter_form' ;
$table -> width = '100%' ;
2023-03-03 14:16:06 +01:00
$table -> size = [];
$table -> size [ 0 ] = '50%' ;
$table -> size [ 1 ] = '50%' ;
$table -> class = 'filter-table-adv' ;
2023-01-25 17:22:54 +01:00
$data = [];
2023-03-03 14:16:06 +01:00
$table -> rowid [ 0 ] = 'update_save_selector' ;
$data [ 0 ][ 0 ] = html_print_label_input_block (
__ ( 'New filter' ),
html_print_radio_button (
'filter_mode' ,
'new' ,
'' ,
true ,
true
)
);
2023-01-25 17:22:54 +01:00
2023-03-03 14:16:06 +01:00
$data [ 0 ][ 1 ] = html_print_label_input_block (
__ ( 'Update/delete filter' ),
html_print_radio_button (
'filter_mode' ,
'update' ,
'' ,
false ,
true
)
);
2023-01-25 17:22:54 +01:00
$table -> rowid [ 1 ] = 'save_filter_row1' ;
2023-03-03 14:16:06 +01:00
$data [ 1 ][ 0 ] = html_print_label_input_block (
__ ( 'Filter name' ),
html_print_input_text ( 'id_name' , '' , '' , 15 , 255 , true )
);
2023-01-25 17:22:54 +01:00
2023-03-03 14:16:06 +01:00
$labelInput = __ ( 'Filter group' );
2023-01-25 17:22:54 +01:00
if ( is_metaconsole () === true ) {
2023-03-03 14:16:06 +01:00
$labelInput = __ ( 'Save in Group' );
2023-01-25 17:22:54 +01:00
}
$user_groups_array = users_get_groups_for_select (
$config [ 'id_user' ],
2023-02-28 17:06:31 +01:00
'AW' ,
users_can_manage_group_all ( 'AW' ),
2023-01-25 17:22:54 +01:00
true
);
2023-03-03 14:16:06 +01:00
$data [ 1 ][ 1 ] = html_print_label_input_block (
$labelInput ,
html_print_select (
$user_groups_array ,
'id_group_filter_dialog' ,
$id_group_filter ,
'' ,
'' ,
0 ,
true ,
false ,
false
),
[ 'div_class' => 'filter-group-dialog' ]
2023-01-25 17:22:54 +01:00
);
$table -> rowid [ 2 ] = 'save_filter_row2' ;
$table -> data [] = $data ;
$table -> rowclass [] = '' ;
2023-02-28 17:06:31 +01:00
$user_groups = users_get_groups (
$config [ 'id_user' ],
'AW' ,
users_can_manage_group_all ( 'AW' ),
true
);
$sql = ' SELECT id_filter , id_name
FROM tagent_filter
WHERE id_group_filter IN ( '.implode(' , ', array_keys($user_groups)).' ) ' ;
2023-01-25 17:22:54 +01:00
$agent_filters = db_get_all_rows_sql ( $sql );
$_filters_update = [];
if ( $agent_filters !== false ) {
foreach ( $agent_filters as $agent_filter ) {
$_filters_update [ $agent_filter [ 'id_filter' ]] = $agent_filter [ 'id_name' ];
}
}
2023-03-03 14:16:06 +01:00
$data [ 2 ][ 0 ] = html_print_label_input_block (
__ ( 'Filter' ),
html_print_select (
$_filters_update ,
'overwrite_filter' ,
'' ,
'' ,
'' ,
0 ,
true
)
2023-01-25 17:22:54 +01:00
);
2023-03-03 14:16:06 +01:00
$table -> data = $data ;
2023-01-25 17:22:54 +01:00
html_print_table ( $table );
2023-03-03 14:16:06 +01:00
html_print_div (
[
'id' => 'submit-save_filter' ,
'class' => 'action-buttons' ,
'content' => html_print_submit_button (
__ ( 'Save current filter' ),
'srcbutton' ,
false ,
[
'icon' => 'search' ,
'mode' => 'mini' ,
'onclick' => 'save_new_filter();' ,
],
true
),
],
false
);
$input_actions = html_print_submit_button (
__ ( 'Delete filter' ),
'delete_filter' ,
false ,
[
'icon' => 'delete' ,
'mode' => 'mini' ,
'onclick' => 'save_delete_filter();' ,
],
true
);
$input_actions .= html_print_submit_button (
__ ( 'Update filter' ),
'srcbutton' ,
false ,
[
'icon' => 'update' ,
'mode' => 'mini' ,
'onclick' => 'save_update_filter();' ,
],
true
);
html_print_div (
[
'id' => 'update_filter_row' ,
'class' => 'action-buttons' ,
'content' => $input_actions ,
],
false
);
2023-01-25 17:22:54 +01:00
} else {
include 'general/noaccess.php' ;
}
echo '</div>' ;
?>
< script type = " text/javascript " >
function show_save_filter () {
2023-03-03 14:16:06 +01:00
$ ( '#save_filter_row2' ) . hide ();
$ ( '#update_filter_row' ) . hide ();
2023-02-28 17:06:31 +01:00
$ ( '#update_delete_row' ) . hide ();
2023-03-03 14:16:06 +01:00
$ ( '.filter-group-dialog' ) . show ();
2023-01-25 17:22:54 +01:00
// Filter save mode selector
$ ( " [name='filter_mode'] " ) . click ( function () {
if ( $ ( this ) . val () == 'new' ) {
2023-03-03 14:16:06 +01:00
$ ( '#save_filter_row2' ) . hide ();
2023-01-25 17:22:54 +01:00
$ ( '#submit-save_filter' ) . show ();
2023-03-03 14:16:06 +01:00
$ ( '#update_filter_row' ) . hide ();
2023-02-28 17:06:31 +01:00
$ ( '#update_delete_row' ) . hide ();
2023-03-03 14:16:06 +01:00
$ ( '.filter-group-dialog' ) . show ();
2023-01-25 17:22:54 +01:00
}
else {
2023-03-03 14:16:06 +01:00
$ ( '#save_filter_row2' ) . show ();
$ ( '#update_filter_row' ) . show ();
2023-01-25 17:22:54 +01:00
$ ( '#submit-save_filter' ) . hide ();
2023-02-28 17:06:31 +01:00
$ ( '#update_delete_row' ) . show ();
2023-03-03 14:16:06 +01:00
$ ( '.filter-group-dialog' ) . hide ();
2023-01-25 17:22:54 +01:00
}
});
$ ( " #save-filter-select " ) . dialog ({
resizable : true ,
draggable : true ,
modal : false ,
2023-03-03 14:16:06 +01:00
closeOnEscape : true ,
width : 450 ,
height : 350
2023-01-25 17:22:54 +01:00
});
}
function save_new_filter () {
// If the filter name is blank show error
if ( $ ( '#text-id_name' ) . val () == '' ) {
$ ( '#show_filter_error' ) . html ( " <h3 class='error'><?php echo __('Filter name cannot be left blank'); ?></h3> " );
// Close dialog
$ ( '.ui-dialog-titlebar-close' ) . trigger ( 'click' );
return false ;
}
var custom_fields_values = $ ( 'input[name^="ag_custom_fields"]' ) . map ( function () {
return this . value ;
}) . get ();
var custom_fields_ids = $ ( " input[name^='ag_custom_fields'] " ) . map ( function () {
var name = $ ( this ) . attr ( " name " );
var number = name . match ( / \ [( .* ? ) \ ] / )[ 1 ];
return number ;
}) . get ();
var ag_custom_fields = custom_fields_ids . reduce ( function ( result , custom_fields_id , index ) {
result [ custom_fields_id ] = custom_fields_values [ index ];
return result ;
}, {});
var id_filter_save ;
jQuery . post ( " <?php echo ui_get_full_url('ajax.php', false, false, false); ?> " ,
{
" page " : " include/ajax/agent " ,
" save_agent_filter " : 1 ,
" id_name " : $ ( " #text-id_name " ) . val (),
" id " : $ ( " #overwrite_filter " ) . val (),
" group_id " : $ ( " #group_id " ) . val (),
" recursion " : $ ( " #checkbox-recursion " ) . is ( ':checked' ),
" status " : $ ( " #status " ) . val (),
" search " : $ ( " #text-search " ) . val (),
" id_os " : $ ( " #os " ) . val (),
" policies " : $ ( " #policies " ) . val (),
" search_custom " : $ ( " #text-search_custom " ) . val (),
" ag_custom_fields " : JSON . stringify ( ag_custom_fields ),
2023-02-28 17:06:31 +01:00
" id_group_filter " : $ ( " #id_group_filter_dialog " ) . val (),
2023-01-25 17:22:54 +01:00
},
2023-02-28 17:06:31 +01:00
2023-01-25 17:22:54 +01:00
function ( data ) {
$ ( " #info_box " ) . hide ();
if ( data == 'error' ) {
$ ( " #info_box " ) . filter ( function ( i , item ) {
if ( $ ( item ) . data ( 'type_info_box' ) == " error_create_filter " ) {
return true ;
}
else
return false ;
}) . show ();
}
else if ( data == 'duplicate' ) {
$ ( " #info_box " ) . filter ( function ( i , item ) {
if ( $ ( item ) . data ( 'type_info_box' ) == " duplicate_create_filter " ) {
return true ;
}
else
return false ;
}) . show ();
}
else {
id_filter_save = data ;
$ ( " #info_box " ) . filter ( function ( i , item ) {
if ( $ ( item ) . data ( 'type_info_box' ) == " success_create_filter " ) {
return true ;
}
else
return false ;
}) . show ();
}
2023-02-28 17:06:31 +01:00
// First remove all options of filters select.
$ ( '#filter_id' ) . find ( 'option' ) . remove () . end ();
// Add 'none' option.
$ ( '#filter_id' ) . append ( $ ( '<option></option>' ) . html ( < ? php echo " ' " . __ ( 'None' ) . " ' " ; ?> ).attr ("value", 0));
// Reload filters select.
jQuery . post ( " <?php echo ui_get_full_url('ajax.php', false, false, false); ?> " ,
{
" page " : " include/ajax/agent " ,
" get_agent_filters " : 1
},
function ( data ) {
jQuery . each ( data , function ( i , val ) {
s = js_html_entity_decode ( val );
$ ( '#filter_id' ) . append ( $ ( '<option></option>' ) . html ( s ) . attr ( " value " , i ));
});
},
" json "
);
2023-01-25 17:22:54 +01:00
// Close dialog.
$ ( " #save-filter-select " ) . dialog ( 'close' );
}
);
}
function save_update_filter () {
var id_filter_update = $ ( " #overwrite_filter " ) . val ();
var name_filter_update = $ ( " #overwrite_filter option[value=' " + id_filter_update + " '] " ) . text ();
var custom_fields_values = $ ( 'input[name^="ag_custom_fields"]' ) . map ( function () {
return this . value ;
}) . get ();
var custom_fields_ids = $ ( " input[name^='ag_custom_fields'] " ) . map ( function () {
var name = $ ( this ) . attr ( " name " );
var number = name . match ( / \ [( .* ? ) \ ] / )[ 1 ];
return number ;
}) . get ();
var ag_custom_fields = custom_fields_ids . reduce ( function ( result , custom_fields_id , index ) {
result [ custom_fields_id ] = custom_fields_values [ index ];
return result ;
}, {});
jQuery . post ( " <?php echo ui_get_full_url('ajax.php', false, false, false); ?> " ,
{
" page " : " include/ajax/agent " ,
" update_agent_filter " : 1 ,
" id " : $ ( " #overwrite_filter " ) . val (),
" group_id " : $ ( " #group_id " ) . val (),
" recursion " : $ ( " #checkbox-recursion " ) . is ( ':checked' ),
" status " : $ ( " #status " ) . val (),
2023-02-28 17:06:31 +01:00
" search " : $ ( " #text-search " ) . val (),
2023-01-25 17:22:54 +01:00
" id_os " : $ ( " #os " ) . val (),
" policies " : $ ( " #policies " ) . val (),
2023-02-28 17:06:31 +01:00
" search_custom " : $ ( " #text-search_custom " ) . val (),
2023-01-25 17:22:54 +01:00
" ag_custom_fields " : JSON . stringify ( ag_custom_fields ),
},
function ( data ) {
$ ( " .info_box " ) . hide ();
if ( data == 'ok' ) {
$ ( " .info_box " ) . filter ( function ( i , item ) {
if ( $ ( item ) . data ( 'type_info_box' ) == " success_update_filter " ) {
return true ;
}
else
return false ;
}) . show ();
}
else {
$ ( " .info_box " ) . filter ( function ( i , item ) {
if ( $ ( item ) . data ( 'type_info_box' ) == " error_create_filter " ) {
return true ;
}
else
return false ;
}) . show ();
}
});
2023-02-28 17:06:31 +01:00
// First remove all options of filters select.
2023-01-25 17:22:54 +01:00
$ ( '#filter_id' ) . find ( 'option' ) . remove () . end ();
2023-02-28 17:06:31 +01:00
// Add 'none' option.
$ ( '#filter_id' ) . append ( $ ( '<option></option>' ) . html ( < ? php echo " ' " . __ ( 'None' ) . " ' " ; ?> ).attr ("value", 0));
// Reload filters select.
2023-01-25 17:22:54 +01:00
jQuery . post ( " <?php echo ui_get_full_url('ajax.php', false, false, false); ?> " ,
{
" page " : " include/ajax/agent " ,
" get_agent_filters " : 1
},
function ( data ) {
jQuery . each ( data , function ( i , val ) {
s = js_html_entity_decode ( val );
if ( i == id_filter_update ) {
$ ( '#filter_id' ) . append ( $ ( '<option selected="selected"></option>' ) . html ( s ) . attr ( " value " , i ));
}
else {
$ ( '#filter_id' ) . append ( $ ( '<option></option>' ) . html ( s ) . attr ( " value " , i ));
}
});
},
" json "
);
// Close dialog
$ ( '.ui-dialog-titlebar-close' ) . trigger ( 'click' );
// Update the info with the loaded filter
$ ( " #hidden-id_name " ) . val ( $ ( '#text-id_name' ) . val ());
$ ( '#filter_loaded_span' ) . html ( $ ( '#filter_loaded_text' ) . html () + ': ' + name_filter_update );
return false ;
}
2023-02-28 17:06:31 +01:00
function save_delete_filter () {
var id_filter_update = $ ( " #overwrite_filter " ) . val ();
jQuery . post ( " <?php echo ui_get_full_url('ajax.php', false, false, false); ?> " ,
{
" page " : " include/ajax/agent " ,
" delete_agent_filter " : 1 ,
" id " : $ ( " #overwrite_filter " ) . val (),
},
function ( data ) {
$ ( " .info_box " ) . hide ();
if ( data == 'ok' ) {
$ ( " .info_box " ) . filter ( function ( i , item ) {
if ( $ ( item ) . data ( 'type_info_box' ) == " success_update_filter " ) {
return true ;
}
else
return false ;
}) . show ();
}
else {
$ ( " .info_box " ) . filter ( function ( i , item ) {
if ( $ ( item ) . data ( 'type_info_box' ) == " error_create_filter " ) {
return true ;
}
else
return false ;
}) . show ();
}
});
// First remove all options of filters select.
$ ( '#filter_id' ) . find ( 'option' ) . remove () . end ();
// Add 'none' option.
$ ( '#filter_id' ) . append ( $ ( '<option></option>' ) . html ( < ? php echo " ' " . __ ( 'None' ) . " ' " ; ?> ).attr ("value", 0));
// Reload filters select.
jQuery . post ( " <?php echo ui_get_full_url('ajax.php', false, false, false); ?> " ,
{
" page " : " include/ajax/agent " ,
" get_agent_filters " : 1
},
function ( data ) {
jQuery . each ( data , function ( i , val ) {
s = js_html_entity_decode ( val );
if ( i == id_filter_update ) {
$ ( '#filter_id' ) . append ( $ ( '<option selected="selected"></option>' ) . html ( s ) . attr ( " value " , i ));
}
else {
$ ( '#filter_id' ) . append ( $ ( '<option></option>' ) . html ( s ) . attr ( " value " , i ));
}
});
},
" json "
);
// Close dialog
$ ( '.ui-dialog-titlebar-close' ) . trigger ( 'click' );
return false ;
}
2023-01-25 17:22:54 +01:00
$ ( document ) . ready ( function () {
show_save_filter ();
});
</ script >
< ? php
return ;
}
2015-06-11 12:08:02 +02:00
return ;