diff --git a/pandora_server/util/pandora_manage.pl b/pandora_server/util/pandora_manage.pl index 5c34e7e952..4335a346a5 100644 --- a/pandora_server/util/pandora_manage.pl +++ b/pandora_server/util/pandora_manage.pl @@ -115,6 +115,7 @@ sub help_screen{ help_screen_line('--get_planned_downtimes_items', ' [ ]', 'Get all items of planned downtimes'); help_screen_line('--set_planned_downtimes_deleted', ' ', 'Deleted a planned downtime'); help_screen_line('--get_agent_group', '', 'Get the group name of an agent'); + help_screen_line('--get_agent_group_id', '', 'Get the group ID of an agent'); help_screen_line('--get_agent_modules', '', 'Get the modules of an agent'); help_screen_line('--get_agents', '[ ]', "Get \n\t list of agents with optative filter parameters"); help_screen_line('--delete_conf_file', '', 'Delete a local conf of a given agent'); @@ -971,10 +972,31 @@ sub cli_delete_agent() { $agent_name = decode_entities($agent_name); print_log "[INFO] Deleting agent '$agent_name'\n\n"; - my $id_agent = get_agent_id($dbh,$agent_name); - exist_check($id_agent,'agent',$agent_name); + if (is_metaconsole($conf) == 1) { + my $servers = enterprise_hook('get_metaconsole_setup_servers',[$dbh]); + my @servers_id = split(',',$servers); + my @list_servers; + my $list_names_servers; + foreach my $server (@servers_id) { + my $dbh_metaconsole = enterprise_hook('get_node_dbh',[$conf, $server, $dbh]); + + my $id_agent = get_agent_id($dbh_metaconsole,$agent_name); + + if ($id_agent == -1) { + next; + } + else { + pandora_delete_agent($dbh_metaconsole,$id_agent,$conf); + } + } + } + else { - pandora_delete_agent($dbh,$id_agent,$conf); + my $id_agent = get_agent_id($dbh,$agent_name); + exist_check($id_agent,'agent',$agent_name); + + pandora_delete_agent($dbh,$id_agent,$conf); + } } @@ -3139,14 +3161,96 @@ sub cli_validate_policy_alerts() { sub cli_get_agent_group() { my $agent_name = @ARGV[2]; - my $id_agent = get_agent_id($dbh,$agent_name); - exist_check($id_agent,'agent',$agent_name); - - my $id_group = get_agent_group ($dbh, $id_agent); - - my $group_name = get_group_name ($dbh, $id_group); + if (is_metaconsole($conf) == 1) { + + my $agents_groups = enterprise_hook('get_metaconsole_agent',[$dbh, $agent_name]); + + if (scalar(@{$agents_groups}) != 0) { + foreach my $agent (@{$agents_groups}) { + my @test = $agent; + print Dumper $test[0]; + my $group_name = get_group_name ($dbh, $agent->{'id_grupo'}); + print "Server: $agent->{'server_name'} Agent: $agent->{'nombre'} Name Group: $group_name \n\n"; + } + } + else { + my $servers = enterprise_hook('get_metaconsole_setup_servers',[$dbh]); + my @servers_id = split(',',$servers); + my @list_servers; + my $list_names_servers; + foreach my $server (@servers_id) { + my $dbh_metaconsole = enterprise_hook('get_node_dbh',[$conf, $server, $dbh]); + + my $id_agent = get_agent_id($dbh_metaconsole,$agent_name); + + if ($id_agent == -1) { + next; + } + else { + my $id_group = get_agent_group ($dbh_metaconsole, $id_agent); + my $group_name = get_group_name ($dbh_metaconsole, $id_group); + my $metaconsole_name = enterprise_hook('get_metaconsole_setup_server_name',[$dbh, $server]); + print "[INFO] Server: $metaconsole_name Agent: $agent_name Name Group: $group_name\n\n"; + } + } + } + } + else { + my $id_agent = get_agent_id($dbh,$agent_name); + exist_check($id_agent,'agent',$agent_name); + + my $id_group = get_agent_group ($dbh, $id_agent); + + my $group_name = get_group_name ($dbh, $id_group); + print $group_name; + } +} - print $group_name; +############################################################################## +# Show the group id where is a given agent +# Related option: --get_agent_group_id +############################################################################## +sub cli_get_agent_group_id() { + my $agent_name = @ARGV[2]; + + if (is_metaconsole($conf) == 1) { + my $agents_groups = enterprise_hook('get_metaconsole_agent',[$dbh, $agent_name]); + + if (scalar(@{$agents_groups}) != 0) { + + foreach my $agent (@{$agents_groups}) { + print "Server: $agent->{'server_name'} Agent: $agent->{'nombre'} ID Group: $agent->{'id_grupo'}\n\n"; + } + } + else { + my $servers = enterprise_hook('get_metaconsole_setup_servers',[$dbh]); + my @servers_id = split(',',$servers); + my @list_servers; + my $list_names_servers; + foreach my $server (@servers_id) { + my $dbh_metaconsole = enterprise_hook('get_node_dbh',[$conf, $server, $dbh]); + + my $metaconsole_name = enterprise_hook('get_metaconsole_setup_server_name',[$dbh, $server]); + my $id_agent = get_agent_id($dbh_metaconsole,$agent_name); + + if ($id_agent == -1) { + next; + } + else { + my $id_group = get_agent_group ($dbh_metaconsole, $id_agent); + print "Server: $metaconsole_name Agent: $agent_name ID Group: $id_group\n\n"; + } + } + } + } + else { + my $id_agent = get_agent_id($dbh,$agent_name); + exist_check($id_agent,'agent',$agent_name); + + my $id_group = get_agent_group ($dbh, $id_agent); + + print $id_group; + } } ############################################################################## @@ -3661,12 +3765,99 @@ sub cli_create_group() { $description = '' unless defined($description); $group_id = pandora_create_group ($group_name, $icon, $parent_group_id, 0, 0, '', 0, $description, $dbh); - + if($group_id == -1) { print_log "[ERROR] A problem has been ocurred creating group '$group_name'\n\n"; } + else { + if (is_metaconsole($conf) == 1) { + my $servers = enterprise_hook('get_metaconsole_setup_servers',[$dbh]); + my @servers_id = split(',',$servers); + my $count_error = 0; + my $count_success = 0; + foreach my $server (@servers_id) { + my $dbh_metaconsole = enterprise_hook('get_node_dbh',[$conf, $server, $dbh]); + my $group_id_nodo; + + my $group_id = get_group_id($dbh_metaconsole,$group_name); + + if ($group_id != -1) { + $count_error++; + next; + } + + eval { + $group_id_nodo = db_insert ($dbh_metaconsole, 'id_grupo', 'INSERT INTO tgrupo (id_grupo, nombre, icon, parent, propagate, disabled, + custom_id, id_skin, description) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)', $group_name, safe_input($group_name), $icon, + $parent_group_id, 0, 0, '', 0, $description); + }; + if ($@) { + print_log "[ERROR] Problems with IDS and doesnt created group\n\n"; + $count_error++; + next; + } + + if ($group_id_nodo == -1) { + $count_error++; + } + else { + $count_success++; + } + } + + print_log "[INFO] Created group success: $count_success error: $count_error\n\n"; + } + else { + print_log "[INFO] Created group '$group_name'\n\n"; + } + } +} + +############################################################################### +# Locate agent in any Nodes of metaconsole +# Related option: --locate_agent +############################################################################### +sub cli_locate_agent () { + my ($agent_name) = @ARGV[2]; + + if (is_metaconsole($conf) == 1) { + my $agents_server = enterprise_hook('get_metaconsole_agent',[$dbh, $agent_name]); + + if (scalar(@{$agents_server}) != 0) { + foreach my $agent (@{$agents_server}) { + my $server = enterprise_hook('get_metaconsole_setup_server_id',[$dbh, $agent->{'server_name'}]); + print " $server \n\n " + } + } + else { + my $servers = enterprise_hook('get_metaconsole_setup_servers',[$dbh]); + my @servers_id = split(',',$servers); + my @list_servers; + my $list_names_servers; + foreach my $server (@servers_id) { + my $dbh_metaconsole = enterprise_hook('get_node_dbh',[$conf, $server, $dbh]); + + my $agent_id = get_agent_id($dbh_metaconsole,$agent_name); + + if ($agent_id == -1) { + next; + } + else { + push @list_servers,$server; + } + } + + if (defined(@list_servers)) { + $list_names_servers = join(',',@list_servers); + print_log "[INFO] The agent: $agent_name find in server with IDS: $list_names_servers\n\n"; + } + else { + print_log "[ERROR] This agent: $agent_name not find in any node\n\n"; + } + } + } else { - print_log "[INFO] Created group '$group_name'\n\n"; + print_log "[ERROR] This functions only working in metaconsole system\n\n"; } } @@ -4326,6 +4517,10 @@ sub pandora_manage_main ($$$) { param_check($ltotal, 1); cli_get_agent_group(); } + elsif ($param eq '--get_agent_group_id') { + param_check($ltotal, 1); + cli_get_agent_group_id(); + } elsif ($param eq '--get_agents_module_current_data') { param_check($ltotal, 1); cli_get_agents_module_current_data(); @@ -4458,6 +4653,10 @@ sub pandora_manage_main ($$$) { param_check($ltotal, 1); cli_set_delete_planned_downtime(); } + elsif ($param eq '--locate_agent') { + param_check($ltotal, 1); + cli_locate_agent(); + } else { print_log "[ERROR] Invalid option '$param'.\n\n"; $param = '';