2010-03-24 14:09:09 +01:00
#!/usr/bin/perl
###############################################################################
# Pandora FMS General Management Tool
###############################################################################
2020-11-27 13:52:35 +01:00
# Copyright (c) 2015-2021 Artica Soluciones Tecnologicas S.L
2010-03-24 14:09:09 +01:00
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License version 2
###############################################################################
# Includes list
use strict ;
use Time::Local ; # DateTime basic manipulation
use DBI ; # DB interface with MySQL
2010-05-19 Ramon Novoa <rnovoa@artica.es>
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/Config.pm,
lib/PandoraFMS/Server.pm, lib/PandoraFMS/NetworkServer.pm,
lib/PandoraFMS/GIS.pm, lib/PandoraFMS/WMIServer.pm,
lib/PandoraFMS/PluginServer.pm, lib/PandoraFMS/ProducerConsumerServer.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
bin/pandora_server, util/pandora_db.pl, util/gpx2pandora_agent_data.pl,
util/pandora_manage.pl, util/pandora_dbstress.pl: Added the default library path
used by RPM and DEB packages.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@2755 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2010-05-19 18:59:00 +02:00
use POSIX qw( strftime ) ;
2010-05-27 18:24:52 +02:00
use POSIX ;
2010-09-03 12:59:43 +02:00
use HTML::Entities ; # Encode or decode strings with HTML entities
2012-12-28 09:26:49 +01:00
use File::Basename ;
2014-08-21 02:39:25 +02:00
use JSON qw( decode_json encode_json ) ;
2013-09-09 18:09:34 +02:00
use MIME::Base64 ;
2014-08-21 02:39:25 +02:00
use Encode qw( decode encode_utf8 ) ;
2015-03-26 13:41:07 +01:00
use LWP::Simple ;
2022-10-27 09:40:33 +02:00
use Data::Dumper ;
2010-05-19 Ramon Novoa <rnovoa@artica.es>
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/Config.pm,
lib/PandoraFMS/Server.pm, lib/PandoraFMS/NetworkServer.pm,
lib/PandoraFMS/GIS.pm, lib/PandoraFMS/WMIServer.pm,
lib/PandoraFMS/PluginServer.pm, lib/PandoraFMS/ProducerConsumerServer.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
bin/pandora_server, util/pandora_db.pl, util/gpx2pandora_agent_data.pl,
util/pandora_manage.pl, util/pandora_dbstress.pl: Added the default library path
used by RPM and DEB packages.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@2755 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2010-05-19 18:59:00 +02:00
# Default lib dir for RPM and DEB packages
2021-04-15 17:56:02 +02:00
BEGIN { push @ INC , '/usr/lib/perl5' ; }
2010-05-19 Ramon Novoa <rnovoa@artica.es>
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/Config.pm,
lib/PandoraFMS/Server.pm, lib/PandoraFMS/NetworkServer.pm,
lib/PandoraFMS/GIS.pm, lib/PandoraFMS/WMIServer.pm,
lib/PandoraFMS/PluginServer.pm, lib/PandoraFMS/ProducerConsumerServer.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
bin/pandora_server, util/pandora_db.pl, util/gpx2pandora_agent_data.pl,
util/pandora_manage.pl, util/pandora_dbstress.pl: Added the default library path
used by RPM and DEB packages.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@2755 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2010-05-19 18:59:00 +02:00
2010-03-24 14:09:09 +01:00
use PandoraFMS::Tools ;
use PandoraFMS::DB ;
2010-05-27 18:24:52 +02:00
use PandoraFMS::Core ;
use PandoraFMS::Config ;
2010-03-24 14:09:09 +01:00
2014-07-11 08:51:39 +02:00
# To handle 'UTF-8' encoded string in command like arguments (similar to "-CA" option for perl)
use Encode::Locale ;
Encode::Locale:: decode_argv ;
2010-03-24 14:09:09 +01:00
# version: define current version
2023-02-22 01:02:03 +01:00
my $ version = "7.0NG.769 Build 230222" ;
2010-03-24 14:09:09 +01:00
2012-12-28 09:26:49 +01:00
# save program name for logging
my $ progname = basename ( $ 0 ) ;
2010-05-27 18:24:52 +02:00
# Parameter
my $ param ;
# Initialize MD5 variables
md5_init ( ) ;
2010-03-24 14:09:09 +01:00
# Pandora server configuration
my % conf ;
# FLUSH in each IO
$| = 0 ;
# Init
2010-06-09 12:04:02 +02:00
pandora_manage_init ( \ % conf ) ;
2010-03-24 14:09:09 +01:00
# Read config file
pandora_load_config ( \ % conf ) ;
# Load enterprise module
2014-10-24 15:17:29 +02:00
my $ enterprise_msg ;
2010-03-24 14:09:09 +01:00
if ( enterprise_load ( \ % conf ) == 0 ) {
2014-10-24 15:17:29 +02:00
$ enterprise_msg = "[*] Pandora FMS Enterprise module not available." ;
2010-03-24 14:09:09 +01:00
} else {
2014-10-24 15:17:29 +02:00
$ enterprise_msg = "[*] Pandora FMS Enterprise module loaded." ;
2010-03-24 14:09:09 +01:00
}
# Connect to the DB
2015-05-12 16:30:05 +02:00
my $ dbh = db_connect ( $ conf { 'dbengine' } , $ conf { 'dbname' } , $ conf { 'dbhost' } , $ conf { 'dbport' } , $ conf { 'dbuser' } , $ conf { 'dbpass' } ) ;
2010-03-24 14:09:09 +01:00
my $ history_dbh = ( $ conf { '_history_db_enabled' } eq '1' ) ? db_connect ( 'mysql' , $ conf { '_history_db_name' } ,
$ conf { '_history_db_host' } , '3306' , $ conf { '_history_db_user' } , $ conf { '_history_db_pass' } ) : undef ;
2014-08-18 15:03:34 +02:00
# Read shared config file
pandora_get_sharedconfig ( \ % conf , $ dbh ) ;
2011-11-14 14:27:21 +01:00
my $ conf = \ % conf ;
2010-03-24 14:09:09 +01:00
# Main
pandora_manage_main ( \ % conf , $ dbh , $ history_dbh ) ;
# Cleanup and exit
db_disconnect ( $ history_dbh ) if defined ( $ history_dbh ) ;
db_disconnect ( $ dbh ) ;
exit ;
2016-01-05 13:17:35 +01:00
########################################################################
########################################################################
2010-05-31 18:04:00 +02:00
# GENERAL FUNCTIONS
2016-01-05 13:17:35 +01:00
########################################################################
########################################################################
2010-05-27 18:24:52 +02:00
2016-01-05 13:17:35 +01:00
########################################################################
2012-01-16 15:55:55 +01:00
# Print a help screen and exit.
2016-01-05 13:17:35 +01:00
########################################################################
2012-01-16 15:55:55 +01:00
sub help_screen {
2020-11-27 13:52:35 +01:00
print "\nPandora FMS CLI $version Copyright (c) 2013-2021 Artica ST\n" ;
2014-10-24 15:17:29 +02:00
print "This program is Free Software, licensed under the terms of GPL License v2\n" ;
print "You can download latest versions and documentation at http://www.pandorafms.org\n\n" ;
print "$enterprise_msg\n\n" ;
2012-01-16 15:55:55 +01:00
print "Usage: $0 <path to pandora_server.conf> [options] \n\n" unless $ param ne '' ;
2012-01-17 14:10:54 +01:00
print "Available options by category:\n\n" unless $ param ne '' ;
2012-01-16 15:55:55 +01:00
print "Available options for $param:\n\n" unless $ param eq '' ;
2012-01-17 14:10:54 +01:00
print "AGENTS:\n\n" unless $ param ne '' ;
2018-12-10 12:21:32 +01:00
help_screen_line ( '--create_agent' , "<agent_name> <operating_system> <group> <server_name> \n\t [<address> <description> <interval> <alias_as_name>]" , 'Create agent' ) ;
2019-10-28 09:48:52 +01:00
help_screen_line ( '--update_agent' , '<agent_name> <field_to_change> <new_value> [<use_alias>]' , "Update an agent field. The fields can be \n\t the following: agent_name, address, description, group_name, interval, os_name, disabled (0-1), \n\t parent_name, cascade_protection (0-1), icon_path, update_gis_data (0-1), custom_id" ) ;
help_screen_line ( '--delete_agent' , '<agent_name> [<use_alias>]' , 'Delete agent' ) ;
2012-01-17 14:10:54 +01:00
help_screen_line ( '--disable_group' , '<group_name>' , 'Disable agents from an entire group' ) ;
2016-01-05 13:17:35 +01:00
help_screen_line ( '--enable_group' , '<group_name>' , 'Enable agents from an entire group' ) ;
help_screen_line ( '--create_group' , '<group_name> [<parent_group_name> <icon> <description>]' , 'Create an agent group' ) ;
2016-06-10 13:36:41 +02:00
help_screen_line ( '--delete_group' , '<group_name>' , 'Delete an agent group' ) ;
help_screen_line ( '--update_group' , '<group_id>' , '[<group_name> <parent_group_name> <icon> <description>]' , 'Update an agent group' ) ;
2012-01-17 14:10:54 +01:00
help_screen_line ( '--stop_downtime' , '<downtime_name>' , 'Stop a planned downtime' ) ;
2018-11-06 16:42:03 +01:00
help_screen_line ( '--create_downtime' , "<downtime_name> <description> <date_from> <date_to> <id_group> <monday> <tuesday>\n\t <wednesday> <thursday> <friday> <saturday> <sunday> <periodically_time_from>\n\t <periodically_time_to> <periodically_day_from> <periodically_day_to> <type_downtime> <type_execution> <type_periodicity> <id_user>" , 'Create a planned downtime' ) ;
2015-11-23 09:21:35 +01:00
help_screen_line ( '--add_item_planned_downtime' , "<id_downtime> <id_agente1,id_agente2,id_agente3...id_agenteN> <name_module1,name_module2,name_module3...name_moduleN> " , 'Add a items planned downtime' ) ;
2015-12-03 11:54:08 +01:00
help_screen_line ( '--get_all_planned_downtimes' , '<name> [<id_group> <type_downtime> <type_execution> <type_periodicity>]' , 'Get all planned downtime' ) ;
help_screen_line ( '--get_planned_downtimes_items' , '<name> [<id_group> <type_downtime> <type_execution> <type_periodicity>]' , 'Get all items of planned downtimes' ) ;
2015-12-02 17:01:28 +01:00
help_screen_line ( '--set_planned_downtimes_deleted' , '<name> ' , 'Deleted a planned downtime' ) ;
2016-06-17 10:36:46 +02:00
help_screen_line ( '--get_module_id' , '<agent_id> <module_name>' , 'Get the id of an module' ) ;
2020-09-17 14:38:01 +02:00
help_screen_line ( '--get_module_custom_id' , '<agentmodule_id>' , 'Get the custom_id of given module' ) ;
help_screen_line ( '--set_module_custom_id' , '<agentmodule_id> [<custom_id>]' , 'Set (or erase if empty) the custom_id of given module' ) ;
2019-10-28 09:48:52 +01:00
help_screen_line ( '--get_agent_group' , '<agent_name> [<use_alias>]' , 'Get the group name of an agent' ) ;
help_screen_line ( '--get_agent_group_id' , '<agent_name> [<use_alias>]' , 'Get the group ID of an agent' ) ;
help_screen_line ( '--get_agent_modules' , '<agent_name> [<use_alias>]' , 'Get the modules of an agent' ) ;
2020-06-10 08:35:01 +02:00
help_screen_line ( '--get_agent_status' , '<agent_name> [<use_alias>]' , 'Get the status of an agent' ) ;
2019-11-13 16:34:08 +01:00
help_screen_line ( '--get_agents_id_name_by_alias' , '<agent_alias>' , '[<strict>]' , 'List id and alias of agents mathing given alias' ) ;
2019-10-28 09:48:52 +01:00
help_screen_line ( '--get_agents' , '[<group_name> <os_name> <status> <max_modules> <filter_substring> <policy_name> <use_alias>]' , "Get \n\t list of agents with optative filter parameters" ) ;
help_screen_line ( '--delete_conf_file' , '<agent_name> [<use_alias>]' , 'Delete a local conf of a given agent' ) ;
help_screen_line ( '--clean_conf_file' , '<agent_name> [<use_alias>]' , "Clean a local conf of a given agent deleting all modules, \n\t policies, file collections and comments" ) ;
2012-01-20 09:52:17 +01:00
help_screen_line ( '--get_bad_conf_files' , '' , 'Get the files bad configured (without essential tokens)' ) ;
2019-10-28 09:48:52 +01:00
help_screen_line ( '--locate_agent' , '<agent_name> [<use_alias>]' , 'Search a agent into of nodes of metaconsole. Only Enterprise.' ) ;
2018-04-02 15:29:59 +02:00
help_screen_line ( '--migration_agent_queue' , '<id_node> <source_node_name> <target_node_name> [<db_only>]' , 'Migrate agent only metaconsole' ) ;
help_screen_line ( '--migration_agent' , '<id_node> ' , 'Is migrating the agent only metaconsole' ) ;
help_screen_line ( '--apply_module_template' , '<id_template> <id_agent>' , 'Apply module template to agent' ) ;
2018-04-09 11:43:41 +02:00
help_screen_line ( '--new_cluster' , '<cluster_name> <cluster_type> <description> <group_id> ' , 'Creating a new cluster' ) ;
help_screen_line ( '--add_cluster_agent' , '<json_data:[{"id":5,"id_agent":2},{"id":5,"id_agent":3}]>' , 'Adding agent to cluster' ) ;
help_screen_line ( '--add_cluster_item' , '<json_data:[{"name":"Swap_Used","id_cluster":5,"type":"AA","critical_limit":80,"warning_limit":60},{"name":"TCP_Connections","id_cluster":5,"type":"AA","critical_limit":80,"warning_limit":60}]> ' , 'Adding item to cluster' ) ;
help_screen_line ( '--delete_cluster' , '<id_cluster>' , 'Deleting cluster' ) ;
help_screen_line ( '--delete_cluster_agent' , '<id_agent> <id_cluster>' , 'Deleting cluster agent' ) ;
help_screen_line ( '--delete_cluster_item' , '<id_item>' , 'Deleting cluster item' ) ;
2018-04-23 13:52:16 +02:00
help_screen_line ( '--get_cluster_status' , '<id_cluster>' , 'Getting cluster status' ) ;
2018-09-25 13:42:29 +02:00
help_screen_line ( '--set_disabled_and_standby' , '<id_agent> <id_node> <value>' , 'Overwrite and disable and standby status' ) ;
2019-01-18 17:24:32 +01:00
help_screen_line ( '--reset_agent_counts' , '<id_agent>' , 'Resets module counts and alert counts in the agents' ) ;
2022-09-20 14:31:48 +02:00
help_screen_line ( '--agent_update_custom_fields' , '<id_agent> <type_field> <field_to_change> <new_value>' , "Update an agent custom field. The fields can be \n\t the following: Serial number, Department ... and types can be 0 text and 1 combo " ) ;
2021-07-09 13:58:01 +02:00
2013-02-05 18:09:18 +01:00
print "\nMODULES:\n\n" unless $ param ne '' ;
2019-10-28 09:48:52 +01:00
help_screen_line ( '--create_data_module' , "<module_name> <module_type> <agent_name> [<description> <module_group> \n\t <min> <max> <post_process> <interval> <warning_min> <warning_max> <critical_min> <critical_max> \n\t <history_data> <definition_file> <warning_str> <critical_str>\n\t <unknown_events> <ff_threshold> <each_ff> <ff_threshold_normal>\n\t <ff_threshold_warning> <ff_threshold_critical> <ff_timeout> <warning_inverse> <critical_inverse>\n\t <critical_instructions> <warning_instructions> <unknown_instructions> <use_alias>]" , 'Add data server module to agent' ) ;
help_screen_line ( '--create_web_module' , "<module_name> <module_type> <agent_name> [<description> <module_group> \n\t <min> <max> <post_process> <interval> <warning_min> <warning_max> <critical_min> <critical_max> \n\t <history_data> <retries> <requests> <agent_browser_id> <auth_server> <auth_realm> <definition_file>\n\t <proxy_url> <proxy_auth_login> <proxy_auth_password> <warning_str> <critical_str>\n\t <unknown_events> <ff_threshold> <each_ff> <ff_threshold_normal>\n\t <ff_threshold_warning> <ff_threshold_critical> <ff_timeout> <warning_inverse> <critical_inverse>\n\t <critical_instructions> <warning_instructions> <unknown_instructions> <use_alias>].\n\t The valid data types are web_data, web_proc, web_content_data or web_content_string" , 'Add web server module to agent' ) ;
help_screen_line ( '--create_network_module' , "<module_name> <module_type> <agent_name> <module_address> \n\t [<module_port> <description> <module_group> <min> <max> <post_process> <interval> \n\t <warning_min> <warning_max> <critical_min> <critical_max> <history_data> <ff_threshold>\n\t <warning_str> <critical_str> <unknown_events> <each_ff>\n\t <ff_threshold_normal> <ff_threshold_warning> <ff_threshold_critical> <timeout> <retries>\n\t <critical_instructions> <warning_instructions> <unknown_instructions>\n\t <warning_inverse> <critical_inverse> <use_alias>]" , 'Add not snmp network module to agent' ) ;
help_screen_line ( '--create_snmp_module' , " <module_name> <module_type> <agent_name> <module_address> <module_port> \ n \ t <version> [ <community> <oid> <description> <module_group> <min> <max> <post_process> <interval> \ n \ t <warning_min> <warning_max> <critical_min> <critical_max> <history_data> \ n \ t <snmp3_priv_method> <snmp3_priv_pass> <snmp3_sec_level> <snmp3_auth_method> \ n \ t <snmp3_auth_user> <snmp3_auth_pass> <ff_threshold> <warning_str> \ n \ t <critical_str> <unknown_events> <each_ff> <ff_threshold_normal> \ n \ t <ff_threshold_warning> <ff_threshold_critical> <timeout> <retries> <use_alias> ]
2016-10-21 11:18:33 +02:00
\ n \ t <critical_instructions> <warning_instructions> <unknown_instructions> \ n \ t <warning_inverse> <critical_inverse> ] " , 'Add snmp network module to agent' ) ;
2019-10-28 09:48:52 +01:00
help_screen_line ( '--create_plugin_module' , "<module_name> <module_type> <agent_name> <module_address> \n\t <module_port> <plugin_name> <user> <password> <parameters> [<description> \n\t <module_group> <min> <max> <post_process> <interval> <warning_min> <warning_max> <critical_min> \n\t <critical_max> <history_data> <ff_threshold> <warning_str> <critical_str>\n\t <unknown_events> <each_ff> <ff_threshold_normal> <ff_threshold_warning>\n\t <ff_threshold_critical> <timeout> \n\t <critical_instructions> <warning_instructions> <unknown_instructions>\n\t <warning_inverse> <critical_inverse> <use_alias>]" , 'Add plug-in module to agent' ) ;
2018-12-11 14:43:27 +01:00
help_screen_line ( '--get_module_group' , '[<module_group_name>]' , 'Dysplay all module groups' ) ;
2016-05-26 12:28:42 +02:00
help_screen_line ( '--create_module_group' , '<module_group_name>' ) ;
2018-12-11 14:43:27 +01:00
help_screen_line ( '--module_group_synch' , "<server_name1|server_name2|server_name3...> [<return_type>]" , 'Synchronize metaconsole module groups' ) ;
2019-10-28 09:48:52 +01:00
help_screen_line ( '--delete_module' , 'Delete module from agent' , '<module_name> <agent_name> [<use_alias>]' ) ;
help_screen_line ( '--data_module' , "<server_name> <agent_name> <module_name> \n\t <module_type> <module_new_data> [<datetime> <use_alias>]" , 'Insert data to module' ) ;
help_screen_line ( '--get_module_data' , "<agent_name> <module_name> <interval> [<csv_separator> <use_alias>]" , "\n\t Show the data of a module in the last X seconds (interval) in CSV format" ) ;
help_screen_line ( '--delete_data' , '-m <module_name> <agent_name> | -a <agent_name> | -g <group_name> [<use_alias>]' , "Delete historic \n\t data of a module, the modules of an agent or the modules of the agents of a group" ) ;
help_screen_line ( '--update_module' , '<module_name> <agent_name> <field_to_change> <new_value> [<use_alias>]' , 'Update a module field' ) ;
2013-02-05 18:09:18 +01:00
help_screen_line ( '--get_agents_module_current_data' , '<module_name>' , "Get the agent and current data \n\t of all the modules with a given name" ) ;
2019-10-28 09:48:52 +01:00
help_screen_line ( '--create_network_module_from_component' , '<agent_name> <component_name> [<use_alias>]' , "Create a new network \n\t module from a network component" ) ;
2019-03-20 12:48:44 +01:00
help_screen_line ( '--create_network_component' , "<network_component_name> <network_component_group> <network_component_type> \n\t [<description> <module_interval> <max_value> <min_value> \n\t <snmp_community> <id_module_group> <max_timeout> \n\t <history_data> <min_warning> <max_warning> \n\t <str_warning> <min_critical> <max_critical> \n\t <str_critical> <min_ff_event> <post_process> \n\t <disabled_types_event> <each_ff> <min_ff_event_normal> \n\t <min_ff_event_warning> <min_ff_event_critical>]" , "Create a new network component" ) ;
2019-10-28 09:48:52 +01:00
help_screen_line ( '--create_synthetic' , "<module_name> <synthetic_type> <agent_name> <source_agent1>,<operation>,<source_module1>|<source_agent1>,<source_module1> \n\t [ <operation>,<fixed_value> | <source agent2>,<operation>,<source_module2> <use_alias>]" , "Create a new Synthetic module" ) ;
2013-02-05 18:09:18 +01:00
print "\nALERTS:\n\n" unless $ param ne '' ;
2019-10-28 09:48:52 +01:00
help_screen_line ( '--create_template_module' , '<template_name> <module_name> <agent_name> [<use_alias>]' , 'Add alert template to module' ) ;
help_screen_line ( '--delete_template_module' , '<template_name> <module_name> <agent_name> [<use_alias>]' , 'Delete alert template from module' ) ;
help_screen_line ( '--create_template_action' , "<action_name> <template_name> <module_name> \n\t <agent_name> [<fires_min> <fires_max> <use_alias>]', 'Add alert action to module-template" ) ;
help_screen_line ( '--delete_template_action' , "<action_name> <template_name> <module_name> \n\t <agent_name> [<use_alias>]" , 'Delete alert action from module-template' ) ;
2012-01-17 14:10:54 +01:00
help_screen_line ( '--disable_alerts' , '' , 'Disable alerts in all groups (system wide)' ) ;
help_screen_line ( '--enable_alerts' , '' , 'Enable alerts in all groups (system wide)' ) ;
2013-02-05 18:09:18 +01:00
help_screen_line ( '--create_alert_template' , "<template_name> <condition_type_serialized>\n\t <time_from> <time_to> [<description> <group_name> <field1> <field2> \n\t <field3> <priority> <default_action> <days> <time_threshold> <min_alerts> \n\t <max_alerts> <alert_recovery> <field2_recovery> <field3_recovery> \n\t <condition_type_separator>]" , 'Create alert template' ) ;
2012-01-17 14:10:54 +01:00
help_screen_line ( '--delete_alert_template' , '<template_name>' , 'Delete alert template' ) ;
2018-12-03 17:38:57 +01:00
help_screen_line ( '--create_alert_command' , "<command_name> <comand> [<id_group> <description> \n\t <internal> <fields_descriptions> <fields_values>" , 'Create alert command' ) ;
help_screen_line ( '--get_alert_commands' , "[<command_name> <comand> <id_group> <description> \n\t <internal>]" , 'Displays all alert commands' ) ;
2018-12-14 17:20:46 +01:00
help_screen_line ( '--get_alert_actions' , '[<action_name> <separator> <return_type>]' , 'get all alert actions' ) ;
help_screen_line ( '--get_alert_actions_meta' , '[<server_name> <action_name> <separator> <return_type>]' , 'get all alert actions in nodes' ) ;
2013-02-05 18:09:18 +01:00
help_screen_line ( '--update_alert_template' , "<template_name> <field_to_change> \n\t <new_value>" , 'Update a field of an alert template' ) ;
2012-01-18 12:21:59 +01:00
help_screen_line ( '--validate_all_alerts' , '' , 'Validate all the alerts' ) ;
2021-04-06 19:21:56 +02:00
help_screen_line ( '--validate_alert' , '<template_name> <agent_id> <module_id> [<use_alias>]' , 'Validate alert given angent, module and alert' ) ;
2021-11-04 12:33:40 +01:00
help_screen_line ( '--create_special_day' , "<special_day> <calendar_name> <same_day> <description> <group>" , 'Create special day' ) ;
2014-05-03 02:57:53 +02:00
help_screen_line ( '--delete_special_day' , '<special_day>' , 'Delete special day' ) ;
help_screen_line ( '--update_special_day' , "<special_day> <field_to_change> <new_value>" , 'Update a field of a special day' ) ;
2019-10-28 09:48:52 +01:00
help_screen_line ( '--create_data_module_from_local_component' , '<agent_name> <component_name> [<use_alias>]' , "Create a new data \n\t module from a local component" ) ;
2014-07-08 15:34:12 +02:00
help_screen_line ( '--create_local_component' , "<component_name> <data> [<description> <id_os> <os_version> \n\t <id_network_component_group> <type> <min> <max> <module_interval> <id_module_group> <history_data> <min_warning> \n\t <max_warning> <str_warning> <min_critical> <max_critical>\n\t <str_critical> <min_ff_event> <post_process> <unit>\n\t <wizard_level> <critical_instructions>\n\t <warning_instructions> <unknown_instructions> <critical_inverse>\n\t <warning_inverse> <id_category> <disabled_types_event>\n\t <tags> <min_ff_event_normal> <min_ff_event_warning>\n\t <min_ff_event_critical> <each_ff> <ff_timeout>]" , 'Create local component' ) ;
2016-01-05 13:17:35 +01:00
2013-02-05 18:09:18 +01:00
print "\nUSERS:\n\n" unless $ param ne '' ;
2016-01-05 13:17:35 +01:00
help_screen_line ( '--create_user' , '<user_name> <user_password> <is_admin> [<comments>]' , 'Create user' ) ;
help_screen_line ( '--delete_user' , '<user_name>' , 'Delete user' ) ;
2018-10-19 11:31:06 +02:00
help_screen_line ( '--update_user' , '<user_id> <field_to_change> <new_value>' , "Update a user field. The fields\n\t can be the following: email, phone, is_admin (0-1), language, id_skin, comments, fullname, password" ) ;
2016-01-05 13:17:35 +01:00
help_screen_line ( '--enable_user' , '<user_id>' , 'Enable a given user' ) ;
help_screen_line ( '--disable_user' , '<user_id>' , 'Disable a given user' ) ;
2016-06-06 15:18:46 +02:00
help_screen_line ( '--add_profile' , '<user_name> <profile_name> <group_name>' , 'Add perfil to user' ) ;
2016-01-05 13:17:35 +01:00
help_screen_line ( '--delete_profile' , '<user_name> <profile_name> <group_name>' , 'Delete perfil from user' ) ;
help_screen_line ( '--add_profile_to_user' , '<user_id> <profile_name> [<group_name>]' , 'Add a profile in group to a user' ) ;
2021-05-13 13:33:45 +02:00
help_screen_line ( '--create_profile' , "<profile_name> <agent_view>\n\t <agent_edit> <agent_disable> <alert_edit> <alert_management> <user_management> <db_management>\n\t <event_view> <event_edit> <event_management> <report_view> <report_edit> <report_management>\n\t <map_view> <map_edit> <map_management> <vconsole_view> <vconsole_edit> <vconsole_management>\n\t <pandora_management>" , 'Create profile' ) ;
help_screen_line ( '--update_profile' , "<profile_name> <agent_view>\n\t <agent_edit> <agent_disable> <alert_edit> <alert_management> <user_management> <db_management>\n\t <event_view> <event_edit> <event_management> <report_view> <report_edit> <report_management>\n\t <map_view> <map_edit> <map_management> <vconsole_view> <vconsole_edit> <vconsole_management>\n\t <pandora_management>" , 'Modify profile' ) ;
2012-01-17 14:10:54 +01:00
help_screen_line ( '--disable_eacl' , '' , 'Disable enterprise ACL system' ) ;
help_screen_line ( '--enable_eacl' , '' , 'Enable enterprise ACL system' ) ;
2014-12-15 14:59:22 +01:00
help_screen_line ( '--disable_double_auth' , '<user_name>' , 'Disable the double authentication for the specified user' ) ;
2013-02-05 18:09:18 +01:00
print "\nEVENTS:\n\n" unless $ param ne '' ;
2019-12-10 11:31:45 +01:00
help_screen_line ( '--create_event' , "<event> <event_type> <group_name> [<agent_name> <module_name>\n\t <event_status> <severity> <template_name> <user_name> <comment> \n\t <source> <id_extra> <tags> <custom_data_json> <force_create_agent> \n\t <critical_instructions> <warning_instructions> <unknown_instructions> <use_alias>]" , 'Add event' ) ;
2019-10-28 09:48:52 +01:00
help_screen_line ( '--validate_event' , "<agent_name> <module_name> <datetime_min> <datetime_max>\n\t <user_name> <criticity> <template_name> [<use_alias>]" , 'Validate events' ) ;
help_screen_line ( '--validate_event_id' , '<event_id>' , 'Validate event given a event id' ) ;
help_screen_line ( '--get_event_info' , '<event_id>[<csv_separator>]' , 'Show info about a event given a event id' ) ;
help_screen_line ( '--add_event_comment' , '<event_id> <user_name> <comment>' , 'Add event\'s comment' ) ;
2013-02-05 18:09:18 +01:00
print "\nPOLICIES:\n\n" unless $ param ne '' ;
2019-02-27 10:28:36 +01:00
help_screen_line ( '--apply_policy' , '<id_policy> [<id_agent> <name(boolean)> <id_server>]' , 'Force apply a policy in an agent' ) ;
2016-01-05 13:17:35 +01:00
help_screen_line ( '--apply_all_policies' , '' , 'Force apply to all the policies' ) ;
2019-10-28 09:48:52 +01:00
help_screen_line ( '--add_agent_to_policy' , '<agent_name> <policy_name> [<use_alias>]' , 'Add an agent to a policy' ) ;
2018-12-17 17:51:30 +01:00
help_screen_line ( '--remove_agent_from_policy' , '<policy_id> <agent_id>' , 'Delete an agent to a policy' ) ;
2016-01-05 13:17:35 +01:00
help_screen_line ( '--delete_not_policy_modules' , '' , 'Delete all modules without policy from configuration file' ) ;
help_screen_line ( '--disable_policy_alerts' , '<policy_name>' , 'Disable all the alerts of a policy' ) ;
2016-05-26 12:28:42 +02:00
help_screen_line ( '--create_policy' , '<policy_name> <group_name> <description>' ) ;
2016-10-21 11:18:33 +02:00
help_screen_line ( '--create_policy_data_module' , "<policy_name> <module_name> <module_type> [<description> \n\t <module_group> <min> <max> <post_process> <interval> <warning_min> <warning_max> \n\t <critical_min> <critical_max> <history_data> <data_configuration> <warning_str> \n\t <critical_str> <unknown_events> <ff_threshold> <each_ff>\n\t <ff_threshold_normal> <ff_threshold_warning> <ff_threshold_critical>\n\t <ff_timeout> <critical_instructions> <warning_instructions> <unknown_instructions>\n\t <warning_inverse> <critical_inverse>]" , 'Add data server module to policy' ) ;
2018-04-06 15:54:48 +02:00
help_screen_line ( '--create_policy_web_module' , "<policy_name> <module_name> <module_type> [<description> \n\t <module_group> <min> <max> <post_process> <interval> <warning_min> <warning_max> \n\t <critical_min> <critical_max> <history_data> <retries> <requests> <agent_browser_id> <auth_server> <auth_realm> <data_configuration> <proxy_url> <proxy_auth_login> <proxy_auth_password> <warning_str> \n\t <critical_str> <unknown_events> <ff_threshold> <each_ff>\n\t <ff_threshold_normal> <ff_threshold_warning> <ff_threshold_critical>\n\t <ff_timeout> <warning_inverse> <critical_inverse> <critical_instructions> <warning_instructions> <unknown_instructions>].\n\t The valid data types are web_data, web_proc, web_content_data or web_content_string" , 'Add web server module to policy' ) ;
2016-10-21 11:18:33 +02:00
help_screen_line ( '--create_policy_network_module' , "<policy_name> <module_name> <module_type> [<module_port> \n\t <description> <module_group> <min> <max> <post_process> <interval> \n\t <warning_min> <warning_max> <critical_min> <critical_max> <history_data> <ff_threshold> \n\t <warning_str> <critical_str> <unknown_events> <each_ff>\n\t <ff_threshold_normal> <ff_threshold_warning> <ff_threshold_critical>\n\t <critical_instructions> <warning_instructions> <unknown_instructions>\n\t <warning_inverse> <critical_inverse>]" , "Add not snmp network module to policy" ) ;
2016-10-19 13:48:25 +02:00
help_screen_line ( '--create_policy_snmp_module' , " <policy_name> <module_name> <module_type> <module_port> \ n \ t <version> [ <community> <oid> <description> <module_group> <min> <max> \ n \ t <post_process> <interval> <warning_min> <warning_max> <critical_min> <critical_max> <history_data> \ n \ t <snmp3_priv_method> <snmp3_priv_pass> <snmp3_sec_level> <snmp3_auth_method> <snmp3_auth_user> \ n \ t <snmp3_priv_pass> <ff_threshold> <warning_str> <critical_str> \ n \ t <unknown_events> <each_ff> <ff_threshold_normal> \ n \ t <ff_threshold_warning> <ff_threshold_critical> \ n \ t
2016-10-21 11:18:33 +02:00
<critical_instructions> <warning_instructions> <unknown_instructions> \ n \ t <warning_inverse> <critical_inverse> ] " , 'Add snmp network module to policy' ) ;
help_screen_line ( '--create_policy_plugin_module' , "<policy_name> <module_name> <module_type> \n\t <module_port> <plugin_name> <user> <password> <parameters> [<description> <module_group> <min> \n\t <max> <post_process> <interval> <warning_min> <warning_max> <critical_min> <critical_max>\n\t <history_data> <ff_threshold> <warning_str> <critical_str>\n\t <unknown_events> <each_ff> <ff_threshold_normal>\n\t <ff_threshold_warning> <ff_threshold_critical>\n\t <critical_instructions> <warning_instructions> <unknown_instructions>\n\t <warning_inverse> <critical_inverse>]" , 'Add plug-in module to policy' ) ;
2016-05-26 12:28:42 +02:00
help_screen_line ( '--create_policy_data_module_from_local_component' , '<policy_name> <component_name>' ) ;
help_screen_line ( '--add_collection_to_policy' , "<policy_name> <collection_name>" ) ;
2012-01-18 12:21:59 +01:00
help_screen_line ( '--validate_policy_alerts' , '<policy_name>' , 'Validate the alerts of a given policy' ) ;
help_screen_line ( '--get_policy_modules' , '<policy_name>' , 'Get the modules of a policy' ) ;
2019-10-28 09:48:52 +01:00
help_screen_line ( '--get_policies' , '[<agent_name> <use_alias>]' , "Get all the policies (without parameters) or \n\tthe policies of a given agent (agent name as parameter)" ) ;
2014-08-18 15:03:34 +02:00
help_screen_line ( '--recreate_collection' , '<collection_id>' , 'Recreate the files of a collection' ) ;
2016-01-05 13:17:35 +01:00
2013-02-05 18:09:18 +01:00
print "\nNETFLOW:\n\n" unless $ param ne '' ;
help_screen_line ( '--create_netflow_filter' , "<filter_name> <group_name> <filter> \n\t <aggregate_by dstip|dstport|none|proto|srcip|srcport> <output_format kilobytes|kilobytespersecond|\n\t megabytes|megabytespersecond>" , "Create a new netflow filter" ) ;
print "\nTOOLS:\n\n" unless $ param ne '' ;
help_screen_line ( '--exec_from_file' , '<file_path> <option_to_execute> <option_params>' , "Execute any CLI option \n\t with macros from CSV file" ) ;
2016-01-05 13:17:35 +01:00
help_screen_line ( '--create_snmp_trap' , '<name> <oid> <description> <severity>' , "Create a new trap definition. \n\tSeverity 0 (Maintenance), 1(Info) , 2 (Normal), 3 (Warning), 4 (Critical), 5 (Minor) and 6 (Major)" ) ;
2022-05-24 10:59:41 +02:00
help_screen_line ( '--start_snmptrapd' , '[no parameters needed]' , "Start the snmptrap process or restart if it is running" ) ;
2013-02-05 18:09:18 +01:00
print "\nSETUP:\n\n" unless $ param ne '' ;
help_screen_line ( '--set_event_storm_protection' , '<value>' , "Enable (1) or disable (0) event \n\t storm protection" ) ;
2012-01-16 15:55:55 +01:00
2015-03-26 13:41:07 +01:00
print "\nTAGS\n\n" unless $ param ne '' ;
help_screen_line ( '--create_tag' , '<tag_name> <tag_description> [<tag_url>] [<tag_email>]' , 'Create a new tag' ) ;
2015-03-26 15:21:49 +01:00
help_screen_line ( '--add_tag_to_user_profile' , '<user_id> <tag_name> <group_name> <profile_name>' , 'Add a tag to the given user profile' ) ;
help_screen_line ( '--add_tag_to_module' , '<agent_name> <module_name> <tag_name>' , 'Add a tag to the given module' ) ;
2017-09-11 16:09:13 +02:00
print "\nVISUAL CONSOLES\n\n" unless $ param ne '' ;
2017-09-13 13:27:37 +02:00
help_screen_line ( '--create_visual_console' , '<name> <background> <width> <height> <group> <mode> [<position_to_locate_elements>] [<background_color>] [<elements>]' , 'Create a new visual console' ) ;
2017-09-14 12:07:52 +02:00
help_screen_line ( '--edit_visual_console' , '<id> [<name>] [<background>] [<width>] [<height>] [<group>] [<mode>] [<position_to_locate_elements>] [<background_color>] [<elements>]' , 'Edit a visual console' ) ;
2017-09-11 16:09:13 +02:00
help_screen_line ( '--delete_visual_console' , '<id>' , 'Delete a visual console' ) ;
help_screen_line ( '--delete_visual_console_objects' , '<id> <mode> <id_mode>' , 'Delete a visual console elements' ) ;
help_screen_line ( '--duplicate_visual_console' , '<id> <times> [<prefix>]' , 'Duplicate a visual console' ) ;
2017-09-27 13:15:51 +02:00
help_screen_line ( '--export_json_visual_console' , '<id> [<path>] [<with_element_id>]' , 'Creates a json with the visual console elements information' ) ;
2017-09-11 16:09:13 +02:00
2020-06-03 15:56:19 +02:00
print "\nEVENTS\n\n" unless $ param ne '' ;
2020-07-15 23:36:21 +02:00
help_screen_line ( '--event_in_progress' , '<id_event> ' , 'Set event in progress' ) ;
2018-03-22 13:18:48 +01:00
2022-09-21 17:41:09 +02:00
print "\nGIS\n\n" unless $ param ne '' ;
help_screen_line ( '--get_gis_agent' , '<agent_id> ' , 'Gets agent GIS information' ) ;
help_screen_line ( '--insert_gis_data' , '<agent_id> [<latitude>] [<longitude>] [<altitude>]' , 'Sets new GIS data for specified agent' ) ;
2016-01-05 13:17:35 +01:00
print "\n" ;
2012-01-16 15:55:55 +01:00
exit ;
}
2016-01-05 13:17:35 +01:00
########################################################################
2015-03-26 13:41:07 +01:00
#
2016-01-05 13:17:35 +01:00
########################################################################
2018-12-11 14:43:27 +01:00
sub api_call ($$$;$$$$) {
my ( $ pa_config , $ op , $ op2 , $ id , $ id2 , $ other , $ return_type ) = @ _ ;
2015-03-26 13:41:07 +01:00
my $ content = undef ;
2022-10-11 11:46:02 +02:00
2015-03-26 13:41:07 +01:00
eval {
# Set the parameters for the POST request.
my $ params = { } ;
$ params - > { "apipass" } = $ pa_config - > { "console_api_pass" } ;
$ params - > { "user" } = $ pa_config - > { "console_user" } ;
$ params - > { "pass" } = $ pa_config - > { "console_pass" } ;
$ params - > { "op" } = $ op ;
$ params - > { "op2" } = $ op2 ;
$ params - > { "id" } = $ id ;
$ params - > { "id2" } = $ id2 ;
$ params - > { "other" } = $ other ;
2018-12-11 14:43:27 +01:00
$ params - > { "return_type" } = $ return_type ;
2015-03-26 13:41:07 +01:00
$ params - > { "other_mode" } = "url_encode_separator_|" ;
2022-09-21 17:41:09 +02:00
2015-03-26 13:41:07 +01:00
# Call the API.
my $ ua = new LWP:: UserAgent ;
my $ url = $ pa_config - > { "console_api_url" } ;
2022-09-21 17:41:09 +02:00
2015-03-26 13:41:07 +01:00
my $ response = $ ua - > post ( $ url , $ params ) ;
2022-05-24 10:59:41 +02:00
2015-03-26 13:41:07 +01:00
if ( $ response - > is_success ) {
$ content = $ response - > decoded_content ( ) ;
2016-01-05 13:17:35 +01:00
}
else {
2015-03-26 13:41:07 +01:00
$ content = $ response - > decoded_content ( ) ;
}
} ;
2022-10-11 11:46:02 +02:00
2015-03-26 13:41:07 +01:00
return $ content ;
}
2019-07-24 16:58:31 +02:00
###############################################################################
# Update token conf file agent
###############################################################################
sub update_conf_txt ($$$$) {
my ( $ conf , $ agent_name , $ token , $ value ) = @ _ ;
# Read the conf of each agent.
my $ conf_file_txt = enterprise_hook (
'read_agent_conf_file' ,
[
$ conf ,
$ agent_name
]
) ;
# Check if there is agent conf.
if ( ! $ conf_file_txt ) {
return 0 ;
}
my $ updated = 0 ;
my $ txt_content = "" ;
my @ lines = split /\n/ , $ conf_file_txt ;
foreach my $ line ( @ lines ) {
if ( $ line =~ /^\s*$token\s/ || $ line =~ /^#$token\s/ || $ line =~ /^#\s$token\s/ ) {
$ txt_content . = $ token . ' ' . $ value . "\n" ;
$ updated = 1 ;
} else {
$ txt_content . = $ line . "\n" ;
}
}
if ( $ updated == 0 ) {
$ txt_content . = "\n$token $value\n" ;
}
# Write the conf.
my $ result = enterprise_hook (
'write_agent_conf_file' ,
[
$ conf ,
$ agent_name ,
$ txt_content
]
) ;
return $ result ;
}
2021-11-24 16:11:32 +01:00
###############################################################################
###############################################################################
# PRINT HELP AND CHECK ERRORS FUNCTIONS
###############################################################################
###############################################################################
###############################################################################
# log wrapper
###############################################################################
sub print_log ($) {
my ( $ msg ) = @ _ ;
print $ msg ; # show message
$ msg =~ s/\n+$// ;
logger ( $ conf , "($progname) $msg" , 10 ) ; # save to logging file
}
2019-07-24 16:58:31 +02:00
2010-05-27 18:24:52 +02:00
###############################################################################
2010-05-19 15:40:21 +02:00
# Disable a entire group
###############################################################################
2010-05-31 13:38:29 +02:00
sub pandora_disable_group ($$$) {
my ( $ conf , $ dbh , $ group ) = @ _ ;
2010-05-19 15:40:21 +02:00
2019-07-24 16:58:31 +02:00
my @ agents_bd = [] ;
my $ result = 0 ;
2021-11-23 12:23:27 +01:00
if ( is_metaconsole ( $ conf ) != 1 && pandora_get_tconfig_token ( $ dbh , 'centralized_management' , '' ) ) {
print_log "[ERROR] This node is configured with centralized mode. To disable a group go to metaconsole. \n\n" ;
exit ;
}
2022-04-22 18:27:29 +02:00
if ( is_metaconsole ( $ conf ) == 1 ) {
my $ servers = enterprise_hook ( 'get_metaconsole_setup_servers' , [ $ dbh ] ) ;
my @ servers_id = split ( ',' , $ servers ) ;
foreach my $ server ( @ servers_id ) {
my $ dbh_metaconsole = enterprise_hook ( 'get_node_dbh' , [ $ conf , $ server , $ dbh ] ) ;
2019-07-24 16:58:31 +02:00
2022-04-22 18:27:29 +02:00
if ( $ group == 0 ) {
# Extract all the names of the pandora agents if it is for all = 0.
@ agents_bd = get_db_rows ( $ dbh_metaconsole , 'SELECT id_agente FROM tagente' ) ;
}
else {
# Extract all the names of the pandora agents if it is for group.
@ agents_bd = get_db_rows ( $ dbh_metaconsole , 'SELECT id_agente FROM tagente WHERE id_grupo = ?' , $ group ) ;
}
2019-07-24 16:58:31 +02:00
2022-04-22 18:27:29 +02:00
foreach my $ id_agent ( @ agents_bd ) {
# Call the API.
2022-04-26 14:47:49 +02:00
$ result += api_call (
$ conf , 'set' , 'disabled_and_standby' , $ id_agent - > { 'id_agente' } , $ server , '1|1'
) ;
2022-04-22 18:27:29 +02:00
}
}
} else {
if ( $ group == 0 ) {
# Extract all the names of the pandora agents if it is for all = 0.
@ agents_bd = get_db_rows ( $ dbh , 'SELECT nombre FROM tagente' ) ;
2019-07-24 16:58:31 +02:00
2022-04-22 18:27:29 +02:00
# Update bbdd.
2022-04-26 14:47:49 +02:00
$ result = db_update ( $ dbh , "UPDATE tagente SET disabled = 1" ) ;
2022-04-22 18:27:29 +02:00
}
else {
# Extract all the names of the pandora agents if it is for group.
@ agents_bd = get_db_rows ( $ dbh , 'SELECT nombre FROM tagente WHERE id_grupo = ?' , $ group ) ;
2019-07-24 16:58:31 +02:00
2022-04-22 18:27:29 +02:00
# Update bbdd.
2022-04-26 14:47:49 +02:00
$ result = db_update ( $ dbh , "UPDATE tagente SET disabled = 1 WHERE id_grupo = $group" ) ;
2022-04-22 18:27:29 +02:00
}
2019-07-24 16:58:31 +02:00
2022-04-22 18:27:29 +02:00
foreach my $ name_agent ( @ agents_bd ) {
# Check the standby field I put it to 0.
my $ new_conf = update_conf_txt (
$ conf ,
$ name_agent - > { 'nombre' } ,
'standby' ,
'1'
) ;
}
2019-07-24 16:58:31 +02:00
}
return $ result ;
2010-05-31 13:38:29 +02:00
}
###############################################################################
# Enable a entire group
###############################################################################
sub pandora_enable_group ($$$) {
my ( $ conf , $ dbh , $ group ) = @ _ ;
2019-07-24 16:58:31 +02:00
my @ agents_bd = [] ;
my $ result = 0 ;
2019-07-18 18:21:20 +02:00
2021-11-23 12:23:27 +01:00
if ( is_metaconsole ( $ conf ) != 1 && pandora_get_tconfig_token ( $ dbh , 'centralized_management' , '' ) ) {
print_log "[ERROR] This node is configured with centralized mode. To enable a group go to metaconsole. \n\n" ;
exit ;
}
2010-05-31 13:38:29 +02:00
if ( $ group == 0 ) {
2019-07-24 16:58:31 +02:00
# Extract all the names of the pandora agents if it is for all = 0.
@ agents_bd = get_db_rows ( $ dbh , 'SELECT nombre FROM tagente' ) ;
2019-07-18 18:21:20 +02:00
2019-07-24 16:58:31 +02:00
# Update bbdd.
$ result = db_do ( $ dbh , "UPDATE tagente SET disabled = 0" ) ;
2010-05-31 13:38:29 +02:00
}
2016-01-05 13:17:35 +01:00
else {
2019-07-24 16:58:31 +02:00
# Extract all the names of the pandora agents if it is for group.
@ agents_bd = get_db_rows ( $ dbh , 'SELECT nombre FROM tagente WHERE id_grupo = ?' , $ group ) ;
# Update bbdd.
$ result = db_do ( $ dbh , "UPDATE tagente SET disabled = 0 WHERE id_grupo = $group" ) ;
2010-05-31 13:38:29 +02:00
}
2019-07-24 16:58:31 +02:00
foreach my $ name_agent ( @ agents_bd ) {
# Check the standby field I put it to 0.
my $ new_conf = update_conf_txt (
$ conf ,
$ name_agent - > { 'nombre' } ,
'standby' ,
'0'
) ;
}
return $ result ;
2010-05-19 15:40:21 +02:00
}
2010-03-24 14:09:09 +01:00
##############################################################################
# Init screen
##############################################################################
2010-06-09 12:04:02 +02:00
sub pandora_manage_init ($) {
2016-01-05 13:17:35 +01:00
my $ conf = shift ;
2010-05-27 18:24:52 +02:00
$ conf - > { "verbosity" } = 0 ; # Verbose 1 by default
$ conf - > { "daemon" } = 0 ; # Daemon 0 by default
$ conf - > { 'PID' } = "" ; # PID file not exist by default
$ conf - > { "quiet" } = 0 ; # Daemon 0 by default
2016-01-05 13:17:35 +01:00
2010-03-24 14:09:09 +01:00
# Load config file from command line
help_screen ( ) if ( $# ARGV < 0 ) ;
2010-05-19 15:40:21 +02:00
2010-05-27 18:24:52 +02:00
$ conf - > { 'pandora_path' } = $ ARGV [ 0 ] ;
2010-05-31 18:04:00 +02:00
help_screen ( ) if ( $ conf - > { 'pandora_path' } =~ m/--*h\w*\z/i ) ;
2010-05-27 18:24:52 +02:00
}
##########################################################################
## Delete a template module.
##########################################################################
sub pandora_delete_template_module ($$) {
my ( $ dbh , $ template_module_id ) = @ _ ;
# Delete the template module
db_do ( $ dbh , 'DELETE FROM talert_template_modules WHERE id = ?' , $ template_module_id ) ;
#
db_do ( $ dbh , 'DELETE FROM talert_template_module_actions WHERE id_alert_template_module = ?' , $ template_module_id ) ;
}
##########################################################################
2010-11-04 18:35:37 +01:00
## Delete a policy template module action.
2010-05-27 18:24:52 +02:00
##########################################################################
sub pandora_delete_template_module_action ($$$) {
2010-11-04 18:35:37 +01:00
my ( $ dbh , $ template_module_id , $ action_id ) = @ _ ;
2010-05-27 18:24:52 +02:00
return db_do ( $ dbh , 'DELETE FROM talert_template_module_actions WHERE id_alert_template_module = ? AND id_alert_action = ?' , $ template_module_id , $ action_id ) ;
}
2012-01-11 11:09:02 +01:00
##########################################################################
## Create an alert template from hash
##########################################################################
sub pandora_create_alert_template_from_hash ($$$) {
my ( $ pa_config , $ parameters , $ dbh ) = @ _ ;
logger ( $ pa_config , "Creating alert_template '$parameters->{'name'}'" , 10 ) ;
my $ template_id = db_process_insert ( $ dbh , 'id' , 'talert_templates' , $ parameters ) ;
return $ template_id ;
}
2012-01-05 13:11:03 +01:00
##########################################################################
# Assign a profile in a group to user
##########################################################################
sub pandora_add_profile_to_user ($$$;$) {
my ( $ dbh , $ user_id , $ profile_id , $ group_id ) = @ _ ;
$ group_id = 0 unless defined ( $ group_id ) ;
2022-10-18 12:49:51 +02:00
my $ centralized = pandora_get_tconfig_token ( $ dbh , 'centralized_management' , '' ) ;
if ( is_metaconsole ( $ conf ) != 1 && $ centralized ) {
print_log "[ERROR] This node is configured with centralized mode. To create a user go to metaconsole. \n\n" ;
exit ;
}
my $ query = 'INSERT INTO tusuario_perfil (id_usuario, id_perfil, id_grupo) VALUES (?, ?, ?)' ;
my @ values = (
safe_input ( $ user_id ) ,
$ profile_id ,
$ group_id
) ;
my $ res = db_do ( $ dbh , $ query , @ values ) ;
if ( is_metaconsole ( $ conf ) == 1 && $ centralized ) {
db_synch_insert ( $ dbh , $ conf , 'tusuario_perfil' , $ query , $ res , @ values ) ;
}
return $ res ;
2012-01-05 13:11:03 +01:00
}
2013-02-05 18:09:18 +01:00
##########################################################################
## Create a SNMP trap, given OID name description
##########################################################################
sub cli_create_snmp_trap ($$) {
my ( $ conf , $ dbh ) = @ _ ;
my ( $ name , $ oid , $ description , $ severity ) ;
( $ name , $ oid , $ description , $ severity ) = @ ARGV [ 2 .. 5 ] ;
db_do ( $ dbh , ' INSERT INTO ttrap_custom_values ( `oid` , `text` , `description` , `severity` )
VALUES ( ? , ? , ? , ? ) ' , $ oid , $ name , $ description , $ severity ) ;
print "Creando $name $oid $description $severity \n" ;
exit ;
}
2010-05-27 18:24:52 +02:00
##########################################################################
## Create a user.
##########################################################################
sub pandora_create_user ($$$$$) {
2013-02-05 18:09:18 +01:00
my ( $ dbh , $ name , $ password , $ is_admin , $ comments ) = @ _ ;
2010-05-27 18:24:52 +02:00
2022-10-17 16:04:45 +02:00
my $ centralized = pandora_get_tconfig_token ( $ dbh , 'centralized_management' , '' ) ;
if ( is_metaconsole ( $ conf ) != 1 && $ centralized ) {
2021-11-23 12:43:07 +01:00
print_log "[ERROR] This node is configured with centralized mode. To create a user go to metaconsole. \n\n" ;
exit ;
}
2022-10-17 16:04:45 +02:00
my $ query = 'INSERT INTO tusuario (id_user, fullname, password, comments, is_admin) VALUES (?, ?, ?, ?, ?)' ;
my @ values = (
safe_input ( $ name ) ,
safe_input ( $ name ) ,
$ password ,
2022-10-18 16:22:53 +02:00
decode_entities ( $ comments ) ,
$ is_admin ? '1' : '0'
2022-10-17 16:04:45 +02:00
) ;
2011-09-26 14:26:58 +02:00
2022-10-17 16:04:45 +02:00
my $ res = db_insert ( $ dbh , 'id_user' , $ query , @ values ) ;
2011-09-26 14:26:58 +02:00
2022-10-17 16:04:45 +02:00
if ( is_metaconsole ( $ conf ) == 1 && $ centralized ) {
db_synch_insert ( $ dbh , $ conf , 'tusuario' , $ query , $ res , @ values ) ;
}
2022-10-18 12:49:51 +02:00
return $ res ;
2010-05-27 18:24:52 +02:00
}
##########################################################################
## Delete a user.
##########################################################################
sub pandora_delete_user ($$) {
my ( $ dbh , $ name ) = @ _ ;
2022-10-18 12:49:51 +02:00
my $ centralized = pandora_get_tconfig_token ( $ dbh , 'centralized_management' , '' ) ;
if ( is_metaconsole ( $ conf ) != 1 && $ centralized ) {
2021-11-23 12:43:07 +01:00
print_log "[ERROR] This node is configured with centralized mode. To delete a user go to metaconsole. \n\n" ;
exit ;
}
2010-05-27 18:24:52 +02:00
2021-11-23 12:43:07 +01:00
# Delete user profiles
2022-10-18 12:49:51 +02:00
my $ result_profile = db_do ( $ dbh , 'DELETE FROM tusuario_perfil WHERE id_usuario = ?' , $ name ) ;
if ( is_metaconsole ( $ conf ) == 1 && $ centralized ) {
db_synch_delete ( $ dbh , $ conf , 'tusuario_perfil' , $ result_profile , $ name ) ;
}
2010-05-27 18:24:52 +02:00
2021-11-23 12:43:07 +01:00
# Delete the user
my $ return = db_do ( $ dbh , 'DELETE FROM tusuario WHERE id_user = ?' , $ name ) ;
2022-10-18 12:49:51 +02:00
if ( is_metaconsole ( $ conf ) == 1 && $ centralized ) {
db_synch_delete ( $ dbh , $ conf , 'tusuario' , $ return , $ name ) ;
}
2021-11-23 12:43:07 +01:00
if ( $ return eq '0E0' ) {
return - 1 ;
}
else {
return 0 ;
}
2010-05-27 18:24:52 +02:00
}
2012-01-13 10:43:29 +01:00
##########################################################################
## Delete an alert template.
##########################################################################
sub pandora_delete_alert_template ($$) {
my ( $ dbh , $ template_name ) = @ _ ;
# Delete the alert_template
my $ return = db_do ( $ dbh , 'DELETE FROM talert_templates WHERE name = ?' , safe_input ( $ template_name ) ) ;
if ( $ return eq '0E0' ) {
return - 1 ;
}
else {
return 0 ;
}
}
2010-05-27 18:24:52 +02:00
##########################################################################
## Assign a profile to the given user/group.
##########################################################################
sub pandora_create_user_profile ($$$$) {
2022-10-18 12:49:51 +02:00
my ( $ dbh , $ user_id , $ profile_id , $ group_id ) = @ _ ;
my $ centralized = pandora_get_tconfig_token ( $ dbh , 'centralized_management' , '' ) ;
if ( is_metaconsole ( $ conf ) != 1 && $ centralized ) {
print_log "[ERROR] This node is configured with centralized mode. To create a user go to metaconsole. \n\n" ;
exit ;
}
my $ query = 'INSERT INTO tusuario_perfil (id_usuario, id_perfil, id_grupo) VALUES (?, ?, ?)' ;
my @ values = (
safe_input ( $ user_id ) ,
$ profile_id ,
$ group_id
) ;
my $ res = db_insert ( $ dbh , 'id_up' , $ query , @ values ) ;
if ( is_metaconsole ( $ conf ) == 1 && $ centralized ) {
db_synch_insert ( $ dbh , $ conf , 'tusuario_perfil' , $ query , $ res , @ values ) ;
}
return $ res ;
2010-05-27 18:24:52 +02:00
}
2016-06-06 15:18:46 +02:00
##########################################################################
## Create profile.
##########################################################################
2021-05-13 13:33:45 +02:00
sub pandora_create_profile ($$$$$$$$$$$$$$$$$$$$$$) {
2022-10-18 12:49:51 +02:00
my ( $ dbh , $ profile_name , $ agent_view ,
2016-06-06 15:18:46 +02:00
$ agent_edit , $ agent_disable , $ alert_edit , $ alert_management , $ user_management , $ db_management ,
$ event_view , $ event_edit , $ event_management , $ report_view , $ report_edit , $ report_management ,
$ map_view , $ map_edit , $ map_management , $ vconsole_view , $ vconsole_edit , $ vconsole_management , $ pandora_management ) = @ _ ;
2022-10-18 12:49:51 +02:00
my $ centralized = pandora_get_tconfig_token ( $ dbh , 'centralized_management' , '' ) ;
2016-06-06 15:18:46 +02:00
2022-10-18 12:49:51 +02:00
if ( is_metaconsole ( $ conf ) != 1 && $ centralized ) {
print_log "[ERROR] This node is configured with centralized mode. To create a user go to metaconsole. \n\n" ;
exit ;
}
my $ query = 'INSERT INTO tperfil (name,agent_view,agent_edit,agent_disable,alert_edit,alert_management,user_management,db_management,event_view,event_edit,event_management,report_view,report_edit,report_management,map_view,map_edit,map_management,vconsole_view,vconsole_edit,vconsole_management,pandora_management) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?);' ;
my @ values = (
safe_input ( $ profile_name ) ,
$ agent_view ,
$ agent_edit ,
$ agent_disable ,
$ alert_edit ,
$ alert_management ,
$ user_management ,
$ db_management ,
$ event_view ,
$ event_edit ,
$ event_management ,
$ report_view ,
$ report_edit ,
$ report_management ,
$ map_view ,
$ map_edit ,
$ map_management ,
$ vconsole_view ,
$ vconsole_edit ,
$ vconsole_management ,
$ pandora_management
) ;
my $ res = db_insert ( $ dbh , 'id_perfil' , $ query , @ values ) ;
if ( is_metaconsole ( $ conf ) == 1 && $ centralized ) {
db_synch_insert ( $ dbh , $ conf , 'tperfil' , $ query , $ res , @ values ) ;
}
return $ res ;
2016-06-06 15:18:46 +02:00
}
2021-04-14 04:07:13 +02:00
##########################################################################
#### Update profile.
###########################################################################
2021-05-13 13:33:45 +02:00
sub pandora_update_profile ($$$$$$$$$$$$$$$$$$$$$$) {
my ( $ dbh , $ profile_name , $ agent_view ,
2021-04-14 04:07:13 +02:00
$ agent_edit , $ agent_disable , $ alert_edit , $ alert_management , $ user_management , $ db_management ,
$ event_view , $ event_edit , $ event_management , $ report_view , $ report_edit , $ report_management ,
$ map_view , $ map_edit , $ map_management , $ vconsole_view , $ vconsole_edit , $ vconsole_management , $ pandora_management ) = @ _ ;
2022-10-18 12:49:51 +02:00
my $ centralized = pandora_get_tconfig_token ( $ dbh , 'centralized_management' , '' ) ;
if ( is_metaconsole ( $ conf ) != 1 && $ centralized ) {
print_log "[ERROR] This node is configured with centralized mode. To create a user go to metaconsole. \n\n" ;
exit ;
}
my @ parameters = (
$ agent_view , $ agent_edit , $ agent_disable ,
$ alert_edit , $ alert_management ,
$ user_management , $ db_management ,
$ event_view , $ event_edit , $ event_management ,
$ report_view , $ report_edit , $ report_management ,
$ map_view , $ map_edit , $ map_management ,
$ vconsole_view , $ vconsole_edit , $ vconsole_management ,
$ pandora_management , safe_input ( $ profile_name )
) ;
my $ query = 'UPDATE tperfil SET agent_view = ?, agent_edit = ?, agent_disable = ?, alert_edit = ?, alert_management = ?, user_management = ?, db_management = ?, event_view = ?, event_edit = ?, event_management = ?, report_view = ?, report_edit = ?, report_management = ?, map_view = ?, map_edit = ?, map_management = ?, vconsole_view = ?, vconsole_edit = ?, vconsole_management = ?, pandora_management = ? WHERE name=?;' ;
my $ result = db_update ( $ dbh , $ query , @ parameters ) ;
if ( is_metaconsole ( $ conf ) == 1 && $ centralized ) {
db_synch_update ( $ dbh , $ conf , 'tperfil' , $ query , $ result , @ parameters ) ;
}
return $ result ;
2021-04-14 04:07:13 +02:00
}
2010-05-27 18:24:52 +02:00
##########################################################################
## Delete a profile from the given user/group.
##########################################################################
sub pandora_delete_user_profile ($$$$) {
2015-12-02 17:01:28 +01:00
my ( $ dbh , $ user_id , $ profile_id , $ group_id ) = @ _ ;
2022-10-18 12:49:51 +02:00
my $ centralized = pandora_get_tconfig_token ( $ dbh , 'centralized_management' , '' ) ;
if ( is_metaconsole ( $ conf ) != 1 && $ centralized ) {
print_log "[ERROR] This node is configured with centralized mode. To delete a user go to metaconsole. \n\n" ;
exit ;
}
my @ parameters = (
$ user_id ,
$ profile_id ,
$ group_id
) ;
# Delete the user
my $ return = db_do ( $ dbh , 'DELETE FROM tusuario_perfil WHERE id_usuario=? AND id_perfil=? AND id_grupo=?' , @ parameters ) ;
if ( is_metaconsole ( $ conf ) == 1 && $ centralized ) {
db_synch_delete ( $ dbh , $ conf , 'tusuario_perfil' , $ return , @ parameters ) ;
}
2015-12-02 17:01:28 +01:00
2022-10-18 12:49:51 +02:00
return $ return ;
2015-12-02 17:01:28 +01:00
}
##########################################################################
## Delete a planned downtime
##########################################################################
sub pandora_delete_planned_downtime ($$) {
my ( $ dbh , $ id_downtime ) = @ _ ;
my $ execute = get_db_single_row ( $ dbh , 'SELECT executed FROM tplanned_downtime WHERE id = ? ' , $ id_downtime ) ;
if ( ! $ execute - > { 'executed' } ) {
my $ result = db_do ( $ dbh , 'DELETE FROM tplanned_downtime WHERE id = ? ' , $ id_downtime ) ;
if ( $ result ) {
return "This planned downtime is deleted" ;
}
else {
return "Problems with this planned downtime" ;
}
}
else {
return "The scheduled downtime is still being executed" ;
}
2010-05-27 18:24:52 +02:00
}
2010-09-03 12:59:43 +02:00
##########################################################################
## Delete all the data of module, agent's modules or group's agent's modules
##########################################################################
sub pandora_delete_data ($$$) {
2015-12-02 17:01:28 +01:00
my ( $ dbh , $ type , $ id ) = @ _ ;
if ( $ type eq 'group' ) {
my @ delete_agents = get_db_rows ( $ dbh , 'SELECT id_agente FROM tagente WHERE id_grupo = ?' , $ id ) ;
foreach my $ agent ( @ delete_agents ) {
my @ delete_modules = get_db_rows ( $ dbh , 'SELECT id_agente_modulo FROM tagente_modulo WHERE id_agente = ?' , $ agent - > { 'id_agente' } ) ;
2010-09-03 12:59:43 +02:00
foreach my $ module ( @ delete_modules ) {
pandora_delete_module_data ( $ dbh , $ module - > { 'id_agente_modulo' } ) ;
}
}
2015-12-02 17:01:28 +01:00
}
elsif ( $ type eq 'agent' ) {
my @ delete_modules = get_db_rows ( $ dbh , 'SELECT id_agente_modulo FROM tagente_modulo WHERE id_agente = ?' , $ id ) ;
foreach my $ module ( @ delete_modules ) {
pandora_delete_module_data ( $ dbh , $ module - > { 'id_agente_modulo' } ) ;
2010-09-03 12:59:43 +02:00
}
2015-12-02 17:01:28 +01:00
}
elsif ( $ type eq 'module' ) {
pandora_delete_module_data ( $ dbh , $ id ) ;
}
else {
return 0 ;
}
2010-09-03 12:59:43 +02:00
}
##########################################################################
## Delete all the data of module
##########################################################################
sub pandora_delete_module_data ($$) {
2015-12-02 17:01:28 +01:00
my ( $ dbh , $ id_module ) = @ _ ;
my $ buffer = 1000 ;
while ( 1 ) {
2019-11-04 16:04:26 +01:00
my $ nd = get_db_value ( $ dbh , 'SELECT count(id_agente_modulo) FROM tagente_datos WHERE id_agente_modulo=?' , $ id_module ) ;
my $ ndinc = get_db_value ( $ dbh , 'SELECT count(id_agente_modulo) FROM tagente_datos_inc WHERE id_agente_modulo=?' , $ id_module ) ;
my $ ndlog4x = get_db_value ( $ dbh , 'SELECT count(id_agente_modulo) FROM tagente_datos_log4x WHERE id_agente_modulo=?' , $ id_module ) ;
2015-12-02 17:01:28 +01:00
my $ ndstring = get_db_value ( $ dbh , 'SELECT count(id_agente_modulo) FROM tagente_datos_string WHERE id_agente_modulo=?' , $ id_module ) ;
my $ ntot = $ nd + $ ndinc + $ ndlog4x + $ ndstring ;
2010-09-03 12:59:43 +02:00
2015-12-02 17:01:28 +01:00
if ( $ ntot == 0 ) {
last ;
}
2010-09-03 12:59:43 +02:00
2015-12-02 17:01:28 +01:00
if ( $ nd > 0 ) {
2019-11-04 16:04:26 +01:00
db_delete_limit ( $ dbh , 'tagente_datos' , 'id_agente_modulo=' . $ id_module , $ buffer ) ;
2010-09-03 12:59:43 +02:00
}
2015-12-02 17:01:28 +01:00
if ( $ ndinc > 0 ) {
2019-11-04 16:04:26 +01:00
db_delete_limit ( $ dbh , 'tagente_datos_inc' , 'id_agente_modulo=' . $ id_module , $ buffer ) ;
2015-12-02 17:01:28 +01:00
}
if ( $ ndlog4x > 0 ) {
2019-11-04 16:04:26 +01:00
db_delete_limit ( $ dbh , 'tagente_datos_log4x' , 'id_agente_modulo=' . $ id_module , $ buffer ) ;
2015-12-02 17:01:28 +01:00
}
if ( $ ndstring > 0 ) {
2019-11-04 16:04:26 +01:00
db_delete_limit ( $ dbh , 'tagente_datos_string' , 'id_agente_modulo=' . $ id_module , $ buffer ) ;
2015-12-02 17:01:28 +01:00
}
}
return 1 ;
2010-09-03 12:59:43 +02:00
}
2010-05-27 18:24:52 +02:00
##########################################################################
# Validate event.
# This validates all events pending to ACK for the same id_agent_module
##########################################################################
sub pandora_validate_event_filter ($$$$$$$$$) {
my ( $ pa_config , $ id_agentmodule , $ id_agent , $ timestamp_min , $ timestamp_max , $ id_user , $ id_alert_agent_module , $ criticity , $ dbh ) = @ _ ;
my $ filter = '' ;
if ( $ id_agentmodule ne '' ) {
$ filter . = " AND id_agentmodule = $id_agentmodule" ;
}
if ( $ id_agent ne '' ) {
$ filter . = " AND id_agente = $id_agent" ;
}
if ( $ timestamp_min ne '' ) {
$ filter . = " AND timestamp >= '$timestamp_min'" ;
}
if ( $ timestamp_max ne '' ) {
$ filter . = " AND timestamp <= '$timestamp_max'" ;
}
if ( $ id_user ne '' ) {
$ filter . = " AND id_usuario = '$id_user'" ;
}
if ( $ id_alert_agent_module ne '' ) {
$ filter . = " AND id_alert_am = $id_alert_agent_module" ;
}
if ( $ criticity ne '' ) {
$ filter . = " AND criticity = $criticity" ;
}
logger ( $ pa_config , "Validating events" , 10 ) ;
db_do ( $ dbh , "UPDATE tevento SET estado = 1 WHERE estado = 0" . $ filter ) ;
}
2012-02-10 10:30:21 +01:00
##########################################################################
# Validate event given a event id
##########################################################################
sub pandora_validate_event_id ($$$) {
my ( $ pa_config , $ id_event , $ dbh ) = @ _ ;
my $ filter = '' ;
if ( $ id_event ne '' ) {
$ filter . = " AND id_evento = $id_event" ;
}
logger ( $ pa_config , "Validating events" , 10 ) ;
db_do ( $ dbh , "UPDATE tevento SET estado = 1 WHERE estado = 0" . $ filter ) ;
}
2012-01-05 13:11:03 +01:00
##########################################################################
## Update a user from hash
##########################################################################
sub pandora_update_user_from_hash ($$$$) {
my ( $ parameters , $ where_column , $ where_value , $ dbh ) = @ _ ;
2022-10-18 12:49:51 +02:00
my $ centralized = pandora_get_tconfig_token ( $ dbh , 'centralized_management' , '' ) ;
my $ result = db_process_update ( $ dbh , 'tusuario' , $ parameters , { $ where_column = > $ where_value } ) ;
if ( is_metaconsole ( $ conf ) == 1 && $ centralized ) {
my @ values = (
values %$ parameters ,
$ where_value
) ;
2021-11-23 12:43:07 +01:00
2022-10-18 12:49:51 +02:00
db_synch_update ( $ dbh , $ conf , 'tusuario' , $ dbh - > { Statement } , $ result , @ values ) ;
}
return $ result ;
2012-01-05 13:11:03 +01:00
}
2012-01-13 10:43:29 +01:00
##########################################################################
## Update an alert template from hash
##########################################################################
sub pandora_update_alert_template_from_hash ($$$$) {
my ( $ parameters , $ where_column , $ where_value , $ dbh ) = @ _ ;
2015-04-06 15:26:26 +02:00
my $ template_id = db_process_update ( $ dbh , 'talert_templates' , $ parameters , { $ where_column = > $ where_value } ) ;
2012-01-13 10:43:29 +01:00
return $ template_id ;
}
2011-11-15 15:37:51 +01:00
###############################################################################
# Get list of all downed agents
###############################################################################
sub pandora_get_downed_agents () {
2012-01-18 12:21:59 +01:00
my @ downed_agents = get_db_rows ( $ dbh , " SELECT tagente . id_agente , tagente . nombre , truncate ( ( NOW ( ) - tagente . ultimo_contacto / 60 ) , 0 ) as downed_time , tagente . server_name from tagente
2011-11-15 15:37:51 +01:00
where UNIX_TIMESTAMP ( NOW ( ) ) - UNIX_TIMESTAMP ( tagente . ultimo_contacto ) > ( tagente . intervalo * 2 )
OR tagente . ultimo_contacto = 0 " ) ;
return \ @ downed_agents ;
}
2012-01-18 12:21:59 +01:00
###############################################################################
# Get the agent (id of agent and module and agent name) list with a given module
###############################################################################
sub pandora_get_module_agents ($$) {
my ( $ dbh , $ module_name ) = @ _ ;
my @ agents = get_db_rows ( $ dbh , " SELECT tagente_modulo . id_agente_modulo , tagente . id_agente , tagente . nombre FROM tagente , tagente_modulo
WHERE tagente . id_agente = tagente_modulo . id_agente AND tagente_modulo . nombre = ? " , safe_input ( $ module_name ) ) ;
return \ @ agents ;
}
2012-01-20 09:52:17 +01:00
###############################################################################
# Get agent status (critical, warning, unknown or normal)
###############################################################################
sub pandora_get_agent_status ($$) {
my ( $ dbh , $ agent_id ) = @ _ ;
my $ critical = get_db_value ( $ dbh , "SELECT COUNT(tagente_estado.id_agente_estado) FROM tagente_estado, tagente, tagente_modulo WHERE tagente.id_agente = $agent_id AND tagente.disabled = 0 AND tagente_estado.id_agente = tagente.id_agente AND tagente_estado.id_agente_modulo = tagente_modulo.id_agente_modulo AND tagente_modulo.disabled = 0 AND estado = 1 AND (utimestamp >= ( UNIX_TIMESTAMP() - (current_interval * 2)) OR tagente_modulo.id_tipo_modulo IN (21,22,23,100))" ) ;
return 'critical' unless $ critical == 0 ;
my $ warning = get_db_value ( $ dbh , "SELECT COUNT(tagente_estado.id_agente_estado) FROM tagente_estado, tagente, tagente_modulo WHERE tagente.id_agente = $agent_id AND tagente.disabled = 0 AND tagente_estado.id_agente = tagente.id_agente AND tagente_estado.id_agente_modulo = tagente_modulo.id_agente_modulo AND tagente_modulo.disabled = 0 AND estado = 2 AND (utimestamp >= ( UNIX_TIMESTAMP() - (current_interval * 2)) OR tagente_modulo.id_tipo_modulo IN (21,22,23,100))" ) ;
return 'warning' unless $ warning == 0 ;
my $ unknown = get_db_value ( $ dbh , "SELECT COUNT(tagente_estado.id_agente_estado) FROM tagente_estado, tagente, tagente_modulo WHERE tagente.id_agente = $agent_id AND tagente.disabled = 0 AND tagente.id_agente = tagente_estado.id_agente AND tagente_estado.id_agente_modulo = tagente_modulo.id_agente_modulo AND tagente_modulo.disabled = 0 AND tagente_modulo.id_tipo_modulo NOT IN (21,22,23,100) AND utimestamp < ( UNIX_TIMESTAMP() - (current_interval * 2)) AND utimestamp != 0" ) ;
return 'unknown' unless $ unknown == 0 ;
my $ normal = get_db_value ( $ dbh , "SELECT COUNT(tagente_estado.id_agente_estado) FROM tagente_estado, tagente, tagente_modulo WHERE tagente.id_agente = $agent_id AND tagente.disabled = 0 AND tagente_estado.id_agente = tagente.id_agente AND tagente_estado.id_agente_modulo = tagente_modulo.id_agente_modulo AND tagente_modulo.disabled = 0 AND estado = 0 AND (utimestamp != 0 OR tagente_modulo.id_tipo_modulo IN (21,22,23)) AND (utimestamp >= ( UNIX_TIMESTAMP() - (current_interval * 2)) OR tagente_modulo.id_tipo_modulo IN (21,22,23,100))" ) ;
return 'normal' unless $ normal == 0 ;
return 'normal' unless $ normal == 0 ;
2020-06-10 08:35:01 +02:00
return 'not_init' ;
2012-01-20 09:52:17 +01:00
}
2012-01-18 12:21:59 +01:00
##########################################################################
## Return the modules of a given agent
##########################################################################
sub pandora_get_agent_modules ($$) {
my ( $ dbh , $ agent_id ) = @ _ ;
my @ modules = get_db_rows ( $ dbh , "SELECT id_agente_modulo, nombre FROM tagente_modulo WHERE delete_pending = 0 AND id_agente = ?" , $ agent_id ) ;
return \ @ modules ;
}
###############################################################################
# Get module current data
###############################################################################
sub pandora_get_module_current_data ($$) {
my ( $ dbh , $ id_agent_module ) = @ _ ;
my $ current_data = get_db_value ( $ dbh , "SELECT datos FROM tagente_estado WHERE id_agente_modulo = ?" , $ id_agent_module ) ;
return $ current_data ;
}
2012-01-11 11:09:02 +01:00
##########################################################################
## SUB get_alert_template_id(id)
## Return the alert template id, given "template_name"
##########################################################################
sub pandora_get_alert_template_id ($$) {
my ( $ dbh , $ template_name ) = @ _ ;
my $ template_id = get_db_value ( $ dbh , "SELECT id FROM talert_templates WHERE name = ?" , safe_input ( $ template_name ) ) ;
return defined ( $ template_id ) ? $ template_id : - 1 ;
}
2012-01-17 14:10:54 +01:00
##########################################################################
## SUB get_planned_downtime_id(id)
## Return the planned downtime id, given "downtime_name"
##########################################################################
sub pandora_get_planned_downtime_id ($$) {
my ( $ dbh , $ downtime_name ) = @ _ ;
my $ downtime_id = get_db_value ( $ dbh , "SELECT id FROM tplanned_downtime WHERE name = ?" , safe_input ( $ downtime_name ) ) ;
return defined ( $ downtime_id ) ? $ downtime_id : - 1 ;
}
2015-12-02 17:01:28 +01:00
##########################################################################
## SUB get_all_planned_downtime
## Return the planned downtime id, given "downtime_name"
##########################################################################
sub pandora_get_all_planned_downtime ($$$$$$) {
my ( $ dbh , $ downtime_name , $ id_group , $ type_downtime , $ type_execution , $ type_periodicity ) = @ _ ;
2016-01-18 17:01:37 +01:00
my $ sql = "SELECT * FROM tplanned_downtime WHERE name LIKE '%" . safe_input ( $ downtime_name ) . "%' " ;
2015-12-02 17:01:28 +01:00
my $ text_sql = '' ;
2016-01-18 17:01:37 +01:00
if ( defined ( $ id_group ) && $ id_group ne '' ) {
2015-12-02 17:01:28 +01:00
$ text_sql . = " id_group = $id_group " ;
}
2016-01-18 17:01:37 +01:00
if ( defined ( $ type_downtime ) && $ type_downtime ne '' ) {
2015-12-02 17:01:28 +01:00
$ text_sql . = " type_downtime = $type_downtime " ;
}
2016-01-18 17:01:37 +01:00
if ( defined ( $ type_execution ) && $ type_execution ne '' ) {
2015-12-02 17:01:28 +01:00
$ text_sql . = " type_execution = $type_execution " ;
}
2016-01-18 17:01:37 +01:00
if ( defined ( $ type_periodicity ) && $ type_periodicity ne '' ) {
2015-12-02 17:01:28 +01:00
$ text_sql . = " type_periodicity = $type_periodicity " ;
}
if ( $ text_sql eq '' ) {
$ text_sql = '' ;
}
2016-01-18 17:01:37 +01:00
$ sql . = $ text_sql ;
my @ downtimes = get_db_rows ( $ dbh , $ sql ) ;
2015-12-02 17:01:28 +01:00
return @ downtimes ;
}
##########################################################################
## SUB get_planned_downtimes_items
## Return the planned downtime id, given "downtime_name"
##########################################################################
sub pandora_get_planned_downtimes_items ($$) {
my ( $ dbh , $ downtime ) = @ _ ;
my $ sql = "SELECT * FROM tplanned_downtime_agents WHERE id_downtime = ?" ;
my @ agents_items = get_db_rows ( $ dbh , $ sql , $ downtime - > { "id" } ) ;
my @ modules_downtime ;
my @ return ;
my $ text_modules ;
foreach my $ agents_item ( @ agents_items ) {
if ( $ downtime - > { "type_downtime" } eq 'quiet' ) {
if ( ! $ agents_item - > { 'all_modules' } ) {
$ sql = "SELECT id_agent_module FROM tplanned_downtime_modules WHERE id_downtime = ? AND id_agent = ?" ;
my @ modules_items = get_db_rows ( $ dbh , $ sql , $ downtime - > { "id" } , $ agents_item - > { "id_agent" } ) ;
foreach my $ modules_item ( @ modules_items ) {
push ( @ modules_downtime , $ modules_item - > { "id_agent_module" } ) ;
}
}
}
if ( @ modules_downtime != undef ) {
$ text_modules = join ( "," , @ modules_downtime ) ;
$ agents_item - > { "modules" } = $ text_modules ;
@ modules_downtime = undef ;
}
push ( @ return , $ agents_item ) ;
}
return @ return ;
}
2014-05-03 02:57:53 +02:00
##########################################################################
## Create a special day from hash
##########################################################################
sub pandora_create_special_day_from_hash ($$$) {
my ( $ pa_config , $ parameters , $ dbh ) = @ _ ;
logger ( $ pa_config , "Creating special_day '$parameters->{'date'}'" , 10 ) ;
my $ template_id = db_process_insert ( $ dbh , 'id' , 'talert_special_days' , $ parameters ) ;
return $ template_id ;
}
##########################################################################
## Update a special day from hash
##########################################################################
sub pandora_update_special_day_from_hash ($$$$) {
my ( $ parameters , $ where_column , $ where_value , $ dbh ) = @ _ ;
2015-04-06 15:26:26 +02:00
my $ special_day_id = db_process_update ( $ dbh , 'talert_special_days' , $ parameters , { $ where_column = > $ where_value } ) ;
2014-05-03 02:57:53 +02:00
return $ special_day_id ;
}
##########################################################################
## SUB get_special_day_id(id)
## Return the special day id, given "special_day"
##########################################################################
sub pandora_get_special_day_id ($$) {
my ( $ dbh , $ special_day ) = @ _ ;
2016-01-19 09:58:48 +01:00
my $ special_day_id = get_db_value ( $ dbh , "SELECT id FROM talert_special_days WHERE ${RDBMS_QUOTE}date${RDBMS_QUOTE} = ?" , $ special_day ) ;
2014-05-03 02:57:53 +02:00
return defined ( $ special_day_id ) ? $ special_day_id : - 1 ;
}
2021-11-04 12:33:40 +01:00
##########################################################################
## SUB pandora_get_calendar_id(id)
## Return calendar id, given "calendar_name"
##########################################################################
sub pandora_get_calendar_id ($$) {
my ( $ dbh , $ calendar_name ) = @ _ ;
my $ calendar_id = get_db_value ( $ dbh , "SELECT id FROM talert_calendar WHERE ${RDBMS_QUOTE}name${RDBMS_QUOTE} = ?" , $ calendar_name ) ;
return defined ( $ calendar_id ) ? $ calendar_id : - 1 ;
}
##########################################################################
## SUB pandora_get_same_day_id(id)
## Return same day id, given "same_day"
##########################################################################
sub pandora_get_same_day_id ($$) {
my ( $ dbh , $ same_day ) = @ _ ;
2021-11-24 17:46:23 +01:00
my $ weeks = { 'monday' = > 1 , 'tuesday' = > 2 , 'wednesday' = > 3 , 'thursday' = > 4 , 'friday' = > 5 , 'saturday' = > 6 , 'sunday' = > 7 , 'holiday' = > 8 } ;
2021-11-04 12:33:40 +01:00
2021-11-23 18:04:34 +01:00
return defined ( $ weeks - > { $ same_day } ) ? $ weeks - > { $ same_day } : - 1 ;
2021-11-04 12:33:40 +01:00
}
2014-05-03 02:57:53 +02:00
##########################################################################
## Delete a special day.
##########################################################################
sub pandora_delete_special_day ($$) {
my ( $ dbh , $ date ) = @ _ ;
# Delete the special_day
my $ return = db_do ( $ dbh , 'DELETE FROM talert_special_days WHERE date = ?' , safe_input ( $ date ) ) ;
if ( $ return eq '0E0' ) {
return - 1 ;
}
else {
return 0 ;
}
}
2010-05-27 18:24:52 +02:00
###############################################################################
# Print a parameter error and exit the program.
###############################################################################
sub param_error ($$) {
print ( STDERR "[ERROR] Parameters error: $_[1] received | $_[0] necessary.\n\n" ) ;
2012-12-28 09:26:49 +01:00
logger ( $ conf , "($progname) [ERROR] Parameters error: $_[1] received | $_[0] necessary." , 10 ) ;
2010-05-27 18:24:52 +02:00
help_screen ( ) ;
exit 1 ;
}
###############################################################################
# Print a 'not exists' error and exit the program.
###############################################################################
sub notexists_error ($$) {
print ( STDERR "[ERROR] Error: The $_[0] '$_[1]' not exists.\n\n" ) ;
2012-12-28 09:26:49 +01:00
logger ( $ conf , "($progname) [ERROR] Error: The $_[0] '$_[1]' not exists." , 10 ) ;
2010-05-27 18:24:52 +02:00
exit 1 ;
}
2011-11-29 11:05:25 +01:00
###############################################################################
# Print a 'exists' error and exit the program.
###############################################################################
sub exists_error ($$) {
print ( STDERR "[ERROR] Error: The $_[0] '$_[1]' already exists.\n\n" ) ;
2012-12-28 09:26:49 +01:00
logger ( $ conf , "($progname) [ERROR] Error: The $_[0] '$_[1]' already exists." , 10 ) ;
2011-11-29 11:05:25 +01:00
exit 1 ;
}
2010-05-27 18:24:52 +02:00
###############################################################################
# Check the return of 'get id' and call the error if its equal to -1.
###############################################################################
sub exist_check ($$$) {
if ( $ _ [ 0 ] == - 1 ) {
notexists_error ( $ _ [ 1 ] , $ _ [ 2 ] ) ;
}
}
2011-11-29 11:05:25 +01:00
###############################################################################
# Check the return of 'get id' and call the error if its not equal to -1.
###############################################################################
sub non_exist_check ($$$) {
if ( $ _ [ 0 ] != - 1 ) {
exists_error ( $ _ [ 1 ] , $ _ [ 2 ] ) ;
}
}
2010-05-27 18:24:52 +02:00
###############################################################################
# Check the parameters.
# Param 0: # of received parameters
2012-01-11 11:09:02 +01:00
# Param 1: # of acceptable parameters
2010-05-27 18:24:52 +02:00
# Param 2: # of optional parameters
###############################################################################
sub param_check ($$;$) {
2012-01-11 11:09:02 +01:00
my ( $ ltotal , $ laccept , $ lopt ) = @ _ ;
2010-05-27 18:24:52 +02:00
$ ltotal = $ ltotal - 1 ;
if ( ! defined ( $ lopt ) ) {
$ lopt = 0 ;
}
2012-01-11 11:09:02 +01:00
if ( $ ltotal < $ laccept - $ lopt || $ ltotal > $ laccept ) {
2010-05-27 18:24:52 +02:00
if ( $ lopt == 0 ) {
2012-01-11 11:09:02 +01:00
param_error ( $ laccept , $ ltotal ) ;
2010-05-27 18:24:52 +02:00
}
else {
2012-01-11 11:09:02 +01:00
param_error ( ( $ laccept - $ lopt ) . "-" . $ laccept , $ ltotal ) ;
2010-05-27 18:24:52 +02:00
}
}
2010-03-24 14:09:09 +01:00
}
2010-05-27 18:24:52 +02:00
##############################################################################
# Print a help line.
##############################################################################
sub help_screen_line ($$$) {
my ( $ option , $ parameters , $ help ) = @ _ ;
2013-02-05 18:09:18 +01:00
print "\n\t$option $parameters : $help.\n" unless ( $ param ne '' && $ param ne $ option ) ;
2010-05-27 18:24:52 +02:00
}
2010-03-24 14:09:09 +01:00
2022-10-31 16:59:38 +01:00
sub check_values ($) {
my ( $ check ) = @ _ ;
2022-10-27 09:40:33 +02:00
my $ arg_cont = 2 ;
2022-10-31 16:59:38 +01:00
my $ cont = 0 ;
my @ args = @ ARGV ;
2022-10-27 09:40:33 +02:00
my $ total = $# args ;
2022-10-31 16:59:38 +01:00
while ( $ arg_cont <= $ total ) {
# Check type.
if ( $ check - > [ $ cont ] - > { 'type' } eq 'json' ) {
my $ json_out = eval { decode_json ( $ args [ $ arg_cont ] ) } ;
if ( $@ )
{
print "\nValue `$args[$arg_cont]` is an invalid json. \nError:$@\n" ;
exit ;
}
}
2022-10-27 09:40:33 +02:00
2022-10-31 16:59:38 +01:00
# Check values.
if ( defined ( $ check - > [ $ cont ] - > { 'values' } ) ) {
2022-12-14 12:24:56 +01:00
if ( ! ( is_in_array ( $ check - > [ $ cont ] - > { 'values' } , $ args [ $ arg_cont ] ) ) ) {
2022-10-31 16:59:38 +01:00
print "\nError: value `$args[$arg_cont]` is not valid for $check->[$cont]->{'name'}\n" ;
print "\tAvailable options: \t$check->[$cont]->{'values'}->[0]" ;
if ( defined ( $ check - > [ $ cont ] - > { 'text_extra' } - > [ 0 ] ) ) {
print " $check->[$cont]->{'text_extra'}->[0]" ;
}
print "\n" ;
2022-10-27 09:40:33 +02:00
2022-10-31 16:59:38 +01:00
my $ cont_aux = 1 ;
my $ while = 'false' ;
while ( $ while eq 'false' ) {
if ( defined ( $ check - > [ $ cont ] - > { 'values' } - > [ $ cont_aux ] ) ) {
print "\t\t\t\t$check->[$cont]->{'values'}->[$cont_aux]" ;
if ( defined ( $ check - > [ $ cont ] - > { 'text_extra' } - > [ $ cont_aux ] ) ) {
print " $check->[$cont]->{'text_extra'}->[$cont_aux]" ;
}
print "\n" ;
} else {
exit ;
}
$ cont_aux + + ;
}
}
}
$ cont + + ;
2022-10-27 09:40:33 +02:00
$ arg_cont + + ;
}
}
2010-05-27 18:24:52 +02:00
###############################################################################
###############################################################################
2011-11-14 14:27:21 +01:00
# CLI FUNCTIONS
2010-05-27 18:24:52 +02:00
###############################################################################
###############################################################################
2011-11-14 14:27:21 +01:00
##############################################################################
# Disable group
# Related option: --disable_group
##############################################################################
2010-03-24 14:09:09 +01:00
2011-11-14 14:27:21 +01:00
sub cli_disable_group () {
my $ group_name = @ ARGV [ 2 ] ;
my $ id_group ;
if ( $ group_name eq "All" ) {
2012-12-28 09:26:49 +01:00
print_log "[INFO] Disabling all groups\n\n" ;
2011-11-14 14:27:21 +01:00
$ id_group = 0 ;
}
else {
$ id_group = get_group_id ( $ dbh , $ group_name ) ;
exist_check ( $ id_group , 'group' , $ group_name ) ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] Disabling group '$group_name'\n\n" ;
2011-11-14 14:27:21 +01:00
}
2022-04-25 13:17:13 +02:00
my $ result = pandora_disable_group ( $ conf , $ dbh , $ id_group ) ;
2022-08-26 11:46:35 +02:00
if ( $ result != 0 ) {
2022-05-04 14:48:39 +02:00
print_log "[INFO] Disabled " . $ result . " agents from group " . $ group_name . "\n\n" ;
2022-08-26 11:46:35 +02:00
} else {
print_log "[INFO] Disabled 0 agents from group " . $ group_name . "\n\n" ;
}
2011-11-14 14:27:21 +01:00
}
2010-05-19 15:40:21 +02:00
2011-11-14 14:27:21 +01:00
##############################################################################
# Enable group
# Related option: --enable_group
##############################################################################
sub cli_enable_group () {
my $ group_name = @ ARGV [ 2 ] ;
my $ id_group ;
if ( $ group_name eq "All" ) {
$ id_group = 0 ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] Enabling all groups\n\n" ;
2011-11-14 14:27:21 +01:00
}
2010-05-27 18:24:52 +02:00
else {
2011-11-14 14:27:21 +01:00
$ id_group = get_group_id ( $ dbh , $ group_name ) ;
exist_check ( $ id_group , 'group' , $ group_name ) ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] Enabling group '$group_name'\n\n" ;
2011-11-14 14:27:21 +01:00
}
pandora_enable_group ( $ conf , $ dbh , $ id_group ) ;
}
2010-05-19 15:40:21 +02:00
2022-05-24 10:59:41 +02:00
##############################################################################
# Start snmptrap process.
# Related option: --start_snmptrapd
##############################################################################
sub cli_start_snmptrapd () {
use PandoraFMS::SNMPServer ;
print_log "[INFO] Starting snmptrap process. \n" ;
PandoraFMS::SNMPServer:: start_snmptrapd ( \ % conf ) ;
}
2011-11-14 14:27:21 +01:00
##############################################################################
# Create an agent.
# Related option: --created_agent
##############################################################################
2010-10-14 13:13:30 +02:00
2011-11-14 14:27:21 +01:00
sub cli_create_agent () {
2018-12-10 12:17:12 +01:00
my ( $ agent_name , $ os_name , $ group_name , $ server_name , $ address , $ description , $ interval , $ alias_as_name ) = @ ARGV [ 2 .. 9 ] ;
2011-11-14 14:27:21 +01:00
2012-12-28 09:26:49 +01:00
print_log "[INFO] Creating agent '$agent_name'\n\n" ;
2011-11-14 14:27:21 +01:00
$ address = '' unless defined ( $ address ) ;
$ description = ( defined ( $ description ) ? safe_input ( $ description ) : '' ) ; # safe_input() might be better at pandora_create_agent() (when passing 'description' to db_insert())
$ interval = 300 unless defined ( $ interval ) ;
2018-12-10 12:17:12 +01:00
$ alias_as_name = 1 unless defined ( $ alias_as_name ) ;
my $ agent_alias = undef ;
if ( ! $ alias_as_name ) {
$ agent_alias = $ agent_name ;
$ agent_name = generate_agent_name_hash ( $ agent_alias , $ conf { 'dbhost' } ) ;
}
2011-11-14 14:27:21 +01:00
my $ id_group = get_group_id ( $ dbh , $ group_name ) ;
exist_check ( $ id_group , 'group' , $ group_name ) ;
my $ os_id = get_os_id ( $ dbh , $ os_name ) ;
exist_check ( $ id_group , 'operating system' , $ group_name ) ;
2011-11-29 11:05:25 +01:00
my $ agent_exists = get_agent_id ( $ dbh , $ agent_name ) ;
non_exist_check ( $ agent_exists , 'agent name' , $ agent_name ) ;
2020-07-06 10:25:14 +02:00
my $ agent_id = pandora_create_agent ( $ conf , $ server_name , $ agent_name , $ address , $ id_group , 0 , $ os_id , $ description , $ interval , $ dbh ,
2018-12-10 12:17:12 +01:00
undef , undef , undef , undef , undef , undef , undef , undef , $ agent_alias ) ;
2020-07-06 10:25:14 +02:00
# Create address for this agent in taddress.
if ( defined ( $ address ) ) {
pandora_add_agent_address ( $ conf , $ agent_id , $ agent_name , $ address , $ dbh ) ;
}
2011-11-14 14:27:21 +01:00
}
2010-10-14 13:13:30 +02:00
2011-11-14 14:27:21 +01:00
##############################################################################
# Delete an agent.
# Related option: --delete_agent
##############################################################################
2010-10-18 18:21:13 +02:00
2011-11-14 14:27:21 +01:00
sub cli_delete_agent () {
2019-10-17 11:14:42 +02:00
my ( $ agent_name , $ use_alias ) = @ ARGV [ 2 .. 3 ] ;
my @ id_agents ;
my $ id_agent ;
2011-11-14 14:27:21 +01:00
$ agent_name = decode_entities ( $ agent_name ) ;
2019-10-17 11:14:42 +02:00
2020-03-20 12:34:58 +01:00
if ( is_metaconsole ( $ conf ) != 1 and pandora_get_tconfig_token ( $ dbh , 'centralized_management' , '' ) ) {
print_log "[ERROR] This node is configured with centralized mode. To delete an agent go to metaconsole. \n\n" ;
exit ;
}
2015-12-29 17:41:39 +01:00
if ( is_metaconsole ( $ conf ) == 1 ) {
2019-10-17 11:14:42 +02:00
if ( not defined $ use_alias ) {
my $ agents_groups = enterprise_hook ( 'get_metaconsole_agent' , [ $ dbh , $ agent_name ] ) ;
if ( scalar ( @ { $ agents_groups } ) != 0 ) {
foreach my $ agent ( @ { $ agents_groups } ) {
my $ return = enterprise_hook ( 'delete_metaconsole_agent' , [ $ dbh , $ agent - > { 'id_agente' } ] ) ;
print_log "[INFO] Deleting agent '$agent_name' \n\n" ;
}
2015-12-30 09:58:08 +01:00
}
}
2019-10-17 11:14:42 +02:00
2015-12-29 17:41:39 +01:00
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 ] ) ;
2019-10-17 11:14:42 +02:00
my @ id_agents ;
my $ id_agent ;
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh_metaconsole , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
if ( $ id - > { 'id_agente' } == - 1 ) {
next ;
}
else {
print_log "[INFO] Deleting agent '$id->{'nombre'}' in ID server: '$server'\n\n" ;
pandora_delete_agent ( $ dbh_metaconsole , $ id - > { 'id_agente' } , $ conf ) ;
}
}
} else {
$ id_agent = get_agent_id ( $ dbh_metaconsole , $ agent_name ) ;
if ( $ id_agent == - 1 ) {
next ;
}
else {
print_log "[INFO] Deleting agent '$agent_name' in ID server: '$server'\n\n" ;
pandora_delete_agent ( $ dbh_metaconsole , $ id_agent , $ conf ) ;
}
2015-12-29 17:41:39 +01:00
}
2019-10-17 11:14:42 +02:00
2015-12-29 17:41:39 +01:00
}
}
else {
2019-10-17 11:14:42 +02:00
my @ id_agents ;
my $ id_agent ;
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
} else {
$ id_agent = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
}
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
foreach my $ id ( @ id_agents ) {
exist_check ( $ id - > { 'id_agente' } , 'agent' , $ agent_name ) ;
print_log "[INFO] Deleting agent '$id->{'nombre'}'\n\n" ;
pandora_delete_agent ( $ dbh , $ id - > { 'id_agente' } , $ conf ) ;
}
} else {
print_log "[INFO] Deleting agent '$agent_name'\n\n" ;
pandora_delete_agent ( $ dbh , $ id_agent , $ conf ) ;
}
2015-12-29 17:41:39 +01:00
}
2011-11-14 14:27:21 +01:00
}
2010-10-18 18:21:13 +02:00
2012-01-11 11:09:02 +01:00
##############################################################################
# Create alert template
# Related option: --create_alert_template
##############################################################################
sub cli_create_alert_template () {
my ( $ template_name , $ condition_type_serialized , $ time_from , $ time_to ,
$ description , $ group_name , $ field1 , $ field2 , $ field3 , $ priority , $ default_action , $ days , $ time_threshold ,
$ min_alerts , $ max_alerts , $ alert_recovery , $ field2_recovery , $ field3_recovery , $ condition_type_separator ) = @ ARGV [ 2 .. 20 ] ;
my $ template_exists = pandora_get_alert_template_id ( $ dbh , $ template_name ) ;
non_exist_check ( $ template_exists , 'alert template' , $ template_name ) ;
my $ id_alert_action = 0 ;
$ id_alert_action = get_action_id ( $ dbh , safe_input ( $ default_action ) ) unless $ default_action eq '' ;
my $ group_id = 0 ;
# If group name is not defined, we assign group All (0)
if ( defined ( $ group_name ) ) {
$ group_id = get_group_id ( $ dbh , $ group_name ) ;
exist_check ( $ group_id , 'group' , $ group_name ) ;
}
else {
$ group_name = 'All' ;
}
$ condition_type_separator = ';' unless defined $ condition_type_separator ;
my % parameters ;
my @ condition_array = split ( $ condition_type_separator , $ condition_type_serialized ) ;
my $ type = $ condition_array [ 0 ] ;
if ( $ type eq 'regex' ) {
$ parameters { 'matches_value' } = $ condition_array [ 1 ] ;
$ parameters { 'value' } = $ condition_array [ 1 ] ;
}
elsif ( $ type eq 'max_min' ) {
$ parameters { 'matches_value' } = $ condition_array [ 1 ] ;
$ parameters { 'min_value' } = $ condition_array [ 2 ] ;
$ parameters { 'max_value' } = $ condition_array [ 3 ] ;
}
elsif ( $ type eq 'max' ) {
$ parameters { 'max_value' } = $ condition_array [ 1 ] ;
}
elsif ( $ type eq 'min' ) {
$ parameters { 'min_value' } = $ condition_array [ 1 ] ;
}
elsif ( $ type eq 'equal' ) {
$ parameters { 'value' } = $ condition_array [ 1 ] ;
}
elsif ( $ type eq 'not_equal' ) {
$ parameters { 'value' } = $ condition_array [ 1 ] ;
}
elsif ( $ type eq 'onchange' ) {
$ parameters { 'matches_value' } = $ condition_array [ 1 ] ;
}
elsif ( $ type eq 'warning' || $ type eq 'critical' || $ type eq 'unknown' || $ type eq 'always' ) {
# Only type is stored
}
else {
$ type = 'always' ;
}
$ parameters { 'name' } = $ template_name ;
$ parameters { 'type' } = $ type ;
$ parameters { 'time_from' } = $ time_from ;
$ parameters { 'time_to' } = $ time_to ;
$ parameters { 'id_alert_action' } = $ id_alert_action unless $ id_alert_action <= 0 ;
$ parameters { 'id_group' } = $ group_id ;
$ parameters { 'field1' } = defined ( $ field1 ) ? safe_input ( $ field1 ) : '' ;
$ parameters { 'field2' } = defined ( $ field2 ) ? safe_input ( $ field2 ) : '' ;
$ parameters { 'field3' } = defined ( $ field3 ) ? safe_input ( $ field3 ) : '' ;
$ parameters { 'priority' } = defined ( $ priority ) ? $ priority : 1 ; # Informational by default
$ parameters { 'description' } = defined ( $ description ) ? safe_input ( $ description ) : '' ;
$ parameters { 'time_threshold' } = defined ( $ time_threshold ) ? $ time_threshold : 86400 ;
$ parameters { 'min_alerts' } = defined ( $ min_alerts ) ? $ min_alerts : 0 ;
$ parameters { 'max_alerts' } = defined ( $ max_alerts ) ? $ max_alerts : 1 ;
$ parameters { 'recovery_notify' } = defined ( $ alert_recovery ) ? $ alert_recovery : 0 ;
$ parameters { 'field2_recovery' } = defined ( $ field2_recovery ) ? safe_input ( $ field2_recovery ) : '' ;
$ parameters { 'field3_recovery' } = defined ( $ field3_recovery ) ? safe_input ( $ field3_recovery ) : '' ;
$ days = '1111111' unless defined ( $ days ) ; # Al days actived by default
my @ days_array = split ( '' , $ days ) ;
$ parameters { 'monday' } = $ days_array [ 0 ] ;
$ parameters { 'tuesday' } = $ days_array [ 1 ] ;
$ parameters { 'wednesday' } = $ days_array [ 2 ] ;
$ parameters { 'thursday' } = $ days_array [ 3 ] ;
$ parameters { 'friday' } = $ days_array [ 4 ] ;
$ parameters { 'saturday' } = $ days_array [ 5 ] ;
$ parameters { 'sunday' } = $ days_array [ 6 ] ;
pandora_create_alert_template_from_hash ( $ conf , \ % parameters , $ dbh ) ;
}
2011-11-14 14:27:21 +01:00
##############################################################################
# Create data module.
# Related option: --create_data_module
##############################################################################
2010-10-18 18:21:13 +02:00
2012-01-11 11:09:02 +01:00
sub cli_create_data_module ($) {
my $ in_policy = shift ;
my ( $ policy_name , $ module_name , $ module_type , $ agent_name , $ description , $ module_group ,
$ min , $ max , $ post_process , $ interval , $ warning_min , $ warning_max , $ critical_min ,
2014-06-15 04:53:41 +02:00
$ critical_max , $ history_data , $ definition_file , $ configuration_data , $ warning_str , $ critical_str , $ enable_unknown_events ,
2016-01-20 10:16:07 +01:00
$ ff_threshold , $ each_ff , $ ff_threshold_normal , $ ff_threshold_warning , $ ff_threshold_critical , $ ff_timeout ,
2019-10-17 11:14:42 +02:00
$ warning_inverse , $ critical_inverse , $ critical_instructions , $ warning_instructions , $ unknown_instructions , $ use_alias ) ;
2013-08-29 13:39:05 +02:00
if ( $ in_policy == 0 ) {
2012-01-11 11:09:02 +01:00
( $ module_name , $ module_type , $ agent_name , $ description , $ module_group ,
$ min , $ max , $ post_process , $ interval , $ warning_min , $ warning_max , $ critical_min ,
2014-06-15 04:53:41 +02:00
$ critical_max , $ history_data , $ definition_file , $ warning_str , $ critical_str , $ enable_unknown_events , $ ff_threshold ,
2016-01-20 10:16:07 +01:00
$ each_ff , $ ff_threshold_normal , $ ff_threshold_warning , $ ff_threshold_critical , $ ff_timeout ,
2019-10-17 11:14:42 +02:00
$ warning_inverse , $ critical_inverse , $ critical_instructions , $ warning_instructions , $ unknown_instructions , $ use_alias ) = @ ARGV [ 2 .. 31 ] ;
2012-01-11 11:09:02 +01:00
}
else {
( $ policy_name , $ module_name , $ module_type , $ description , $ module_group ,
$ min , $ max , $ post_process , $ interval , $ warning_min , $ warning_max , $ critical_min ,
2014-06-15 04:53:41 +02:00
$ critical_max , $ history_data , $ configuration_data , $ warning_str , $ critical_str , $ enable_unknown_events , $ ff_threshold ,
2016-01-20 10:16:07 +01:00
$ each_ff , $ ff_threshold_normal , $ ff_threshold_warning , $ ff_threshold_critical , $ ff_timeout ,
2016-10-19 13:48:25 +02:00
$ warning_inverse , $ critical_inverse , $ critical_instructions , $ warning_instructions , $ unknown_instructions ) = @ ARGV [ 2 .. 31 ] ;
2012-01-11 11:09:02 +01:00
}
2011-11-14 14:27:21 +01:00
my $ module_name_def ;
my $ module_type_def ;
2011-11-29 11:05:25 +01:00
2012-01-11 11:09:02 +01:00
my $ agent_id ;
2019-10-17 11:14:42 +02:00
my @ id_agents ;
2012-01-11 11:09:02 +01:00
my $ policy_id ;
2013-08-29 13:39:05 +02:00
my $ disabled_types_event = { } ;
if ( $ enable_unknown_events ) {
$ disabled_types_event - > { 'going_unknown' } = 0 ;
}
else {
$ disabled_types_event - > { 'going_unknown' } = 1 ;
}
my $ disabled_types_event_json = encode_json ( $ disabled_types_event ) ;
if ( $ in_policy == 0 ) {
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
exist_check ( $ id - > { 'id_agente' } , 'agent' , $ agent_name ) ;
my $ module_exists = get_agent_module_id ( $ dbh , $ module_name , $ id - > { 'id_agente' } ) ;
non_exist_check ( $ module_exists , 'module name' , $ module_name ) ;
}
} else {
$ agent_id = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ agent_id , 'agent' , $ agent_name ) ;
my $ module_exists = get_agent_module_id ( $ dbh , $ module_name , $ agent_id ) ;
non_exist_check ( $ module_exists , 'module name' , $ module_name ) ;
}
2012-01-11 11:09:02 +01:00
}
else {
$ policy_id = enterprise_hook ( 'get_policy_id' , [ $ dbh , safe_input ( $ policy_name ) ] ) ;
exist_check ( $ policy_id , 'policy' , $ policy_name ) ;
2013-08-29 13:39:05 +02:00
2012-01-11 11:09:02 +01:00
my $ policy_module_exist = enterprise_hook ( 'get_policy_module_id' , [ $ dbh , $ policy_id , $ module_name ] ) ;
non_exist_check ( $ policy_module_exist , 'policy module' , $ module_name ) ;
2016-10-26 16:57:33 +02:00
#~ print_log "[INFO] Adding module '$module_name' to policy '$policy_name'\n\n";
2012-01-11 11:09:02 +01:00
}
2013-08-29 13:39:05 +02:00
2014-06-15 04:53:41 +02:00
$ module_name_def = $ module_name ;
$ module_type_def = $ module_type ;
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
foreach my $ id ( @ id_agents ) {
# If the module is local and is not to policy, we add it to the conf file
if ( defined ( $ definition_file ) && ( - e $ definition_file ) && ( - e $ conf - > { incomingdir } . '/conf/' . md5 ( $ id - > { 'nombre' } ) . '.conf' ) ) {
open ( FILE , $ definition_file ) ;
my @ file = <FILE> ;
my $ definition = join ( "" , @ file ) ;
close ( FILE ) ;
# If the parameter name or type and the definition file name or type
# dont match will be set the file definitions
open ( FILE , $ definition_file ) ;
while ( <FILE> ) {
chomp ;
my ( $ key , $ val ) = split / / , 2 ;
if ( $ key eq 'module_name' ) {
$ module_name_def = $ val ;
}
if ( $ key eq 'module_type' ) {
$ module_type_def = $ val ;
}
}
close ( FILE ) ;
open ( FILE , $ conf - > { incomingdir } . '/conf/' . md5 ( $ id - > { 'nombre' } ) . '.conf' ) ;
my @ file = <FILE> ;
my $ conf_file = join ( "" , @ file ) ;
close ( FILE ) ;
open FILE , "> " . $ conf - > { incomingdir } . '/conf/' . md5 ( $ id - > { 'nombre' } ) . '.conf' ;
print FILE "$conf_file\n$definition" ;
close ( FILE ) ;
enterprise_hook ( 'pandora_update_md5_file' , [ $ conf , $ id - > { 'nombre' } ] ) ;
2010-10-18 18:21:13 +02:00
}
2019-10-17 11:14:42 +02:00
}
} else {
# If the module is local and is not to policy, we add it to the conf file
if ( defined ( $ definition_file ) && ( - e $ definition_file ) && ( - e $ conf - > { incomingdir } . '/conf/' . md5 ( $ agent_name ) . '.conf' ) ) {
open ( FILE , $ definition_file ) ;
my @ file = <FILE> ;
my $ definition = join ( "" , @ file ) ;
close ( FILE ) ;
# If the parameter name or type and the definition file name or type
# dont match will be set the file definitions
open ( FILE , $ definition_file ) ;
while ( <FILE> ) {
chomp ;
my ( $ key , $ val ) = split / / , 2 ;
if ( $ key eq 'module_name' ) {
$ module_name_def = $ val ;
}
if ( $ key eq 'module_type' ) {
$ module_type_def = $ val ;
}
2010-10-18 18:21:13 +02:00
}
2019-10-17 11:14:42 +02:00
close ( FILE ) ;
open ( FILE , $ conf - > { incomingdir } . '/conf/' . md5 ( $ agent_name ) . '.conf' ) ;
my @ file = <FILE> ;
my $ conf_file = join ( "" , @ file ) ;
close ( FILE ) ;
open FILE , "> " . $ conf - > { incomingdir } . '/conf/' . md5 ( $ agent_name ) . '.conf' ;
print FILE "$conf_file\n$definition" ;
close ( FILE ) ;
enterprise_hook ( 'pandora_update_md5_file' , [ $ conf , $ agent_name ] ) ;
2011-11-14 14:27:21 +01:00
}
}
2013-08-29 13:39:05 +02:00
2016-10-26 16:57:33 +02:00
if ( $ in_policy == 0 ) {
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
foreach my $ id ( @ id_agents ) {
my $ module_exists = get_agent_module_id ( $ dbh , $ module_name_def , $ id - > { 'id_agente' } ) ;
non_exist_check ( $ module_exists , 'module name' , $ module_name_def ) ;
print_log "[INFO] Adding module '$module_name' to agent '$id->{'nombre'}'\n\n" ;
}
} else {
my $ module_exists = get_agent_module_id ( $ dbh , $ module_name_def , $ agent_id ) ;
non_exist_check ( $ module_exists , 'module name' , $ module_name_def ) ;
print_log "[INFO] Adding module '$module_name' to agent '$agent_name'\n\n" ;
}
2016-10-26 16:57:33 +02:00
}
else {
2016-10-27 15:25:01 +02:00
my $ policy_module_exist = enterprise_hook ( 'get_policy_module_id' , [ $ dbh , $ policy_id , $ module_name_def ] ) ;
2016-10-26 16:57:33 +02:00
non_exist_check ( $ policy_module_exist , 'policy module' , $ module_name_def ) ;
print_log "[INFO] Adding module '$module_name' to policy '$policy_name'\n\n" ;
}
2013-08-29 13:39:05 +02:00
if ( defined ( $ definition_file ) && $ module_type ne $ module_type_def ) {
2011-11-14 14:27:21 +01:00
$ module_type = $ module_type_def ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] The module type has been forced to '$module_type' by the definition file\n\n" ;
2011-11-14 14:27:21 +01:00
}
2013-08-29 13:39:05 +02:00
if ( defined ( $ definition_file ) && $ module_name ne $ module_name_def ) {
2011-11-14 14:27:21 +01:00
$ module_name = $ module_name_def ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] The module name has been forced to '$module_name' by the definition file\n\n" ;
2011-11-14 14:27:21 +01:00
}
my $ module_type_id = get_module_id ( $ dbh , $ module_type ) ;
exist_check ( $ module_type_id , 'module type' , $ module_type ) ;
2013-08-29 13:39:05 +02:00
2011-11-14 14:27:21 +01:00
if ( $ module_type !~ m/.?generic.?/ && $ module_type !~ m/.?async.?/ && $ module_type ne 'log4x' && $ module_type ne 'keep_alive' ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] '$module_type' is not valid type for data modules. Try with generic, asyncronous, keep alive or log4x types\n\n" ;
2011-11-14 14:27:21 +01:00
exit ;
}
2013-08-29 13:39:05 +02:00
2012-01-12 17:02:04 +01:00
my $ module_group_id = 0 ;
2013-08-29 13:39:05 +02:00
if ( defined ( $ module_group ) ) {
2012-01-12 17:02:04 +01:00
$ module_group_id = get_module_group_id ( $ dbh , $ module_group ) ;
exist_check ( $ module_group_id , 'module group' , $ module_group ) ;
}
2011-11-14 14:27:21 +01:00
my % parameters ;
$ parameters { 'id_tipo_modulo' } = $ module_type_id ;
2019-10-17 11:14:42 +02:00
2013-08-29 13:39:05 +02:00
if ( $ in_policy == 0 ) {
2012-01-11 11:09:02 +01:00
$ parameters { 'nombre' } = safe_input ( $ module_name ) ;
2019-10-17 11:14:42 +02:00
if ( not defined $ use_alias ) {
$ parameters { 'id_agente' } = $ agent_id ;
}
2012-01-11 11:09:02 +01:00
}
else {
$ parameters { 'name' } = safe_input ( $ module_name ) ;
$ parameters { 'id_policy' } = $ policy_id ;
}
2013-08-29 13:39:05 +02:00
2011-11-14 14:27:21 +01:00
# Optional parameters
$ parameters { 'id_module_group' } = $ module_group_id unless ! defined ( $ module_group ) ;
$ parameters { 'min_warning' } = $ warning_min unless ! defined ( $ warning_min ) ;
$ parameters { 'max_warning' } = $ warning_max unless ! defined ( $ warning_max ) ;
$ parameters { 'min_critical' } = $ critical_min unless ! defined ( $ critical_min ) ;
$ parameters { 'max_critical' } = $ critical_max unless ! defined ( $ critical_max ) ;
$ parameters { 'history_data' } = $ history_data unless ! defined ( $ history_data ) ;
2013-08-29 13:39:05 +02:00
if ( $ in_policy == 0 ) {
2012-01-11 11:09:02 +01:00
$ parameters { 'descripcion' } = safe_input ( $ description ) unless ! defined ( $ description ) ;
$ parameters { 'id_modulo' } = 1 ;
}
else {
$ parameters { 'description' } = safe_input ( $ description ) unless ! defined ( $ description ) ;
2012-01-11 16:42:52 +01:00
$ parameters { 'id_module' } = 1 ;
$ configuration_data !~ s/\\n/\n/g ;
$ parameters { 'configuration_data' } = safe_input ( $ configuration_data ) ;
2012-01-11 11:09:02 +01:00
}
2011-11-14 14:27:21 +01:00
$ parameters { 'min' } = $ min unless ! defined ( $ min ) ;
$ parameters { 'max' } = $ max unless ! defined ( $ max ) ;
$ parameters { 'post_process' } = $ post_process unless ! defined ( $ post_process ) ;
2012-01-11 11:09:02 +01:00
$ parameters { 'module_interval' } = $ interval unless ! defined ( $ interval ) ;
$ parameters { 'str_warning' } = safe_input ( $ warning_str ) unless ! defined ( $ warning_str ) ;
$ parameters { 'str_critical' } = safe_input ( $ critical_str ) unless ! defined ( $ critical_str ) ;
2013-08-29 13:39:05 +02:00
$ parameters { 'disabled_types_event' } = $ disabled_types_event_json ;
2014-06-15 04:53:41 +02:00
$ parameters { 'min_ff_event' } = $ ff_threshold unless ! defined ( $ ff_threshold ) ;
$ parameters { 'each_ff' } = $ each_ff unless ! defined ( $ each_ff ) ;
$ parameters { 'min_ff_event_normal' } = $ ff_threshold_normal unless ! defined ( $ ff_threshold_normal ) ;
$ parameters { 'min_ff_event_warning' } = $ ff_threshold_warning unless ! defined ( $ ff_threshold_warning ) ;
$ parameters { 'min_ff_event_critical' } = $ ff_threshold_critical unless ! defined ( $ ff_threshold_critical ) ;
$ parameters { 'ff_timeout' } = $ ff_timeout unless ! defined ( $ ff_timeout ) ;
2016-01-20 10:16:07 +01:00
$ parameters { 'critical_inverse' } = $ critical_inverse unless ! defined ( $ critical_inverse ) ;
$ parameters { 'warning_inverse' } = $ warning_inverse unless ! defined ( $ warning_inverse ) ;
2016-10-19 13:48:25 +02:00
$ parameters { 'critical_instructions' } = $ critical_instructions unless ! defined ( $ critical_instructions ) ;
$ parameters { 'warning_instructions' } = $ warning_instructions unless ! defined ( $ warning_instructions ) ;
$ parameters { 'unknown_instructions' } = $ unknown_instructions unless ! defined ( $ unknown_instructions ) ;
2011-11-14 14:27:21 +01:00
2013-08-29 13:39:05 +02:00
if ( $ in_policy == 0 ) {
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
foreach my $ id ( @ id_agents ) {
$ parameters { 'id_agente' } = $ id - > { 'id_agente' } ;
pandora_create_module_from_hash ( $ conf , \ % parameters , $ dbh ) ;
}
} else {
pandora_create_module_from_hash ( $ conf , \ % parameters , $ dbh ) ;
}
2012-01-11 11:09:02 +01:00
}
else {
enterprise_hook ( 'pandora_create_policy_module_from_hash' , [ $ conf , \ % parameters , $ dbh ] ) ;
}
2011-11-14 14:27:21 +01:00
}
2010-10-18 18:21:13 +02:00
2016-12-16 10:30:16 +01:00
##############################################################################
# Create web module.
# Related option: --create_web_module
##############################################################################
sub cli_create_web_module ($) {
my $ in_policy = shift ;
my ( $ policy_name , $ module_name , $ module_type , $ agent_name , $ description , $ module_group ,
$ min , $ max , $ post_process , $ interval , $ warning_min , $ warning_max , $ critical_min ,
2018-04-04 12:06:10 +02:00
$ critical_max , $ history_data , $ retries , $ requests , $ agent_browser_id , $ auth_server , $ auth_realm ,
2018-04-06 15:54:48 +02:00
$ definition_file , $ proxy_url , $ proxy_auth_login , $ proxy_auth_password , $ configuration_data , $ warning_str , $ critical_str , $ enable_unknown_events ,
2016-12-16 10:30:16 +01:00
$ ff_threshold , $ each_ff , $ ff_threshold_normal , $ ff_threshold_warning , $ ff_threshold_critical , $ ff_timeout ,
2019-10-17 11:14:42 +02:00
$ warning_inverse , $ critical_inverse , $ critical_instructions , $ warning_instructions , $ unknown_instructions , $ use_alias ) ;
2016-12-16 10:30:16 +01:00
if ( $ in_policy == 0 ) {
( $ module_name , $ module_type , $ agent_name , $ description , $ module_group ,
$ min , $ max , $ post_process , $ interval , $ warning_min , $ warning_max , $ critical_min ,
2018-04-04 12:06:10 +02:00
$ critical_max , $ history_data , $ retries , $ requests , $ agent_browser_id , $ auth_server , $ auth_realm ,
2018-04-06 15:54:48 +02:00
$ definition_file , $ proxy_url , $ proxy_auth_login , $ proxy_auth_password , $ warning_str , $ critical_str ,
2018-04-04 12:06:10 +02:00
$ enable_unknown_events , $ ff_threshold , $ each_ff , $ ff_threshold_normal , $ ff_threshold_warning , $ ff_threshold_critical , $ ff_timeout ,
2019-10-17 11:14:42 +02:00
$ warning_inverse , $ critical_inverse , $ critical_instructions , $ warning_instructions , $ unknown_instructions , $ use_alias ) = @ ARGV [ 2 .. 39 ] ;
2016-12-16 10:30:16 +01:00
}
else {
( $ policy_name , $ module_name , $ module_type , $ description , $ module_group ,
$ min , $ max , $ post_process , $ interval , $ warning_min , $ warning_max , $ critical_min ,
2018-04-06 15:54:48 +02:00
$ critical_max , $ history_data , $ retries , $ requests , $ agent_browser_id , $ auth_server , $ auth_realm , $ configuration_data , $ proxy_url ,
$ proxy_auth_login , $ proxy_auth_password , $ warning_str , $ critical_str ,
2018-04-04 12:06:10 +02:00
$ enable_unknown_events , $ ff_threshold , $ each_ff , $ ff_threshold_normal , $ ff_threshold_warning , $ ff_threshold_critical , $ ff_timeout ,
2018-04-06 15:54:48 +02:00
$ warning_inverse , $ critical_inverse , $ critical_instructions , $ warning_instructions , $ unknown_instructions ) = @ ARGV [ 2 .. 38 ] ;
2016-12-16 10:30:16 +01:00
}
my $ module_name_def ;
my $ module_type_def ;
my $ agent_id ;
2019-10-17 11:14:42 +02:00
my @ id_agents ;
2016-12-16 10:30:16 +01:00
my $ policy_id ;
my $ disabled_types_event = { } ;
if ( $ enable_unknown_events ) {
$ disabled_types_event - > { 'going_unknown' } = 0 ;
}
else {
$ disabled_types_event - > { 'going_unknown' } = 1 ;
}
my $ disabled_types_event_json = encode_json ( $ disabled_types_event ) ;
if ( $ in_policy == 0 ) {
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
exist_check ( $ id - > { 'id_agente' } , 'agent' , $ agent_name ) ;
my $ module_exists = get_agent_module_id ( $ dbh , $ module_name , $ id - > { 'id_agente' } ) ;
non_exist_check ( $ module_exists , 'module name' , $ module_name ) ;
}
} else {
$ agent_id = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ agent_id , 'agent' , $ agent_name ) ;
my $ module_exists = get_agent_module_id ( $ dbh , $ module_name , $ agent_id ) ;
non_exist_check ( $ module_exists , 'module name' , $ module_name ) ;
}
2016-12-16 10:30:16 +01:00
}
else {
$ policy_id = enterprise_hook ( 'get_policy_id' , [ $ dbh , safe_input ( $ policy_name ) ] ) ;
exist_check ( $ policy_id , 'policy' , $ policy_name ) ;
my $ policy_module_exist = enterprise_hook ( 'get_policy_module_id' , [ $ dbh , $ policy_id , $ module_name ] ) ;
non_exist_check ( $ policy_module_exist , 'policy module' , $ module_name ) ;
#~ print_log "[INFO] Adding module '$module_name' to policy '$policy_name'\n\n";
}
$ module_name_def = $ module_name ;
$ module_type_def = $ module_type ;
2019-10-17 11:14:42 +02:00
2016-12-16 10:30:16 +01:00
# If the module is local and is not to policy, we add it to the conf file
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
foreach my $ id ( @ id_agents ) {
if ( defined ( $ definition_file ) && ( - e $ definition_file ) && ( - e $ conf - > { incomingdir } . '/conf/' . md5 ( $ agent_name ) . '.conf' ) ) {
open ( FILE , $ definition_file ) ;
my @ file = <FILE> ;
my $ definition = join ( "" , @ file ) ;
close ( FILE ) ;
# If the parameter name or type and the definition file name or type
# dont match will be set the file definitions
open ( FILE , $ definition_file ) ;
while ( <FILE> ) {
chomp ;
my ( $ key , $ val ) = split / / ;
if ( $ key eq 'module_name' ) {
$ module_name_def = $ val ;
}
if ( $ key eq 'module_type' ) {
$ module_type_def = $ val ;
}
}
close ( FILE ) ;
#open (FILE, $conf->{incomingdir}.'/conf/'.md5($agent_name).'.conf');
#my @file = <FILE>;
#my $conf_file = join("", @file);
#close(FILE);
#open FILE, "> ".$conf->{incomingdir}.'/conf/'.md5($agent_name).'.conf';
#print FILE "$conf_file\n$definition";
#close(FILE);
enterprise_hook ( 'pandora_update_md5_file' , [ $ conf , $ agent_name ] ) ;
2016-12-16 10:30:16 +01:00
}
2019-10-17 11:14:42 +02:00
}
} else {
if ( defined ( $ definition_file ) && ( - e $ definition_file ) && ( - e $ conf - > { incomingdir } . '/conf/' . md5 ( $ agent_name ) . '.conf' ) ) {
open ( FILE , $ definition_file ) ;
my @ file = <FILE> ;
my $ definition = join ( "" , @ file ) ;
close ( FILE ) ;
# If the parameter name or type and the definition file name or type
# dont match will be set the file definitions
open ( FILE , $ definition_file ) ;
while ( <FILE> ) {
chomp ;
my ( $ key , $ val ) = split / / ;
if ( $ key eq 'module_name' ) {
$ module_name_def = $ val ;
}
if ( $ key eq 'module_type' ) {
$ module_type_def = $ val ;
}
2016-12-16 10:30:16 +01:00
}
2019-10-17 11:14:42 +02:00
close ( FILE ) ;
#open (FILE, $conf->{incomingdir}.'/conf/'.md5($agent_name).'.conf');
#my @file = <FILE>;
#my $conf_file = join("", @file);
#close(FILE);
#open FILE, "> ".$conf->{incomingdir}.'/conf/'.md5($agent_name).'.conf';
#print FILE "$conf_file\n$definition";
#close(FILE);
enterprise_hook ( 'pandora_update_md5_file' , [ $ conf , $ agent_name ] ) ;
2016-12-16 10:30:16 +01:00
}
}
2019-10-17 11:14:42 +02:00
2016-12-16 10:30:16 +01:00
if ( $ in_policy == 0 ) {
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
foreach my $ id ( @ id_agents ) {
my $ module_exists = get_agent_module_id ( $ dbh , $ module_name_def , $ id - > { 'id_agente' } ) ;
non_exist_check ( $ module_exists , 'module name' , $ module_name_def ) ;
print_log "[INFO] Adding module '$module_name' to agent '$id->{'nombre'}'\n\n" ;
}
} else {
my $ module_exists = get_agent_module_id ( $ dbh , $ module_name_def , $ agent_id ) ;
non_exist_check ( $ module_exists , 'module name' , $ module_name_def ) ;
print_log "[INFO] Adding module '$module_name' to agent '$agent_name'\n\n" ;
}
2016-12-16 10:30:16 +01:00
}
else {
my $ policy_module_exist = enterprise_hook ( 'get_policy_module_id' , [ $ dbh , $ policy_id , $ module_name_def ] ) ;
non_exist_check ( $ policy_module_exist , 'policy module' , $ module_name_def ) ;
print_log "[INFO] Adding module '$module_name' to policy '$policy_name'\n\n" ;
}
if ( defined ( $ definition_file ) && $ module_type ne $ module_type_def ) {
$ module_type = $ module_type_def ;
print_log "[INFO] The module type has been forced to '$module_type' by the definition file\n\n" ;
}
if ( defined ( $ definition_file ) && $ module_name ne $ module_name_def ) {
$ module_name = $ module_name_def ;
print_log "[INFO] The module name has been forced to '$module_name' by the definition file\n\n" ;
}
# The get_module_id has wrong name. Change in future
my $ module_type_id = get_module_id ( $ dbh , $ module_type ) ;
exist_check ( $ module_type_id , 'module type' , $ module_type ) ;
if ( $ module_type !~ m/.?web.?/ ) {
print_log "[ERROR] '$module_type' is not valid type for web modules. Try with web_data, web_proc, web_content_data or web_content_string types\n\n" ;
exit ;
}
my $ module_group_id = 0 ;
if ( defined ( $ module_group ) ) {
$ module_group_id = get_module_group_id ( $ dbh , $ module_group ) ;
exist_check ( $ module_group_id , 'module group' , $ module_group ) ;
}
my % parameters ;
$ parameters { 'id_tipo_modulo' } = $ module_type_id ;
if ( $ in_policy == 0 ) {
$ parameters { 'nombre' } = safe_input ( $ module_name ) ;
2019-10-17 11:14:42 +02:00
if ( not defined $ use_alias ) {
$ parameters { 'id_agente' } = $ agent_id ;
}
2016-12-16 10:30:16 +01:00
}
else {
$ parameters { 'name' } = safe_input ( $ module_name ) ;
$ parameters { 'id_policy' } = $ policy_id ;
}
# Optional parameters
$ parameters { 'id_module_group' } = $ module_group_id unless ! defined ( $ module_group ) ;
$ parameters { 'min_warning' } = $ warning_min unless ! defined ( $ warning_min ) ;
$ parameters { 'max_warning' } = $ warning_max unless ! defined ( $ warning_max ) ;
$ parameters { 'min_critical' } = $ critical_min unless ! defined ( $ critical_min ) ;
$ parameters { 'max_critical' } = $ critical_max unless ! defined ( $ critical_max ) ;
$ parameters { 'history_data' } = $ history_data unless ! defined ( $ history_data ) ;
if ( $ in_policy == 0 ) {
$ parameters { 'descripcion' } = safe_input ( $ description ) unless ! defined ( $ description ) ;
$ parameters { 'id_modulo' } = 7 ;
}
else {
$ parameters { 'description' } = safe_input ( $ description ) unless ! defined ( $ description ) ;
$ parameters { 'id_module' } = 7 ;
$ configuration_data !~ s/\\n/\n/g ;
$ parameters { 'configuration_data' } = safe_input ( $ configuration_data ) ;
}
$ parameters { 'min' } = $ min unless ! defined ( $ min ) ;
$ parameters { 'max' } = $ max unless ! defined ( $ max ) ;
$ parameters { 'post_process' } = $ post_process unless ! defined ( $ post_process ) ;
$ parameters { 'module_interval' } = $ interval unless ! defined ( $ interval ) ;
$ parameters { 'str_warning' } = safe_input ( $ warning_str ) unless ! defined ( $ warning_str ) ;
$ parameters { 'str_critical' } = safe_input ( $ critical_str ) unless ! defined ( $ critical_str ) ;
$ parameters { 'disabled_types_event' } = $ disabled_types_event_json ;
$ parameters { 'min_ff_event' } = $ ff_threshold unless ! defined ( $ ff_threshold ) ;
$ parameters { 'each_ff' } = $ each_ff unless ! defined ( $ each_ff ) ;
$ parameters { 'min_ff_event_normal' } = $ ff_threshold_normal unless ! defined ( $ ff_threshold_normal ) ;
$ parameters { 'min_ff_event_warning' } = $ ff_threshold_warning unless ! defined ( $ ff_threshold_warning ) ;
$ parameters { 'min_ff_event_critical' } = $ ff_threshold_critical unless ! defined ( $ ff_threshold_critical ) ;
$ parameters { 'ff_timeout' } = $ ff_timeout unless ! defined ( $ ff_timeout ) ;
$ parameters { 'critical_inverse' } = $ critical_inverse unless ! defined ( $ critical_inverse ) ;
$ parameters { 'warning_inverse' } = $ warning_inverse unless ! defined ( $ warning_inverse ) ;
$ parameters { 'critical_instructions' } = $ critical_instructions unless ! defined ( $ critical_instructions ) ;
$ parameters { 'warning_instructions' } = $ warning_instructions unless ! defined ( $ warning_instructions ) ;
$ parameters { 'unknown_instructions' } = $ unknown_instructions unless ! defined ( $ unknown_instructions ) ;
2018-04-04 12:06:10 +02:00
$ parameters { 'max_retries' } = $ retries unless ! defined ( $ retries ) ;
$ parameters { 'plugin_pass' } = $ requests unless ! defined ( $ requests ) ;
$ parameters { 'plugin_user' } = $ agent_browser_id unless ! defined ( $ agent_browser_id ) ;
2018-04-06 15:54:48 +02:00
# $parameters{'http_user'} = $http_auth_login unless !defined ($http_auth_login);
# $parameters{'http_pass'} = $http_auth_password unless !defined ($http_auth_password);
2018-04-04 12:06:10 +02:00
$ parameters { 'snmp_oid' } = defined ( $ proxy_url ) ? $ proxy_url : '' ;
$ parameters { 'tcp_send' } = $ proxy_auth_login unless ! defined ( $ proxy_auth_login ) ;
$ parameters { 'tcp_rcv' } = $ proxy_auth_password unless ! defined ( $ proxy_auth_password ) ;
$ parameters { 'ip_target' } = $ auth_server unless ! defined ( $ auth_server ) ;
$ parameters { 'snmp_community' } = $ auth_realm unless ! defined ( $ auth_realm ) ;
2018-04-06 15:54:48 +02:00
2016-12-16 10:30:16 +01:00
if ( $ in_policy == 0 ) {
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
foreach my $ id ( @ id_agents ) {
$ parameters { 'id_agente' } = $ id - > { 'id_agente' } ;
pandora_create_module_from_hash ( $ conf , \ % parameters , $ dbh ) ;
}
} else {
pandora_create_module_from_hash ( $ conf , \ % parameters , $ dbh ) ;
}
2016-12-16 10:30:16 +01:00
}
else {
enterprise_hook ( 'pandora_create_policy_module_from_hash' , [ $ conf , \ % parameters , $ dbh ] ) ;
}
2017-01-19 16:27:53 +01:00
#Begin Insert module definition from file_definition in bd
2019-10-17 11:14:42 +02:00
if ( defined ( $ definition_file ) ) {
2017-01-19 16:27:53 +01:00
open ( my $ fh , '<' , $ definition_file ) or die ( $! ) ;
my @ lines = <$fh> ;
close ( $ fh ) ;
my $ sql = get_db_value ( $ dbh , "SELECT MAX(id_agente_modulo) FROM tagente_modulo" ) ;
my $ sql2 = "UPDATE tagente_modulo SET plugin_parameter = '" . join ( "" , @ lines ) . "' WHERE id_agente_modulo = " . $ sql ;
my $ create = $ dbh - > do ( $ sql2 ) ;
if ( $ create ) {
print "Success" ;
}
else {
print "Failure<br/>$DBI::errstr" ;
}
}
#End Insert module definition from file_definition in bd
2016-12-16 10:30:16 +01:00
}
2016-05-26 12:28:42 +02:00
##############################################################################
# Create module group.
# Related option: --create_module_group
##############################################################################
sub cli_create_module_group () {
my $ module_group_name = @ ARGV [ 2 ] ;
my $ id_module_group = get_module_group_id ( $ dbh , $ module_group_name ) ;
non_exist_check ( $ id_module_group , 'group' , $ module_group_name ) ;
db_insert ( $ dbh , 'id_mg' , 'INSERT INTO tmodule_group (name) VALUES (?)' , safe_input ( $ module_group_name ) ) ;
}
2018-12-11 14:43:27 +01:00
##############################################################################
# Show all the module group (without parameters) or the module groups with a filter parameters
# Related option: --get_module_group
##############################################################################
sub cli_get_module_group () {
my ( $ module_group_name ) = @ ARGV [ 2 .. 2 ] ;
my $ condition = ' 1=1 ' ;
if ( $ module_group_name ne '' ) {
$ condition . = " AND name LIKE '%$module_group_name%' " ;
}
my @ module_group = get_db_rows ( $ dbh , "SELECT * FROM tmodule_group WHERE $condition" ) ;
if ( scalar ( @ module_group ) == 0 ) {
print_log "[INFO] No groups found\n\n" ;
exit ;
}
my $ head_print = 0 ;
foreach my $ groups ( @ module_group ) {
if ( $ head_print == 0 ) {
$ head_print = 1 ;
print "id_module_group, group_name\n" ;
}
print $ groups - > { 'id_mg' } . "," . safe_output ( $ groups - > { 'name' } ) . "\n" ;
}
if ( $ head_print == 0 ) {
print_log "[INFO] No groups found\n\n" ;
}
}
sub cli_module_group_synch () {
my $ other = @ ARGV [ 2 ] ;
my $ return_type = @ ARGV [ 3 ] ;
if ( $ return_type eq '' ) {
$ return_type = 'csv' ;
}
my $ result = api_call ( \ % conf , 'set' , 'module_group_synch' , undef , undef , "$other" , $ return_type ) ;
print "$result \n\n " ;
}
2012-05-17 11:42:52 +02:00
##############################################################################
# Create network module from component.
# Related option: --create_network_module_from_component
##############################################################################
sub cli_create_network_module_from_component () {
2019-10-17 11:14:42 +02:00
my ( $ agent_name , $ component_name , $ use_alias ) = @ ARGV [ 2 .. 4 ] ;
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
my @ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
my $ agent_id ;
my $ module_exists ;
my $ component ;
my $ nc_id ;
foreach my $ id ( @ id_agents ) {
$ agent_id = $ id - > { 'id_agente' } ;
exist_check ( $ agent_id , 'agent' , $ agent_name ) ;
$ nc_id = pandora_get_network_component_id ( $ dbh , $ component_name ) ;
exist_check ( $ nc_id , 'network component' , $ component_name ) ;
# Get network component data
$ component = get_db_single_row ( $ dbh , 'SELECT * FROM tnetwork_component WHERE id_nc = ?' , $ nc_id ) ;
my $ module_exists = get_agent_module_id ( $ dbh , $ component_name , $ agent_id ) ;
non_exist_check ( $ module_exists , 'module name' , $ component_name ) ;
print_log "[INFO] Creating module from component '$component_name'\n\n" ;
pandora_create_module_from_network_component ( $ conf , $ component , $ agent_id , $ dbh ) ;
}
} else {
my $ nc_id = pandora_get_network_component_id ( $ dbh , $ component_name ) ;
exist_check ( $ nc_id , 'network component' , $ component_name ) ;
# Get network component data
my $ component = get_db_single_row ( $ dbh , 'SELECT * FROM tnetwork_component WHERE id_nc = ?' , $ nc_id ) ;
my $ agent_id = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ agent_id , 'agent' , $ agent_name ) ;
my $ module_exists = get_agent_module_id ( $ dbh , $ component_name , $ agent_id ) ;
non_exist_check ( $ module_exists , 'module name' , $ component_name ) ;
print_log "[INFO] Creating module from component '$component_name'\n\n" ;
pandora_create_module_from_network_component ( $ conf , $ component , $ agent_id , $ dbh ) ;
}
2012-05-17 11:42:52 +02:00
}
2019-03-20 12:48:44 +01:00
##############################################################################
# Create a network component.
# Related option: --create_network_component
##############################################################################
sub cli_create_network_component () {
my ( $ c_name , $ c_group , $ c_type ) = @ ARGV [ 2 .. 4 ] ;
my @ todo = @ ARGV [ 5 .. 20 ] ;
my $ other = join ( '|' , @ todo ) ;
my @ todo2 = @ ARGV [ 22 .. 26 ] ;
my $ other2 = join ( '|' , @ todo2 ) ;
# Call the API.
my $ result = api_call ( $ conf , 'set' , 'new_network_component' , $ c_name , undef , "$c_type|$other|$c_group|$other2" ) ;
print "$result \n\n " ;
}
2013-01-16 16:56:31 +01:00
##############################################################################
# Create netflow filter
# Related option: --create_netflow_filter
##############################################################################
sub cli_create_netflow_filter () {
my ( $ filter_name , $ group_name , $ filter , $ aggregate_by , $ output_format ) = @ ARGV [ 2 .. 6 ] ;
my $ group_id = get_group_id ( $ dbh , $ group_name ) ;
exist_check ( $ group_id , 'group' , $ group_name ) ;
logger ( $ conf , 'Creating netflow filter "' . $ filter_name . '"' , 10 ) ;
# Create the module
my $ module_id = db_insert ( $ dbh , 'id_sg' , ' INSERT INTO tnetflow_filter ( id_name , id_group , advanced_filter , filter_args , aggregate , output )
VALUES ( ? , ? , ? , ? , ? , ? ) ' ,
safe_input ( $ filter_name ) , $ group_id , safe_input ( $ filter ) ,
'"(' . $ filter . ')"' , $ aggregate_by , $ output_format ) ;
}
2011-11-14 14:27:21 +01:00
##############################################################################
# Create network module.
# Related option: --create_network_module
##############################################################################
2010-10-18 18:21:13 +02:00
2012-01-12 17:02:04 +01:00
sub cli_create_network_module ($) {
my $ in_policy = shift ;
my ( $ policy_name , $ module_name , $ module_type , $ agent_name , $ module_address , $ module_port , $ description ,
2011-11-14 14:27:21 +01:00
$ module_group , $ min , $ max , $ post_process , $ interval , $ warning_min , $ warning_max , $ critical_min ,
2015-02-05 09:03:30 +01:00
$ critical_max , $ history_data , $ ff_threshold , $ warning_str , $ critical_str , $ enable_unknown_events , $ each_ff ,
2016-10-19 13:48:25 +02:00
$ ff_threshold_normal , $ ff_threshold_warning , $ ff_threshold_critical , $ timeout , $ retries , $ critical_instructions ,
2019-10-17 11:14:42 +02:00
$ warning_instructions , $ unknown_instructions , $ warning_inverse , $ critical_inverse , $ use_alias ) ;
2013-08-29 13:39:05 +02:00
if ( $ in_policy == 0 ) {
2012-01-12 17:02:04 +01:00
( $ module_name , $ module_type , $ agent_name , $ module_address , $ module_port , $ description ,
$ module_group , $ min , $ max , $ post_process , $ interval , $ warning_min , $ warning_max , $ critical_min ,
2014-06-15 04:53:41 +02:00
$ critical_max , $ history_data , $ ff_threshold , $ warning_str , $ critical_str , $ enable_unknown_events ,
$ each_ff , $ ff_threshold_normal , $ ff_threshold_warning ,
2016-10-21 11:18:33 +02:00
$ ff_threshold_critical , $ timeout , $ retries , $ critical_instructions , $ warning_instructions , $ unknown_instructions ,
2019-10-17 11:14:42 +02:00
$ warning_inverse , $ critical_inverse , $ use_alias ) = @ ARGV [ 2 .. 33 ] ;
2012-01-12 17:02:04 +01:00
}
else {
( $ policy_name , $ module_name , $ module_type , $ module_port , $ description ,
$ module_group , $ min , $ max , $ post_process , $ interval , $ warning_min , $ warning_max , $ critical_min ,
2014-06-15 04:53:41 +02:00
$ critical_max , $ history_data , $ ff_threshold , $ warning_str , $ critical_str , $ enable_unknown_events ,
$ each_ff , $ ff_threshold_normal , $ ff_threshold_warning ,
2016-10-21 11:18:33 +02:00
$ ff_threshold_critical , $ timeout , $ retries , $ critical_instructions , $ warning_instructions , $ unknown_instructions ,
$ warning_inverse , $ critical_inverse ) = @ ARGV [ 2 .. 31 ] ;
2012-01-12 17:02:04 +01:00
}
2019-10-17 11:14:42 +02:00
2011-11-14 14:27:21 +01:00
my $ module_name_def ;
my $ module_type_def ;
2019-10-17 11:14:42 +02:00
2012-01-12 17:02:04 +01:00
my $ agent_id ;
2019-10-17 11:14:42 +02:00
my @ id_agents ;
2012-01-12 17:02:04 +01:00
my $ policy_id ;
2011-11-14 14:27:21 +01:00
2013-08-29 13:39:05 +02:00
my $ disabled_types_event = { } ;
if ( $ enable_unknown_events ) {
$ disabled_types_event - > { 'going_unknown' } = 0 ;
}
else {
$ disabled_types_event - > { 'going_unknown' } = 1 ;
}
my $ disabled_types_event_json = encode_json ( $ disabled_types_event ) ;
if ( $ in_policy == 0 ) {
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
exist_check ( $ id - > { 'id_agente' } , 'agent' , $ agent_name ) ;
my $ module_exists = get_agent_module_id ( $ dbh , $ module_name , $ id - > { 'id_agente' } ) ;
non_exist_check ( $ module_exists , 'module name' , $ module_name ) ;
print_log "[INFO] Adding module '$module_name' to agent '$id->{'nombre'}'\n\n" ;
}
} else {
$ agent_id = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ agent_id , 'agent' , $ agent_name ) ;
my $ module_exists = get_agent_module_id ( $ dbh , $ module_name , $ agent_id ) ;
non_exist_check ( $ module_exists , 'module name' , $ module_name ) ;
print_log "[INFO] Adding module '$module_name' to agent '$agent_name'\n\n" ;
}
2012-01-12 17:02:04 +01:00
}
else {
$ policy_id = enterprise_hook ( 'get_policy_id' , [ $ dbh , safe_input ( $ policy_name ) ] ) ;
exist_check ( $ policy_id , 'policy' , $ policy_name ) ;
2016-10-21 11:18:33 +02:00
2012-01-12 17:02:04 +01:00
my $ policy_module_exist = enterprise_hook ( 'get_policy_module_id' , [ $ dbh , $ policy_id , $ module_name ] ) ;
non_exist_check ( $ policy_module_exist , 'policy module' , $ module_name ) ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] Adding module '$module_name' to policy '$policy_name'\n\n" ;
2012-01-12 17:02:04 +01:00
}
2011-11-14 14:27:21 +01:00
if ( $ module_type =~ m/.?snmp.?/ ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] '$module_type' is not a valid type. For snmp modules use --create_snmp_module parameter\n\n" ;
2011-11-14 14:27:21 +01:00
$ param = '--create_snmp_module' ;
help_screen ( ) ;
exit 1 ;
}
if ( $ module_type !~ m/.?icmp.?/ && $ module_type !~ m/.?tcp.?/ ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] '$module_type' is not valid type for (not snmp) network modules. Try with icmp or tcp types\n\n" ;
2011-11-14 14:27:21 +01:00
exit ;
}
# The get_module_id has wrong name. Change in future
my $ module_type_id = get_module_id ( $ dbh , $ module_type ) ;
exist_check ( $ module_type_id , 'module type' , $ module_type ) ;
2013-08-29 13:39:05 +02:00
2012-01-12 17:02:04 +01:00
my $ module_group_id = 0 ;
2011-11-14 14:27:21 +01:00
2012-01-12 17:02:04 +01:00
if ( defined ( $ module_group ) ) {
$ module_group_id = get_module_group_id ( $ dbh , $ module_group ) ;
exist_check ( $ module_group_id , 'module group' , $ module_group ) ;
}
2011-11-14 14:27:21 +01:00
if ( $ module_type !~ m/.?icmp.?/ ) {
if ( not defined ( $ module_port ) ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] Port error. Agents of type distinct of icmp need port\n\n" ;
2011-11-14 14:27:21 +01:00
exit ;
2010-05-27 18:24:52 +02:00
}
2011-11-14 14:27:21 +01:00
if ( $ module_port > 65535 || $ module_port < 1 ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] Port error. Port must into [1-65535]\n\n" ;
2011-11-14 14:27:21 +01:00
exit ;
2010-05-27 18:24:52 +02:00
}
2011-11-14 14:27:21 +01:00
}
my % parameters ;
$ parameters { 'id_tipo_modulo' } = $ module_type_id ;
2013-08-29 13:39:05 +02:00
if ( $ in_policy == 0 ) {
2012-01-12 17:02:04 +01:00
$ parameters { 'nombre' } = safe_input ( $ module_name ) ;
2019-10-17 11:14:42 +02:00
if ( not defined $ use_alias ) {
$ parameters { 'id_agente' } = $ agent_id ;
}
2012-01-12 17:02:04 +01:00
$ parameters { 'ip_target' } = $ module_address ;
}
else {
$ parameters { 'name' } = safe_input ( $ module_name ) ;
$ parameters { 'id_policy' } = $ policy_id ;
}
2013-08-29 13:39:05 +02:00
2011-11-14 14:27:21 +01:00
# Optional parameters
$ parameters { 'id_module_group' } = $ module_group_id unless ! defined ( $ module_group ) ;
$ parameters { 'min_warning' } = $ warning_min unless ! defined ( $ warning_min ) ;
$ parameters { 'max_warning' } = $ warning_max unless ! defined ( $ warning_max ) ;
$ parameters { 'min_critical' } = $ critical_min unless ! defined ( $ critical_min ) ;
$ parameters { 'max_critical' } = $ critical_max unless ! defined ( $ critical_max ) ;
$ parameters { 'history_data' } = $ history_data unless ! defined ( $ history_data ) ;
$ parameters { 'tcp_port' } = $ module_port unless ! defined ( $ module_port ) ;
2013-08-29 13:39:05 +02:00
if ( $ in_policy == 0 ) {
2012-01-12 17:02:04 +01:00
$ parameters { 'descripcion' } = safe_input ( $ description ) unless ! defined ( $ description ) ;
2013-08-29 13:39:05 +02:00
$ parameters { 'id_modulo' } = 2 ;
2012-01-12 17:02:04 +01:00
}
else {
$ parameters { 'description' } = safe_input ( $ description ) unless ! defined ( $ description ) ;
$ parameters { 'id_module' } = 2 ;
}
2011-11-14 14:27:21 +01:00
$ parameters { 'min' } = $ min unless ! defined ( $ min ) ;
$ parameters { 'max' } = $ max unless ! defined ( $ max ) ;
$ parameters { 'post_process' } = $ post_process unless ! defined ( $ post_process ) ;
$ parameters { 'module_interval' } = $ interval unless ! defined ( $ interval ) ;
$ parameters { 'min_ff_event' } = $ ff_threshold unless ! defined ( $ ff_threshold ) ;
2012-01-11 11:09:02 +01:00
$ parameters { 'str_warning' } = safe_input ( $ warning_str ) unless ! defined ( $ warning_str ) ;
$ parameters { 'str_critical' } = safe_input ( $ critical_str ) unless ! defined ( $ critical_str ) ;
2013-08-29 13:39:05 +02:00
$ parameters { 'disabled_types_event' } = $ disabled_types_event_json ;
2014-06-15 04:53:41 +02:00
$ parameters { 'each_ff' } = $ each_ff unless ! defined ( $ each_ff ) ;
$ parameters { 'min_ff_event_normal' } = $ ff_threshold_normal unless ! defined ( $ ff_threshold_normal ) ;
$ parameters { 'min_ff_event_warning' } = $ ff_threshold_warning unless ! defined ( $ ff_threshold_warning ) ;
$ parameters { 'min_ff_event_critical' } = $ ff_threshold_critical unless ! defined ( $ ff_threshold_critical ) ;
2015-02-05 09:03:30 +01:00
$ parameters { 'max_timeout' } = $ timeout unless ! defined ( $ timeout ) ;
$ parameters { 'max_retries' } = $ retries unless ! defined ( $ retries ) ;
2016-10-19 13:48:25 +02:00
$ parameters { 'critical_instructions' } = $ critical_instructions unless ! defined ( $ critical_instructions ) ;
$ parameters { 'warning_instructions' } = $ warning_instructions unless ! defined ( $ warning_instructions ) ;
$ parameters { 'unknown_instructions' } = $ unknown_instructions unless ! defined ( $ unknown_instructions ) ;
2016-10-21 11:18:33 +02:00
$ parameters { 'critical_inverse' } = $ critical_inverse unless ! defined ( $ critical_inverse ) ;
$ parameters { 'warning_inverse' } = $ warning_inverse unless ! defined ( $ warning_inverse ) ;
2013-08-29 13:39:05 +02:00
if ( $ in_policy == 0 ) {
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
foreach my $ id ( @ id_agents ) {
$ parameters { 'id_agente' } = $ id - > { 'id_agente' } ;
pandora_create_module_from_hash ( $ conf , \ % parameters , $ dbh ) ;
}
} else {
pandora_create_module_from_hash ( $ conf , \ % parameters , $ dbh ) ;
}
2012-01-12 17:02:04 +01:00
}
else {
enterprise_hook ( 'pandora_create_policy_module_from_hash' , [ $ conf , \ % parameters , $ dbh ] ) ;
}
2011-11-14 14:27:21 +01:00
}
2010-09-20 17:25:15 +02:00
2011-11-14 14:27:21 +01:00
##############################################################################
# Create snmp module.
# Related option: --create_snmp_module
##############################################################################
2010-09-20 17:25:15 +02:00
2012-01-12 17:02:04 +01:00
sub cli_create_snmp_module ($) {
my $ in_policy = shift ;
my ( $ policy_name , $ module_name , $ module_type , $ agent_name , $ module_address , $ module_port , $ version , $ community ,
$ oid , $ description , $ module_group , $ min , $ max , $ post_process , $ interval , $ warning_min ,
$ warning_max , $ critical_min , $ critical_max , $ history_data , $ snmp3_priv_method , $ snmp3_priv_pass ,
2014-06-15 04:53:41 +02:00
$ snmp3_sec_level , $ snmp3_auth_method , $ snmp3_auth_user , $ snmp3_auth_pass , $ ff_threshold , $ warning_str , $ critical_str , $ enable_unknown_events ,
2016-10-19 13:48:25 +02:00
$ each_ff , $ ff_threshold_normal , $ ff_threshold_warning , $ ff_threshold_critical , $ timeout , $ retries ,
2019-10-17 11:14:42 +02:00
$ critical_instructions , $ warning_instructions , $ unknown_instructions , $ warning_inverse , $ critical_inverse , $ use_alias ) ;
2013-08-29 13:39:05 +02:00
if ( $ in_policy == 0 ) {
2012-01-12 17:02:04 +01:00
( $ module_name , $ module_type , $ agent_name , $ module_address , $ module_port , $ version , $ community ,
$ oid , $ description , $ module_group , $ min , $ max , $ post_process , $ interval , $ warning_min ,
$ warning_max , $ critical_min , $ critical_max , $ history_data , $ snmp3_priv_method , $ snmp3_priv_pass ,
2014-06-15 04:53:41 +02:00
$ snmp3_sec_level , $ snmp3_auth_method , $ snmp3_auth_user , $ snmp3_auth_pass , $ ff_threshold , $ warning_str , $ critical_str , $ enable_unknown_events ,
2016-10-19 13:48:25 +02:00
$ each_ff , $ ff_threshold_normal , $ ff_threshold_warning , $ ff_threshold_critical , $ timeout , $ retries ,
2019-10-17 11:14:42 +02:00
$ critical_instructions , $ warning_instructions , $ unknown_instructions , $ warning_inverse , $ critical_inverse , $ use_alias ) = @ ARGV [ 2 .. 42 ] ;
2012-01-12 17:02:04 +01:00
}
else {
( $ policy_name , $ module_name , $ module_type , $ module_port , $ version , $ community ,
$ oid , $ description , $ module_group , $ min , $ max , $ post_process , $ interval , $ warning_min ,
$ warning_max , $ critical_min , $ critical_max , $ history_data , $ snmp3_priv_method , $ snmp3_priv_pass ,
2014-06-15 04:53:41 +02:00
$ snmp3_sec_level , $ snmp3_auth_method , $ snmp3_auth_user , $ snmp3_auth_pass , $ ff_threshold , $ warning_str , $ critical_str , $ enable_unknown_events ,
2016-10-19 13:48:25 +02:00
$ each_ff , $ ff_threshold_normal , $ ff_threshold_warning , $ ff_threshold_critical , $ timeout , $ retries ,
2016-10-21 11:18:33 +02:00
$ critical_instructions , $ warning_instructions , $ unknown_instructions , $ warning_inverse , $ critical_inverse ) = @ ARGV [ 2 .. 40 ] ;
2012-01-12 17:02:04 +01:00
}
2013-08-29 13:39:05 +02:00
2011-11-14 14:27:21 +01:00
my $ module_name_def ;
my $ module_type_def ;
2019-10-17 11:14:42 +02:00
2012-01-12 17:02:04 +01:00
my $ agent_id ;
2019-10-17 11:14:42 +02:00
my @ id_agents ;
2012-01-12 17:02:04 +01:00
my $ policy_id ;
2011-11-14 14:27:21 +01:00
2013-08-29 13:39:05 +02:00
my $ disabled_types_event = { } ;
if ( $ enable_unknown_events ) {
$ disabled_types_event - > { 'going_unknown' } = 0 ;
}
else {
$ disabled_types_event - > { 'going_unknown' } = 1 ;
}
my $ disabled_types_event_json = encode_json ( $ disabled_types_event ) ;
if ( $ in_policy == 0 ) {
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
exist_check ( $ id - > { 'id_agente' } , 'agent' , $ agent_name ) ;
my $ module_exists = get_agent_module_id ( $ dbh , $ module_name , $ id - > { 'id_agente' } ) ;
non_exist_check ( $ module_exists , 'module name' , $ module_name ) ;
print_log "[INFO] Adding module '$module_name' to agent '$id->{'nombre'}'\n\n" ;
}
} else {
$ agent_id = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ agent_id , 'agent' , $ agent_name ) ;
my $ module_exists = get_agent_module_id ( $ dbh , $ module_name , $ agent_id ) ;
non_exist_check ( $ module_exists , 'module name' , $ module_name ) ;
print_log "[INFO] Adding module '$module_name' to agent '$agent_name'\n\n" ;
}
2012-01-12 17:02:04 +01:00
}
else {
$ policy_id = enterprise_hook ( 'get_policy_id' , [ $ dbh , safe_input ( $ policy_name ) ] ) ;
exist_check ( $ policy_id , 'policy' , $ policy_name ) ;
2011-11-14 14:27:21 +01:00
2012-01-12 17:02:04 +01:00
my $ policy_module_exist = enterprise_hook ( 'get_policy_module_id' , [ $ dbh , $ policy_id , $ module_name ] ) ;
non_exist_check ( $ policy_module_exist , 'policy module' , $ module_name ) ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] Adding module '$module_name' to policy '$policy_name'\n\n" ;
2013-08-29 13:39:05 +02:00
}
2011-11-29 11:31:14 +01:00
2011-11-14 14:27:21 +01:00
# The get_module_id has wrong name. Change in future
my $ module_type_id = get_module_id ( $ dbh , $ module_type ) ;
exist_check ( $ module_type_id , 'module type' , $ module_type ) ;
2012-01-12 17:02:04 +01:00
my $ module_group_id = 0 ;
2013-08-29 13:39:05 +02:00
if ( defined ( $ module_group ) ) {
2012-01-12 17:02:04 +01:00
$ module_group_id = get_module_group_id ( $ dbh , $ module_group ) ;
exist_check ( $ module_group_id , 'module group' , $ module_group ) ;
}
2011-11-14 14:27:21 +01:00
if ( $ module_type !~ m/.?snmp.?/ ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] '$module_type' is not a valid snmp type\n\n" ;
2011-11-14 14:27:21 +01:00
exit ;
}
if ( $ module_port > 65535 || $ module_port < 1 ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] Port error. Port must into [1-65535]\n\n" ;
2011-11-14 14:27:21 +01:00
exit ;
}
my % parameters ;
$ parameters { 'id_tipo_modulo' } = $ module_type_id ;
2012-01-12 17:02:04 +01:00
2013-08-29 13:39:05 +02:00
if ( $ in_policy == 0 ) {
2012-01-12 17:02:04 +01:00
$ parameters { 'nombre' } = safe_input ( $ module_name ) ;
2019-10-17 11:14:42 +02:00
if ( not defined $ use_alias ) {
$ parameters { 'id_agente' } = $ agent_id ;
}
2012-01-12 17:02:04 +01:00
$ parameters { 'ip_target' } = $ module_address ;
}
else {
$ parameters { 'name' } = safe_input ( $ module_name ) ;
$ parameters { 'id_policy' } = $ policy_id ;
}
2013-08-29 13:39:05 +02:00
2011-11-14 14:27:21 +01:00
$ parameters { 'tcp_port' } = $ module_port ;
$ parameters { 'tcp_send' } = $ version ;
2013-08-29 13:39:05 +02:00
2011-11-14 14:27:21 +01:00
# Optional parameters
$ parameters { 'id_module_group' } = $ module_group_id unless ! defined ( $ module_group ) ;
$ parameters { 'min_warning' } = $ warning_min unless ! defined ( $ warning_min ) ;
$ parameters { 'max_warning' } = $ warning_max unless ! defined ( $ warning_max ) ;
$ parameters { 'min_critical' } = $ critical_min unless ! defined ( $ critical_min ) ;
$ parameters { 'max_critical' } = $ critical_max unless ! defined ( $ critical_max ) ;
$ parameters { 'history_data' } = $ history_data unless ! defined ( $ history_data ) ;
2013-08-29 13:39:05 +02:00
if ( $ in_policy == 0 ) {
2012-01-12 17:02:04 +01:00
$ parameters { 'descripcion' } = safe_input ( $ description ) unless ! defined ( $ description ) ;
#2 for snmp modules
2013-08-29 13:39:05 +02:00
$ parameters { 'id_modulo' } = 2 ;
2012-01-12 17:02:04 +01:00
}
else {
$ parameters { 'description' } = safe_input ( $ description ) unless ! defined ( $ description ) ;
#2 for snmp modules
$ parameters { 'id_module' } = 2 ;
}
2011-11-14 14:27:21 +01:00
$ parameters { 'min' } = $ min unless ! defined ( $ min ) ;
$ parameters { 'max' } = $ max unless ! defined ( $ max ) ;
$ parameters { 'post_process' } = $ post_process unless ! defined ( $ post_process ) ;
$ parameters { 'module_interval' } = $ interval unless ! defined ( $ interval ) ;
$ parameters { 'snmp_community' } = $ community unless ! defined ( $ community ) ;
$ parameters { 'snmp_oid' } = $ oid unless ! defined ( $ oid ) ;
$ parameters { 'min_ff_event' } = $ ff_threshold unless ! defined ( $ ff_threshold ) ;
2012-01-11 11:09:02 +01:00
$ parameters { 'str_warning' } = safe_input ( $ warning_str ) unless ! defined ( $ warning_str ) ;
$ parameters { 'str_critical' } = safe_input ( $ critical_str ) unless ! defined ( $ critical_str ) ;
2011-11-14 14:27:21 +01:00
2013-08-29 13:39:05 +02:00
if ( $ version == 3 ) {
2011-11-14 14:27:21 +01:00
$ parameters { 'custom_string_1' } = $ snmp3_priv_method ;
$ parameters { 'custom_string_2' } = $ snmp3_priv_pass ;
$ parameters { 'custom_string_3' } = $ snmp3_sec_level ;
$ parameters { 'plugin_parameter' } = $ snmp3_auth_method ;
$ parameters { 'plugin_user' } = $ snmp3_auth_user ;
2012-01-11 16:09:07 +01:00
$ parameters { 'plugin_pass' } = $ snmp3_auth_pass ;
2011-11-14 14:27:21 +01:00
}
2013-08-29 13:39:05 +02:00
$ parameters { 'disabled_types_event' } = $ disabled_types_event_json ;
2014-06-15 04:53:41 +02:00
$ parameters { 'each_ff' } = $ each_ff unless ! defined ( $ each_ff ) ;
$ parameters { 'min_ff_event_normal' } = $ ff_threshold_normal unless ! defined ( $ ff_threshold_normal ) ;
$ parameters { 'min_ff_event_warning' } = $ ff_threshold_warning unless ! defined ( $ ff_threshold_warning ) ;
$ parameters { 'min_ff_event_critical' } = $ ff_threshold_critical unless ! defined ( $ ff_threshold_critical ) ;
2015-02-05 09:03:30 +01:00
$ parameters { 'max_timeout' } = $ timeout unless ! defined ( $ timeout ) ;
$ parameters { 'max_retries' } = $ retries unless ! defined ( $ retries ) ;
2016-10-19 13:48:25 +02:00
$ parameters { 'critical_instructions' } = $ critical_instructions unless ! defined ( $ critical_instructions ) ;
$ parameters { 'warning_instructions' } = $ warning_instructions unless ! defined ( $ warning_instructions ) ;
$ parameters { 'unknown_instructions' } = $ unknown_instructions unless ! defined ( $ unknown_instructions ) ;
2016-10-21 11:18:33 +02:00
$ parameters { 'critical_inverse' } = $ critical_inverse unless ! defined ( $ critical_inverse ) ;
$ parameters { 'warning_inverse' } = $ warning_inverse unless ! defined ( $ warning_inverse ) ;
2013-08-29 13:39:05 +02:00
if ( $ in_policy == 0 ) {
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
foreach my $ id ( @ id_agents ) {
$ parameters { 'id_agente' } = $ id - > { 'id_agente' } ;
pandora_create_module_from_hash ( $ conf , \ % parameters , $ dbh ) ;
}
} else {
pandora_create_module_from_hash ( $ conf , \ % parameters , $ dbh ) ;
}
2012-01-12 17:02:04 +01:00
}
else {
enterprise_hook ( 'pandora_create_policy_module_from_hash' , [ $ conf , \ % parameters , $ dbh ] ) ;
}
2011-11-14 14:27:21 +01:00
}
##############################################################################
# Create plugin module.
# Related option: --create_plugin_module
##############################################################################
2012-01-12 17:02:04 +01:00
sub cli_create_plugin_module ($) {
my $ in_policy = shift ;
my ( $ policy_name , $ module_name , $ module_type , $ agent_name , $ module_address , $ module_port , $ plugin_name ,
2013-08-29 13:39:05 +02:00
$ user , $ password , $ params , $ description , $ module_group , $ min , $ max , $ post_process ,
$ interval , $ warning_min , $ warning_max , $ critical_min , $ critical_max , $ history_data ,
2014-06-15 04:53:41 +02:00
$ ff_threshold , $ warning_str , $ critical_str , $ enable_unknown_events ,
2016-10-19 13:48:25 +02:00
$ each_ff , $ ff_threshold_normal , $ ff_threshold_warning , $ ff_threshold_critical , $ timeout ,
2019-10-17 11:14:42 +02:00
$ critical_instructions , $ warning_instructions , $ unknown_instructions , $ warning_inverse , $ critical_inverse , $ use_alias ) ;
2011-11-14 14:27:21 +01:00
2013-08-29 13:39:05 +02:00
if ( $ in_policy == 0 ) {
2012-01-12 17:02:04 +01:00
( $ module_name , $ module_type , $ agent_name , $ module_address , $ module_port , $ plugin_name ,
$ user , $ password , $ params , $ description , $ module_group , $ min , $ max , $ post_process ,
$ interval , $ warning_min , $ warning_max , $ critical_min , $ critical_max , $ history_data ,
2014-06-15 04:53:41 +02:00
$ ff_threshold , $ warning_str , $ critical_str , $ enable_unknown_events ,
2016-10-19 13:48:25 +02:00
$ each_ff , $ ff_threshold_normal , $ ff_threshold_warning , $ ff_threshold_critical , $ timeout ,
2019-10-17 11:14:42 +02:00
$ critical_instructions , $ warning_instructions , $ unknown_instructions , $ warning_inverse , $ critical_inverse , $ use_alias ) = @ ARGV [ 2 .. 36 ] ;
2012-01-12 17:02:04 +01:00
}
else {
( $ policy_name , $ module_name , $ module_type , $ module_port , $ plugin_name ,
$ user , $ password , $ params , $ description , $ module_group , $ min , $ max , $ post_process ,
$ interval , $ warning_min , $ warning_max , $ critical_min , $ critical_max , $ history_data ,
2014-06-15 04:53:41 +02:00
$ ff_threshold , $ warning_str , $ critical_str , $ enable_unknown_events ,
2016-10-19 13:48:25 +02:00
$ each_ff , $ ff_threshold_normal , $ ff_threshold_warning , $ ff_threshold_critical , $ timeout ,
2016-10-21 11:18:33 +02:00
$ critical_instructions , $ warning_instructions , $ unknown_instructions , $ warning_inverse , $ critical_inverse ) = @ ARGV [ 2 .. 34 ] ;
2012-01-12 17:02:04 +01:00
}
2019-10-17 11:14:42 +02:00
2011-11-14 14:27:21 +01:00
my $ module_name_def ;
my $ module_type_def ;
2019-10-17 11:14:42 +02:00
2012-01-12 17:02:04 +01:00
my $ agent_id ;
2019-10-17 11:14:42 +02:00
my @ id_agents ;
2012-01-12 17:02:04 +01:00
my $ policy_id ;
2013-08-29 13:39:05 +02:00
my $ disabled_types_event = { } ;
if ( $ enable_unknown_events ) {
$ disabled_types_event - > { 'going_unknown' } = 0 ;
}
else {
$ disabled_types_event - > { 'going_unknown' } = 1 ;
}
my $ disabled_types_event_json = encode_json ( $ disabled_types_event ) ;
if ( $ in_policy == 0 ) {
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
exist_check ( $ id - > { 'id_agente' } , 'agent' , $ agent_name ) ;
my $ module_exists = get_agent_module_id ( $ dbh , $ module_name , $ id - > { 'id_agente' } ) ;
non_exist_check ( $ module_exists , 'module name' , $ module_name ) ;
print_log "[INFO] Adding module '$module_name' to agent '$id->{'nombre'}'\n\n" ;
}
} else {
$ agent_id = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ agent_id , 'agent' , $ agent_name ) ;
my $ module_exists = get_agent_module_id ( $ dbh , $ module_name , $ agent_id ) ;
non_exist_check ( $ module_exists , 'module name' , $ module_name ) ;
print_log "[INFO] Adding module '$module_name' to agent '$agent_name'\n\n" ;
}
2012-01-12 17:02:04 +01:00
}
else {
$ policy_id = enterprise_hook ( 'get_policy_id' , [ $ dbh , safe_input ( $ policy_name ) ] ) ;
exist_check ( $ policy_id , 'policy' , $ policy_name ) ;
2011-11-14 14:27:21 +01:00
2012-01-12 17:02:04 +01:00
my $ policy_module_exist = enterprise_hook ( 'get_policy_module_id' , [ $ dbh , $ policy_id , $ module_name ] ) ;
non_exist_check ( $ policy_module_exist , 'policy module' , $ module_name ) ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] Adding module '$module_name' to policy '$policy_name'\n\n" ;
2012-01-12 17:02:04 +01:00
}
2011-11-29 11:31:14 +01:00
2011-11-14 14:27:21 +01:00
# The get_module_id has wrong name. Change in future
my $ module_type_id = get_module_id ( $ dbh , $ module_type ) ;
exist_check ( $ module_type_id , 'module type' , $ module_type ) ;
2013-08-29 13:39:05 +02:00
2011-11-14 14:27:21 +01:00
if ( $ module_type !~ m/.?generic.?/ && $ module_type ne 'log4x' ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] '$module_type' is not valid type for plugin modules. Try with generic or log4x types\n\n" ;
2011-11-14 14:27:21 +01:00
exit ;
}
2013-08-29 13:39:05 +02:00
2011-11-14 14:27:21 +01:00
my $ module_group_id = get_module_group_id ( $ dbh , $ module_group ) ;
exist_check ( $ module_group_id , 'module group' , $ module_group ) ;
2013-08-29 13:39:05 +02:00
2011-11-14 14:27:21 +01:00
my $ plugin_id = get_plugin_id ( $ dbh , $ plugin_name ) ;
exist_check ( $ plugin_id , 'plugin' , $ plugin_name ) ;
if ( $ module_port > 65535 || $ module_port < 1 ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] Port error. Port must into [1-65535]\n\n" ;
2011-11-14 14:27:21 +01:00
exit ;
}
2013-08-29 13:39:05 +02:00
2011-11-14 14:27:21 +01:00
my % parameters ;
$ parameters { 'id_tipo_modulo' } = $ module_type_id ;
2013-08-29 13:39:05 +02:00
if ( $ in_policy == 0 ) {
2012-01-12 17:02:04 +01:00
$ parameters { 'nombre' } = safe_input ( $ module_name ) ;
2019-10-17 11:14:42 +02:00
if ( not defined $ use_alias ) {
$ parameters { 'id_agente' } = $ agent_id ;
}
2012-01-12 17:02:04 +01:00
$ parameters { 'ip_target' } = $ module_address ;
}
else {
$ parameters { 'name' } = safe_input ( $ module_name ) ;
$ parameters { 'id_policy' } = $ policy_id ;
}
2011-11-14 14:27:21 +01:00
$ parameters { 'tcp_port' } = $ module_port ;
$ parameters { 'id_plugin' } = $ plugin_id ;
$ parameters { 'plugin_user' } = $ user ;
$ parameters { 'plugin_pass' } = $ password ;
2015-08-04 11:18:39 +02:00
#$parameters{'plugin_parameter'} = safe_input($params);
my @ user_params = split ( /\s+/ , $ params ) ;
my $ plug_params = get_db_value ( $ dbh , 'SELECT macros FROM tplugin WHERE id =?' , $ plugin_id ) ;
if ( $ plug_params eq undef ) {
print "[ERROR] Error to create module\n\n" ;
help_screen ( ) ;
}
2016-01-18 17:01:37 +01:00
if ( $ { RDBMS } eq 'oracle' ) {
$ plug_params =~ s/\\//g ;
}
2015-08-04 11:18:39 +02:00
my $ decode_params = decode_json ( $ plug_params ) ;
my $ user_params_size = scalar ( @ user_params ) ;
foreach ( my $ i = 1 ; $ i <= $ user_params_size ; $ i + + ) {
$ decode_params - > { $ i } - > { 'value' } = $ user_params [ $ i - 1 ] ;
}
my $ p_params = encode_json ( $ decode_params ) ;
$ parameters { 'macros' } = $ p_params ;
2011-11-14 14:27:21 +01:00
# Optional parameters
$ parameters { 'id_module_group' } = $ module_group_id unless ! defined ( $ module_group ) ;
$ parameters { 'min_warning' } = $ warning_min unless ! defined ( $ warning_min ) ;
$ parameters { 'max_warning' } = $ warning_max unless ! defined ( $ warning_max ) ;
$ parameters { 'min_critical' } = $ critical_min unless ! defined ( $ critical_min ) ;
$ parameters { 'max_critical' } = $ critical_max unless ! defined ( $ critical_max ) ;
$ parameters { 'history_data' } = $ history_data unless ! defined ( $ history_data ) ;
2013-08-29 13:39:05 +02:00
if ( $ in_policy == 0 ) {
2012-01-12 17:02:04 +01:00
$ parameters { 'descripcion' } = safe_input ( $ description ) unless ! defined ( $ description ) ;
#4 for plugin modules
$ parameters { 'id_modulo' } = 4 ;
}
else {
$ parameters { 'description' } = safe_input ( $ description ) unless ! defined ( $ description ) ;
#4 for plugin modules
$ parameters { 'id_module' } = 4 ;
}
2011-11-14 14:27:21 +01:00
$ parameters { 'min' } = $ min unless ! defined ( $ min ) ;
$ parameters { 'max' } = $ max unless ! defined ( $ max ) ;
$ parameters { 'post_process' } = $ post_process unless ! defined ( $ post_process ) ;
$ parameters { 'module_interval' } = $ interval unless ! defined ( $ interval ) ;
$ parameters { 'min_ff_event' } = $ ff_threshold unless ! defined ( $ ff_threshold ) ;
2012-01-11 11:09:02 +01:00
$ parameters { 'str_warning' } = safe_input ( $ warning_str ) unless ! defined ( $ warning_str ) ;
$ parameters { 'str_critical' } = safe_input ( $ critical_str ) unless ! defined ( $ critical_str ) ;
2013-08-29 13:39:05 +02:00
$ parameters { 'disabled_types_event' } = $ disabled_types_event_json ;
2014-06-15 04:53:41 +02:00
$ parameters { 'each_ff' } = $ each_ff unless ! defined ( $ each_ff ) ;
$ parameters { 'min_ff_event_normal' } = $ ff_threshold_normal unless ! defined ( $ ff_threshold_normal ) ;
$ parameters { 'min_ff_event_warning' } = $ ff_threshold_warning unless ! defined ( $ ff_threshold_warning ) ;
$ parameters { 'min_ff_event_critical' } = $ ff_threshold_critical unless ! defined ( $ ff_threshold_critical ) ;
2015-02-05 09:03:30 +01:00
$ parameters { 'max_timeout' } = $ timeout unless ! defined ( $ timeout ) ;
2016-10-19 13:48:25 +02:00
$ parameters { 'critical_instructions' } = $ critical_instructions unless ! defined ( $ critical_instructions ) ;
$ parameters { 'warning_instructions' } = $ warning_instructions unless ! defined ( $ warning_instructions ) ;
$ parameters { 'unknown_instructions' } = $ unknown_instructions unless ! defined ( $ unknown_instructions ) ;
2016-10-21 11:18:33 +02:00
$ parameters { 'critical_inverse' } = $ critical_inverse unless ! defined ( $ critical_inverse ) ;
$ parameters { 'warning_inverse' } = $ warning_inverse unless ! defined ( $ warning_inverse ) ;
2013-08-29 13:39:05 +02:00
if ( $ in_policy == 0 ) {
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
foreach my $ id ( @ id_agents ) {
$ parameters { 'id_agente' } = $ id - > { 'id_agente' } ;
pandora_create_module_from_hash ( $ conf , \ % parameters , $ dbh ) ;
}
} else {
pandora_create_module_from_hash ( $ conf , \ % parameters , $ dbh ) ;
}
2012-01-12 17:02:04 +01:00
}
else {
enterprise_hook ( 'pandora_create_policy_module_from_hash' , [ $ conf , \ % parameters , $ dbh ] ) ;
}
2011-11-14 14:27:21 +01:00
}
##############################################################################
2012-02-28 18:41:01 +01:00
# Delete module.
2011-11-14 14:27:21 +01:00
# Related option: --delete_module
##############################################################################
sub cli_delete_module () {
2019-10-17 11:14:42 +02:00
my ( $ module_name , $ agent_name , $ use_alias ) = @ ARGV [ 2 .. 4 ] ;
2011-11-14 14:27:21 +01:00
2019-10-17 11:14:42 +02:00
my @ id_agents ;
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
my $ id_agent ;
foreach my $ id ( @ id_agents ) {
print_log "[INFO] Deleting module '$module_name' from agent '$id->{'nombre'}' \n\n" ;
$ id_agent = $ id - > { 'id_agente' } ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
my $ id_module = get_agent_module_id ( $ dbh , $ module_name , $ id_agent ) ;
if ( $ id_module == - 1 ) {
next ;
}
pandora_delete_module ( $ dbh , $ id_module , $ conf ) ;
}
} else {
print_log "[INFO] Deleting module '$module_name' from agent '$agent_name' \n\n" ;
my $ id_agent = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
my $ id_module = get_agent_module_id ( $ dbh , $ module_name , $ id_agent ) ;
exist_check ( $ id_module , 'module' , $ module_name ) ;
pandora_delete_module ( $ dbh , $ id_module , $ conf ) ;
}
2011-11-14 14:27:21 +01:00
}
##############################################################################
2012-02-28 18:41:01 +01:00
# Delete not policy modules.
2011-11-14 14:27:21 +01:00
# Related option: --delete_not_policy_modules
##############################################################################
sub cli_delete_not_policy_modules () {
my $ incomingdir ;
2012-02-28 18:41:01 +01:00
my $ incomingdirmd5 ;
2011-11-14 14:27:21 +01:00
$ incomingdir = $ conf - > { incomingdir } . '/conf/' ;
2012-02-28 18:41:01 +01:00
$ incomingdirmd5 = $ conf - > { incomingdir } . '/md5/' ;
2011-11-14 14:27:21 +01:00
# Open the folder
opendir FOLDER , $ incomingdir || die "[ERROR] Opening incoming directory" ;
# Store the list of files
my @ files = readdir ( FOLDER ) ;
my $ file ;
2012-02-28 18:41:01 +01:00
my $ filemd5 ;
2011-11-14 14:27:21 +01:00
2012-12-28 09:26:49 +01:00
print_log "[INFO] Deleting modules without policy from conf files \n\n" ;
2011-11-14 14:27:21 +01:00
foreach $ file ( @ files )
{
if ( $ file ne '.' && $ file ne '..' ) {
2012-02-28 18:41:01 +01:00
# Creates md5 filename of agent
$ filemd5 = $ file ;
$ filemd5 =~ s/\.conf/\.md5/g ;
my $ ret = enterprise_hook ( 'pandora_delete_not_policy_modules' , [ $ incomingdir . $ file , $ incomingdirmd5 . $ filemd5 ] ) ;
2011-11-14 14:27:21 +01:00
}
}
my @ local_modules_without_policies = get_db_rows ( $ dbh , 'SELECT * FROM tagente_modulo WHERE id_policy_module = 0 AND id_tipo_modulo = 1' ) ;
foreach my $ module ( @ local_modules_without_policies ) {
pandora_delete_module ( $ dbh , $ module - > { 'id_agente_modulo' } ) ;
}
}
##############################################################################
# Create template module.
# Related option: --create_template_module
##############################################################################
sub cli_create_template_module () {
2019-10-17 11:14:42 +02:00
my ( $ template_name , $ module_name , $ agent_name , $ use_alias ) = @ ARGV [ 2 .. 5 ] ;
2011-11-14 14:27:21 +01:00
2019-10-17 11:14:42 +02:00
my @ id_agents ;
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
print_log "[INFO] Adding template '$template_name' to module '$module_name' from agent '$agent_name' \n\n" ;
my $ id_agent = $ id - > { 'id_agente' } ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
my $ module_id = get_agent_module_id ( $ dbh , $ module_name , $ id_agent ) ;
if ( $ module_id == - 1 ) {
2019-10-28 09:48:52 +01:00
print_log "[ERROR] Error: The module '$module_name' does not exist. \n\n" ;
2019-10-17 11:14:42 +02:00
next ;
}
my $ template_id = get_template_id ( $ dbh , $ template_name ) ;
exist_check ( $ template_id , 'template' , $ template_name ) ;
pandora_create_template_module ( $ conf , $ dbh , $ module_id , $ template_id ) ;
}
} else {
print_log "[INFO] Adding template '$template_name' to module '$module_name' from agent '$agent_name' \n\n" ;
my $ id_agent = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
my $ module_id = get_agent_module_id ( $ dbh , $ module_name , $ id_agent ) ;
exist_check ( $ module_id , 'module' , $ module_name ) ;
my $ template_id = get_template_id ( $ dbh , $ template_name ) ;
exist_check ( $ template_id , 'template' , $ template_name ) ;
pandora_create_template_module ( $ conf , $ dbh , $ module_id , $ template_id ) ;
}
2011-11-14 14:27:21 +01:00
}
##############################################################################
# Delete template module.
# Related option: --delete_template_module
##############################################################################
sub cli_delete_template_module () {
2019-10-17 11:14:42 +02:00
my ( $ template_name , $ module_name , $ agent_name , $ use_alias ) = @ ARGV [ 2 .. 5 ] ;
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
my @ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
2011-11-14 14:27:21 +01:00
2019-10-17 11:14:42 +02:00
my $ id_agent ;
2011-11-14 14:27:21 +01:00
2019-10-17 11:14:42 +02:00
foreach my $ id ( @ id_agents ) {
print_log "[INFO] Delete template '$template_name' from module '$module_name' from agent '$agent_name' \n\n" ;
$ id_agent = $ id - > { 'id_agente' } ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
my $ module_id = get_agent_module_id ( $ dbh , $ module_name , $ id_agent ) ;
if ( $ module_id eq - 1 ) {
2019-10-28 09:48:52 +01:00
print_log "[ERROR] Error: The module '$module_name' does not exist. \n\n" ;
2019-10-17 11:14:42 +02:00
next ;
}
my $ template_id = get_template_id ( $ dbh , $ template_name ) ;
exist_check ( $ template_id , 'template' , $ template_name ) ;
2011-11-14 14:27:21 +01:00
2019-10-17 11:14:42 +02:00
my $ template_module_id = get_template_module_id ( $ dbh , $ module_id , $ template_id ) ;
exist_check ( $ template_module_id , "template '$template_name' on module" , $ module_name ) ;
2011-11-14 14:27:21 +01:00
2019-10-17 11:14:42 +02:00
pandora_delete_template_module ( $ dbh , $ template_module_id ) ;
}
} else {
print_log "[INFO] Delete template '$template_name' from module '$module_name' from agent '$agent_name' \n\n" ;
2011-11-14 14:27:21 +01:00
2019-10-17 11:14:42 +02:00
my $ id_agent = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
my $ module_id = get_agent_module_id ( $ dbh , $ module_name , $ id_agent ) ;
exist_check ( $ module_id , 'module' , $ module_name ) ;
my $ template_id = get_template_id ( $ dbh , $ template_name ) ;
exist_check ( $ template_id , 'template' , $ template_name ) ;
2011-11-14 14:27:21 +01:00
2019-10-17 11:14:42 +02:00
my $ template_module_id = get_template_module_id ( $ dbh , $ module_id , $ template_id ) ;
exist_check ( $ template_module_id , "template '$template_name' on module" , $ module_name ) ;
2011-11-14 14:27:21 +01:00
2019-10-17 11:14:42 +02:00
pandora_delete_template_module ( $ dbh , $ template_module_id ) ;
}
2011-11-14 14:27:21 +01:00
}
##############################################################################
2019-10-17 11:14:42 +02:00
# Create template action.
# Related option: --create_template_action
2011-11-14 14:27:21 +01:00
##############################################################################
2019-10-17 11:14:42 +02:00
sub cli_create_template_action () {
my ( $ action_name , $ template_name , $ module_name , $ agent_name , $ fires_min , $ fires_max , $ use_alias ) = @ ARGV [ 2 .. 8 ] ;
2011-11-14 14:27:21 +01:00
2019-10-17 11:14:42 +02:00
my @ id_agents ;
2011-11-14 14:27:21 +01:00
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
2011-11-14 14:27:21 +01:00
2019-10-17 11:14:42 +02:00
foreach my $ id ( @ id_agents ) {
print_log "[INFO] Adding action '$action_name' to template '$template_name' in module '$module_name' from agent '$agent_name' with $fires_min min. fires and $fires_max max. fires\n\n" ;
my $ id_agent = $ id - > { 'id_agente' } ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
my $ module_id = get_agent_module_id ( $ dbh , $ module_name , $ id_agent ) ;
if ( $ module_id eq - 1 ) {
2019-10-28 09:48:52 +01:00
print_log "[ERROR] Error: The module '$module_name' does not exist. \n\n" ;
2019-10-17 11:14:42 +02:00
next ;
}
my $ template_id = get_template_id ( $ dbh , $ template_name ) ;
exist_check ( $ template_id , 'template' , $ template_name ) ;
my $ template_module_id = get_template_module_id ( $ dbh , $ module_id , $ template_id ) ;
exist_check ( $ template_module_id , 'template module' , $ template_name ) ;
my $ action_id = get_action_id ( $ dbh , safe_input ( $ action_name ) ) ;
exist_check ( $ action_id , 'action' , $ action_name ) ;
$ fires_min = 0 unless defined ( $ fires_min ) ;
$ fires_max = 0 unless defined ( $ fires_max ) ;
my % parameters ;
$ parameters { 'id_alert_template_module' } = $ template_module_id ;
$ parameters { 'id_alert_action' } = $ action_id ;
$ parameters { 'fires_min' } = $ fires_min ;
$ parameters { 'fires_max' } = $ fires_max ;
pandora_create_template_module_action ( $ conf , \ % parameters , $ dbh ) ;
}
} else {
print_log "[INFO] Adding action '$action_name' to template '$template_name' in module '$module_name' from agent '$agent_name' with $fires_min min. fires and $fires_max max. fires\n\n" ;
my $ id_agent = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
my $ module_id = get_agent_module_id ( $ dbh , $ module_name , $ id_agent ) ;
exist_check ( $ module_id , 'module' , $ module_name ) ;
my $ template_id = get_template_id ( $ dbh , $ template_name ) ;
exist_check ( $ template_id , 'template' , $ template_name ) ;
my $ template_module_id = get_template_module_id ( $ dbh , $ module_id , $ template_id ) ;
exist_check ( $ template_module_id , 'template module' , $ template_name ) ;
my $ action_id = get_action_id ( $ dbh , safe_input ( $ action_name ) ) ;
exist_check ( $ action_id , 'action' , $ action_name ) ;
$ fires_min = 0 unless defined ( $ fires_min ) ;
$ fires_max = 0 unless defined ( $ fires_max ) ;
my % parameters ;
$ parameters { 'id_alert_template_module' } = $ template_module_id ;
$ parameters { 'id_alert_action' } = $ action_id ;
$ parameters { 'fires_min' } = $ fires_min ;
$ parameters { 'fires_max' } = $ fires_max ;
pandora_create_template_module_action ( $ conf , \ % parameters , $ dbh ) ;
}
}
##############################################################################
# Delete template action.
# Related option: --delete_template_action
##############################################################################
sub cli_delete_template_action () {
my ( $ action_name , $ template_name , $ module_name , $ agent_name , $ use_alias ) = @ ARGV [ 2 .. 6 ] ;
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
my @ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
print_log "[INFO] Deleting action '$action_name' from template '$template_name' in module '$module_name' from agent '$agent_name')\n\n" ;
my $ id_agent = $ id - > { 'id_agente' } ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
my $ module_id = get_agent_module_id ( $ dbh , $ module_name , $ id_agent ) ;
if ( $ module_id eq - 1 ) {
2019-10-28 09:48:52 +01:00
print_log "[ERROR] Error: The module '$module_name' does not exist. \n\n" ;
2019-10-17 11:14:42 +02:00
next ;
}
my $ template_id = get_template_id ( $ dbh , $ template_name ) ;
exist_check ( $ template_id , 'template' , $ template_name ) ;
my $ template_module_id = get_template_module_id ( $ dbh , $ module_id , $ template_id ) ;
exist_check ( $ template_module_id , 'template module' , $ template_name ) ;
my $ action_id = get_action_id ( $ dbh , safe_input ( $ action_name ) ) ;
exist_check ( $ action_id , 'action' , $ action_name ) ;
pandora_delete_template_module_action ( $ dbh , $ template_module_id , $ action_id ) ;
}
} else {
print_log "[INFO] Deleting action '$action_name' from template '$template_name' in module '$module_name' from agent '$agent_name')\n\n" ;
my $ id_agent = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
my $ module_id = get_agent_module_id ( $ dbh , $ module_name , $ id_agent ) ;
exist_check ( $ module_id , 'module' , $ module_name ) ;
my $ template_id = get_template_id ( $ dbh , $ template_name ) ;
exist_check ( $ template_id , 'template' , $ template_name ) ;
my $ template_module_id = get_template_module_id ( $ dbh , $ module_id , $ template_id ) ;
exist_check ( $ template_module_id , 'template module' , $ template_name ) ;
my $ action_id = get_action_id ( $ dbh , safe_input ( $ action_name ) ) ;
exist_check ( $ action_id , 'action' , $ action_name ) ;
pandora_delete_template_module_action ( $ dbh , $ template_module_id , $ action_id ) ;
}
}
##############################################################################
# Insert data to module.
# Related option: --data_module
2011-11-14 14:27:21 +01:00
##############################################################################
sub cli_data_module () {
2019-10-17 11:14:42 +02:00
my ( $ server_name , $ agent_name , $ module_name , $ module_type , $ module_new_data , $ datetime , $ use_alias ) = @ ARGV [ 2 .. 8 ] ;
2011-11-14 14:27:21 +01:00
my $ utimestamp ;
2019-10-17 11:14:42 +02:00
my @ id_agents ;
2011-11-14 14:27:21 +01:00
if ( defined ( $ datetime ) ) {
if ( $ datetime !~ /([0-9]{2,4})\-([0-1][0-9])\-([0-3][0-9]) +([0-2][0-9]):([0-5][0-9])/ ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] Invalid datetime $datetime. (Correct format: YYYY-MM-DD HH:mm)\n" ;
2011-11-14 14:27:21 +01:00
exit ;
}
# Add the seconds
$ datetime . = ":00" ;
$ utimestamp = dateTimeToTimestamp ( $ datetime ) ;
}
else {
$ utimestamp = time ( ) ;
}
# The get_module_id has wrong name. Change in future
my $ module_type_id = get_module_id ( $ dbh , $ module_type ) ;
exist_check ( $ module_type_id , 'module type' , $ module_type ) ;
2019-10-17 11:14:42 +02:00
2011-11-14 14:27:21 +01:00
# Server_type 0 is dataserver
my $ server_id = get_server_id ( $ dbh , $ server_name , 0 ) ;
exist_check ( $ server_id , 'data server' , $ server_name ) ;
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
my $ id_agent ;
foreach my $ id ( @ id_agents ) {
$ id_agent = $ id - > { 'id_agente' } ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
my $ id_module = get_agent_module_id ( $ dbh , $ module_name , $ id_agent ) ;
if ( $ id_module == - 1 ) {
next ;
}
my $ module = get_db_single_row ( $ dbh , 'SELECT * FROM tagente_modulo WHERE id_agente_modulo = ? AND id_tipo_modulo = ?' , $ id_module , $ module_type_id ) ;
if ( not defined ( $ module - > { 'module_interval' } ) ) {
print_log "[ERROR] No module found with this type. \n\n" ;
exit ;
}
my % data = ( 'data' = > $ module_new_data ) ;
pandora_process_module ( $ conf , \ % data , '' , $ module , $ module_type , '' , $ utimestamp , $ server_id , $ dbh ) ;
print_log "[INFO] Inserting data to module '$module_name'\n\n" ;
}
} else {
my $ id_agent = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
my $ id_module = get_agent_module_id ( $ dbh , $ module_name , $ id_agent ) ;
exist_check ( $ id_module , 'module name' , $ module_name ) ;
my $ module = get_db_single_row ( $ dbh , 'SELECT * FROM tagente_modulo WHERE id_agente_modulo = ? AND id_tipo_modulo = ?' , $ id_module , $ module_type_id ) ;
if ( not defined ( $ module - > { 'module_interval' } ) ) {
print_log "[ERROR] No module found with this type. \n\n" ;
exit ;
}
my % data = ( 'data' = > $ module_new_data ) ;
pandora_process_module ( $ conf , \ % data , '' , $ module , $ module_type , '' , $ utimestamp , $ server_id , $ dbh ) ;
print_log "[INFO] Inserting data to module '$module_name'\n\n" ;
2011-11-14 14:27:21 +01:00
}
}
##############################################################################
# Create a user.
# Related option: --create_user
##############################################################################
sub cli_create_user () {
my ( $ user_name , $ password , $ is_admin , $ comments ) = @ ARGV [ 2 .. 5 ] ;
$ comments = ( defined ( $ comments ) ? safe_input ( $ comments ) : '' ) ;
2012-01-17 10:30:52 +01:00
my $ user_exists = get_user_exists ( $ dbh , $ user_name ) ;
non_exist_check ( $ user_exists , 'user' , $ user_name ) ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] Creating user '$user_name'\n\n" ;
2011-11-14 14:27:21 +01:00
pandora_create_user ( $ dbh , $ user_name , md5 ( $ password ) , $ is_admin , $ comments ) ;
}
2012-01-05 13:11:03 +01:00
##############################################################################
# Update a user.
# Related option: --update_user
##############################################################################
sub cli_user_update () {
my ( $ user_id , $ field , $ new_value ) = @ ARGV [ 2 .. 4 ] ;
2021-11-24 16:07:20 +01:00
if ( is_metaconsole ( $ conf ) != 1 && pandora_get_tconfig_token ( $ dbh , 'centralized_management' , '' ) ) {
print_log "[ERROR] This node is configured with centralized mode. To update a user go to metaconsole. \n\n" ;
exit ;
}
2012-01-05 13:11:03 +01:00
my $ user_exists = get_user_exists ( $ dbh , $ user_id ) ;
exist_check ( $ user_exists , 'user' , $ user_id ) ;
2021-11-24 16:07:20 +01:00
2018-10-19 11:31:06 +02:00
if ( $ field eq 'email' || $ field eq 'phone' || $ field eq 'is_admin' || $ field eq 'language' || $ field eq 'id_skin' ) {
2012-01-05 13:11:03 +01:00
# Fields admited, no changes
}
elsif ( $ field eq 'comments' || $ field eq 'fullname' ) {
$ new_value = safe_input ( $ new_value ) ;
}
elsif ( $ field eq 'password' ) {
if ( $ new_value eq '' ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] Field '$field' cannot be empty\n\n" ;
2012-01-05 13:11:03 +01:00
exit ;
}
$ new_value = md5 ( $ new_value ) ;
}
else {
2022-05-05 11:47:49 +02:00
print_log "[ERROR] Field '$field' doesn't exist\n\n" ;
2012-01-05 13:11:03 +01:00
exit ;
}
2012-12-28 09:26:49 +01:00
print_log "[INFO] Updating field '$field' in user '$user_id'\n\n" ;
2012-01-05 13:11:03 +01:00
my $ update ;
$ update - > { $ field } = $ new_value ;
pandora_update_user_from_hash ( $ update , 'id_user' , safe_input ( $ user_id ) , $ dbh ) ;
}
2021-07-09 13:58:01 +02:00
##############################################################################
# Update an agent customs field.
2022-09-20 14:31:48 +02:00
# Related option: --agent_update_custom_fields
2021-07-09 13:58:01 +02:00
##############################################################################
sub cli_agent_update_custom_fields () {
2021-09-30 12:50:59 +02:00
my ( $ id_agent , $ type , $ field , $ new_value ) = @ ARGV [ 2 .. 5 ] ;
2021-07-09 13:58:01 +02:00
my $ agent_name = get_agent_name ( $ dbh , $ id_agent ) ;
my $ id_field ;
2021-09-30 12:50:59 +02:00
my $ found = 0 ;
2021-07-09 13:58:01 +02:00
if ( $ agent_name eq '' ) {
2022-05-05 11:47:49 +02:00
print_log "[ERROR] Agent '$id_agent' doesn't exist\n\n" ;
2022-09-20 14:31:48 +02:00
print "--agent_update_custom_fields, <id_agent> <type_field> <field_to_change> <new_value>, Updates an agent custom field. The fields can be \n\t the following: Serial number, Department ... and types can be 0 text and 1 combo )\n\n" ;
2021-07-09 13:58:01 +02:00
exit ;
}
2021-09-27 17:56:41 +02:00
# Department, Serial number ...
2021-09-28 09:31:06 +02:00
my $ custom_field = pandora_select_id_custom_field ( $ dbh , $ field ) ;
2021-07-09 13:58:01 +02:00
2021-09-30 12:50:59 +02:00
2021-09-27 17:56:41 +02:00
if ( $ custom_field eq '' ) {
2022-05-05 11:47:49 +02:00
print_log "[ERROR] Field '$field' doesn't exist\n\n" ;
2022-09-20 14:31:48 +02:00
print "--agent_update_custom_fields, <id_agent> <type_field> <field_to_change> <new_value>, Updates an agent custom field. The fields can be \n\t the following: Serial number, Department ... and types can be 0 text and 1 combo )\n\n" ;
2021-09-27 17:56:41 +02:00
exit ;
2021-07-09 13:58:01 +02:00
}
2021-09-30 12:50:59 +02:00
if ( $ type == 1 ) {
my $ exist_option = pandora_select_combo_custom_field ( $ dbh , $ custom_field ) ;
my @ fields = split ( ',' , $ exist_option ) ;
foreach my $ combo ( @ fields ) {
2021-09-30 14:34:58 +02:00
if ( $ combo eq safe_input ( $ new_value ) ) {
2021-09-30 12:50:59 +02:00
$ found = 1 ;
}
}
if ( $ found == 0 ) {
print_log "\n[ERROR] Field '$new_value' doesn't match with combo option values\n\n" ;
exit
}
}
print_log "\n[INFO] Updating field '$field' in agent with ID '$id_agent'\n\n" ;
2021-07-09 13:58:01 +02:00
2022-09-20 14:31:48 +02:00
my $ result = pandora_agent_update_custom_field ( $ dbh , $ new_value , $ custom_field , $ id_agent ) ;
2021-09-28 11:20:26 +02:00
if ( $ result == "0E0" ) {
2021-09-30 12:50:59 +02:00
print_log "[ERROR] Error updating field '$field'\n\n" ;
2021-09-28 11:20:26 +02:00
} else {
2022-05-05 11:47:49 +02:00
print_log "[INFO] Field '$field' updated successfully!\n\n" ;
2021-09-28 11:20:26 +02:00
}
2021-07-09 13:58:01 +02:00
exit ;
}
2012-01-20 09:52:17 +01:00
##############################################################################
# Update an agent field.
# Related option: --update_agent
##############################################################################
sub cli_agent_update () {
2019-10-17 11:14:42 +02:00
my ( $ agent_name , $ field , $ new_value , $ use_alias ) = @ ARGV [ 2 .. 5 ] ;
my @ id_agents ;
my $ id_agent ;
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
exist_check ( $ id - > { 'id_agente' } , 'agent' , $ agent_name ) ;
}
} else {
$ id_agent = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
}
2012-01-20 09:52:17 +01:00
# agent_name, address, description, group_name, interval, os_name, disabled, parent_name, cascade_protection, icon_path, update_gis_data, custom_id
if ( $ field eq 'disabled' || $ field eq 'cascade_protection' || $ field eq 'icon_path' ||
$ field eq 'update_gis_data' || $ field eq 'custom_id' ) {
# Fields admited, no changes
}
elsif ( $ field eq 'interval' ) {
$ field = 'intervalo' ;
}
elsif ( $ field eq 'description' ) {
$ field = 'comentarios' ;
$ new_value = safe_input ( $ new_value ) ;
}
elsif ( $ field eq 'parent_name' ) {
my $ id_parent = get_agent_id ( $ dbh , $ new_value ) ;
exist_check ( $ id_parent , 'agent' , $ new_value ) ;
$ field = 'id_parent' ;
$ new_value = $ id_parent ;
}
elsif ( $ field eq 'agent_name' ) {
my $ agent_exists = get_agent_id ( $ dbh , $ new_value ) ;
non_exist_check ( $ agent_exists , 'agent' , $ new_value ) ;
$ field = 'nombre' ;
}
elsif ( $ field eq 'group_name' ) {
my $ id_group = get_group_id ( $ dbh , $ new_value ) ;
exist_check ( $ id_group , 'group' , $ new_value ) ;
$ new_value = $ id_group ;
$ field = 'id_grupo' ;
}
elsif ( $ field eq 'os_name' ) {
my $ id_os = get_os_id ( $ dbh , $ new_value ) ;
exist_check ( $ id_os , 'operating system' , $ new_value ) ;
$ new_value = $ id_os ;
$ field = 'id_os' ;
}
elsif ( $ field eq 'address' ) {
# Check if the address already exist
my $ address_id = get_addr_id ( $ dbh , $ new_value ) ;
2022-05-05 11:47:49 +02:00
# If the addres doesn't exist, we add it to the addresses list
2012-01-20 09:52:17 +01:00
if ( $ address_id == - 1 ) {
$ address_id = add_address ( $ dbh , $ new_value ) ;
}
# Add the address to the agent
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
foreach my $ id ( @ id_agents ) {
2021-04-07 17:38:38 +02:00
my $ ag_addr_id = get_agent_addr_id ( $ dbh , $ address_id , $ id - > { 'id_agente' } ) ;
if ( $ ag_addr_id == - 1 ) {
add_new_address_agent ( $ dbh , $ address_id , $ id - > { 'id_agente' } ) ;
}
2019-10-17 11:14:42 +02:00
}
} else {
2021-04-07 17:38:38 +02:00
my $ ag_addr_id = get_agent_addr_id ( $ dbh , $ address_id , $ id_agent ) ;
if ( $ ag_addr_id == - 1 ) {
add_new_address_agent ( $ dbh , $ address_id , $ id_agent ) ;
}
2019-10-17 11:14:42 +02:00
}
2012-01-20 09:52:17 +01:00
$ field = 'direccion' ;
}
else {
2022-05-05 11:47:49 +02:00
print_log "[ERROR] Field '$field' doesn't exist\n\n" ;
2012-01-20 09:52:17 +01:00
exit ;
}
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
print_log "[INFO] Updating field '$field' in agents with alias '$agent_name'\n\n" ;
} else {
print_log "[INFO] Updating field '$field' in agent '$agent_name'\n\n" ;
}
2012-01-20 09:52:17 +01:00
my $ update ;
$ update - > { $ field } = $ new_value ;
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
foreach my $ id ( @ id_agents ) {
pandora_update_table_from_hash ( $ conf , $ update , 'id_agente' , safe_input ( $ id - > { 'id_agente' } ) , 'tagente' , $ dbh ) ;
}
} else {
pandora_update_table_from_hash ( $ conf , $ update , 'id_agente' , safe_input ( $ id_agent ) , 'tagente' , $ dbh ) ;
}
2023-01-16 14:28:00 +01:00
enterprise_hook ( 'update_agent_cache' , [ $ conf , $ dbh , $ id_agent ] ) if ( $ conf - > { 'node_metaconsole' } == 1 ) ;
2012-01-20 09:52:17 +01:00
}
2012-01-13 10:43:29 +01:00
##############################################################################
# Update an alert template.
# Related option: --update_alert_template
##############################################################################
sub cli_alert_template_update () {
my ( $ template_name , $ field , $ new_value ) = @ ARGV [ 2 .. 4 ] ;
my $ template_id = pandora_get_alert_template_id ( $ dbh , $ template_name ) ;
exist_check ( $ template_id , 'alert template' , $ template_name ) ;
if ( $ field eq 'matches_value' || $ field eq 'value' || $ field eq 'min_value' ||
$ field eq 'max_value' || $ field eq 'type' || $ field eq 'time_threshold' ||
$ field eq 'time_from' || $ field eq 'time_to' || $ field eq 'monday' ||
$ field eq 'tuesday' || $ field eq 'wednesday' || $ field eq 'thursday' ||
$ field eq 'friday' || $ field eq 'saturday' || $ field eq 'sunday' ||
$ field eq 'min_alerts' || $ field eq 'max_alerts' || $ field eq 'recovery_notify' ) {
# Fields admited, no changes
}
elsif ( $ field eq 'name' || $ field eq 'description' || $ field eq 'field1' || $ field eq 'field2' || $ field eq 'field3' || $ field eq 'recovery_field2' || $ field eq 'recovery_field3' ) {
$ new_value = safe_input ( $ new_value ) ;
}
elsif ( $ field eq 'priority' ) {
if ( $ new_value < 0 || $ new_value > 4 ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] Field '$field' is out of interval (0-4)\n\n" ;
2012-01-13 10:43:29 +01:00
exit ;
}
}
elsif ( $ field eq 'default_action' ) {
# Check if exist
my $ id_alert_action = get_action_id ( $ dbh , safe_input ( $ new_value ) ) ;
2012-01-20 09:52:17 +01:00
exist_check ( $ id_alert_action , 'alert action' , $ new_value ) ;
2012-01-13 10:43:29 +01:00
$ new_value = $ id_alert_action ;
$ field = 'id_alert_action' ;
}
elsif ( $ field eq 'group_name' ) {
# Check if exist
my $ id_group = get_group_id ( $ dbh , $ new_value ) ;
2012-01-20 09:52:17 +01:00
exist_check ( $ id_group , 'group' , $ new_value ) ;
2012-01-13 10:43:29 +01:00
$ new_value = $ id_group ;
$ field = 'id_group' ;
}
else {
2022-05-05 11:47:49 +02:00
print_log "[ERROR] Field '$field' doesn't exist\n\n" ;
2012-01-13 10:43:29 +01:00
exit ;
}
2012-12-28 09:26:49 +01:00
print_log "[INFO] Updating field '$field' in alert template '$template_name'\n\n" ;
2012-01-13 10:43:29 +01:00
my $ update ;
$ update - > { $ field } = $ new_value ;
pandora_update_alert_template_from_hash ( $ update , 'id' , $ template_id , $ dbh ) ;
}
2012-01-16 15:55:55 +01:00
##############################################################################
# Check the specific fields of data module when update
##############################################################################
sub pandora_check_data_module_fields ($) {
my $ field_value = shift ;
2014-06-15 04:53:41 +02:00
if ( $ field_value - > { 'field' } eq 'ff_timeout' ) {
$ field_value - > { 'field' } = 'ff_timeout' ;
}
else {
print_log "[ERROR] The field '" . $ field_value - > { 'field' } . "' is not available for data modules\n\n" ;
exit ;
}
2012-01-16 15:55:55 +01:00
}
##############################################################################
# Check the specific fields of network module when update
##############################################################################
sub pandora_check_network_module_fields ($) {
my $ field_value = shift ;
2014-06-15 04:53:41 +02:00
if ( $ field_value - > { 'field' } eq 'module_address' ) {
2012-01-16 15:55:55 +01:00
my $ agent_name = @ ARGV [ 3 ] ;
my $ id_agent = get_agent_id ( $ dbh , $ agent_name ) ;
$ field_value - > { 'field' } = 'ip_target' ;
# Check if the address already exist
my $ address_id = get_addr_id ( $ dbh , $ field_value - > { 'new_value' } ) ;
2022-05-05 11:47:49 +02:00
# If the addres doesn't exist, we add it to the addresses list
2012-01-16 15:55:55 +01:00
if ( $ address_id == - 1 ) {
$ address_id = add_address ( $ dbh , $ field_value - > { 'new_value' } ) ;
}
# Add the address to the agent
add_new_address_agent ( $ dbh , $ address_id , $ id_agent ) ;
# Only pending set as main address (Will be done at the end of the function)
}
elsif ( $ field_value - > { 'field' } eq 'module_port' ) {
if ( $ field_value - > { 'new_value' } > 65535 || $ field_value - > { 'new_value' } < 1 ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] Port error. Port must into [1-65535]\n\n" ;
2012-01-16 15:55:55 +01:00
exit ;
}
$ field_value - > { 'field' } = 'tcp_port' ;
}
2015-02-05 09:03:30 +01:00
elsif ( $ field_value - > { 'field' } eq 'timeout' ) {
$ field_value - > { 'field' } = 'max_timeout' ;
}
elsif ( $ field_value - > { 'field' } eq 'retries' ) {
$ field_value - > { 'field' } = 'max_retries' ;
}
2012-01-16 15:55:55 +01:00
else {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] The field '" . $ field_value - > { 'field' } . "' is not available for network modules\n\n" ;
2012-01-16 15:55:55 +01:00
exit ;
}
}
##############################################################################
# Check the specific fields of snmp module when update
##############################################################################
sub pandora_check_snmp_module_fields ($) {
my $ field_value = shift ;
if ( $ field_value - > { 'field' } eq 'version' ) {
$ field_value - > { 'field' } = 'tcp_send' ;
}
elsif ( $ field_value - > { 'field' } eq 'community' ) {
$ field_value - > { 'field' } = 'snmp_community' ;
}
elsif ( $ field_value - > { 'field' } eq 'oid' ) {
$ field_value - > { 'field' } = 'snmp_oid' ;
}
elsif ( $ field_value - > { 'field' } eq 'snmp3_priv_method' ) {
$ field_value - > { 'field' } = 'custom_string_1' ;
}
elsif ( $ field_value - > { 'field' } eq 'snmp3_priv_pass' ) {
$ field_value - > { 'field' } = 'custom_string_2' ;
}
elsif ( $ field_value - > { 'field' } eq 'snmp3_sec_level' ) {
$ field_value - > { 'field' } = 'custom_string_3' ;
}
elsif ( $ field_value - > { 'field' } eq 'snmp3_auth_method' ) {
$ field_value - > { 'field' } = 'plugin_parameter' ;
}
elsif ( $ field_value - > { 'field' } eq 'snmp3_auth_user' ) {
$ field_value - > { 'field' } = 'plugin_user' ;
}
elsif ( $ field_value - > { 'field' } eq 'snmp3_auth_pass' ) {
$ field_value - > { 'field' } = 'plugin_pass' ;
}
elsif ( $ field_value - > { 'field' } eq 'module_address' ) {
my $ agent_name = @ ARGV [ 3 ] ;
my $ id_agent = get_agent_id ( $ dbh , $ agent_name ) ;
$ field_value - > { 'field' } = 'ip_target' ;
# Check if the address already exist
my $ address_id = get_addr_id ( $ dbh , $ field_value - > { 'new_value' } ) ;
2022-05-05 11:47:49 +02:00
# If the addres doesn't exist, we add it to the addresses list
2012-01-16 15:55:55 +01:00
if ( $ address_id == - 1 ) {
$ address_id = add_address ( $ dbh , $ field_value - > { 'new_value' } ) ;
}
# Add the address to the agent
add_new_address_agent ( $ dbh , $ address_id , $ id_agent ) ;
# Only pending set as main address (Will be done at the end of the function)
}
elsif ( $ field_value - > { 'field' } eq 'module_port' ) {
if ( $ field_value - > { 'new_value' } > 65535 || $ field_value - > { 'new_value' } < 1 ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] Port error. Port must into [1-65535]\n\n" ;
2012-01-16 15:55:55 +01:00
exit ;
}
$ field_value - > { 'field' } = 'tcp_port' ;
}
2015-02-05 09:03:30 +01:00
elsif ( $ field_value - > { 'field' } eq 'timeout' ) {
$ field_value - > { 'field' } = 'max_timeout' ;
}
elsif ( $ field_value - > { 'field' } eq 'retries' ) {
$ field_value - > { 'field' } = 'max_retries' ;
}
2012-01-16 15:55:55 +01:00
else {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] The field '" . $ field_value - > { 'field' } . "' is not available for SNMP modules\n\n" ;
2012-01-16 15:55:55 +01:00
exit ;
}
}
##############################################################################
# Check the specific fields of plugin module when update
##############################################################################
sub pandora_check_plugin_module_fields ($) {
my $ field_value = shift ;
if ( $ field_value - > { 'field' } eq 'plugin_name' ) {
my $ plugin_id = get_plugin_id ( $ dbh , $ field_value - > { 'new_value' } ) ;
exist_check ( $ plugin_id , 'plugin' , $ field_value - > { 'new_value' } ) ;
$ field_value - > { 'new_value' } = $ plugin_id ;
$ field_value - > { 'field' } = 'id_plugin' ;
}
elsif ( $ field_value - > { 'field' } eq 'user' ) {
$ field_value - > { 'field' } = 'plugin_user' ;
}
elsif ( $ field_value - > { 'field' } eq 'password' ) {
$ field_value - > { 'field' } = 'plugin_pass' ;
}
elsif ( $ field_value - > { 'field' } eq 'parameters' ) {
$ field_value - > { 'field' } = 'plugin_parameter' ;
$ field_value - > { 'new_value' } = safe_input ( $ field_value - > { 'new_value' } ) ;
}
elsif ( $ field_value - > { 'field' } eq 'module_address' ) {
my $ agent_name = @ ARGV [ 3 ] ;
my $ id_agent = get_agent_id ( $ dbh , $ agent_name ) ;
$ field_value - > { 'field' } = 'ip_target' ;
# Check if the address already exist
my $ address_id = get_addr_id ( $ dbh , $ field_value - > { 'new_value' } ) ;
2022-05-05 11:47:49 +02:00
# If the addres doesn't exist, we add it to the addresses list
2012-01-16 15:55:55 +01:00
if ( $ address_id == - 1 ) {
$ address_id = add_address ( $ dbh , $ field_value - > { 'new_value' } ) ;
}
# Add the address to the agent
add_new_address_agent ( $ dbh , $ address_id , $ id_agent ) ;
# Only pending set as main address (Will be done at the end of the function)
}
elsif ( $ field_value - > { 'field' } eq 'module_port' ) {
$ field_value - > { 'field' } = 'tcp_port' ;
}
2015-02-05 09:03:30 +01:00
elsif ( $ field_value - > { 'field' } eq 'timeout' ) {
$ field_value - > { 'field' } = 'max_timeout' ;
}
2012-01-16 15:55:55 +01:00
else {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] The field '" . $ field_value - > { 'field' } . "' is not available for plugin modules\n\n" ;
2012-01-16 15:55:55 +01:00
exit ;
}
}
##############################################################################
# Add a profile to a User in a Group
# Related option: --update_module
##############################################################################
sub cli_module_update () {
2019-10-17 11:14:42 +02:00
my ( $ module_name , $ agent_name , $ field , $ new_value , $ use_alias ) = @ ARGV [ 2 .. 6 ] ;
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
my @ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
my $ save_initial_field = $ field ;
my $ save_new_value = $ new_value ;
foreach my $ id ( @ id_agents ) {
$ field = $ save_initial_field ;
$ new_value = $ save_new_value ;
my $ id_agent = $ id - > { 'id_agente' } ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
my $ id_agent_module = get_agent_module_id ( $ dbh , $ module_name , $ id_agent ) ;
if ( $ id_agent_module == - 1 ) {
next ;
}
# Check and adjust parameters in common values
if ( $ field eq 'min' || $ field eq 'max' || $ field eq 'post_process' || $ field eq 'history_data' ) {
# Fields admited, no changes
}
elsif ( $ field eq 'interval' ) {
$ field = 'module_interval' ;
}
elsif ( $ field eq 'warning_min' ) {
$ field = 'min_warning' ;
}
elsif ( $ field eq 'warning_max' ) {
$ field = 'max_warning' ;
}
elsif ( $ field eq 'critical_min' ) {
$ field = 'min_critical' ;
}
elsif ( $ field eq 'critical_max' ) {
$ field = 'max_critical' ;
}
elsif ( $ field eq 'warning_str' ) {
$ field = 'str_warning' ;
$ new_value = safe_input ( $ new_value ) ;
}
elsif ( $ field eq 'critical_str' ) {
$ field = 'str_critical' ;
$ new_value = safe_input ( $ new_value ) ;
}
elsif ( $ field eq 'agent_name' ) {
my $ id_agent_change = get_agent_id ( $ dbh , $ new_value ) ;
exist_check ( $ id_agent_change , 'agent' , $ new_value ) ;
my $ id_agent_module_exist = get_agent_module_id ( $ dbh , $ module_name , $ id_agent_change ) ;
if ( $ id_agent_module_exist != - 1 ) {
print_log "[ERROR] A module called '$module_name' already exist in the agent '$new_value'\n\n" ;
exit ;
}
$ field = 'id_agente' ;
$ new_value = $ id_agent_change ;
}
elsif ( $ field eq 'module_name' ) {
my $ id_agent_module_change = get_agent_module_id ( $ dbh , $ new_value , $ id_agent ) ;
if ( $ id_agent_module_change != - 1 ) {
print_log "[ERROR] A module called '$new_value' already exist in the agent '$agent_name'\n\n" ;
exit ;
}
$ field = 'nombre' ;
$ new_value = safe_input ( $ new_value ) ;
}
elsif ( $ field eq 'description' ) {
$ field = 'descripcion' ;
$ new_value = safe_input ( $ new_value ) ;
}
elsif ( $ field eq 'module_group' ) {
my $ module_group_id = get_module_group_id ( $ dbh , $ new_value ) ;
if ( $ module_group_id == - 1 ) {
2022-05-05 11:47:49 +02:00
print_log "[ERROR] Module group '$new_value' doesn't exist\n\n" ;
2019-10-17 11:14:42 +02:00
exit ;
}
$ field = 'id_module_group' ;
$ new_value = $ module_group_id ;
}
elsif ( $ field eq 'enable_unknown_events' ) {
my $ disabled_types_event = { } ;
if ( $ new_value ) {
$ disabled_types_event - > { 'going_unknown' } = 0 ;
}
else {
$ disabled_types_event - > { 'going_unknown' } = 1 ;
}
$ field = 'disabled_types_event' ;
$ new_value = encode_json ( $ disabled_types_event ) ;
}
elsif ( $ field eq 'ff_threshold' ) {
$ field = 'min_ff_event' ;
}
elsif ( $ field eq 'each_ff' ) {
$ field = 'each_ff' ;
}
elsif ( $ field eq 'ff_threshold_normal' ) {
$ field = 'min_ff_event_normal' ;
}
elsif ( $ field eq 'ff_threshold_warning' ) {
$ field = 'min_ff_event_warning' ;
}
elsif ( $ field eq 'ff_threshold_critical' ) {
$ field = 'min_ff_event_critical' ;
}
elsif ( $ field eq 'critical_instructions' ) {
$ field = 'critical_instructions' ;
}
elsif ( $ field eq 'warning_instructions' ) {
$ field = 'warning_instructions' ;
}
elsif ( $ field eq 'unknown_instructions' ) {
$ field = 'unknown_instructions' ;
}
else {
# If is not a common value, check type and call type update funtion
my $ type = pandora_get_module_type ( $ dbh , $ id_agent_module ) ;
print ( "TYPE EN ELSE" . $ type ) ;
my % field_value ;
$ field_value { 'field' } = $ field ;
$ field_value { 'new_value' } = $ new_value ;
if ( $ type eq 'data' ) {
pandora_check_data_module_fields ( \ % field_value ) ;
}
elsif ( $ type eq 'network' ) {
pandora_check_network_module_fields ( \ % field_value ) ;
}
elsif ( $ type eq 'snmp' ) {
pandora_check_snmp_module_fields ( \ % field_value ) ;
}
elsif ( $ type eq 'plugin' ) {
pandora_check_plugin_module_fields ( \ % field_value ) ;
}
else {
print_log "[ERROR] The field '$field' is not available for this type of module\n\n" ;
}
$ field = $ field_value { 'field' } ;
$ new_value = $ field_value { 'new_value' } ;
}
print_log "[INFO] Updating field '$field' in module '$module_name' of agent '$agent_name' with new value '$new_value'\n\n" ;
my $ update ;
$ update - > { $ field } = $ new_value ;
my $ policy_id = enterprise_hook ( 'get_id_policy_module_agent_module' , [ $ dbh , safe_input ( $ id_agent_module ) ] ) ;
if ( $ policy_id > 0 ) {
$ update - > { policy_linked } = 0 ;
}
pandora_update_module_from_hash ( $ conf , $ update , 'id_agente_modulo' , $ id_agent_module , $ dbh ) ;
2012-01-16 15:55:55 +01:00
}
2019-10-17 11:14:42 +02:00
} else {
my $ id_agent = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
my $ id_agent_module = get_agent_module_id ( $ dbh , $ module_name , $ id_agent ) ;
exist_check ( $ id_agent_module , 'agent module' , $ module_name ) ;
2013-08-29 13:39:05 +02:00
2019-10-17 11:14:42 +02:00
# Check and adjust parameters in common values
if ( $ field eq 'min' || $ field eq 'max' || $ field eq 'post_process' || $ field eq 'history_data' ) {
# Fields admited, no changes
2012-01-16 15:55:55 +01:00
}
2019-10-17 11:14:42 +02:00
elsif ( $ field eq 'interval' ) {
$ field = 'module_interval' ;
2013-08-29 13:39:05 +02:00
}
2019-10-17 11:14:42 +02:00
elsif ( $ field eq 'warning_min' ) {
$ field = 'min_warning' ;
2013-08-29 13:39:05 +02:00
}
2019-10-17 11:14:42 +02:00
elsif ( $ field eq 'warning_max' ) {
$ field = 'max_warning' ;
}
elsif ( $ field eq 'critical_min' ) {
$ field = 'min_critical' ;
}
elsif ( $ field eq 'critical_max' ) {
$ field = 'max_critical' ;
}
elsif ( $ field eq 'warning_str' ) {
$ field = 'str_warning' ;
$ new_value = safe_input ( $ new_value ) ;
}
elsif ( $ field eq 'critical_str' ) {
$ field = 'str_critical' ;
$ new_value = safe_input ( $ new_value ) ;
}
elsif ( $ field eq 'agent_name' ) {
my $ id_agent_change = get_agent_id ( $ dbh , $ new_value ) ;
exist_check ( $ id_agent_change , 'agent' , $ new_value ) ;
my $ id_agent_module_exist = get_agent_module_id ( $ dbh , $ module_name , $ id_agent_change ) ;
if ( $ id_agent_module_exist != - 1 ) {
print_log "[ERROR] A module called '$module_name' already exist in the agent '$new_value'\n\n" ;
exit ;
}
$ field = 'id_agente' ;
$ new_value = $ id_agent_change ;
}
elsif ( $ field eq 'module_name' ) {
my $ id_agent_module_change = get_agent_module_id ( $ dbh , $ new_value , $ id_agent ) ;
if ( $ id_agent_module_change != - 1 ) {
print_log "[ERROR] A module called '$new_value' already exist in the agent '$agent_name'\n\n" ;
exit ;
}
$ field = 'nombre' ;
$ new_value = safe_input ( $ new_value ) ;
}
elsif ( $ field eq 'description' ) {
$ field = 'descripcion' ;
$ new_value = safe_input ( $ new_value ) ;
}
elsif ( $ field eq 'module_group' ) {
my $ module_group_id = get_module_group_id ( $ dbh , $ new_value ) ;
if ( $ module_group_id == - 1 ) {
2022-05-05 11:47:49 +02:00
print_log "[ERROR] Module group '$new_value' doesn't exist\n\n" ;
2019-10-17 11:14:42 +02:00
exit ;
}
$ field = 'id_module_group' ;
$ new_value = $ module_group_id ;
}
elsif ( $ field eq 'enable_unknown_events' ) {
my $ disabled_types_event = { } ;
if ( $ new_value ) {
$ disabled_types_event - > { 'going_unknown' } = 0 ;
}
else {
$ disabled_types_event - > { 'going_unknown' } = 1 ;
}
$ field = 'disabled_types_event' ;
$ new_value = encode_json ( $ disabled_types_event ) ;
}
elsif ( $ field eq 'ff_threshold' ) {
$ field = 'min_ff_event' ;
}
elsif ( $ field eq 'each_ff' ) {
$ field = 'each_ff' ;
2012-01-16 15:55:55 +01:00
}
2019-10-17 11:14:42 +02:00
elsif ( $ field eq 'ff_threshold_normal' ) {
$ field = 'min_ff_event_normal' ;
2012-01-16 15:55:55 +01:00
}
2019-10-17 11:14:42 +02:00
elsif ( $ field eq 'ff_threshold_warning' ) {
$ field = 'min_ff_event_warning' ;
2012-01-16 15:55:55 +01:00
}
2019-10-17 11:14:42 +02:00
elsif ( $ field eq 'ff_threshold_critical' ) {
$ field = 'min_ff_event_critical' ;
}
elsif ( $ field eq 'critical_instructions' ) {
$ field = 'critical_instructions' ;
}
elsif ( $ field eq 'warning_instructions' ) {
$ field = 'warning_instructions' ;
}
elsif ( $ field eq 'unknown_instructions' ) {
$ field = 'unknown_instructions' ;
2012-01-16 15:55:55 +01:00
}
else {
2019-10-17 11:14:42 +02:00
# If is not a common value, check type and call type update funtion
my $ type = pandora_get_module_type ( $ dbh , $ id_agent_module ) ;
my % field_value ;
$ field_value { 'field' } = $ field ;
$ field_value { 'new_value' } = $ new_value ;
if ( $ type eq 'data' ) {
pandora_check_data_module_fields ( \ % field_value ) ;
}
elsif ( $ type eq 'network' ) {
pandora_check_network_module_fields ( \ % field_value ) ;
}
elsif ( $ type eq 'snmp' ) {
pandora_check_snmp_module_fields ( \ % field_value ) ;
}
elsif ( $ type eq 'plugin' ) {
pandora_check_plugin_module_fields ( \ % field_value ) ;
}
else {
print_log "[ERROR] The field '$field' is not available for this type of module\n\n" ;
}
$ field = $ field_value { 'field' } ;
$ new_value = $ field_value { 'new_value' } ;
2012-01-16 15:55:55 +01:00
}
2019-10-17 11:14:42 +02:00
print_log "[INFO] Updating field '$field' in module '$module_name' of agent '$agent_name' with new value '$new_value'\n\n" ;
my $ update ;
$ update - > { $ field } = $ new_value ;
2015-12-17 17:43:17 +01:00
2019-10-17 11:14:42 +02:00
my $ policy_id = enterprise_hook ( 'get_id_policy_module_agent_module' , [ $ dbh , safe_input ( $ id_agent_module ) ] ) ;
if ( $ policy_id > 0 ) {
$ update - > { policy_linked } = 0 ;
}
pandora_update_module_from_hash ( $ conf , $ update , 'id_agente_modulo' , $ id_agent_module , $ dbh ) ;
2015-12-17 17:43:17 +01:00
}
2012-01-16 15:55:55 +01:00
}
2012-01-17 10:30:52 +01:00
##############################################################################
# Exec a CLI option from file
# Related option: --exec_from_file
##############################################################################
sub cli_exec_from_file () {
my $ c = 0 ;
my $ command = $ 0 ;
my $ file ;
foreach my $ opt ( @ ARGV ) {
$ c + + ;
# First and second are the script and conf paths
if ( $ c < 2 ) {
$ command = "$command $opt" ;
}
# Third param is ignored, because is --exec_from_file
# Fourth param is the file path
elsif ( $ c == 3 ) {
$ file = $ opt ;
if ( ! ( - e $ file ) ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] File '$file' not exists or cannot be opened\n\n" ;
2012-01-17 10:30:52 +01:00
exit ;
}
}
# Fifth parameter is the option (we add -- before it)
elsif ( $ c == 4 ) {
$ command = "$command --$opt" ;
}
# Next parameters are the option params, we add quotes to them to avoid errors
elsif ( $ c > 4 ) {
if ( $ opt =~ m/\s/g ) {
$ command = $ command . ' "' . $ opt . '"' ;
}
else {
$ command = $ command . ' ' . $ opt ;
}
}
}
open ( FILE , $ file ) ;
while ( <FILE> ) {
my $ command_tr = $ command ;
chomp ;
my @ fields = split ( ',' , $ _ ) ;
$ c = 0 ;
foreach my $ field ( @ fields ) {
$ c + + ;
my $ macro_name = "__FIELD" . $ c . "__" ;
if ( $ field =~ m/\s/g && $ field !~ m/^"/ ) {
$ field = '"' . $ field . '"' ;
}
$ command_tr !~ s/$macro_name/$field/g ;
}
print `./$command_tr` ;
}
close ( FILE ) ;
exit ;
}
2012-01-16 15:55:55 +01:00
##############################################################################
# Return the type of given module (data, network, snmp or plugin)
##############################################################################
sub pandora_get_module_type ($$) {
my ( $ dbh , $ id_agent_module ) = @ _ ;
my $ id_modulo = get_db_value ( $ dbh , 'SELECT id_modulo FROM tagente_modulo WHERE id_agente_modulo = ?' , $ id_agent_module ) ;
if ( $ id_modulo == 1 ) {
return 'data' ;
}
if ( $ id_modulo == 2 ) {
my $ id_module_type = get_db_value ( $ dbh , 'SELECT id_tipo_modulo FROM tagente_modulo WHERE id_agente_modulo = ?' , $ id_agent_module ) ;
if ( $ id_module_type >= 15 && $ id_module_type <= 18 ) {
return 'snmp' ;
}
else {
return 'network' ;
}
}
elsif ( $ id_modulo == 4 ) {
return 'plugin' ;
}
elsif ( $ id_modulo == 6 ) {
return 'wmi' ;
}
elsif ( $ id_modulo == 7 ) {
return 'web' ;
}
else {
return 'unknown' ;
}
}
2012-01-05 13:11:03 +01:00
##############################################################################
# Add a profile to a User in a Group
# Related option: --add_profile_to_user
##############################################################################
sub cli_user_add_profile () {
my ( $ user_id , $ profile_name , $ group_name ) = @ ARGV [ 2 .. 4 ] ;
my $ user_exists = get_user_exists ( $ dbh , $ user_id ) ;
exist_check ( $ user_exists , 'user' , $ user_id ) ;
my $ profile_id = get_profile_id ( $ dbh , $ profile_name ) ;
exist_check ( $ profile_id , 'profile' , $ profile_name ) ;
my $ group_id = 0 ;
# If group name is not defined, we assign group All (0)
if ( defined ( $ group_name ) ) {
$ group_id = get_group_id ( $ dbh , $ group_name ) ;
exist_check ( $ group_id , 'group' , $ group_name ) ;
}
else {
$ group_name = 'All' ;
}
2012-12-28 09:26:49 +01:00
print_log "[INFO] Adding profile '$profile_name' to user '$user_id' in group '$group_name'\n\n" ;
2012-01-05 13:11:03 +01:00
pandora_add_profile_to_user ( $ dbh , $ user_id , $ profile_id , $ group_id ) ;
}
2011-11-14 14:27:21 +01:00
##############################################################################
# Delete a user.
# Related option: --delete_user
##############################################################################
sub cli_delete_user () {
my $ user_name = @ ARGV [ 2 ] ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] Deleting user '$user_name' \n\n" ;
2011-11-14 14:27:21 +01:00
my $ result = pandora_delete_user ( $ dbh , $ user_name ) ;
exist_check ( $ result , 'user' , $ user_name ) ;
}
2012-01-13 10:43:29 +01:00
##############################################################################
# Delete an alert_template.
# Related option: --delete_user
##############################################################################
sub cli_delete_alert_template () {
my $ template_name = @ ARGV [ 2 ] ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] Deleting template '$template_name' \n\n" ;
2012-01-13 10:43:29 +01:00
my $ result = pandora_delete_alert_template ( $ dbh , $ template_name ) ;
exist_check ( $ result , 'alert template' , $ template_name ) ;
}
2018-12-03 17:38:57 +01:00
##############################################################################
# Add alert command.
# Related option: --create_alert_command
##############################################################################
sub cli_create_alert_command () {
my ( $ command_name , $ command , $ group_name , $ description , $ internal , $ fields_descriptions , $ fields_values ) = @ ARGV [ 2 .. 8 ] ;
print_log "[INFO] Adding command '$command_name'\n\n" ;
my $ command_id = get_command_id ( $ dbh , $ command_name ) ;
non_exist_check ( $ command_id , 'command' , $ command_name ) ;
my $ id_group ;
if ( ! $ group_name || $ group_name eq "All" ) {
$ id_group = 0 ;
}
else {
$ id_group = get_group_id ( $ dbh , $ group_name ) ;
exist_check ( $ id_group , 'group' , $ group_name ) ;
}
my % parameters ;
$ parameters { 'name' } = $ command_name ;
$ parameters { 'command' } = $ command ;
$ parameters { 'id_group' } = $ id_group ;
$ parameters { 'description' } = $ description ;
$ parameters { 'internal' } = $ internal ;
$ parameters { 'fields_descriptions' } = $ fields_descriptions ;
$ parameters { 'fields_values' } = $ fields_values ;
pandora_create_alert_command ( $ conf , \ % parameters , $ dbh ) ;
}
##############################################################################
# Show all the alert commands (without parameters) or the alert commands with a filter parameters
# Related option: --get_alert_commands
##############################################################################
sub cli_get_alert_commands () {
my ( $ command_name , $ command , $ group_name , $ description , $ internal ) = @ ARGV [ 2 .. 6 ] ;
my $ id_group ;
my $ condition = ' 1=1 ' ;
if ( $ command_name ne '' ) {
my $ name = safe_input ( $ command_name ) ;
$ condition . = " AND name LIKE '%$name%' " ;
}
if ( $ command ne '' ) {
$ condition . = " AND command LIKE '%$command%' " ;
}
if ( $ group_name ne '' ) {
$ id_group = get_group_id ( $ dbh , $ group_name ) ;
exist_check ( $ id_group , 'group' , $ group_name ) ;
2019-01-29 17:40:25 +01:00
$ condition . = " AND id_group = $id_group " ;
2018-12-03 17:38:57 +01:00
}
if ( $ description ne '' ) {
$ condition . = " AND description LIKE '%$description%' " ;
}
if ( $ internal ne '' ) {
$ condition . = " AND internal = $internal " ;
}
my @ alert_command = get_db_rows ( $ dbh , "SELECT * FROM talert_commands WHERE $condition" ) ;
if ( scalar ( @ alert_command ) == 0 ) {
print_log "[INFO] No commands found\n\n" ;
exit ;
}
my $ head_print = 0 ;
foreach my $ commands ( @ alert_command ) {
if ( $ head_print == 0 ) {
$ head_print = 1 ;
print "id_command, command_name\n" ;
}
print $ commands - > { 'id' } . "," . safe_output ( $ commands - > { 'name' } ) . "\n" ;
}
if ( $ head_print == 0 ) {
print_log "[INFO] No commands found\n\n" ;
}
2019-01-29 17:16:47 +01:00
}
2018-12-03 17:38:57 +01:00
2018-12-14 17:20:46 +01:00
##############################################################################
# Get alert actions.
# Related option: --get_alert_actions
##############################################################################
sub cli_get_alert_actions () {
my ( $ action_name , $ separator , $ return_type ) = @ ARGV [ 2 .. 4 ] ;
if ( $ return_type eq '' ) {
$ return_type = 'csv' ;
}
my $ result = api_call ( \ % conf , 'get' , 'alert_actions' , undef , undef , "$action_name|$separator" , $ return_type ) ;
print "$result \n\n " ;
}
##############################################################################
# Get alert actions in nodes.
# Related option: --get_alert_actions_meta
##############################################################################
sub cli_get_alert_actions_meta () {
my ( $ server_name , $ action_name , $ separator , $ return_type ) = @ ARGV [ 2 .. 5 ] ;
if ( $ return_type eq '' ) {
$ return_type = 'csv' ;
}
my $ result = api_call ( \ % conf , 'get' , 'alert_actions_meta' , undef , undef , "$server_name|$action_name|$separator" , $ return_type ) ;
print "$result \n\n " ;
}
2011-11-14 14:27:21 +01:00
##############################################################################
2016-06-06 15:18:46 +02:00
# Add profile.
# Related option: --add_profile
2011-11-14 14:27:21 +01:00
##############################################################################
2016-06-06 15:18:46 +02:00
sub cli_add_profile () {
2011-11-14 14:27:21 +01:00
my ( $ user_name , $ profile_name , $ group_name ) = @ ARGV [ 2 .. 4 ] ;
my $ id_profile = get_profile_id ( $ dbh , $ profile_name ) ;
exist_check ( $ id_profile , 'profile' , $ profile_name ) ;
my $ id_group ;
if ( $ group_name eq "All" ) {
$ id_group = 0 ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] Adding profile '$profile_name' to all groups for user '$user_name') \n\n" ;
2011-11-14 14:27:21 +01:00
}
else {
$ id_group = get_group_id ( $ dbh , $ group_name ) ;
exist_check ( $ id_group , 'group' , $ group_name ) ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] Adding profile '$profile_name' to group '$group_name' for user '$user_name') \n\n" ;
2011-11-14 14:27:21 +01:00
}
pandora_create_user_profile ( $ dbh , $ user_name , $ id_profile , $ id_group ) ;
}
2016-06-06 15:18:46 +02:00
##############################################################################
# Create profile.
# Related option: --create_profile
##############################################################################
sub cli_create_profile () {
2021-05-13 13:33:45 +02:00
my ( $ profile_name , $ agent_view ,
2016-06-06 15:18:46 +02:00
$ agent_edit , $ agent_disable , $ alert_edit , $ alert_management , $ user_management , $ db_management ,
$ event_view , $ event_edit , $ event_management , $ report_view , $ report_edit , $ report_management ,
$ map_view , $ map_edit , $ map_management , $ vconsole_view , $ vconsole_edit , $ vconsole_management , $ pandora_management ) = @ ARGV [ 2 .. 25 ] ;
my $ id_profile = get_profile_id ( $ dbh , $ profile_name ) ;
non_exist_check ( $ id_profile , 'profile' , $ profile_name ) ;
2021-05-13 13:33:45 +02:00
pandora_create_profile ( $ dbh , $ profile_name , $ agent_view ,
2016-06-06 15:18:46 +02:00
$ agent_edit , $ agent_disable , $ alert_edit , $ alert_management , $ user_management , $ db_management ,
$ event_view , $ event_edit , $ event_management , $ report_view , $ report_edit , $ report_management ,
$ map_view , $ map_edit , $ map_management , $ vconsole_view , $ vconsole_edit , $ vconsole_management , $ pandora_management ) ;
}
2021-04-14 04:07:13 +02:00
##############################################################################
## Update profile.
## Related option: --update_profile
##############################################################################
#
sub cli_update_profile () {
2021-05-13 13:33:45 +02:00
my ( $ profile_name , $ agent_view ,
2021-04-14 04:07:13 +02:00
$ agent_edit , $ agent_disable , $ alert_edit , $ alert_management , $ user_management , $ db_management ,
$ event_view , $ event_edit , $ event_management , $ report_view , $ report_edit , $ report_management ,
$ map_view , $ map_edit , $ map_management , $ vconsole_view , $ vconsole_edit , $ vconsole_management , $ pandora_management ) = @ ARGV [ 2 .. 25 ] ;
my $ id_profile = get_profile_id ( $ dbh , $ profile_name ) ;
exist_check ( $ id_profile , 'profile' , $ profile_name ) ;
2021-05-13 13:33:45 +02:00
pandora_update_profile ( $ dbh , $ profile_name , $ agent_view ,
2021-04-14 04:07:13 +02:00
$ agent_edit , $ agent_disable , $ alert_edit , $ alert_management , $ user_management , $ db_management ,
$ event_view , $ event_edit , $ event_management , $ report_view , $ report_edit , $ report_management ,
$ map_view , $ map_edit , $ map_management , $ vconsole_view , $ vconsole_edit , $ vconsole_management , $ pandora_management ) ;
}
2011-11-14 14:27:21 +01:00
##############################################################################
# Delete profile.
# Related option: --delete_profile
##############################################################################
sub cli_delete_profile () {
my ( $ user_name , $ profile_name , $ group_name ) = @ ARGV [ 2 .. 4 ] ;
my $ id_profile = get_profile_id ( $ dbh , $ profile_name ) ;
exist_check ( $ id_profile , 'profile' , $ profile_name ) ;
my $ id_group ;
if ( $ group_name eq "All" ) {
$ id_group = 0 ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] Deleting profile '$profile_name' from all groups for user '$user_name') \n\n" ;
2011-11-14 14:27:21 +01:00
}
else {
$ id_group = get_group_id ( $ dbh , $ group_name ) ;
exist_check ( $ id_group , 'group' , $ group_name ) ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] Deleting profile '$profile_name' from group '$group_name' for user '$user_name') \n\n" ;
2011-11-14 14:27:21 +01:00
}
pandora_delete_user_profile ( $ dbh , $ user_name , $ id_profile , $ id_group ) ;
}
##############################################################################
2012-01-16 15:55:55 +01:00
# Create event
2011-11-14 14:27:21 +01:00
# Related option: --create_event
##############################################################################
sub cli_create_event () {
2022-03-23 14:24:39 +01:00
my ( $ event , $ event_type , $ group_name , $ agent_name , $ module_name , $ event_status , $ severity , $ template_name , $ user_name , $ comment , $ source , $ id_extra , $ tags , $ custom_data , $ force_create_agent , $ c_instructions , $ w_instructions , $ u_instructions , $ use_alias , $ server_id ) = @ ARGV [ 2 .. 21 ] ;
2011-11-14 14:27:21 +01:00
$ event_status = 0 unless defined ( $ event_status ) ;
$ severity = 0 unless defined ( $ severity ) ;
2012-02-14 15:53:22 +01:00
my $ id_user ;
2017-08-22 10:43:22 +02:00
if ( ! defined ( $ user_name ) || $ user_name eq '' ) {
2012-02-14 15:53:22 +01:00
$ id_user = 0 ;
}
else {
$ id_user = pandora_get_user_id ( $ dbh , $ user_name ) ;
exist_check ( $ id_user , 'user' , $ user_name ) ;
}
2011-11-14 14:27:21 +01:00
my $ id_group ;
2016-04-28 07:06:23 +02:00
if ( ! $ group_name || $ group_name eq "All" ) {
2011-11-14 14:27:21 +01:00
$ id_group = 0 ;
}
else {
$ id_group = get_group_id ( $ dbh , $ group_name ) ;
exist_check ( $ id_group , 'group' , $ group_name ) ;
}
my $ id_agent ;
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
my @ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
if ( ! $ agent_name ) {
$ id_agent = 0 ;
}
else {
$ id_agent = $ id - > { 'id_agente' } ;
}
my $ id_agentmodule ;
if ( ! $ module_name ) {
$ id_agentmodule = 0 ;
}
else {
$ id_agentmodule = get_agent_module_id ( $ dbh , $ module_name , $ id_agent ) ;
if ( $ id_agentmodule eq - 1 ) {
next ;
}
}
my $ id_alert_agent_module ;
if ( defined ( $ template_name ) && $ template_name ne '' ) {
my $ id_template = get_template_id ( $ dbh , $ template_name ) ;
exist_check ( $ id_template , 'template' , $ template_name ) ;
$ id_alert_agent_module = get_template_module_id ( $ dbh , $ id_agentmodule , $ id_template ) ;
exist_check ( $ id_alert_agent_module , 'alert template module' , $ template_name ) ;
}
else {
$ id_alert_agent_module = 0 ;
}
print_log "[INFO] Adding event '$event' for agent '$agent_name' \n\n" ;
pandora_event ( $ conf , $ event , $ id_group , $ id_agent , $ severity ,
2022-03-23 14:24:39 +01:00
$ id_alert_agent_module , $ id_agentmodule , $ event_type , $ event_status , $ dbh , $ source , $ user_name , safe_input ( $ comment ) , $ id_extra , $ tags , $ c_instructions , $ w_instructions , $ u_instructions , $ custom_data , undef , undef , $ server_id ) ;
2019-10-17 11:14:42 +02:00
}
} else {
if ( ! $ agent_name ) {
$ id_agent = 0 ;
}
else {
$ id_agent = get_agent_id ( $ dbh , $ agent_name ) ;
# exist_check($id_agent,'agent',$agent_name);
if ( $ id_agent == - 1 ) {
if ( $ force_create_agent == 1 ) {
pandora_create_agent ( $ conf , '' , $ agent_name , '' , '' , '' , '' , 'Created by cli_create_event' , '' , $ dbh ) ;
print_log "[INFO] Adding agent '$agent_name' \n\n" ;
$ id_agent = get_agent_id ( $ dbh , $ agent_name ) ;
}
else {
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
}
2017-08-22 10:43:22 +02:00
}
2019-10-17 11:14:42 +02:00
}
my $ id_agentmodule ;
if ( ! $ module_name ) {
$ id_agentmodule = 0 ;
2017-08-22 10:43:22 +02:00
}
2019-10-17 11:14:42 +02:00
else {
$ id_agentmodule = get_agent_module_id ( $ dbh , $ module_name , $ id_agent ) ;
exist_check ( $ id_agentmodule , 'module' , $ module_name ) ;
}
my $ id_alert_agent_module ;
if ( defined ( $ template_name ) && $ template_name ne '' ) {
my $ id_template = get_template_id ( $ dbh , $ template_name ) ;
exist_check ( $ id_template , 'template' , $ template_name ) ;
$ id_alert_agent_module = get_template_module_id ( $ dbh , $ id_agentmodule , $ id_template ) ;
exist_check ( $ id_alert_agent_module , 'alert template module' , $ template_name ) ;
}
else {
$ id_alert_agent_module = 0 ;
}
print_log "[INFO] Adding event '$event' for agent '$agent_name' \n\n" ;
2017-08-22 10:43:22 +02:00
2019-10-17 11:14:42 +02:00
pandora_event ( $ conf , $ event , $ id_group , $ id_agent , $ severity ,
2022-03-23 14:24:39 +01:00
$ id_alert_agent_module , $ id_agentmodule , $ event_type , $ event_status , $ dbh , $ source , $ user_name , safe_input ( $ comment ) , $ id_extra , $ tags , $ c_instructions , $ w_instructions , $ u_instructions , $ custom_data , undef , undef , $ server_id ) ;
2013-09-09 18:09:34 +02:00
2019-10-17 11:14:42 +02:00
}
2011-11-14 14:27:21 +01:00
}
##############################################################################
# Validate event.
# Related option: --validate_event
##############################################################################
sub cli_validate_event () {
2019-10-17 11:14:42 +02:00
my ( $ agent_name , $ module_name , $ datetime_min , $ datetime_max , $ user_name , $ criticity , $ template_name , $ use_alias ) = @ ARGV [ 2 .. 9 ] ;
2011-11-14 14:27:21 +01:00
my $ id_agent = '' ;
my $ id_agentmodule = '' ;
if ( defined ( $ datetime_min ) && $ datetime_min ne '' ) {
if ( $ datetime_min !~ /([0-9]{2,4})\-([0-1][0-9])\-([0-3][0-9]) +([0-2][0-9]):([0-5][0-9])/ ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] Invalid datetime_min format. (Correct format: YYYY-MM-DD HH:mm)\n" ;
2011-11-14 14:27:21 +01:00
exit ;
}
# Add the seconds
$ datetime_min . = ":00" ;
}
if ( defined ( $ datetime_max ) && $ datetime_max ne '' ) {
if ( $ datetime_max !~ /([0-9]{2,4})\-([0-1][0-9])\-([0-3][0-9]) +([0-2][0-9]):([0-5][0-9])/ ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] Invalid datetime_max $datetime_max. (Correct format: YYYY-MM-DD HH:mm)\n" ;
2011-11-14 14:27:21 +01:00
exit ;
}
# Add the seconds
$ datetime_max . = ":00" ;
}
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
my @ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
if ( defined ( $ agent_name ) && $ agent_name ne '' ) {
$ id_agent = $ id - > { 'id_agente' } ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
2011-11-14 14:27:21 +01:00
2019-10-17 11:14:42 +02:00
if ( $ module_name ne '' ) {
$ id_agentmodule = get_agent_module_id ( $ dbh , $ module_name , $ id_agent ) ;
if ( $ id_agentmodule eq - 1 ) {
next ;
}
}
}
my $ id_alert_agent_module = '' ;
if ( defined ( $ template_name ) && $ template_name ne '' ) {
my $ id_template = get_template_id ( $ dbh , $ template_name ) ;
exist_check ( $ id_template , 'template' , $ template_name ) ;
$ id_alert_agent_module = get_template_module_id ( $ dbh , $ id_agentmodule , $ id_template ) ;
exist_check ( $ id_alert_agent_module , 'template module' , $ template_name ) ;
}
pandora_validate_event_filter ( $ conf , $ id_agentmodule , $ id_agent , $ datetime_min , $ datetime_max , $ user_name , $ id_alert_agent_module , $ criticity , $ dbh ) ;
print_log "[INFO] Validating event for agent '$id->{'nombre'}'\n\n" ;
}
} else {
if ( defined ( $ agent_name ) && $ agent_name ne '' ) {
$ id_agent = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
if ( $ module_name ne '' ) {
$ id_agentmodule = get_agent_module_id ( $ dbh , $ module_name , $ id_agent ) ;
exist_check ( $ id_agentmodule , 'module' , $ module_name ) ;
}
}
my $ id_alert_agent_module = '' ;
if ( defined ( $ template_name ) && $ template_name ne '' ) {
my $ id_template = get_template_id ( $ dbh , $ template_name ) ;
exist_check ( $ id_template , 'template' , $ template_name ) ;
$ id_alert_agent_module = get_template_module_id ( $ dbh , $ id_agentmodule , $ id_template ) ;
exist_check ( $ id_alert_agent_module , 'template module' , $ template_name ) ;
}
pandora_validate_event_filter ( $ conf , $ id_agentmodule , $ id_agent , $ datetime_min , $ datetime_max , $ user_name , $ id_alert_agent_module , $ criticity , $ dbh ) ;
print_log "[INFO] Validating event for agent '$agent_name'\n\n" ;
}
2011-11-14 14:27:21 +01:00
}
2012-02-10 10:30:21 +01:00
##############################################################################
# Validate event.
# Related option: --validate_event_id
##############################################################################
sub cli_validate_event_id () {
my $ id_event = @ ARGV [ 2 ] ;
2012-02-13 15:07:02 +01:00
my $ event_name = pandora_get_event_name ( $ dbh , $ id_event ) ;
exist_check ( $ event_name , 'event' , $ id_event ) ;
2012-02-10 10:30:21 +01:00
2012-12-28 09:26:49 +01:00
print_log "[INFO] Validating event '$id_event'\n\n" ;
2012-02-10 10:30:21 +01:00
my $ result = pandora_validate_event_id ( $ conf , $ id_event , $ dbh ) ;
exist_check ( $ result , 'event' , $ id_event ) ;
}
2012-02-13 18:35:54 +01:00
###############################################################################
# Get event info
# Related option: --get_event_info
###############################################################################
sub cli_get_event_info () {
my ( $ id_event , $ csv_separator ) = @ ARGV [ 2 .. 3 ] ;
my $ event_name = pandora_get_event_name ( $ dbh , $ id_event ) ;
exist_check ( $ event_name , 'event' , $ id_event ) ;
2012-02-14 11:50:25 +01:00
$ csv_separator = '|' unless defined ( $ csv_separator ) ;
2017-07-18 11:36:57 +02:00
2022-05-31 12:50:43 +02:00
my $ query = "SELECT * FROM tevento WHERE id_evento=" . $ id_event ;
2012-02-13 18:35:54 +01:00
my $ header = "Event ID" . $ csv_separator . "Event name" . $ csv_separator . "Agent ID" . $ csv_separator . "User ID" . $ csv_separator .
"Group ID" . $ csv_separator . "Status" . $ csv_separator . "Timestamp" . $ csv_separator . "Event type" . $ csv_separator .
"Agent module ID" . $ csv_separator . "Alert module ID" . $ csv_separator . "Criticity" . $ csv_separator .
"Comment" . $ csv_separator . "Tags" . $ csv_separator . "Source" . $ csv_separator . "Extra ID" . "\n" ;
print $ header ;
my @ result = get_db_single_row ( $ dbh , $ query ) ;
foreach my $ event_data ( @ result ) {
print $ event_data - > { 'id_evento' } ;
print $ csv_separator ;
print $ event_data - > { 'evento' } ;
print $ csv_separator ;
print $ event_data - > { 'id_agente' } ;
print $ csv_separator ;
print $ event_data - > { 'id_usuario' } ;
print $ csv_separator ;
print $ event_data - > { 'id_grupo' } ;
print $ csv_separator ;
print $ event_data - > { 'estado' } ;
print $ csv_separator ;
print $ event_data - > { 'timestamp' } ;
print $ csv_separator ;
print $ event_data - > { 'event_type' } ;
print $ csv_separator ;
print $ event_data - > { 'id_agentmodule' } ;
print $ csv_separator ;
print $ event_data - > { 'id_alert_am' } ;
print $ csv_separator ;
print $ event_data - > { 'criticity' } ;
print $ csv_separator ;
print $ event_data - > { 'user_comment' } ;
print $ csv_separator ;
print $ event_data - > { 'tags' } ;
print $ csv_separator ;
print $ event_data - > { 'source' } ;
print $ csv_separator ;
print $ event_data - > { 'id_extra' } ;
print "\n" ;
}
exit ;
}
2014-08-21 02:39:25 +02:00
###############################################################################
# Add event comment
# Related option: --add_event_comment
###############################################################################
sub cli_add_event_comment () {
my ( $ id_event , $ user_name , $ comment ) = @ ARGV [ 2 .. 4 ] ;
2014-10-15 17:02:49 +02:00
2014-08-21 02:39:25 +02:00
my $ id_user ;
if ( ! defined ( $ user_name ) || $ user_name eq '' ) {
$ id_user = 'admin' ;
}
else {
2022-11-04 12:36:44 +01:00
$ id_user = pandora_get_user_id ( $ dbh , safe_input ( $ user_name ) ) ;
2014-08-21 02:39:25 +02:00
exist_check ( $ id_user , 'user' , $ user_name ) ;
}
2014-10-15 17:02:49 +02:00
2014-08-21 02:39:25 +02:00
my $ event_name = pandora_get_event_name ( $ dbh , $ id_event ) ;
exist_check ( $ event_name , 'event' , $ id_event ) ;
2014-10-15 17:02:49 +02:00
2014-08-21 02:39:25 +02:00
my $ current_comment = encode_utf8 ( pandora_get_event_comment ( $ dbh , $ id_event ) ) ;
my $ utimestamp = time ( ) ;
2022-11-04 12:36:44 +01:00
my @ additional_comment = ( { comment = > safe_input ( $ comment ) , action = > "Added comment" , id_user = > $ id_user , utimestamp = > $ utimestamp , event_id = > $ id_event } ) ;
2014-10-15 17:02:49 +02:00
2014-08-21 02:39:25 +02:00
print_log "[INFO] Adding event comment for event '$id_event'. \n\n" ;
2014-10-15 17:02:49 +02:00
2014-08-21 02:39:25 +02:00
my $ decoded_comment ;
my $ update ;
if ( $ current_comment eq '' ) {
$ update - > { 'user_comment' } = encode_json \ @ additional_comment ;
}
else {
$ decoded_comment = decode_json ( $ current_comment ) ;
2014-10-15 17:02:49 +02:00
push ( @ { $ decoded_comment } , @ additional_comment ) ;
$ update - > { 'user_comment' } = encode_json ( $ decoded_comment ) ;
2014-08-21 02:39:25 +02:00
}
2014-10-15 17:02:49 +02:00
2014-08-21 02:39:25 +02:00
pandora_update_event_from_hash ( $ update , 'id_evento' , $ id_event , $ dbh ) ;
}
2011-11-14 14:27:21 +01:00
##############################################################################
# Delete data.
# Related option: --delete_data
##############################################################################
sub cli_delete_data ($) {
my $ ltotal = shift ;
2019-10-17 11:14:42 +02:00
my ( $ opt , $ name , $ name2 , $ use_alias ) = @ ARGV [ 2 .. 5 ] ;
2011-11-14 14:27:21 +01:00
if ( $ opt eq '-m' || $ opt eq '--m' ) {
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
my @ id_agents = get_agent_ids_from_alias ( $ dbh , $ name2 ) ;
foreach my $ id ( @ id_agents ) {
# Delete module data
param_check ( $ ltotal , 3 ) unless ( $ name2 ne '' ) ;
my $ id_agent = $ id - > { 'id_agente' } ;
exist_check ( $ id_agent , 'agent' , $ name2 ) ;
my $ id_module = get_agent_module_id ( $ dbh , $ name , $ id_agent ) ;
exist_check ( $ id_module , 'module' , $ name ) ;
print_log "DELETING THE DATA OF THE MODULE $name OF THE AGENT $name2\n\n" ;
2019-10-28 09:48:52 +01:00
pandora_delete_data ( $ dbh , 'module' , $ id_module ) ;
2019-10-17 11:14:42 +02:00
}
} else {
# Delete module data
param_check ( $ ltotal , 3 ) unless ( $ name2 ne '' ) ;
my $ id_agent = get_agent_id ( $ dbh , $ name2 ) ;
exist_check ( $ id_agent , 'agent' , $ name2 ) ;
my $ id_module = get_agent_module_id ( $ dbh , $ name , $ id_agent ) ;
exist_check ( $ id_module , 'module' , $ name ) ;
2011-11-14 14:27:21 +01:00
2019-10-17 11:14:42 +02:00
print_log "DELETING THE DATA OF THE MODULE $name OF THE AGENT $name2\n\n" ;
pandora_delete_data ( $ dbh , 'module' , $ id_module ) ;
}
2011-11-14 14:27:21 +01:00
}
elsif ( $ opt eq '-a' || $ opt eq '--a' ) {
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
my @ id_agents = get_agent_ids_from_alias ( $ dbh , $ name ) ;
foreach my $ id ( @ id_agents ) {
# Delete agent's modules data
my $ id_agent = $ id - > { 'id_agente' } ;
exist_check ( $ id_agent , 'agent' , $ name ) ;
2011-11-14 14:27:21 +01:00
2019-10-17 11:14:42 +02:00
print_log "DELETING THE DATA OF THE AGENT $name\n\n" ;
2011-11-14 14:27:21 +01:00
2019-11-04 16:04:26 +01:00
pandora_delete_data ( $ dbh , 'agent' , $ id_agent ) ;
2019-10-17 11:14:42 +02:00
}
} else {
my $ id_agent = get_agent_id ( $ dbh , $ name ) ;
exist_check ( $ id_agent , 'agent' , $ name ) ;
2011-11-14 14:27:21 +01:00
2019-10-17 11:14:42 +02:00
print_log "DELETING THE DATA OF THE AGENT $name\n\n" ;
2011-11-14 14:27:21 +01:00
2019-11-04 16:04:26 +01:00
pandora_delete_data ( $ dbh , 'agent' , $ id_agent ) ;
2019-10-17 11:14:42 +02:00
}
}
elsif ( $ opt eq '-g' || $ opt eq '--g' ) {
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
my @ id_agents = get_agent_ids_from_alias ( $ dbh , $ name ) ;
foreach my $ id ( @ id_agents ) {
# Delete group's modules data
my $ id_group = $ id - > { 'id_agente' } ;
exist_check ( $ id_group , 'group' , $ name ) ;
print_log "DELETING THE DATA OF THE GROUP $name\n\n" ;
pandora_delete_data ( $ dbh , 'group' , $ id_group ) ;
}
} else {
# Delete group's modules data
my $ id_group = get_group_id ( $ dbh , $ name ) ;
exist_check ( $ id_group , 'group' , $ name ) ;
print_log "DELETING THE DATA OF THE GROUP $name\n\n" ;
pandora_delete_data ( $ dbh , 'group' , $ id_group ) ;
}
2011-11-14 14:27:21 +01:00
}
else {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] Invalid parameter '$opt'.\n\n" ;
2011-11-14 14:27:21 +01:00
help_screen ( ) ;
exit ;
}
}
##############################################################################
# Add policy to apply queue.
2012-01-17 14:10:54 +01:00
# Related option: --apply_policy
2011-11-14 14:27:21 +01:00
##############################################################################
sub cli_apply_policy () {
2019-02-27 10:28:36 +01:00
my ( $ id_policy , $ id_agent , $ name , $ id_server ) = @ ARGV [ 2 .. 5 ] ;
2019-01-29 15:30:04 +01:00
# Call the API.
2019-02-27 10:28:36 +01:00
my $ result = api_call ( \ % conf , 'set' , 'apply_policy' , $ id_policy , $ id_agent , "$name|$id_server" ) ;
2019-01-29 15:30:04 +01:00
print "\n$result\n" ;
2011-11-14 14:27:21 +01:00
}
2012-01-17 14:10:54 +01:00
##############################################################################
# Add all policies to apply queue.
# Related option: --apply_all_policies
##############################################################################
sub cli_apply_all_policies () {
my $ policies = enterprise_hook ( 'get_policies' , [ $ dbh , 0 ] ) ;
my $ npolicies = scalar ( @ { $ policies } ) ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] $npolicies policies found\n\n" ;
2012-01-17 14:10:54 +01:00
my $ added = 0 ;
foreach my $ policy ( @ { $ policies } ) {
2019-02-18 16:58:04 +01:00
my $ ret = enterprise_hook ( 'pandora_add_policy_queue' , [ $ dbh , $ conf , $ policy - > { 'id' } , 'apply' , 0 , 1 ] ) ;
2012-01-17 14:10:54 +01:00
if ( $ ret != - 1 ) {
$ added + + ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] Added operation 'apply' to policy '" . safe_output ( $ policy - > { 'name' } ) . "'\n" ;
2012-01-17 14:10:54 +01:00
}
}
if ( $ npolicies > $ added ) {
my $ failed = $ npolicies - $ added ;
2012-12-28 09:26:49 +01:00
print_log "[ERROR] $failed policies cannot be added to apply queue. Maybe the queue already contains these operations.\n" ;
2012-01-17 14:10:54 +01:00
}
}
2014-08-18 15:03:34 +02:00
##############################################################################
# Recreate the files of a collection.
# Related option: --recreate_collection
##############################################################################
sub cli_recreate_collection () {
my $ collection_id = @ ARGV [ 2 ] ;
my $ result = enterprise_hook ( 'pandora_recreate_collection' , [ $ conf , $ collection_id , $ dbh ] ) ;
if ( $ result == 1 ) {
print_log "[INFO] Collection recreated successfully.\n" ;
}
elsif ( $ result == 0 ) {
print_log "[ERROR] Collection not recreated.\n" ;
}
}
2012-01-18 12:21:59 +01:00
##############################################################################
# Validate all the alerts
# Related option: --validate_all_alerts
##############################################################################
sub cli_validate_all_alerts () {
2012-12-28 09:26:49 +01:00
print_log "[INFO] Validating all the alerts\n\n" ;
2012-01-18 12:21:59 +01:00
my $ res = db_update ( $ dbh , "UPDATE talert_template_modules SET times_fired = 0, internal_counter = 0" ) ;
if ( $ res == - 1 ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] Alerts cannot be validated\n\n" ;
2012-01-18 12:21:59 +01:00
}
2013-03-04 13:57:37 +01:00
else {
# Update fired alerts count in agents
db_update ( $ dbh , "UPDATE tagente SET fired_count = 0" ) ;
}
2012-01-18 12:21:59 +01:00
}
2021-04-06 19:21:56 +02:00
##############################################################################
# Validate all the alerts
# Related option: --validate_alert
##############################################################################
sub cli_validate_alert () {
my ( $ template_name , $ agent_id , $ module_id , $ use_alias ) = @ ARGV [ 2 .. 6 ] ;
my $ id_agent = '' ;
my $ id_agentmodule = '' ;
my $ result = 0 ;
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
my @ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_id ) ;
if ( ! @ id_agents ) {
print ( STDERR "[ERROR] Error: The agent '$agent_id' not exists.\n\n" ) ;
}
foreach my $ id ( @ id_agents ) {
if ( defined ( $ agent_id ) && $ agent_id ne '' ) {
$ id_agent = $ id - > { 'id_agente' } ;
exist_check ( $ id_agent , 'agent' , $ agent_id ) ;
if ( $ module_id ne '' ) {
$ module_id = get_agent_module_id ( $ dbh , $ module_id , $ id_agent ) ;
if ( $ module_id eq - 1 ) {
next ;
}
}
}
my $ id_alert_agent_module = '' ;
if ( defined ( $ template_name ) && $ template_name ne '' ) {
my $ id_template = get_template_id ( $ dbh , $ template_name ) ;
exist_check ( $ id_template , 'template' , $ template_name ) ;
$ id_alert_agent_module = get_template_module_id ( $ dbh , $ module_id , $ id_template ) ;
exist_check ( $ id_alert_agent_module , 'template module' , $ template_name ) ;
}
$ result = pandora_validate_alert_id ( $ id_alert_agent_module , $ id , $ module_id , $ template_name ) ;
print_log "[INFO] Validating alert for agent '$id->{'nombre'}'\n\n" ;
}
} else {
if ( defined ( $ agent_id ) && $ agent_id ne '' ) {
my $ agent_name = get_agent_name ( $ dbh , $ agent_id ) ;
exist_check ( $ agent_id , 'agent' , $ agent_name ) ;
if ( $ module_id ne '' ) {
my $ module_name = get_module_name ( $ dbh , $ module_id ) ;
exist_check ( $ module_id , 'module' , $ module_name ) ;
}
}
my $ id_alert_agent_module = '' ;
if ( defined ( $ template_name ) && $ template_name ne '' ) {
my $ id_template = get_template_id ( $ dbh , $ template_name ) ;
exist_check ( $ id_template , 'template' , $ template_name ) ;
$ id_alert_agent_module = get_template_module_id ( $ dbh , $ module_id , $ id_template ) ;
exist_check ( $ id_alert_agent_module , 'template module' , $ template_name ) ;
}
$ result = pandora_validate_alert_id ( $ id_alert_agent_module , $ id_agent , $ module_id , $ template_name ) ;
print_log "[INFO] Validating alert for agent '$agent_id'\n\n" ;
}
if ( $ result == 0 ) {
print_log "[ERROR] Alert could not be validated\n\n" ;
}
else {
2022-05-05 11:47:49 +02:00
print_log "[INFO] Alert successfully validated\n\n" ;
2021-04-06 19:21:56 +02:00
;
}
}
2012-01-18 12:21:59 +01:00
##############################################################################
# Validate the alerts of a given policy
# Related option: --validate_policy_alerts
##############################################################################
sub cli_validate_policy_alerts () {
my $ policy_name = @ ARGV [ 2 ] ;
my $ policy_id = enterprise_hook ( 'get_policy_id' , [ $ dbh , safe_input ( $ policy_name ) ] ) ;
exist_check ( $ policy_id , 'policy' , $ policy_name ) ;
my $ policy_alerts = enterprise_hook ( 'get_policy_alerts' , [ $ dbh , $ policy_id ] ) ;
my @ policy_alerts_id_array ;
my $ policy_alerts_id = '' ;
my $ cont = 0 ;
foreach my $ alert ( @ { $ policy_alerts } ) {
$ policy_alerts_id_array [ $ cont ] = $ alert - > { 'id' } ;
$ cont + + ;
}
if ( $# policy_alerts_id_array == - 1 ) {
2012-12-28 09:26:49 +01:00
print_log "[INFO] No alerts found in the policy '$policy_name'\n\n" ;
2013-03-05 11:53:17 +01:00
return ;
2012-01-18 12:21:59 +01:00
}
$ policy_alerts_id = join ( ',' , @ policy_alerts_id_array ) ;
2013-03-05 11:53:17 +01:00
#Get the fired alerts that match with the filter to update counts after validate it
my @ fired_alerts = get_db_rows ( $ dbh , "SELECT id_agent_module, count(id) alerts FROM talert_template_modules WHERE id_policy_alerts IN (?) AND times_fired > 0 GROUP BY id_agent_module" , $ policy_alerts_id ) ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] Validating the alerts of the policy '$policy_name'\n\n" ;
2012-01-18 12:21:59 +01:00
my $ res = db_update ( $ dbh , "UPDATE talert_template_modules SET times_fired = 0, internal_counter = 0 WHERE id_policy_alerts IN (?)" , $ policy_alerts_id ) ;
2013-03-05 11:53:17 +01:00
2012-01-18 12:21:59 +01:00
if ( $ res == - 1 ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] Alerts cannot be validated\n\n" ;
2012-01-18 12:21:59 +01:00
}
2013-03-04 13:57:37 +01:00
else {
2013-03-05 11:53:17 +01:00
# Update fired alerts count in agents if necessary
if ( $# fired_alerts > - 1 ) {
foreach my $ fired_alert ( @ fired_alerts ) {
my $ id_agent = get_module_agent_id ( $ dbh , $ fired_alert - > { 'id_agent_module' } ) ;
db_update ( $ dbh , 'UPDATE tagente SET fired_count=fired_count-? WHERE id_agente=?' , $ fired_alert - > { 'alerts' } , $ id_agent ) ;
}
}
2013-03-04 13:57:37 +01:00
}
2012-01-18 12:21:59 +01:00
}
2016-06-17 08:50:30 +02:00
##############################################################################
# Show the module id where is a given agent
# Related option: --get_module_id
# perl pandora_manage.pl /etc/pandora/pandora_server.conf --get_module_id 4 'host alive'
##############################################################################
sub cli_get_module_id () {
( my $ agent_id , my $ module_name ) = @ ARGV [ 2 .. 3 ] ;
exist_check ( $ agent_id , 'agent' , $ agent_id ) ;
my $ module_id = get_agent_module_id ( $ dbh , $ module_name , $ agent_id ) ;
exist_check ( $ module_id , 'module name' , $ module_name ) ;
print $ module_id ;
}
2020-09-17 14:38:01 +02:00
##############################################################################
# Retrieves the module custom_id given id_agente_modulo.
# Related option: --get_module_custom_id
# perl pandora_manage.pl /etc/pandora/pandora_server.conf --get_module_custom_id 4
##############################################################################
sub cli_get_module_custom_id {
my $ module_id = $ ARGV [ 2 ] ;
my $ custom_id = get_agentmodule_custom_id ( $ dbh , $ module_id ) ;
if ( defined ( $ custom_id ) ) {
print $ custom_id ;
2020-10-01 16:23:00 +02:00
} else {
print "\n" ;
2020-09-17 14:38:01 +02:00
}
}
##############################################################################
# Update sor erases the module custom_id given id_agente_modulo.
# Related option: --get_module_custom_id
# perl pandora_manage.pl /etc/pandora/pandora_server.conf --get_module_custom_id 4 test
##############################################################################
sub cli_set_module_custom_id {
my ( $ module_id , $ custom_id ) = @ ARGV [ 2 .. 3 ] ;
my $ rs = set_agentmodule_custom_id ( $ dbh , $ module_id , $ custom_id ) ;
if ( $ rs > 0 ) {
print $ custom_id ;
} else {
print "[ERROR] No changes." ;
}
}
2016-06-17 08:50:30 +02:00
2012-01-18 12:21:59 +01:00
##############################################################################
2019-10-17 11:14:42 +02:00
# Show the group name where a given agent is
2012-01-18 12:21:59 +01:00
# Related option: --get_agent_group
##############################################################################
sub cli_get_agent_group () {
2019-10-17 11:14:42 +02:00
my ( $ agent_name , $ use_alias ) = @ ARGV [ 2 .. 3 ] ;
2015-12-29 17:41:39 +01:00
if ( is_metaconsole ( $ conf ) == 1 ) {
my $ agents_groups = enterprise_hook ( 'get_metaconsole_agent' , [ $ dbh , $ agent_name ] ) ;
2019-10-17 11:14:42 +02:00
if ( not defined $ use_alias and scalar ( @ { $ agents_groups } ) != 0 ) {
2015-12-29 17:41:39 +01:00
foreach my $ agent ( @ { $ agents_groups } ) {
my @ test = $ agent ;
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 ] ) ;
2019-10-17 11:14:42 +02:00
my @ id_agents ;
my $ id_agent ;
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh_metaconsole , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
if ( $ id - > { 'id_agente' } == - 1 ) {
next ;
}
else {
my $ id_group = get_agent_group ( $ dbh_metaconsole , $ id - > { 'id_agente' } ) ;
my $ group_name = get_group_name ( $ dbh_metaconsole , $ id_group ) ;
$ agent_name = safe_output ( $ agent_name ) ;
print "[INFO] Agent: $id->{'nombre'} Name Group: $group_name\n\n" ;
}
}
} else {
$ 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 ) ;
$ agent_name = safe_output ( $ agent_name ) ;
print "[INFO] Agent: $agent_name Name Group: $group_name\n\n" ;
}
2015-12-29 17:41:39 +01:00
}
}
}
}
else {
2019-10-17 11:14:42 +02:00
my @ id_agents ;
my $ id_agent ;
my $ id_group ;
my $ group_name ;
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
exist_check ( $ id - > { 'id_agente' } , 'agent' , $ agent_name ) ;
$ id_group = get_agent_group ( $ dbh , $ id - > { 'id_agente' } ) ;
$ group_name = get_group_name ( $ dbh , $ id_group ) ;
print $ group_name . "\n" ;
}
} else {
$ id_agent = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
$ id_group = get_agent_group ( $ dbh , $ id_agent ) ;
2015-12-29 17:41:39 +01:00
2019-10-17 11:14:42 +02:00
$ group_name = get_group_name ( $ dbh , $ id_group ) ;
print $ group_name ;
}
2015-12-29 17:41:39 +01:00
2019-10-17 11:14:42 +02:00
2015-12-29 17:41:39 +01:00
}
}
##############################################################################
# Show the group id where is a given agent
# Related option: --get_agent_group_id
##############################################################################
sub cli_get_agent_group_id () {
2019-10-17 11:14:42 +02:00
my ( $ agent_name , $ use_alias ) = @ ARGV [ 2 .. 3 ] ;
2012-01-18 12:21:59 +01:00
2015-12-29 17:41:39 +01:00
if ( is_metaconsole ( $ conf ) == 1 ) {
2019-10-17 11:14:42 +02:00
2015-12-29 17:41:39 +01:00
my $ agents_groups = enterprise_hook ( 'get_metaconsole_agent' , [ $ dbh , $ agent_name ] ) ;
2019-10-17 11:14:42 +02:00
if ( not defined $ use_alias and scalar ( @ { $ agents_groups } ) != 0 ) {
2015-12-29 17:41:39 +01:00
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 ] ) ;
2019-10-17 11:14:42 +02:00
my @ id_agents ;
my $ id_agent ;
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh_metaconsole , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
if ( $ id - > { 'id_agente' } == - 1 ) {
next ;
}
else {
my $ id_group = get_agent_group ( $ dbh_metaconsole , $ id - > { 'id_agente' } ) ;
$ agent_name = safe_output ( $ agent_name ) ;
print "Agent: $id->{'nombre'} ID Group: $id_group\n\n" ;
}
}
} else {
$ 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 ) ;
$ agent_name = safe_output ( $ agent_name ) ;
print "Agent: $agent_name ID Group: $id_group\n\n" ;
}
2015-12-29 17:41:39 +01:00
}
}
}
}
else {
2019-10-17 11:14:42 +02:00
my @ id_agents ;
my $ id_agent ;
my $ id_group ;
my $ group_name ;
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
exist_check ( $ id - > { 'id_agente' } , 'agent' , $ agent_name ) ;
$ id_group = get_agent_group ( $ dbh , $ id - > { 'id_agente' } ) ;
2015-12-29 17:41:39 +01:00
2019-10-17 11:14:42 +02:00
print $ id_group . "\n" ;
}
} else {
$ id_agent = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
2012-01-18 12:21:59 +01:00
2019-10-17 11:14:42 +02:00
$ id_group = get_agent_group ( $ dbh , $ id_agent ) ;
print $ id_group ;
}
2015-12-29 17:41:39 +01:00
}
2012-01-18 12:21:59 +01:00
}
##############################################################################
# Show the agent and current data of all the modules with the same name
# Related option: --get_agents_module_current_data
##############################################################################
sub cli_get_agents_module_current_data () {
my $ module_name = @ ARGV [ 2 ] ;
my $ agents = pandora_get_module_agents ( $ dbh , $ module_name ) ;
exist_check ( scalar ( @ { $ agents } ) - 1 , 'data of module' , $ module_name ) ;
print "id_agent,agent_name,module_data\n" ;
foreach my $ agent ( @ { $ agents } ) {
my $ current_data = pandora_get_module_current_data ( $ dbh , $ agent - > { 'id_agente_modulo' } ) ;
print $ agent - > { 'id_agente' } . "," . $ agent - > { 'nombre' } . ",$current_data\n" ;
}
}
##############################################################################
# Show all the modules of an agent
# Related option: --get_agent_modules
##############################################################################
sub cli_get_agent_modules () {
2019-10-17 11:14:42 +02:00
my ( $ agent_name , $ use_alias ) = @ ARGV [ 2 .. 3 ] ;
2012-01-18 12:21:59 +01:00
2019-10-17 11:14:42 +02:00
my @ id_agents ;
my $ id_agent ;
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
exist_check ( $ id - > { 'id_agente' } , 'agent' , $ agent_name ) ;
my $ modules = pandora_get_agent_modules ( $ dbh , $ id - > { 'id_agente' } ) ;
if ( scalar ( @ { $ modules } ) == 0 ) {
print_log "[INFO] The agent '$agent_name' have no modules\n\n" ;
}
print "\n" . $ id - > { 'nombre' } . "\n" ;
print "id_module, module_name\n" ;
foreach my $ module ( @ { $ modules } ) {
print $ module - > { 'id_agente_modulo' } . "," . safe_output ( $ module - > { 'nombre' } ) . "\n" ;
}
}
} else {
$ id_agent = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
2015-01-15 16:36:22 +01:00
2019-10-17 11:14:42 +02:00
my $ modules = pandora_get_agent_modules ( $ dbh , $ id_agent ) ;
if ( scalar ( @ { $ modules } ) == 0 ) {
print_log "[INFO] The agent '$agent_name' have no modules\n\n" ;
}
2012-01-18 12:21:59 +01:00
2019-10-17 11:14:42 +02:00
print "id_module, module_name\n" ;
foreach my $ module ( @ { $ modules } ) {
print $ module - > { 'id_agente_modulo' } . "," . safe_output ( $ module - > { 'nombre' } ) . "\n" ;
}
2012-01-18 12:21:59 +01:00
}
}
2020-06-10 08:35:01 +02:00
##############################################################################
# Show the status of an agent
# Related option: --get_agent_status
##############################################################################
sub cli_get_agent_status () {
my ( $ agent_name , $ use_alias ) = @ ARGV [ 2 .. 3 ] ;
my @ id_agents ;
my $ id_agent ;
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
exist_check ( $ id - > { 'id_agente' } , 'agent' , $ agent_name ) ;
my $ agent_status = pandora_get_agent_status ( $ dbh , $ id - > { 'id_agente' } ) ;
print pandora_get_agent_status ( $ dbh , $ id - > { 'id_agente' } ) . "\n" ;
}
} else {
$ id_agent = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
print pandora_get_agent_status ( $ dbh , $ id_agent ) . "\n" ;
}
}
2019-10-10 14:25:17 +02:00
##############################################################################
# Show id, name and id_server of an agent given alias
# Related option: --get_agents_id_name_by_alias
##############################################################################
sub cli_get_agents_id_name_by_alias () {
my $ agent_alias = @ ARGV [ 2 ] ;
2019-10-18 12:22:20 +02:00
my $ strict = @ ARGV [ 3 ] ;
2019-10-10 14:25:17 +02:00
my @ agents ;
2019-10-18 12:22:20 +02:00
my $ where_value ;
2019-10-10 14:25:17 +02:00
2019-10-18 12:22:20 +02:00
if ( $ strict eq 'strict' ) {
$ where_value = $ agent_alias ;
2019-10-10 14:25:17 +02:00
} else {
2019-10-18 12:22:20 +02:00
$ where_value = "%" . $ agent_alias . "%" ;
2019-10-10 14:25:17 +02:00
}
if ( is_metaconsole ( $ conf ) == 1 ) {
2019-10-18 12:48:38 +02:00
@ agents = get_db_rows ( $ dbh , "SELECT alias, id_agente, id_tagente, id_tmetaconsole_setup as 'id_server', server_name FROM tmetaconsole_agent WHERE UPPER(alias) LIKE UPPER(?)" , $ where_value ) ;
2019-10-10 14:25:17 +02:00
} else {
2019-10-18 12:48:38 +02:00
@ agents = get_db_rows ( $ dbh , "SELECT alias, id_agente FROM tagente WHERE UPPER(alias) LIKE UPPER(?)" , $ where_value ) ;
2019-10-10 14:25:17 +02:00
}
2019-10-18 12:22:20 +02:00
if ( scalar ( @ agents ) == 0 ) {
print "[ERROR] No agents retrieved.\n\n" ;
} else {
if ( is_metaconsole ( $ conf ) == 1 ) {
2019-10-18 12:48:38 +02:00
print "alias, id_agente, id_tagente, id_server, server_name\n" ;
2019-10-10 14:25:17 +02:00
2019-10-18 12:22:20 +02:00
foreach my $ agent ( @ agents ) {
2019-10-18 12:48:38 +02:00
print safe_output ( $ agent - > { 'alias' } ) . ", " . $ agent - > { 'id_agente' } . ", " . $ agent - > { 'id_tagente' } . ", " . $ agent - > { 'id_server' } . ", " . $ agent - > { 'server_name' } . "\n" ;
2019-10-18 12:22:20 +02:00
}
} else {
2019-10-18 12:48:38 +02:00
print "alias, id_agente\n" ;
2019-10-18 12:22:20 +02:00
foreach my $ agent ( @ agents ) {
print $ agent - > { 'id_agente' } . "," . safe_output ( $ agent - > { 'alias' } ) . "\n" ;
}
}
}
2019-10-10 14:25:17 +02:00
}
2015-12-21 15:34:41 +01:00
sub cli_create_synthetic () {
my $ name_module = @ ARGV [ 2 ] ;
my $ synthetic_type = @ ARGV [ 3 ] ;
my $ agent_name = @ ARGV [ 4 ] ;
2019-10-17 11:14:42 +02:00
my @ module_data ;
if ( @ ARGV [ $# ARGV ] == "use_alias" ) {
@ module_data = @ ARGV [ 5 .. $# ARGV - 1 ] ;
} else {
@ module_data = @ ARGV [ 5 .. $# ARGV ] ;
}
2015-12-21 15:34:41 +01:00
my $ module ;
2016-01-26 15:03:41 +01:00
my ( @ filterdata , @ data_module ) ;
2015-12-21 15:34:41 +01:00
if ( $ synthetic_type ne 'arithmetic' && $ synthetic_type ne 'average' ) {
print ( "[ERROR] Type of syntethic module doesn't exists \n\n" ) ;
exit 1 ;
}
2016-01-26 15:03:41 +01:00
if ( scalar ( @ { module_data } ) == 0 ) {
2015-12-23 16:27:08 +01:00
print ( "[ERROR] No modules data \n\n" ) ;
exit 1 ;
}
2016-01-26 15:03:41 +01:00
if ( $ name_module eq '' ) {
2015-12-23 16:27:08 +01:00
print ( "[ERROR] No module name \n\n" ) ;
exit 1 ;
}
2015-12-21 15:34:41 +01:00
$ module - > { 'custom_integer_1' } = 0 ;
$ module - > { 'custom_integer_2' } = 0 ;
$ module - > { 'prediction_module' } = 3 ; # Synthetic code is 3
2016-01-27 15:43:06 +01:00
$ module - > { 'flag' } = 1 ;
2019-10-17 11:14:42 +02:00
my @ id_agents ;
my $ id_agent ;
if ( @ ARGV [ $# ARGV ] eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
@ filterdata = ( ) ;
$ id_agent = $ id - > { 'id_agente' } ;
if ( $ id_agent > 0 ) {
foreach my $ i ( 0 .. $# module_data ) {
my @ split_data = split ( ',' , $ module_data [ $ i ] ) ;
if ( @ split_data [ 0 ] =~ m/(x|\/|\+|\*|\-)/ && length ( @ split_data [ 0 ] ) == 1 ) {
if ( @ split_data [ 0 ] =~ m/(\/|\+|\*|\-)/ && $ synthetic_type eq 'average' ) {
print ( "[ERROR] With this type: $synthetic_type only be allow use this operator: 'x' \n\n" ) ;
exit 1 ;
}
if ( is_numeric ( @ split_data [ 1 ] ) == 0 ) {
next ;
}
@ data_module = ( "" , @ split_data [ 0 ] , @ split_data [ 1 ] ) ;
my $ text_data = join ( ',' , @ data_module ) ;
push ( @ filterdata , $ text_data ) ;
}
else {
if ( scalar ( @ split_data ) == 2 ) {
@ data_module = ( safe_output ( @ split_data [ 0 ] ) , '' , safe_output ( @ split_data [ 1 ] ) ) ;
my $ text_data = join ( ',' , @ data_module ) ;
push ( @ filterdata , $ text_data ) ;
}
else {
if ( length ( @ split_data [ 1 ] ) > 1 ) {
print ( "[ERROR] You can only use +, -, *, / or x, and you use this: @split_data[1] \n\n" ) ;
exit 1 ;
}
if ( @ split_data [ 1 ] =~ m/(\/|\+|\*|\-)/ && $ synthetic_type eq 'average' ) {
print ( "[ERROR] With this type: $synthetic_type only be allow use this operator: 'x' \n\n" ) ;
exit 1 ;
}
if ( $ synthetic_type eq 'arithmetic' && $ i == 0 ) {
@ data_module = ( safe_output ( @ split_data [ 0 ] ) , '' , safe_output ( @ split_data [ 2 ] ) ) ;
}
else {
@ data_module = ( safe_output ( @ split_data [ 0 ] ) , @ split_data [ 1 ] , safe_output ( @ split_data [ 2 ] ) ) ;
}
my $ text_data = join ( ',' , @ data_module ) ;
push ( @ filterdata , $ text_data ) ;
}
}
2015-12-21 15:34:41 +01:00
}
2019-10-17 11:14:42 +02:00
my $ module_exists = get_agent_module_id ( $ dbh , $ name_module , $ id_agent ) ;
non_exist_check ( $ module_exists , 'module name' , $ name_module ) ;
$ module - > { 'id_agente' } = $ id_agent ;
$ module - > { 'nombre' } = safe_input ( $ name_module ) ;
my $ id_tipo_modulo = get_db_value ( $ dbh , "SELECT id_tipo FROM ttipo_modulo WHERE nombre = ?" , "generic_data" ) ;
$ module - > { 'id_modulo' } = 5 ;
$ module - > { 'id_tipo_modulo' } = $ id_tipo_modulo ;
my $ id_module = db_process_insert ( $ dbh , 'id_agente_modulo' , 'tagente_modulo' , $ module ) ;
if ( $ id_module ) {
my $ result = enterprise_hook ( 'create_synthetic_operations_by_alias' ,
[ $ dbh , int ( $ id_module ) , @ filterdata ] ) ;
if ( $ result ) {
db_do ( $ dbh , ' INSERT INTO tagente_estado ( id_agente_modulo , id_agente , estado ,
known_status , last_status , last_known_status , last_try , datos )
VALUES ( ? , ? , ? , ? , ? , ? , \ '1970-01-01 00:00:00\', \'\')' , $ id_module , $ id_agent , 4 , 4 , 4 , 4 ) ;
# Update the module status count. When the module is created disabled dont do it
pandora_mark_agent_for_module_update ( $ dbh , $ id_agent ) ;
print ( "[OK] Created module ID: $id_module \n\n" ) ;
}
else {
#db_do ($dbh, 'DELETE FROM tagente_modulo WHERE id_agente_modulo = ?', $id_module);
print ( "[ERROR] Problems with creating data module. \n\n" ) ;
}
}
else {
db_do ( $ dbh , 'DELETE FROM tagente_modulo WHERE nombre = ? AND id_agente = ?' , $ name_module , $ id_agent ) ;
print ( "[INFO] Problems with creating module \n\n" ) ;
2015-12-23 16:27:08 +01:00
}
2015-12-21 15:34:41 +01:00
}
else {
2019-10-17 11:14:42 +02:00
print ( "[INFO] The agent '$id->{'nombre'}' doesn't exist\n\n" ) ;
}
}
} else {
my $ id_agent = int ( get_agent_id ( $ dbh , $ agent_name ) ) ;
if ( $ id_agent > 0 ) {
foreach my $ i ( 0 .. $# module_data ) {
my @ split_data = split ( ',' , $ module_data [ $ i ] ) ;
if ( @ split_data [ 0 ] =~ m/(x|\/|\+|\*|\-)/ && length ( @ split_data [ 0 ] ) == 1 ) {
if ( @ split_data [ 0 ] =~ m/(\/|\+|\*|\-)/ && $ synthetic_type eq 'average' ) {
2015-12-21 15:34:41 +01:00
print ( "[ERROR] With this type: $synthetic_type only be allow use this operator: 'x' \n\n" ) ;
exit 1 ;
}
2019-10-17 11:14:42 +02:00
if ( is_numeric ( @ split_data [ 1 ] ) == 0 ) {
next ;
2016-02-03 12:23:45 +01:00
}
2019-10-17 11:14:42 +02:00
@ data_module = ( "" , @ split_data [ 0 ] , @ split_data [ 1 ] ) ;
2015-12-21 15:34:41 +01:00
my $ text_data = join ( ',' , @ data_module ) ;
push ( @ filterdata , $ text_data ) ;
}
2019-10-17 11:14:42 +02:00
else {
if ( scalar ( @ split_data ) == 2 ) {
@ data_module = ( safe_output ( @ split_data [ 0 ] ) , '' , safe_output ( @ split_data [ 1 ] ) ) ;
my $ text_data = join ( ',' , @ data_module ) ;
push ( @ filterdata , $ text_data ) ;
}
else {
if ( length ( @ split_data [ 1 ] ) > 1 ) {
print ( "[ERROR] You can only use +, -, *, / or x, and you use this: @split_data[1] \n\n" ) ;
exit 1 ;
}
if ( @ split_data [ 1 ] =~ m/(\/|\+|\*|\-)/ && $ synthetic_type eq 'average' ) {
print ( "[ERROR] With this type: $synthetic_type only be allow use this operator: 'x' \n\n" ) ;
exit 1 ;
}
if ( $ synthetic_type eq 'arithmetic' && $ i == 0 ) {
@ data_module = ( safe_output ( @ split_data [ 0 ] ) , '' , safe_output ( @ split_data [ 2 ] ) ) ;
}
else {
@ data_module = ( safe_output ( @ split_data [ 0 ] ) , @ split_data [ 1 ] , safe_output ( @ split_data [ 2 ] ) ) ;
}
my $ text_data = join ( ',' , @ data_module ) ;
push ( @ filterdata , $ text_data ) ;
}
}
2015-12-21 15:34:41 +01:00
}
2019-10-17 11:14:42 +02:00
my $ module_exists = get_agent_module_id ( $ dbh , $ name_module , $ id_agent ) ;
non_exist_check ( $ module_exists , 'module name' , $ name_module ) ;
$ module - > { 'id_agente' } = $ id_agent ;
$ module - > { 'nombre' } = safe_input ( $ name_module ) ;
my $ id_tipo_modulo = get_db_value ( $ dbh , "SELECT id_tipo FROM ttipo_modulo WHERE nombre = ?" , "generic_data" ) ;
$ module - > { 'id_modulo' } = 5 ;
$ module - > { 'id_tipo_modulo' } = $ id_tipo_modulo ;
my $ id_module = db_process_insert ( $ dbh , 'id_agente_modulo' , 'tagente_modulo' , $ module ) ;
if ( $ id_module ) {
my $ result = enterprise_hook ( 'create_synthetic_operations' ,
[ $ dbh , int ( $ id_module ) , @ filterdata ] ) ;
if ( $ result ) {
db_do ( $ dbh , ' INSERT INTO tagente_estado ( id_agente_modulo , id_agente , estado ,
known_status , last_status , last_known_status , last_try , datos )
VALUES ( ? , ? , ? , ? , ? , ? , \ '1970-01-01 00:00:00\', \'\')' , $ id_module , $ id_agent , 4 , 4 , 4 , 4 ) ;
# Update the module status count. When the module is created disabled dont do it
pandora_mark_agent_for_module_update ( $ dbh , $ id_agent ) ;
print ( "[OK] Created module ID: $id_module \n\n" ) ;
}
else {
db_do ( $ dbh , 'DELETE FROM tagente_modulo WHERE id_agente_modulo = ?' , $ id_module ) ;
print ( "[ERROR] Problems with creating data module. \n\n" ) ;
}
2015-12-21 15:34:41 +01:00
}
else {
2019-10-17 11:14:42 +02:00
db_do ( $ dbh , 'DELETE FROM tagente_modulo WHERE nombre = ? AND id_agente = ?' , $ name_module , $ id_agent ) ;
print ( "[INFO] Problems with creating module \n\n" ) ;
2015-12-21 15:34:41 +01:00
}
}
2019-10-17 11:14:42 +02:00
else {
print ( "[INFO] The agent '$agent_name' doesn't exist\n\n" ) ;
2015-12-21 15:34:41 +01:00
}
}
2019-10-17 11:14:42 +02:00
2015-12-21 15:34:41 +01:00
}
2015-01-15 16:36:22 +01:00
########################################################################
2012-01-18 12:21:59 +01:00
# Show all the modules of a policy
# Related option: --get_policy_modules
2015-01-15 16:36:22 +01:00
########################################################################
2012-01-18 12:21:59 +01:00
sub cli_get_policy_modules () {
my $ policy_name = @ ARGV [ 2 ] ;
2015-01-15 16:36:22 +01:00
my $ policy_id = enterprise_hook ( 'get_policy_id' ,
[ $ dbh , safe_input ( $ policy_name ) ] ) ;
exist_check ( $ policy_id , 'policy' , $ policy_name ) ;
my $ policy_modules = enterprise_hook (
'get_policy_modules' , [ $ dbh , $ policy_id ] ) ;
2012-01-18 12:21:59 +01:00
2015-01-15 16:36:22 +01:00
if ( defined ( $ policy_modules ) ) {
exist_check ( scalar ( @ { $ policy_modules } ) - 1 , 'modules in policy' ,
$ policy_name ) ;
}
2012-01-18 12:21:59 +01:00
print "id_policy_module, module_name\n" ;
foreach my $ module ( @ { $ policy_modules } ) {
2015-01-15 16:36:22 +01:00
print $ module - > { 'id' } . "," . safe_output ( $ module - > { 'name' } ) . "\n" ;
2012-01-18 12:21:59 +01:00
}
}
2015-01-15 16:36:22 +01:00
########################################################################
# Show all the policies (without parameters) or the policies of given
# agent.
2012-01-18 13:25:03 +01:00
# Related option: --get_policies
2015-01-15 16:36:22 +01:00
########################################################################
2012-01-18 13:25:03 +01:00
sub cli_get_policies () {
2019-10-17 11:14:42 +02:00
my ( $ agent_name , $ use_alias ) = @ ARGV [ 2 .. 3 ] ;
2012-01-18 13:25:03 +01:00
my $ policies ;
2015-01-15 16:36:22 +01:00
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
my @ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
if ( defined ( $ agent_name ) ) {
my $ id_agent = $ id - > { 'id_agente' } ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
$ policies = enterprise_hook ( 'get_agent_policies' , [ $ dbh , $ id_agent ] ) ;
if ( scalar ( @ { $ policies } ) == 0 ) {
print_log "[INFO] No policies found on agent $id->{'nombre'}\n\n" ;
exit ;
}
}
else {
$ policies = enterprise_hook ( 'get_policies' , [ $ dbh ] ) ;
if ( scalar ( @ { $ policies } ) == 0 ) {
print_log "[INFO] No policies found\n\n" ;
exit ;
}
}
print "agent_name, id_policy, policy_name\n" ;
foreach my $ module ( @ { $ policies } ) {
print $ id - > { 'nombre' } . "," . $ module - > { 'id' } . "," . safe_output ( $ module - > { 'name' } ) . "\n" ;
}
}
} else {
if ( defined ( $ agent_name ) ) {
my $ id_agent = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ id_agent , 'agent' , $ agent_name ) ;
$ policies = enterprise_hook ( 'get_agent_policies' , [ $ dbh , $ id_agent ] ) ;
if ( scalar ( @ { $ policies } ) == 0 ) {
print_log "[INFO] No policies found on agent '$agent_name'\n\n" ;
exit ;
}
2012-01-18 13:25:03 +01:00
}
2019-10-17 11:14:42 +02:00
else {
$ policies = enterprise_hook ( 'get_policies' , [ $ dbh ] ) ;
if ( scalar ( @ { $ policies } ) == 0 ) {
print_log "[INFO] No policies found\n\n" ;
exit ;
}
}
print "id_policy, policy_name\n" ;
foreach my $ module ( @ { $ policies } ) {
print $ module - > { 'id' } . "," . safe_output ( $ module - > { 'name' } ) . "\n" ;
2012-01-18 13:25:03 +01:00
}
}
2019-10-17 11:14:42 +02:00
2012-01-18 13:25:03 +01:00
}
2012-01-20 09:52:17 +01:00
##############################################################################
# Show all the agents (without parameters) or the agents with a filter parameters
# Related option: --get_agents
##############################################################################
sub cli_get_agents () {
2019-10-17 11:14:42 +02:00
my ( $ group_name , $ os_name , $ status , $ max_modules , $ filter_substring , $ policy_name , $ use_alias ) = @ ARGV [ 2 .. 8 ] ;
2015-12-22 14:01:58 +01:00
my $ condition = ' disabled=0' ;
2012-01-20 09:52:17 +01:00
my $ id_group ;
my $ id_os ;
my $ policy_id ;
if ( $ group_name ne '' ) {
$ id_group = get_group_id ( $ dbh , $ group_name ) ;
exist_check ( $ id_group , 'group' , $ group_name ) ;
2019-10-17 11:14:42 +02:00
2012-01-20 09:52:17 +01:00
$ condition . = " AND id_grupo = $id_group " ;
}
if ( $ os_name ne '' ) {
$ id_os = get_os_id ( $ dbh , $ os_name ) ;
exist_check ( $ id_os , 'operative system' , $ os_name ) ;
$ condition . = " AND id_os = $id_os " ;
}
if ( $ policy_name ne '' ) {
$ policy_id = enterprise_hook ( 'get_policy_id' , [ $ dbh , safe_input ( $ policy_name ) ] ) ;
exist_check ( $ policy_id , 'policy' , $ policy_name ) ;
$ condition . = " AND id_agente IN ( SELECT id_agent FROM tpolicy_agents
WHERE id_policy = $ policy_id ) " ;
}
if ( $ max_modules ne '' ) {
$ condition . = " AND id_agente NOT IN ( SELECT id_agente FROM tagente_modulo t1
WHERE ( SELECT count ( * ) FROM tagente_modulo WHERE id_agente = t1 . id_agente ) > $ max_modules ) " ;
}
if ( $ filter_substring ne '' ) {
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
$ condition . = " AND alias LIKE '%" . safe_input ( $ filter_substring ) . "%'" ;
} else {
$ condition . = " AND nombre LIKE '%" . safe_input ( $ filter_substring ) . "%'" ;
}
2012-01-20 09:52:17 +01:00
}
my @ agents = get_db_rows ( $ dbh , "SELECT * FROM tagente WHERE $condition" ) ;
if ( scalar ( @ agents ) == 0 ) {
2012-12-28 09:26:49 +01:00
print_log "[INFO] No agents found\n\n" ;
2012-01-20 09:52:17 +01:00
exit ;
}
my $ agent_status ;
my $ head_print = 0 ;
2019-10-17 11:14:42 +02:00
2012-01-20 09:52:17 +01:00
foreach my $ agent ( @ agents ) {
if ( $ status ne '' ) {
$ agent_status = pandora_get_agent_status ( $ dbh , $ agent - > { 'id_agente' } ) ;
if ( $ status ne $ agent_status || $ agent_status eq '' ) {
next ;
}
}
if ( $ head_print == 0 ) {
$ head_print = 1 ;
print "id_agent, agent_name\n" ;
}
2019-10-17 11:14:42 +02:00
2012-01-20 09:52:17 +01:00
print $ agent - > { 'id_agente' } . "," . safe_output ( $ agent - > { 'nombre' } ) . "\n" ;
}
if ( $ head_print == 0 ) {
2012-12-28 09:26:49 +01:00
print_log "[INFO] No agents found\n\n" ;
2012-01-20 09:52:17 +01:00
}
}
##############################################################################
# Delete agent conf.
# Related option: --delete_conf_file
##############################################################################
sub cli_delete_conf_file () {
2019-10-17 11:14:42 +02:00
my ( $ agent_name , $ use_alias ) = @ ARGV [ 2 .. 3 ] ;
2012-01-20 09:52:17 +01:00
my $ conf_deleted = 0 ;
my $ md5_deleted = 0 ;
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
my @ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
$ agent_name = $ id - > { 'nombre' } ;
if ( - e $ conf - > { incomingdir } . '/conf/' . md5 ( $ agent_name ) . '.conf' ) {
unlink ( $ conf - > { incomingdir } . '/conf/' . md5 ( $ agent_name ) . '.conf' ) ;
$ conf_deleted = 1 ;
}
if ( - e $ conf - > { incomingdir } . '/md5/' . md5 ( $ agent_name ) . '.md5' ) {
unlink ( $ conf - > { incomingdir } . '/md5/' . md5 ( $ agent_name ) . '.md5' ) ;
$ md5_deleted = 1 ;
}
if ( $ conf_deleted == 1 || $ md5_deleted == 1 ) {
2022-05-05 11:47:49 +02:00
print_log "[INFO] Local conf files of the agent '$agent_name' has been deleted successfully\n\n" ;
2019-10-17 11:14:42 +02:00
}
else {
print_log "[ERROR] Local conf file of the agent '$agent_name' was not found\n\n" ;
exit ;
}
}
} else {
if ( - e $ conf - > { incomingdir } . '/conf/' . md5 ( $ agent_name ) . '.conf' ) {
unlink ( $ conf - > { incomingdir } . '/conf/' . md5 ( $ agent_name ) . '.conf' ) ;
$ conf_deleted = 1 ;
}
if ( - e $ conf - > { incomingdir } . '/md5/' . md5 ( $ agent_name ) . '.md5' ) {
unlink ( $ conf - > { incomingdir } . '/md5/' . md5 ( $ agent_name ) . '.md5' ) ;
$ md5_deleted = 1 ;
}
if ( $ conf_deleted == 1 || $ md5_deleted == 1 ) {
2022-05-05 11:47:49 +02:00
print_log "[INFO] Local conf files of the agent '$agent_name' has been deleted successfully\n\n" ;
2019-10-17 11:14:42 +02:00
}
else {
print_log "[ERROR] Local conf file of the agent '$agent_name' was not found\n\n" ;
exit ;
}
2012-01-20 09:52:17 +01:00
}
}
##############################################################################
# Delete modules from all conf files (without parameters) or of the conf file of the given agent.
# Related option: --clean_conf_file
##############################################################################
sub cli_clean_conf_file () {
2019-10-17 11:14:42 +02:00
my ( $ agent_name , $ use_alias ) = @ ARGV [ 2 .. 3 ] ;
2012-01-20 09:52:17 +01:00
my $ result ;
if ( defined ( $ agent_name ) ) {
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
my @ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
$ agent_name = $ id - > { 'nombre' } ;
if ( - e $ conf - > { incomingdir } . '/conf/' . md5 ( $ agent_name ) . '.conf' ) {
$ result = enterprise_hook ( 'pandora_clean_conf_file' , [ $ conf , md5 ( $ agent_name ) ] ) ;
if ( $ result != - 1 ) {
print_log "[INFO] Conf file '" . $ conf - > { incomingdir } . '/conf/' . md5 ( $ agent_name ) . ".conf has been cleaned'\n\n" ;
}
}
}
} else {
if ( - e $ conf - > { incomingdir } . '/conf/' . md5 ( $ agent_name ) . '.conf' ) {
$ result = enterprise_hook ( 'pandora_clean_conf_file' , [ $ conf , md5 ( $ agent_name ) ] ) ;
if ( $ result != - 1 ) {
print_log "[INFO] Conf file '" . $ conf - > { incomingdir } . '/conf/' . md5 ( $ agent_name ) . ".conf has been cleaned'\n\n" ;
}
2012-01-20 09:52:17 +01:00
}
}
}
else {
my $ list_command = 'ls ' . $ conf - > { incomingdir } . '/conf/' ;
my $ out = `$list_command` ;
my @ files = split ( '\n' , $ out ) ;
# TODO: FINISH OPTION! NOW ONLY SHOW FILES
foreach my $ file ( @ files ) {
# Get the md5 hash
my @ filesplit = split ( '.' , $ file ) ;
$ result = enterprise_hook ( 'pandora_clean_conf_file' , [ $ conf , $ filesplit [ 0 ] ] ) ;
if ( $ result != - 1 ) {
2012-12-28 09:26:49 +01:00
print_log "[INFO] Conf file '" . $ conf - > { incomingdir } . '/conf/' . $ filesplit [ 0 ] . ".conf has been cleaned'\n\n" ;
2012-01-20 09:52:17 +01:00
}
}
}
}
##############################################################################
# Get the files bad configured (without essential tokens)
# Related option: --get_bad_conf_files
##############################################################################
sub cli_get_bad_conf_files () {
my $ list_command = 'ls ' . $ conf - > { incomingdir } . '/conf/' ;
my $ out = `$list_command` ;
my @ files = split ( '\n' , $ out ) ;
my $ bad_files = 0 ;
foreach my $ file ( @ files ) {
# Check important tokens
my $ missings = 0 ;
2015-11-10 13:39:21 +01:00
my @ tokens = ( "server_ip" , "server_path" , "temporal" , "log_file" ) ;
2012-01-20 09:52:17 +01:00
2016-12-27 12:00:00 +01:00
if ( $ file !~ /.srv./ ) {
foreach my $ token ( @ tokens ) {
if ( enterprise_hook ( 'pandora_check_conf_token' , [ $ conf - > { incomingdir } . '/conf/' . $ file , $ token ] ) == 0 ) {
$ missings + + ;
}
}
# If any token of checked is missed we print the file path
if ( $ missings > 0 ) {
print $ conf - > { incomingdir } . '/conf/' . $ file . "\n" ;
$ bad_files + + ;
2012-01-20 09:52:17 +01:00
}
}
}
if ( $ bad_files == 0 ) {
2012-12-28 09:26:49 +01:00
print_log "[INFO] No bad files found\n\n" ;
2012-01-20 09:52:17 +01:00
}
}
2011-11-14 14:27:21 +01:00
##############################################################################
# Disable policy alerts.
# Related option: --disable_policy_alerts
##############################################################################
sub cli_disable_policy_alerts () {
my $ policy_name = @ ARGV [ 2 ] ;
my $ policy_id = enterprise_hook ( 'get_policy_id' , [ $ dbh , safe_input ( $ policy_name ) ] ) ;
exist_check ( $ policy_id , 'policy' , $ policy_name ) ;
# Flag as disabled the policy alerts
my $ array_pointer_ag = enterprise_hook ( 'pandora_disable_policy_alerts' , [ $ dbh , $ policy_id ] ) ;
}
2011-12-29 18:12:13 +01:00
##############################################################################
# Add an agent to a policy
# Related option: --add_agent_to_policy
##############################################################################
sub cli_policy_add_agent () {
2019-10-17 11:14:42 +02:00
my ( $ agent_name , $ policy_name , $ use_alias ) = @ ARGV [ 2 .. 4 ] ;
2011-12-29 18:12:13 +01:00
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
my @ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
foreach my $ id ( @ id_agents ) {
my $ agent_id = $ id - > { 'id_agente' } ;
exist_check ( $ agent_id , 'agent' , $ agent_name ) ;
my $ policy_id = enterprise_hook ( 'get_policy_id' , [ $ dbh , safe_input ( $ policy_name ) ] ) ;
exist_check ( $ policy_id , 'policy' , $ policy_name ) ;
# Add the agent to policy
my $ policy_agent_id = enterprise_hook ( 'pandora_policy_add_agent' , [ $ policy_id , $ agent_id , $ dbh ] ) ;
if ( $ policy_agent_id == - 1 ) {
print_log "[ERROR] A problem has been ocurred adding agent $id->{'nombre'} to policy '$policy_name'\n\n" ;
}
else {
print_log "[INFO] Added agent $id->{'nombre'} to policy $policy_name. Is necessary to apply the policy in order to changes take effect.\n\n" ;
}
}
} else {
my $ agent_id = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ agent_id , 'agent' , $ agent_name ) ;
2011-12-29 18:12:13 +01:00
2019-10-17 11:14:42 +02:00
my $ policy_id = enterprise_hook ( 'get_policy_id' , [ $ dbh , safe_input ( $ policy_name ) ] ) ;
exist_check ( $ policy_id , 'policy' , $ policy_name ) ;
# Add the agent to policy
my $ policy_agent_id = enterprise_hook ( 'pandora_policy_add_agent' , [ $ policy_id , $ agent_id , $ dbh ] ) ;
if ( $ policy_agent_id == - 1 ) {
print_log "[ERROR] A problem has been ocurred adding agent '$agent_name' to policy '$policy_name'\n\n" ;
}
else {
print_log "[INFO] Added agent '$agent_name' to policy '$policy_name'. Is necessary to apply the policy in order to changes take effect.\n\n" ;
}
2011-12-29 18:12:13 +01:00
}
2019-10-17 11:14:42 +02:00
2011-12-29 18:12:13 +01:00
}
2018-12-17 17:51:30 +01:00
##############################################################################
# delete an agent to a policy
# Related option: --remove_agent_from_policy
##############################################################################
sub cli_policy_delete_agent () {
my ( $ policy_id , $ agent_id ) = @ ARGV [ 2 .. 3 ] ;
my $ result = api_call ( \ % conf , 'set' , 'remove_agent_from_policy' , $ policy_id , $ agent_id ) ;
print "$result \n\n " ;
}
2015-11-23 09:21:35 +01:00
sub cli_create_planned_downtime () {
my $ name = @ ARGV [ 2 ] ;
2018-11-06 16:42:03 +01:00
my @ todo = @ ARGV [ 3 .. 21 ] ;
2015-11-23 09:21:35 +01:00
my $ other = join ( '|' , @ todo ) ;
my $ result = api_call ( \ % conf , 'set' , 'planned_downtimes_created' , $ name , undef , "$other" ) ;
2015-12-03 11:54:08 +01:00
print "$result \n\n " ;
2015-11-23 09:21:35 +01:00
}
sub cli_add_item_planned_downtime () {
my $ id = @ ARGV [ 2 ] ;
my $ agent = @ ARGV [ 3 ] ;
my $ moduls = @ ARGV [ 4 ] ;
my @ agents = split /,/ , $ agent ;
my @ modules = split /,/ , $ moduls ;
my $ other_agents = join ( ';' , @ agents ) ;
my $ other_modules = join ( ';' , @ modules ) ;
my $ other = $ other_agents . "|" . $ other_modules ;
my $ result = api_call ( \ % conf , 'set' , 'planned_downtimes_additem' , $ id , undef , "$other" ) ;
print_log "$result \n\n" ;
}
2015-12-02 17:01:28 +01:00
sub cli_set_delete_planned_downtime () {
my $ name_downtime = @ ARGV [ 2 ] ;
my $ id_downtime = pandora_get_planned_downtime_id ( $ dbh , $ name_downtime ) ;
my $ result = pandora_delete_planned_downtime ( $ dbh , $ id_downtime ) ;
print_log "$result \n\n" ;
}
sub cli_get_all_planned_downtime () {
my $ name_downtime = @ ARGV [ 2 ] ;
my ( $ id_group , $ type_downtime , $ type_execution , $ type_periodicity ) = @ ARGV [ 3 .. 6 ] ;
my @ results = pandora_get_all_planned_downtime ( $ dbh , $ name_downtime , $ id_group , $ type_downtime , $ type_execution , $ type_periodicity ) ;
if ( ! defined ( $ results [ 0 ] ) ) {
print_log "[ERROR] No data found with this parameters. Please check and launch again\n\n" ;
}
else {
foreach my $ result ( @ results ) {
2015-12-03 11:54:08 +01:00
print ( "\nID: " . $ result - > { 'id' } . ", NAME: " . $ result - > { 'name' } . ", DESC: " . safe_output ( $ result - > { 'description' } ) . ", DATE FROM: " .
2015-12-02 17:01:28 +01:00
localtime ( $ result - > { 'date_from' } ) . " DATE TO: " . localtime ( $ result - > { 'date_to' } ) .
" \nID GROUP: " . $ result - > { 'id_group' } . ", MONDAY: " . $ result - > { 'monday' } . ", TUESDAY: " . $ result - > { 'tuesday' } .
", WEDNESDAY: " . $ result - > { 'wednesday' } . ", THURSDAY: " . $ result - > { 'thursday' } . ", FRIDAY: " . $ result - > { 'friday' } .
", SATURDAY: " . $ result - > { 'saturday' } . ", SUNDAY: " . $ result - > { 'sunday' } . ", PEDIODICALLY TIME FROM: " . $ result - > { 'periodically_time_from' } .
" \nPEDIODICALLY TIME TO: " . $ result - > { 'periodically_time_to' } . ", PEDIODICALLY DAY FROM: " . $ result - > { 'periodically_day_from' } .
"PEDIODICALLY DAY TO: " . $ result - > { 'periodically_day_to' } . ", TYPE DOWNTIME: " . $ result - > { 'type_downtime' } .
", TYPE OF EXECUTION: " . $ result - > { 'type_execution' } . "\nTYPE OF PERIODICITY: " . $ result - > { 'type_periodicity' } .
2015-12-03 11:54:08 +01:00
", USER: " . $ result - > { 'id_user' } . "\n\n" ) ;
2015-12-02 17:01:28 +01:00
}
}
}
sub cli_get_planned_downtimes_items () {
my $ name_downtime = @ ARGV [ 2 ] ;
my ( $ id_group , $ type_downtime , $ type_execution , $ type_periodicity ) = @ ARGV [ 3 .. 6 ] ;
my $ text ;
my @ results = pandora_get_all_planned_downtime ( $ dbh , $ name_downtime , $ id_group , $ type_downtime , $ type_execution , $ type_periodicity ) ;
if ( ! defined ( $ results [ 0 ] ) ) {
print_log "[ERROR] No data found with this parameters. Please check and launch again\n\n" ;
}
else {
my @ items ;
foreach my $ result ( @ results ) {
print ( " ITEMS OF $result->{'name'} \n " ) ;
@ items = pandora_get_planned_downtimes_items ( $ dbh , $ result ) ;
foreach my $ item ( @ items ) {
if ( $ item - > { 'modules' } != '' ) {
$ text = " This Agent have this MODULES ID: " . $ item - > { "modules" } ;
} else {
$ text = " All modules quiet of this agent" ;
}
print ( "AGENT ID: " . $ item - > { "id_agent" } . $ text . "\n " ) ;
}
}
}
}
2011-12-29 18:12:13 +01:00
##############################################################################
# Create group
# Related option: --create_group
##############################################################################
sub cli_create_group () {
2012-10-30 10:32:35 +01:00
my ( $ group_name , $ parent_group_name , $ icon , $ description ) = @ ARGV [ 2 .. 5 ] ;
2021-11-23 12:23:27 +01:00
if ( is_metaconsole ( $ conf ) != 1 && pandora_get_tconfig_token ( $ dbh , 'centralized_management' , '' ) ) {
print_log "[ERROR] This node is configured with centralized mode. To create a group go to metaconsole. \n\n" ;
exit ;
}
2011-12-29 18:12:13 +01:00
my $ group_id = get_group_id ( $ dbh , $ group_name ) ;
non_exist_check ( $ group_id , 'group name' , $ group_name ) ;
my $ parent_group_id = 0 ;
2012-01-11 17:25:15 +01:00
if ( defined ( $ parent_group_name ) && $ parent_group_name ne 'All' ) {
2011-12-29 18:12:13 +01:00
$ parent_group_id = get_group_id ( $ dbh , $ parent_group_name ) ;
exist_check ( $ parent_group_id , 'group name' , $ parent_group_name ) ;
}
2012-01-11 17:25:15 +01:00
$ icon = '' unless defined ( $ icon ) ;
2012-10-30 10:32:35 +01:00
$ description = '' unless defined ( $ description ) ;
2012-01-11 17:25:15 +01:00
2012-10-30 10:32:35 +01:00
$ group_id = pandora_create_group ( $ group_name , $ icon , $ parent_group_id , 0 , 0 , '' , 0 , $ description , $ dbh ) ;
2015-12-29 17:41:39 +01:00
2011-12-29 18:12:13 +01:00
if ( $ group_id == - 1 ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] A problem has been ocurred creating group '$group_name'\n\n" ;
2011-12-29 18:12:13 +01:00
}
2015-12-29 17:41:39 +01:00
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 ( $@ ) {
2022-05-05 11:47:49 +02:00
print_log "[ERROR] Problems with IDS and doesn't created group\n\n" ;
2015-12-29 17:41:39 +01:00
$ 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" ;
}
}
}
2016-06-10 13:36:41 +02:00
##############################################################################
# Delete group
# Related option: --delete_group
##############################################################################
sub cli_delete_group () {
my ( $ group_name ) = @ ARGV [ 2 ] ;
2021-11-23 12:23:27 +01:00
if ( is_metaconsole ( $ conf ) != 1 && pandora_get_tconfig_token ( $ dbh , 'centralized_management' , '' ) ) {
print_log "[ERROR] This node is configured with centralized mode. To delete a group go to metaconsole. \n\n" ;
exit ;
}
2016-06-10 13:36:41 +02:00
my $ group_id = get_group_id ( $ dbh , $ group_name ) ;
exist_check ( $ group_id , 'group name' , $ group_name ) ;
2020-11-05 16:14:06 +01:00
$ group_id = db_do ( $ dbh , 'DELETE FROM tgrupo WHERE nombre=?' , safe_input ( $ group_name ) ) ;
2016-06-10 13:36:41 +02:00
2022-04-27 10:42:06 +02:00
# Delete on nodes too if metaconsole.
if ( is_metaconsole ( $ conf ) == 1 && pandora_get_tconfig_token ( $ dbh , 'centralized_management' , '' ) ) {
my $ servers = enterprise_hook ( 'get_metaconsole_setup_servers' , [ $ dbh ] ) ;
my @ servers_id = split ( ',' , $ servers ) ;
foreach my $ server ( @ servers_id ) {
my $ dbh_node = enterprise_hook ( 'get_node_dbh' , [ $ conf , $ server , $ dbh ] ) ;
my $ group_id = get_group_id ( $ dbh_node , $ group_name ) ;
exist_check ( $ group_id , 'group name' , $ group_name ) ;
$ group_id = db_do ( $ dbh_node , 'DELETE FROM tgrupo WHERE nombre=?' , safe_input ( $ group_name ) ) ;
}
}
2016-06-10 13:36:41 +02:00
if ( $ group_id == - 1 ) {
print_log "[ERROR] A problem has been ocurred deleting group '$group_name'\n\n" ;
} else {
print_log "[INFO] Deleted group '$group_name'\n\n" ;
}
}
##############################################################################
# Update group
# Related option: --update_group
##############################################################################
sub cli_update_group () {
my ( $ group_id , $ group_name , $ parent_group_name , $ icon , $ description ) = @ ARGV [ 2 .. 6 ] ;
my $ result ;
2020-11-05 14:31:26 +01:00
2021-11-23 12:23:27 +01:00
if ( is_metaconsole ( $ conf ) != 1 && pandora_get_tconfig_token ( $ dbh , 'centralized_management' , '' ) ) {
print_log "[ERROR] This node is configured with centralized mode. To update a group go to metaconsole. \n\n" ;
exit ;
}
2020-11-05 14:31:26 +01:00
$ result = get_db_value ( $ dbh , 'SELECT * FROM tgrupo WHERE id_grupo=?' , $ group_id ) ;
2016-06-10 13:36:41 +02:00
if ( $ result == "0E0" ) {
print_log "[ERROR] Group '$group_id' doesn`t exist \n\n" ;
} else {
if ( defined ( $ group_name ) ) {
if ( defined ( $ parent_group_name ) ) {
2020-11-05 14:31:26 +01:00
my $ parent_group_id = 0 ;
if ( $ parent_group_name ne 'All' ) {
$ parent_group_id = get_group_id ( $ dbh , $ parent_group_name ) ;
exist_check ( $ parent_group_id , 'group name' , $ parent_group_name ) ;
}
2016-06-10 13:36:41 +02:00
if ( defined ( $ icon ) ) {
if ( defined ( $ description ) ) {
db_do ( $ dbh , 'UPDATE tgrupo SET nombre=? , parent=? , icon=? , description=? WHERE id_grupo=?' , $ group_name , $ parent_group_id , $ icon , $ description , $ group_id ) ;
} else {
db_do ( $ dbh , 'UPDATE tgrupo SET nombre=? , parent=? , icon=? WHERE id_grupo=?' , $ group_name , $ parent_group_id , $ icon , $ group_id ) ;
}
} else {
db_do ( $ dbh , 'UPDATE tgrupo SET nombre=? , parent=? WHERE id_grupo=?' , $ group_name , $ parent_group_id , $ group_id ) ;
}
} else {
db_do ( $ dbh , 'UPDATE tgrupo SET nombre=? WHERE id_grupo=?' , $ group_name , $ group_id ) ;
}
print_log "[INFO] Updated group '$group_id'\n\n" ;
}
}
}
2015-12-29 17:41:39 +01:00
###############################################################################
2017-02-01 12:47:45 +01:00
# Returns the Nodes ID where the agent is defined (Metaconsole only)
2015-12-29 17:41:39 +01:00
# Related option: --locate_agent
###############################################################################
sub cli_locate_agent () {
2019-10-17 11:14:42 +02:00
my ( $ agent_name , $ use_alias ) = @ ARGV [ 2 .. 3 ] ;
2017-02-01 12:47:45 +01:00
2015-12-29 17:41:39 +01:00
if ( is_metaconsole ( $ conf ) == 1 ) {
2017-02-01 12:47:45 +01:00
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
2015-12-29 17:41:39 +01:00
my $ servers = enterprise_hook ( 'get_metaconsole_setup_servers' , [ $ dbh ] ) ;
my @ servers_id = split ( ',' , $ servers ) ;
my @ list_servers ;
my $ list_names_servers ;
2019-10-17 11:14:42 +02:00
my @ id_agents ;
2015-12-29 17:41:39 +01:00
foreach my $ server ( @ servers_id ) {
my $ dbh_metaconsole = enterprise_hook ( 'get_node_dbh' , [ $ conf , $ server , $ dbh ] ) ;
2019-10-17 11:14:42 +02:00
@ id_agents = get_agent_ids_from_alias ( $ dbh_metaconsole , $ agent_name ) ;
2015-12-29 17:41:39 +01:00
2019-10-17 11:14:42 +02:00
foreach my $ id ( @ id_agents ) {
if ( $ id - > { 'id_agente' } == - 1 ) {
next ;
}
else {
push @ list_servers , $ server ;
last ;
}
2015-12-29 17:41:39 +01:00
}
}
2016-03-30 11:18:30 +02:00
if ( scalar ( @ list_servers ) > 0 ) {
2015-12-29 17:41:39 +01:00
$ list_names_servers = join ( ',' , @ list_servers ) ;
2019-10-17 11:14:42 +02:00
print_log "[INFO] One or more agents with the alias '$agent_name' were found in server with IDS: $list_names_servers\n\n" ;
2015-12-29 17:41:39 +01:00
}
else {
2019-10-17 11:14:42 +02:00
print_log "[ERROR] No agent with alias '$agent_name' found in any node\n\n" ;
}
} else {
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 $ agent - > { 'id_tmetaconsole_setup' } . "\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 ( scalar ( @ list_servers ) > 0 ) {
$ list_names_servers = join ( ',' , @ list_servers ) ;
print_log "[INFO] Agent '$agent_name' found in server with IDS: $list_names_servers\n\n" ;
}
else {
print_log "[ERROR] Agent '$agent_name' not found in any node\n\n" ;
}
2015-12-29 17:41:39 +01:00
}
}
2019-10-17 11:14:42 +02:00
2015-12-29 17:41:39 +01:00
}
2011-12-29 18:12:13 +01:00
else {
2019-10-17 11:14:42 +02:00
print_log "[ERROR] This function can only be used in metaconsole\n\n" ;
2011-12-29 18:12:13 +01:00
}
}
2011-11-14 14:27:21 +01:00
###############################################################################
# Disable alert system globally
# Related option: --disable_alerts
###############################################################################
sub cli_disable_alerts ($$) {
my ( $ conf , $ dbh ) = @ _ ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] Disabling all alerts \n\n" ;
2011-11-14 14:27:21 +01:00
# This works by disabling alerts in each defined group
# If you have previously a group with alert disabled, and you disable
# alerts globally, when enabled it again, it will enabled also !
db_do ( $ dbh , "UPDATE tgrupo SET disabled = 1" ) ;
exit ;
}
###############################################################################
# Enable alert system globally
# Related option: --enable_alerts
###############################################################################
sub cli_enable_alerts ($$) {
my ( $ conf , $ dbh ) = @ _ ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] Enabling all alerts \n\n" ;
2011-11-14 14:27:21 +01:00
db_do ( $ dbh , "UPDATE tgrupo SET disabled = 0" ) ;
exit ;
}
###############################################################################
# Disable enterprise ACL
# Related option: --disable_eacl
###############################################################################
sub cli_disable_eacl ($$) {
my ( $ conf , $ dbh ) = @ _ ;
2011-09-15 17:41:50 +02:00
2012-12-28 09:26:49 +01:00
print_log "[INFO] Disabling Enterprise ACL system (system wide)\n\n" ;
2011-11-14 14:27:21 +01:00
db_do ( $ dbh , "UPDATE tconfig SET `value` ='0' WHERE `token` = 'acl_enterprise'" ) ;
exit ;
}
###############################################################################
# Enable enterprise ACL
# Related option: --enable_eacl
###############################################################################
sub cli_enable_eacl ($$) {
my ( $ conf , $ dbh ) = @ _ ;
2012-12-28 09:26:49 +01:00
print_log "[INFO] Enabling Enterprise ACL system (system wide)\n\n" ;
2011-11-14 14:27:21 +01:00
db_do ( $ dbh , "UPDATE tconfig SET `value` ='1' WHERE `token` = 'acl_enterprise'" ) ;
exit ;
}
2014-12-15 14:59:22 +01:00
###############################################################################
# Disable double authentication
# Related option: --disable_double_auth
###############################################################################
sub cli_disable_double_auth () {
my $ user_id = @ ARGV [ 2 ] ;
print_log "[INFO] Disabling double authentication for the user '$user_id'\n\n" ;
$ user_id = safe_input ( $ user_id ) ;
# Delete the user secret
my $ result = db_do ( $ dbh , 'DELETE FROM tuser_double_auth WHERE id_user = ?' , $ user_id ) ;
exit ;
}
2012-01-04 16:09:02 +01:00
###############################################################################
# Enable user
# Related option: --enable_user
###############################################################################
sub cli_user_enable () {
my $ user_id = @ ARGV [ 2 ] ;
2022-10-18 16:14:35 +02:00
my $ centralized = pandora_get_tconfig_token ( $ dbh , 'centralized_management' , '' ) ;
if ( is_metaconsole ( $ conf ) != 1 && $ centralized ) {
print_log "[ERROR] This node is configured with centralized mode. To create a user go to metaconsole. \n\n" ;
2021-11-23 12:43:07 +01:00
exit ;
}
2012-01-04 16:09:02 +01:00
my $ user_disabled = get_user_disabled ( $ dbh , $ user_id ) ;
exist_check ( $ user_disabled , 'user' , $ user_id ) ;
if ( $ user_disabled == 0 ) {
2012-12-28 09:26:49 +01:00
print_log "[INFO] The user '$user_id' is already enabled. Nothing to do.\n\n" ;
2012-01-04 16:09:02 +01:00
exit ;
}
2012-12-28 09:26:49 +01:00
print_log "[INFO] Enabling user '$user_id'\n\n" ;
2012-01-04 16:09:02 +01:00
$ user_id = safe_input ( $ user_id ) ;
2022-10-18 16:14:35 +02:00
my $ result = db_do ( $ dbh , "UPDATE tusuario SET disabled = '0' WHERE id_user = '$user_id'" ) ;
if ( is_metaconsole ( $ conf ) == 1 && $ centralized ) {
my @ values ;
db_synch_update ( $ dbh , $ conf , 'tusuario' , $ dbh - > { Statement } , $ result , @ values ) ;
}
2022-10-18 12:49:51 +02:00
exit ;
2012-01-04 16:09:02 +01:00
}
###############################################################################
# Disable user
# Related option: --disable_user
###############################################################################
sub cli_user_disable () {
my $ user_id = @ ARGV [ 2 ] ;
2022-10-18 16:14:35 +02:00
my $ centralized = pandora_get_tconfig_token ( $ dbh , 'centralized_management' , '' ) ;
if ( is_metaconsole ( $ conf ) != 1 && $ centralized ) {
print_log "[ERROR] This node is configured with centralized mode. To create a user go to metaconsole. \n\n" ;
2021-11-23 12:43:07 +01:00
exit ;
}
2012-01-04 16:09:02 +01:00
my $ user_disabled = get_user_disabled ( $ dbh , $ user_id ) ;
exist_check ( $ user_disabled , 'user' , $ user_id ) ;
if ( $ user_disabled == 1 ) {
2012-12-28 09:26:49 +01:00
print_log "[INFO] The user '$user_id' is already disabled. Nothing to do.\n\n" ;
2012-01-04 16:09:02 +01:00
exit ;
}
2012-12-28 09:26:49 +01:00
print_log "[INFO] Disabling user '$user_id'\n\n" ;
2012-01-04 16:09:02 +01:00
$ user_id = safe_input ( $ user_id ) ;
2022-10-18 16:14:35 +02:00
my $ result = db_do ( $ dbh , "UPDATE tusuario SET disabled = '1' WHERE id_user = '$user_id'" ) ;
if ( is_metaconsole ( $ conf ) == 1 && $ centralized ) {
my @ values ;
db_synch_update ( $ dbh , $ conf , 'tusuario' , $ dbh - > { Statement } , $ result , @ values ) ;
}
2012-01-04 16:09:02 +01:00
2022-10-18 16:14:35 +02:00
exit ;
2012-01-04 16:09:02 +01:00
}
2012-01-17 14:10:54 +01:00
###############################################################################
# Stop Planned downtime
# Related option: --stop_downtime
###############################################################################
sub cli_stop_downtime () {
my $ downtime_name = @ ARGV [ 2 ] ;
my $ downtime_id = pandora_get_planned_downtime_id ( $ dbh , $ downtime_name ) ;
exist_check ( $ downtime_id , 'planned downtime' , $ downtime_id ) ;
my $ current_time = time ;
2019-09-11 12:36:15 +02:00
my $ data = get_db_single_row ( $ dbh , 'SELECT date_to, type_execution, executed FROM tplanned_downtime WHERE id=?' , $ downtime_id ) ;
2019-09-11 10:04:18 +02:00
2019-09-11 11:41:14 +02:00
if ( $ data - > { 'type_execution' } eq 'periodically' && $ data - > { 'executed' } == 1 ) {
print_log "[ERROR] Planned_downtime '$downtime_name' cannot be stopped.\n" ;
print_log "[INFO] Periodical and running planned downtime cannot be stopped.\n\n" ;
2019-09-11 10:04:18 +02:00
exit ;
}
2019-09-11 11:41:14 +02:00
2019-09-11 12:36:15 +02:00
if ( $ current_time >= $ data - > { 'date_to' } ) {
2012-12-28 09:26:49 +01:00
print_log "[INFO] Planned_downtime '$downtime_name' is already stopped\n\n" ;
2012-01-17 14:10:54 +01:00
exit ;
}
2012-12-28 09:26:49 +01:00
print_log "[INFO] Stopping planned downtime '$downtime_name'\n\n" ;
2012-01-17 14:10:54 +01:00
my $ parameters - > { 'date_to' } = time ;
2015-04-06 15:26:26 +02:00
db_process_update ( $ dbh , 'tplanned_downtime' , $ parameters , { 'id' = > $ downtime_id } ) ;
2012-01-17 14:10:54 +01:00
}
2012-01-05 17:11:11 +01:00
###############################################################################
# Get module data
# Related option: --get_module_data
###############################################################################
sub cli_module_get_data () {
2019-10-17 11:14:42 +02:00
my ( $ agent_name , $ module_name , $ interval , $ csv_separator , $ use_alias ) = @ ARGV [ 2 .. 6 ] ;
2015-02-06 16:26:07 +01:00
$ csv_separator = '|' unless defined ( $ csv_separator ) ;
if ( $ interval <= 0 ) {
print_log "[ERROR] Interval must be a possitive value\n\n" ;
exit ;
}
2019-10-17 11:14:42 +02:00
my @ id_agents ;
2015-02-06 16:26:07 +01:00
2019-10-17 11:14:42 +02:00
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
my $ agent_id ;
foreach my $ id ( @ id_agents ) {
$ agent_id = $ id - > { 'id_agente' } ; # se hace para cada agente
exist_check ( $ agent_id , 'agent name' , $ agent_name ) ;
my $ module_id = get_agent_module_id ( $ dbh , $ module_name , $ agent_id ) ; # se hace para ada agente
if ( $ module_id == - 1 ) {
next ;
}
my $ id_agent_module = get_agent_module_id ( $ dbh , $ module_name , $ agent_id ) ; # 6
my $ module_type_id = get_db_value ( $ dbh ,
"SELECT id_tipo_modulo FROM tagente_modulo WHERE id_agente_modulo = ?" ,
$ id_agent_module ) ; # se hace para cada agente
my $ module_type = get_db_value ( $ dbh ,
"SELECT nombre FROM ttipo_modulo WHERE id_tipo = ?" ,
$ module_type_id ) ; # se hace para cada agente
my @ data = NULL ;
if ( $ module_type eq "log4x" ) {
@ data = get_db_rows ( $ dbh , " SELECT utimestamp , datos
FROM tagente_datos_log4x
WHERE id_agente_modulo = $ id_agent_module
AND utimestamp > ( UNIX_TIMESTAMP ( NOW ( ) ) - $ interval )
ORDER BY utimestamp DESC " ) ;
}
elsif ( $ module_type =~ m/_string/ ) {
@ data = get_db_rows ( $ dbh , " SELECT utimestamp , datos
FROM tagente_datos_string
WHERE id_agente_modulo = $ id_agent_module
AND utimestamp > ( UNIX_TIMESTAMP ( NOW ( ) ) - $ interval )
ORDER BY utimestamp DESC " ) ;
}
else {
@ data = get_db_rows ( $ dbh , " SELECT utimestamp , datos
FROM tagente_datos
WHERE id_agente_modulo = $ id_agent_module
AND utimestamp > ( UNIX_TIMESTAMP ( NOW ( ) ) - $ interval )
ORDER BY utimestamp DESC " ) ;
}
foreach my $ data_timestamp ( @ data ) {
print $ data_timestamp - > { 'utimestamp' } ;
print $ csv_separator ;
print $ data_timestamp - > { 'datos' } ;
print "\n" ;
}
}
} else {
my $ agent_id = get_agent_id ( $ dbh , $ agent_name ) ; # se hace para cada agente
exist_check ( $ agent_id , 'agent name' , $ agent_name ) ;
my $ module_id = get_agent_module_id ( $ dbh , $ module_name , $ agent_id ) ; # se hace para ada agente
exist_check ( $ module_id , 'module name' , $ module_name ) ;
my $ id_agent_module = get_agent_module_id ( $ dbh , $ module_name , $ agent_id ) ; # 6
my $ module_type_id = get_db_value ( $ dbh ,
"SELECT id_tipo_modulo FROM tagente_modulo WHERE id_agente_modulo = ?" ,
$ id_agent_module ) ; # se hace para cada agente
my $ module_type = get_db_value ( $ dbh ,
"SELECT nombre FROM ttipo_modulo WHERE id_tipo = ?" ,
$ module_type_id ) ; # se hace para cada agente
my @ data = NULL ;
if ( $ module_type eq "log4x" ) {
@ data = get_db_rows ( $ dbh , " SELECT utimestamp , datos
FROM tagente_datos_log4x
WHERE id_agente_modulo = $ id_agent_module
AND utimestamp > ( UNIX_TIMESTAMP ( NOW ( ) ) - $ interval )
ORDER BY utimestamp DESC " ) ;
}
elsif ( $ module_type =~ m/_string/ ) {
@ data = get_db_rows ( $ dbh , " SELECT utimestamp , datos
FROM tagente_datos_string
WHERE id_agente_modulo = $ id_agent_module
AND utimestamp > ( UNIX_TIMESTAMP ( NOW ( ) ) - $ interval )
ORDER BY utimestamp DESC " ) ;
}
else {
@ data = get_db_rows ( $ dbh , " SELECT utimestamp , datos
FROM tagente_datos
WHERE id_agente_modulo = $ id_agent_module
AND utimestamp > ( UNIX_TIMESTAMP ( NOW ( ) ) - $ interval )
ORDER BY utimestamp DESC " ) ;
}
foreach my $ data_timestamp ( @ data ) {
print $ data_timestamp - > { 'utimestamp' } ;
print $ csv_separator ;
print $ data_timestamp - > { 'datos' } ;
print "\n" ;
}
2012-01-05 17:11:11 +01:00
}
2019-10-17 11:14:42 +02:00
2012-01-05 17:11:11 +01:00
2015-02-06 16:26:07 +01:00
exit ;
2012-01-05 17:11:11 +01:00
}
2013-01-31 19:02:41 +01:00
##############################################################################
# Enable or disable event flow protection
# Related option: --create_netflow_filter
##############################################################################
sub cli_set_event_storm_protection () {
my $ value = @ ARGV [ 2 ] ;
# Check for a valid value
if ( $ value != 0 && $ value != 1 ) {
print_log "[ERROR] Invalid value: $value. Value must be either 0 or 1\n\n" ;
return ;
}
# Set the value of event
db_do ( $ dbh , 'UPDATE tconfig SET value=? WHERE token=?' , $ value , 'event_storm_protection' ) ;
}
2012-02-13 15:07:02 +01:00
##############################################################################
# Return event name given a event id
##############################################################################
sub pandora_get_event_name ($$) {
my ( $ dbh , $ id_event ) = @ _ ;
2022-05-31 12:50:43 +02:00
my $ event_name = get_db_value ( $ dbh , 'SELECT evento FROM tevento WHERE id_evento = ?' , $ id_event ) ;
2012-02-13 15:07:02 +01:00
return defined ( $ event_name ) ? $ event_name : - 1 ;
}
2014-08-21 02:39:25 +02:00
##########################################################################
## Update event from hash
##########################################################################
sub pandora_update_event_from_hash ($$$$) {
my ( $ parameters , $ where_column , $ where_value , $ dbh ) = @ _ ;
2014-10-15 17:02:49 +02:00
2022-05-31 12:50:43 +02:00
my $ event_id = db_process_update ( $ dbh , 'tevento' , $ parameters , { $ where_column = > $ where_value } ) ;
2014-08-21 02:39:25 +02:00
return $ event_id ;
}
##############################################################################
# Return event comment given a event id
##############################################################################
sub pandora_get_event_comment ($$) {
my ( $ dbh , $ id_event ) = @ _ ;
2022-05-31 12:50:43 +02:00
my $ event_name = get_db_value ( $ dbh , 'SELECT user_comment FROM tevento WHERE id_evento = ?' , $ id_event ) ;
2014-08-21 02:39:25 +02:00
return defined ( $ event_name ) ? $ event_name : - 1 ;
}
2012-02-14 15:53:22 +01:00
##############################################################################
# Return user id given a user name
##############################################################################
sub pandora_get_user_id ($$) {
my ( $ dbh , $ user_name ) = @ _ ;
my $ user_id = get_db_value ( $ dbh , 'SELECT id_user FROM tusuario WHERE id_user = ? or fullname = ?' , $ user_name , $ user_name ) ;
return defined ( $ user_id ) ? $ user_id : - 1 ;
}
2012-05-17 11:42:52 +02:00
##############################################################################
# Return network component id given the name
##############################################################################
sub pandora_get_network_component_id ($$) {
my ( $ dbh , $ name ) = @ _ ;
my $ nc_id = get_db_value ( $ dbh , 'SELECT id_nc FROM tnetwork_component WHERE name = ?' , safe_input ( $ name ) ) ;
return defined ( $ nc_id ) ? $ nc_id : - 1 ;
}
2014-05-03 02:57:53 +02:00
##############################################################################
# Create special day
# Related option: --create_special_day
##############################################################################
sub cli_create_special_day () {
2021-11-04 12:33:40 +01:00
my ( $ special_day , $ calendar_name , $ same_day , $ description , $ group_name ) = @ ARGV [ 2 .. 5 ] ;
my $ calendar_name_exists = pandora_get_calendar_id ( $ dbh , $ calendar_name ) ;
my $ same_day_exists = pandora_get_same_day_id ( $ dbh , $ same_day ) ;
2014-05-03 02:57:53 +02:00
my $ special_day_exists = pandora_get_special_day_id ( $ dbh , $ special_day ) ;
non_exist_check ( $ special_day_exists , 'special day' , $ special_day ) ;
2021-11-04 12:33:40 +01:00
non_exist_check ( $ calendar_name_exists , 'calendar name' , $ calendar_name ) ;
non_exist_check ( $ same_day_exists , 'same day' , $ same_day ) ;
2014-05-03 02:57:53 +02:00
my $ group_id = 0 ;
2021-11-04 12:33:40 +01:00
2014-05-03 02:57:53 +02:00
# If group name is not defined, we assign group All (0)
if ( defined ( $ group_name ) ) {
$ group_id = get_group_id ( $ dbh , decode ( 'UTF-8' , $ group_name ) ) ;
exist_check ( $ group_id , 'group' , $ group_name ) ;
}
else {
$ group_name = 'All' ;
}
if ( $ special_day !~ /^[0-9]{4}-[0-9]{2}-[0-9]{2}$/ ) {
print_log "[ERROR] '$special_day' is invalid date format.\n\n" ;
$ param = '--create_special_day' ;
help_screen ( ) ;
exit 1 ;
}
2021-11-04 12:33:40 +01:00
if ( $ same_day !~ /monday|tuesday|wednesday|thursday|friday|saturday|sunday|holiday/ ) {
2014-05-03 02:57:53 +02:00
print_log "[ERROR] '$same_day' is invalid day.\n\n" ;
$ param = '--create_special_day' ;
help_screen ( ) ;
exit 1 ;
}
2021-11-04 12:33:40 +01:00
2014-05-03 02:57:53 +02:00
my % parameters ;
2021-11-04 12:33:40 +01:00
2016-01-19 09:58:48 +01:00
$ parameters { "${RDBMS_QUOTE}date${RDBMS_QUOTE}" } = $ special_day ;
2014-05-03 02:57:53 +02:00
$ parameters { 'same_day' } = $ same_day ;
$ parameters { 'description' } = decode ( 'UTF-8' , $ description ) ;
$ parameters { 'id_group' } = $ group_id ;
2021-11-04 12:33:40 +01:00
$ parameters { 'calendar_name' } = $ calendar_name ;
2014-05-03 02:57:53 +02:00
pandora_create_special_day_from_hash ( $ conf , \ % parameters , $ dbh ) ;
}
##############################################################################
# Update a special day.
# Related option: --update_special_day
##############################################################################
sub cli_update_special_day () {
my ( $ special_day , $ field , $ new_value ) = @ ARGV [ 2 .. 4 ] ;
my $ special_day_id = pandora_get_special_day_id ( $ dbh , $ special_day ) ;
exist_check ( $ special_day_id , 'special day' , $ special_day ) ;
if ( $ field eq 'date' ) {
if ( $ new_value !~ /^[0-9]{4}-[0-9]{2}-[0-9]{2}$/ ) {
print_log "[ERROR] '$new_value' is invalid date format.\n\n" ;
$ param = '--update_special_day' ;
help_screen ( ) ;
exit 1 ;
}
}
elsif ( $ field eq 'same_day' ) {
if ( $ new_value !~ /monday|tuesday|wednesday|thursday|friday|saturday|sunday/ ) {
print_log "[ERROR] '$new_value' is invalid day.\n\n" ;
$ param = '--update_special_day' ;
help_screen ( ) ;
exit 1 ;
}
}
elsif ( $ field eq 'description' ) {
$ new_value = decode ( 'UTF-8' , $ new_value ) ;
}
elsif ( $ field eq 'group' ) {
my $ group_id = 0 ;
$ group_id = get_group_id ( $ dbh , decode ( 'UTF-8' , $ new_value ) ) ;
exist_check ( $ group_id , 'group' , $ new_value ) ;
$ new_value = $ group_id ;
$ field = 'id_group' ;
}
else {
2022-05-05 11:47:49 +02:00
print_log "[ERROR] Field '$field' doesn't exist\n\n" ;
2014-05-03 02:57:53 +02:00
exit ;
}
print_log "[INFO] Updating field '$field' in special day '$special_day'\n\n" ;
my $ update ;
$ update - > { $ field } = $ new_value ;
pandora_update_special_day_from_hash ( $ update , 'id' , $ special_day_id , $ dbh ) ;
}
##############################################################################
# Delete a special_day.
# Related option: --delete_special_day
##############################################################################
sub cli_delete_special_day () {
my $ special_day = @ ARGV [ 2 ] ;
print_log "[INFO] Deleting special day '$special_day' \n\n" ;
my $ result = pandora_delete_special_day ( $ dbh , $ special_day ) ;
exist_check ( $ result , 'special day' , $ special_day ) ;
}
2017-09-11 16:09:13 +02:00
##############################################################################
# Creates a new visual console.
# Related option: --create_visual_console
##############################################################################
sub cli_create_visual_console () {
2017-09-13 13:27:37 +02:00
my ( $ name , $ background , $ width , $ height , $ group , $ mode , $ element_square_positions , $ background_color , $ elements ) = @ ARGV [ 2 .. 10 ] ;
2017-09-11 16:09:13 +02:00
if ( $ name eq '' ) {
print_log "[ERROR] Name field cannot be empty.\n\n" ;
exit 1 ;
}
elsif ( $ background eq '' ) {
print_log "[ERROR] Background field cannot be empty.\n\n" ;
exit 1 ;
}
elsif ( ( $ width eq '' ) || ( $ height eq '' ) ) {
print_log "[ERROR] Please specify size.\n\n" ;
exit 1 ;
}
elsif ( $ group eq '' ) {
print_log "[ERROR] Group field cannot be empty.\n\n" ;
exit 1 ;
}
2017-09-13 13:27:37 +02:00
elsif ( $ mode eq '' ) {
print_log "[ERROR] Mode parameter must be 'static_objects' or 'auto_creation'.\n\n" ;
exit 1 ;
}
2017-09-11 16:09:13 +02:00
if ( $ background_color eq '' ) {
$ background_color = '#FFF' ;
}
print_log "[INFO] Creating visual console '$name' \n\n" ;
my $ vc_id = db_insert ( $ dbh , 'id' , ' INSERT INTO tlayout ( name , id_group , background , width , height , background_color )
VALUES ( ? , ? , ? , ? , ? , ? ) ' , safe_input ( $ name ) , $ group , $ background , $ width , $ height , $ background_color ) ;
print_log "[INFO] The visual console id is '$vc_id' \n\n" ;
if ( $ elements ne '' ) {
2017-09-11 17:56:42 +02:00
my $ elements_in_array = decode_json ( $ elements ) ;
2017-09-13 13:27:37 +02:00
if ( $ mode eq 'static_objects' ) {
my $ elem_count = 1 ;
foreach my $ elem ( @$ elements_in_array ) {
my $ pos_x = $ elem - > { 'pos_x' } ;
my $ pos_y = $ elem - > { 'pos_y' } ;
my $ width = $ elem - > { 'width' } ;
my $ height = $ elem - > { 'height' } ;
my $ label = $ elem - > { 'label' } ;
my $ image = $ elem - > { 'image' } ;
my $ type = $ elem - > { 'type' } ;
my $ period = $ elem - > { 'period' } ;
my $ id_agente_modulo = $ elem - > { 'id_agente_modulo' } ;
my $ id_agent = $ elem - > { 'id_agent' } ;
my $ id_layout_linked = $ elem - > { 'id_layout_linked' } ;
2017-09-27 12:26:13 +02:00
my $ parent_item = 0 ;
2017-09-13 13:27:37 +02:00
my $ enable_link = $ elem - > { 'enable_link' } ;
my $ id_metaconsole = $ elem - > { 'id_metaconsole' } ;
my $ id_group = $ elem - > { 'id_group' } ;
my $ id_custom_graph = $ elem - > { 'id_custom_graph' } ;
my $ border_width = $ elem - > { 'border_width' } ;
my $ type_graph = $ elem - > { 'type_graph' } ;
my $ label_position = $ elem - > { 'label_position' } ;
my $ border_color = $ elem - > { 'border_color' } ;
my $ fill_color = $ elem - > { 'fill_color' } ;
2017-11-17 13:12:35 +01:00
my $ show_statistics = $ elem - > { 'fill_color' } ;
my $ id_layout_linked_weight = $ elem - > { 'id_layout_linked_weight' } ;
my $ element_group = $ elem - > { 'element_group' } ;
my $ show_on_top = $ elem - > { 'show_on_top' } ;
2017-09-13 13:27:37 +02:00
2017-11-17 13:12:35 +01:00
my $ elem_id = db_insert ( $ dbh , 'id' , ' INSERT INTO tlayout_data ( id_layout , pos_x , pos_y , height , width , label , image , type , period , id_agente_modulo , id_agent , id_layout_linked , parent_item , enable_link , id_metaconsole , id_group , id_custom_graph , border_width , type_graph , label_position , border_color , fill_color , show_statistics , id_layout_linked_weight , element_group , show_on_top )
VALUES ( ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? ) ' , $ vc_id , $ pos_x , $ pos_y , $ height , $ width , $ label , $ image , $ type , $ period , $ id_agente_modulo , $ id_agent , $ id_layout_linked , $ parent_item , $ enable_link , $ id_metaconsole , $ id_group , $ id_custom_graph , $ border_width , $ type_graph , $ label_position , $ border_color , $ fill_color , 0 , $ id_layout_linked_weight , $ element_group , $ show_on_top ) ;
2017-09-13 13:27:37 +02:00
print_log "[INFO] The element id in position $elem_count is '$elem_id' \n\n" ;
$ elem_count + + ;
}
}
elsif ( $ mode eq 'auto_creation' ) {
if ( $ element_square_positions eq '' ) {
print_log "[ERROR] With this mode, square positions is obligatory'.\n\n" ;
exit 1 ;
}
else {
my $ positions = decode_json ( $ element_square_positions ) ;
my $ pos1X = $ positions - > { 'pos1x' } ;
my $ pos1Y = $ positions - > { 'pos1y' } ;
my $ pos2X = $ positions - > { 'pos2x' } ;
my $ pos2Y = $ positions - > { 'pos2y' } ;
my $ number_of_elements = scalar ( @$ elements_in_array ) ;
2017-09-28 09:56:15 +02:00
my $ x_divider = 8 ;
2017-09-13 13:27:37 +02:00
my $ y_divider = 1 ;
for ( my $ i = 1 ; $ i <= 1000 ; $ i + + ) {
2017-09-28 09:56:15 +02:00
if ( ( $ i * 8 ) < $ number_of_elements ) {
2017-09-13 13:27:37 +02:00
$ y_divider + + ;
}
else {
last ;
}
}
my $ elem_width = ( $ pos2X - $ pos1X ) / $ x_divider ;
my $ elem_height = ( $ pos2Y - $ pos1Y ) / $ y_divider ;
2017-09-28 09:56:15 +02:00
if ( $ number_of_elements <= 8 ) {
$ elem_height = ( $ pos2Y - $ pos1Y ) / 4 ;
2017-09-13 13:27:37 +02:00
}
2017-09-11 17:56:42 +02:00
2017-09-13 13:27:37 +02:00
my $ elem_count = 1 ;
2017-09-27 13:15:51 +02:00
my $ pos_aux_count = 0 ;
my $ pos_helper_x = $ pos1X ;
my $ pos_helper_y = $ pos1Y ;
2017-09-13 13:27:37 +02:00
foreach my $ elem ( @$ elements_in_array ) {
2017-09-27 13:15:51 +02:00
my $ pos_x = $ pos_helper_x ;
my $ pos_y = $ pos_helper_y ;
2017-09-13 13:27:37 +02:00
my $ width = $ elem_width ;
my $ height = $ elem_height ;
my $ label = $ elem - > { 'label' } ;
my $ image = $ elem - > { 'image' } ;
my $ type = $ elem - > { 'type' } ;
my $ period = $ elem - > { 'period' } ;
my $ id_agente_modulo = $ elem - > { 'id_agente_modulo' } ;
my $ id_agent = $ elem - > { 'id_agent' } ;
my $ id_layout_linked = $ elem - > { 'id_layout_linked' } ;
my $ parent_item = $ elem - > { 'parent_item' } ;
my $ enable_link = $ elem - > { 'enable_link' } ;
my $ id_metaconsole = $ elem - > { 'id_metaconsole' } ;
my $ id_group = $ elem - > { 'id_group' } ;
my $ id_custom_graph = $ elem - > { 'id_custom_graph' } ;
my $ border_width = $ elem - > { 'border_width' } ;
my $ type_graph = $ elem - > { 'type_graph' } ;
my $ label_position = $ elem - > { 'label_position' } ;
my $ border_color = $ elem - > { 'border_color' } ;
my $ fill_color = $ elem - > { 'fill_color' } ;
2017-11-17 13:12:35 +01:00
my $ id_layout_linked_weight = $ elem - > { 'id_layout_linked_weight' } ;
my $ element_group = $ elem - > { 'element_group' } ;
my $ show_on_top = $ elem - > { 'show_on_top' } ;
2017-09-13 13:27:37 +02:00
2017-11-17 13:12:35 +01:00
my $ elem_id = db_insert ( $ dbh , 'id' , ' INSERT INTO tlayout_data ( id_layout , pos_x , pos_y , height , width , label , image , type , period , id_agente_modulo , id_agent , id_layout_linked , parent_item , enable_link , id_metaconsole , id_group , id_custom_graph , border_width , type_graph , label_position , border_color , fill_color , show_statistics , id_layout_linked_weight , element_group , show_on_top )
VALUES ( ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? ) ' , $ vc_id , $ pos_x , $ pos_y , $ height , $ width , $ label , $ image , $ type , $ period , $ id_agente_modulo , $ id_agent , $ id_layout_linked , $ parent_item , $ enable_link , $ id_metaconsole , $ id_group , $ id_custom_graph , $ border_width , $ type_graph , $ label_position , $ border_color , $ fill_color , 0 , $ id_layout_linked_weight , $ element_group , $ show_on_top ) ;
2017-09-13 13:27:37 +02:00
print_log "[INFO] The element id in position $elem_count is '$elem_id' \n\n" ;
$ elem_count + + ;
2017-09-28 09:56:15 +02:00
if ( $ pos_aux_count == 7 ) {
2017-09-27 13:15:51 +02:00
$ pos_helper_x = $ pos1X ;
$ pos_helper_y += $ elem_height ;
$ pos_aux_count = 0 ;
2017-09-13 13:27:37 +02:00
}
else {
2017-09-27 13:15:51 +02:00
$ pos_aux_count + + ;
$ pos_helper_x += $ elem_width ;
2017-09-13 13:27:37 +02:00
}
}
}
}
else {
print_log "[ERROR] Mode parameter must be 'static_objects' or 'auto_creation'.\n\n" ;
exit 1 ;
2017-09-11 16:09:13 +02:00
}
}
}
2017-09-14 12:07:52 +02:00
##############################################################################
# Edit a visual console.
# Related option: --edit_visual_console
##############################################################################
sub cli_edit_visual_console () {
my ( $ id , $ name , $ background , $ width , $ height , $ group , $ mode , $ element_square_positions , $ background_color , $ elements ) = @ ARGV [ 2 .. 11 ] ;
if ( $ id eq '' ) {
print_log "[ERROR] ID field cannot be empty.\n\n" ;
exit 1 ;
}
my $ console = get_db_single_row ( $ dbh , " SELECT *
FROM tlayout
WHERE id = $ id " ) ;
my $ new_name = $ console - > { 'name' } ;
my $ new_background = $ console - > { 'background' } ;
my $ new_console_width = $ console - > { 'width' } ;
my $ new_console_height = $ console - > { 'height' } ;
my $ new_console_id_group = $ console - > { 'id_group' } ;
my $ new_background_color = $ console - > { 'background_color' } ;
if ( $ name ne '' ) {
$ new_name = $ name ;
}
if ( $ background ne '' ) {
$ new_background = $ background ;
}
if ( $ width ne '' ) {
$ new_console_width = $ width ;
}
if ( $ height ne '' ) {
$ new_console_height = $ height ;
}
if ( $ group ne '' ) {
$ new_console_id_group = $ group ;
}
if ( $ background_color ne '' ) {
$ new_background_color = $ background_color ;
}
print_log "[INFO] The visual console with id $id is updated \n\n" ;
db_update ( $ dbh , "UPDATE tlayout SET name = '" . $ new_name . "', background = '" . $ new_background . "', width = " . $ new_console_width . ", height = " . $ new_console_height . ", id_group = " . $ new_console_id_group . ", background_color = '" . $ new_background_color . "' WHERE id = " . $ id ) ;
if ( $ elements ne '' ) {
my $ elements_in_array = decode_json ( $ elements ) ;
if ( $ mode eq 'static_objects' ) {
foreach my $ elem ( @$ elements_in_array ) {
if ( defined ( $ elem - > { 'id' } ) ) {
print_log "[INFO] Edit element with id " . $ elem - > { 'id' } . " \n\n" ;
my $ element_in_db = get_db_single_row ( $ dbh , " SELECT *
FROM tlayout_data
WHERE id = " . $ elem - > { 'id' } ) ;
my $ new_pos_x = $ element_in_db - > { 'pos_x' } ;
my $ new_pos_y = $ element_in_db - > { 'pos_y' } ;
my $ new_width = $ element_in_db - > { 'width' } ;
my $ new_height = $ element_in_db - > { 'height' } ;
my $ new_label = $ element_in_db - > { 'label' } ;
my $ new_image = $ element_in_db - > { 'image' } ;
my $ new_type = $ element_in_db - > { 'type' } ;
my $ new_period = $ element_in_db - > { 'period' } ;
my $ new_id_agente_modulo = $ element_in_db - > { 'id_agente_modulo' } ;
my $ new_id_agent = $ element_in_db - > { 'id_agent' } ;
my $ new_id_layout_linked = $ element_in_db - > { 'id_layout_linked' } ;
my $ new_parent_item = $ element_in_db - > { 'parent_item' } ;
my $ new_enable_link = $ element_in_db - > { 'enable_link' } ;
my $ new_id_metaconsole = $ element_in_db - > { 'id_metaconsole' } ;
my $ new_id_group = $ element_in_db - > { 'id_group' } ;
my $ new_id_custom_graph = $ element_in_db - > { 'id_custom_graph' } ;
my $ new_border_width = $ element_in_db - > { 'border_width' } ;
my $ new_type_graph = $ element_in_db - > { 'type_graph' } ;
my $ new_label_position = $ element_in_db - > { 'label_position' } ;
my $ new_border_color = $ element_in_db - > { 'border_color' } ;
my $ new_fill_color = $ element_in_db - > { 'fill_color' } ;
2017-11-17 13:12:35 +01:00
my $ new_id_layout_linked_weight = $ elem - > { 'id_layout_linked_weight' } ;
my $ new_element_group = $ elem - > { 'element_group' } ;
my $ new_show_on_top = $ elem - > { 'show_on_top' } ;
2017-09-14 12:07:52 +02:00
if ( defined ( $ elem - > { 'pos_x' } ) ) {
$ new_pos_x = $ elem - > { 'pos_x' } ;
}
if ( defined ( $ elem - > { 'pos_y' } ) ) {
$ new_pos_y = $ elem - > { 'pos_y' } ;
}
if ( defined ( $ elem - > { 'width' } ) ) {
$ new_width = $ elem - > { 'width' } ;
}
if ( defined ( $ elem - > { 'height' } ) ) {
$ new_height = $ elem - > { 'height' } ;
}
if ( defined ( $ elem - > { 'label' } ) ) {
$ new_label = $ elem - > { 'label' } ;
}
if ( defined ( $ elem - > { 'image' } ) ) {
$ new_image = $ elem - > { 'image' } ;
}
if ( defined ( $ elem - > { 'type' } ) ) {
$ new_type = $ elem - > { 'type' } ;
}
if ( defined ( $ elem - > { 'period' } ) ) {
$ new_period = $ elem - > { 'period' } ;
}
if ( defined ( $ elem - > { 'id_agente_modulo' } ) ) {
$ new_id_agente_modulo = $ elem - > { 'id_agente_modulo' } ;
}
if ( defined ( $ elem - > { 'id_agent' } ) ) {
$ new_id_agent = $ elem - > { 'id_agent' } ;
}
if ( defined ( $ elem - > { 'id_layout_linked' } ) ) {
$ new_id_layout_linked = $ elem - > { 'id_layout_linked' } ;
}
if ( defined ( $ elem - > { 'parent_item' } ) ) {
$ new_parent_item = $ elem - > { 'parent_item' } ;
}
if ( defined ( $ elem - > { 'enable_link' } ) ) {
$ new_enable_link = $ elem - > { 'enable_link' } ;
}
if ( defined ( $ elem - > { 'id_metaconsole' } ) ) {
$ new_id_metaconsole = $ elem - > { 'id_metaconsole' } ;
}
if ( defined ( $ elem - > { 'id_group' } ) ) {
$ new_id_group = $ elem - > { 'id_group' } ;
}
if ( defined ( $ elem - > { 'id_custom_graph' } ) ) {
$ new_id_custom_graph = $ elem - > { 'id_custom_graph' } ;
}
if ( defined ( $ elem - > { 'border_width' } ) ) {
$ new_border_width = $ elem - > { 'border_width' } ;
}
if ( defined ( $ elem - > { 'type_graph' } ) ) {
$ new_type_graph = $ elem - > { 'type_graph' } ;
}
if ( defined ( $ elem - > { 'label_position' } ) ) {
$ new_label_position = $ elem - > { 'label_position' } ;
}
if ( defined ( $ elem - > { 'border_color' } ) ) {
$ new_border_color = $ elem - > { 'border_color' } ;
}
if ( defined ( $ elem - > { 'fill_color' } ) ) {
$ new_fill_color = $ elem - > { 'fill_color' } ;
}
2017-11-17 13:12:35 +01:00
if ( defined ( $ elem - > { 'id_layout_linked_weight' } ) ) {
$ new_id_layout_linked_weight = $ elem - > { 'id_layout_linked_weight' } ;
}
if ( defined ( $ elem - > { 'element_group' } ) ) {
$ new_element_group = $ elem - > { 'element_group' } ;
}
if ( defined ( $ elem - > { 'show_on_top' } ) ) {
$ new_show_on_top = $ elem - > { 'show_on_top' } ;
}
2017-09-14 12:07:52 +02:00
db_update ( $ dbh , "UPDATE tlayout_data SET pos_x = " . $ new_pos_x . ", pos_y = " . $ new_pos_y . ", width = " . $ new_width .
", height = " . $ new_height . ", label = '" . $ new_label . "', image = '" . $ new_image .
"', type = " . $ new_type . ", period = " . $ new_period . ", id_agente_modulo = " . $ new_id_agente_modulo .
", id_agent = " . $ new_id_agent . ", id_layout_linked = " . $ new_id_layout_linked . ", parent_item = " . $ new_parent_item .
", enable_link = " . $ new_enable_link . ", id_metaconsole = " . $ new_id_metaconsole . ", id_group = " . $ new_id_group .
", id_custom_graph = " . $ new_id_custom_graph . ", border_width = " . $ new_border_width . ", type_graph = '" . $ new_type_graph .
"', label_position = '" . $ new_label_position . "', border_color = '" . $ new_border_color . "', fill_color = '" . $ new_fill_color .
2017-11-17 13:12:35 +01:00
"', id_layout_linked_weight = '" . $ new_id_layout_linked_weight . "', element_group = '" . $ new_element_group . "', show_on_top = '" . $ new_show_on_top .
2017-09-14 12:07:52 +02:00
"' WHERE id = " . $ elem - > { 'id' } ) ;
print_log "[INFO] Element with id " . $ elem - > { 'id' } . " has been updated \n\n" ;
}
else {
my $ pos_x = $ elem - > { 'pos_x' } ;
my $ pos_y = $ elem - > { 'pos_y' } ;
my $ width = $ elem - > { 'width' } ;
my $ height = $ elem - > { 'height' } ;
my $ label = $ elem - > { 'label' } ;
my $ image = $ elem - > { 'image' } ;
my $ type = $ elem - > { 'type' } ;
my $ period = $ elem - > { 'period' } ;
my $ id_agente_modulo = $ elem - > { 'id_agente_modulo' } ;
my $ id_agent = $ elem - > { 'id_agent' } ;
my $ id_layout_linked = $ elem - > { 'id_layout_linked' } ;
my $ parent_item = $ elem - > { 'parent_item' } ;
my $ enable_link = $ elem - > { 'enable_link' } ;
my $ id_metaconsole = $ elem - > { 'id_metaconsole' } ;
my $ id_group = $ elem - > { 'id_group' } ;
my $ id_custom_graph = $ elem - > { 'id_custom_graph' } ;
my $ border_width = $ elem - > { 'border_width' } ;
my $ type_graph = $ elem - > { 'type_graph' } ;
my $ label_position = $ elem - > { 'label_position' } ;
my $ border_color = $ elem - > { 'border_color' } ;
my $ fill_color = $ elem - > { 'fill_color' } ;
2017-11-17 13:12:35 +01:00
my $ id_layout_linked_weight = $ elem - > { 'id_layout_linked_weight' } ;
my $ element_group = $ elem - > { 'element_group' } ;
my $ show_on_top = $ elem - > { 'show_on_top' } ;
2017-09-14 12:07:52 +02:00
2017-11-17 13:12:35 +01:00
my $ new_elem_id = db_insert ( $ dbh , 'id' , ' INSERT INTO tlayout_data ( id_layout , pos_x , pos_y , height , width , label , image , type , period , id_agente_modulo , id_agent , id_layout_linked , parent_item , enable_link , id_metaconsole , id_group , id_custom_graph , border_width , type_graph , label_position , border_color , fill_color , show_statistics , id_layout_linked_weight , element_group , show_on_top )
VALUES ( ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? ) ' , $ id , $ pos_x , $ pos_y , $ height , $ width , $ label , $ image , $ type , $ period , $ id_agente_modulo , $ id_agent , $ id_layout_linked , $ parent_item , $ enable_link , $ id_metaconsole , $ id_group , $ id_custom_graph , $ border_width , $ type_graph , $ label_position , $ border_color , $ fill_color , 0 , $ id_layout_linked_weight , $ element_group , $ show_on_top ) ;
2017-09-14 12:07:52 +02:00
print_log "[INFO] New element with id $new_elem_id has been created \n\n" ;
}
}
}
elsif ( $ mode eq 'auto_creation' ) {
if ( $ element_square_positions eq '' ) {
print_log "[ERROR] With this mode, square positions is obligatory'.\n\n" ;
exit 1 ;
}
else {
2017-09-14 13:14:31 +02:00
foreach my $ elem ( @$ elements_in_array ) {
if ( defined ( $ elem - > { 'id' } ) ) {
print_log "[INFO] Edit element with id " . $ elem - > { 'id' } . " \n\n" ;
my $ element_in_db = get_db_single_row ( $ dbh , " SELECT *
FROM tlayout_data
WHERE id = " . $ elem - > { 'id' } ) ;
my $ new_pos_x = $ element_in_db - > { 'pos_x' } ;
my $ new_pos_y = $ element_in_db - > { 'pos_y' } ;
my $ new_width = $ element_in_db - > { 'width' } ;
my $ new_height = $ element_in_db - > { 'height' } ;
my $ new_label = $ element_in_db - > { 'label' } ;
my $ new_image = $ element_in_db - > { 'image' } ;
my $ new_type = $ element_in_db - > { 'type' } ;
my $ new_period = $ element_in_db - > { 'period' } ;
my $ new_id_agente_modulo = $ element_in_db - > { 'id_agente_modulo' } ;
my $ new_id_agent = $ element_in_db - > { 'id_agent' } ;
my $ new_id_layout_linked = $ element_in_db - > { 'id_layout_linked' } ;
my $ new_parent_item = $ element_in_db - > { 'parent_item' } ;
my $ new_enable_link = $ element_in_db - > { 'enable_link' } ;
my $ new_id_metaconsole = $ element_in_db - > { 'id_metaconsole' } ;
my $ new_id_group = $ element_in_db - > { 'id_group' } ;
my $ new_id_custom_graph = $ element_in_db - > { 'id_custom_graph' } ;
my $ new_border_width = $ element_in_db - > { 'border_width' } ;
my $ new_type_graph = $ element_in_db - > { 'type_graph' } ;
my $ new_label_position = $ element_in_db - > { 'label_position' } ;
my $ new_border_color = $ element_in_db - > { 'border_color' } ;
my $ new_fill_color = $ element_in_db - > { 'fill_color' } ;
2017-11-17 13:12:35 +01:00
my $ new_id_layout_linked_weight = $ elem - > { 'id_layout_linked_weight' } ;
my $ new_element_group = $ elem - > { 'element_group' } ;
my $ new_show_on_top = $ elem - > { 'show_on_top' } ;
2017-09-14 13:14:31 +02:00
if ( defined ( $ elem - > { 'width' } ) ) {
$ new_width = $ elem - > { 'width' } ;
}
if ( defined ( $ elem - > { 'height' } ) ) {
$ new_height = $ elem - > { 'height' } ;
}
if ( defined ( $ elem - > { 'label' } ) ) {
$ new_label = $ elem - > { 'label' } ;
}
if ( defined ( $ elem - > { 'image' } ) ) {
$ new_image = $ elem - > { 'image' } ;
}
if ( defined ( $ elem - > { 'type' } ) ) {
$ new_type = $ elem - > { 'type' } ;
}
if ( defined ( $ elem - > { 'period' } ) ) {
$ new_period = $ elem - > { 'period' } ;
}
if ( defined ( $ elem - > { 'id_agente_modulo' } ) ) {
$ new_id_agente_modulo = $ elem - > { 'id_agente_modulo' } ;
}
if ( defined ( $ elem - > { 'id_agent' } ) ) {
$ new_id_agent = $ elem - > { 'id_agent' } ;
}
if ( defined ( $ elem - > { 'id_layout_linked' } ) ) {
$ new_id_layout_linked = $ elem - > { 'id_layout_linked' } ;
}
if ( defined ( $ elem - > { 'parent_item' } ) ) {
$ new_parent_item = $ elem - > { 'parent_item' } ;
}
if ( defined ( $ elem - > { 'enable_link' } ) ) {
$ new_enable_link = $ elem - > { 'enable_link' } ;
}
if ( defined ( $ elem - > { 'id_metaconsole' } ) ) {
$ new_id_metaconsole = $ elem - > { 'id_metaconsole' } ;
}
if ( defined ( $ elem - > { 'id_group' } ) ) {
$ new_id_group = $ elem - > { 'id_group' } ;
}
if ( defined ( $ elem - > { 'id_custom_graph' } ) ) {
$ new_id_custom_graph = $ elem - > { 'id_custom_graph' } ;
}
if ( defined ( $ elem - > { 'border_width' } ) ) {
$ new_border_width = $ elem - > { 'border_width' } ;
}
if ( defined ( $ elem - > { 'type_graph' } ) ) {
$ new_type_graph = $ elem - > { 'type_graph' } ;
}
if ( defined ( $ elem - > { 'label_position' } ) ) {
$ new_label_position = $ elem - > { 'label_position' } ;
}
if ( defined ( $ elem - > { 'border_color' } ) ) {
$ new_border_color = $ elem - > { 'border_color' } ;
}
if ( defined ( $ elem - > { 'fill_color' } ) ) {
$ new_fill_color = $ elem - > { 'fill_color' } ;
}
2017-11-17 13:12:35 +01:00
if ( defined ( $ elem - > { 'id_layout_linked_weight' } ) ) {
$ new_id_layout_linked_weight = $ elem - > { 'id_layout_linked_weight' } ;
}
if ( defined ( $ elem - > { 'element_group' } ) ) {
$ new_element_group = $ elem - > { 'element_group' } ;
}
if ( defined ( $ elem - > { 'show_on_top' } ) ) {
$ new_show_on_top = $ elem - > { 'show_on_top' } ;
}
2017-09-14 13:14:31 +02:00
db_update ( $ dbh , "UPDATE tlayout_data SET pos_x = " . $ new_pos_x . ", pos_y = " . $ new_pos_y . ", width = " . $ new_width .
", height = " . $ new_height . ", label = '" . $ new_label . "', image = '" . $ new_image .
"', type = " . $ new_type . ", period = " . $ new_period . ", id_agente_modulo = " . $ new_id_agente_modulo .
", id_agent = " . $ new_id_agent . ", id_layout_linked = " . $ new_id_layout_linked . ", parent_item = " . $ new_parent_item .
", enable_link = " . $ new_enable_link . ", id_metaconsole = " . $ new_id_metaconsole . ", id_group = " . $ new_id_group .
", id_custom_graph = " . $ new_id_custom_graph . ", border_width = " . $ new_border_width . ", type_graph = '" . $ new_type_graph .
"', label_position = '" . $ new_label_position . "', border_color = '" . $ new_border_color . "', fill_color = '" . $ new_fill_color .
2017-11-17 13:12:35 +01:00
"', id_layout_linked_weight = '" . $ new_id_layout_linked_weight . "', element_group = '" . $ new_element_group . "', show_on_top = '" . $ new_show_on_top .
2017-09-14 13:14:31 +02:00
"' WHERE id = " . $ elem - > { 'id' } ) ;
print_log "[INFO] Element with id " . $ elem - > { 'id' } . " has been updated \n\n" ;
}
else {
my $ pos_x = 0 ;
my $ pos_y = 0 ;
my $ width = $ elem - > { 'width' } ;
my $ height = $ elem - > { 'height' } ;
my $ label = $ elem - > { 'label' } ;
my $ image = $ elem - > { 'image' } ;
my $ type = $ elem - > { 'type' } ;
my $ period = $ elem - > { 'period' } ;
my $ id_agente_modulo = $ elem - > { 'id_agente_modulo' } ;
my $ id_agent = $ elem - > { 'id_agent' } ;
my $ id_layout_linked = $ elem - > { 'id_layout_linked' } ;
my $ parent_item = $ elem - > { 'parent_item' } ;
my $ enable_link = $ elem - > { 'enable_link' } ;
my $ id_metaconsole = $ elem - > { 'id_metaconsole' } ;
my $ id_group = $ elem - > { 'id_group' } ;
my $ id_custom_graph = $ elem - > { 'id_custom_graph' } ;
my $ border_width = $ elem - > { 'border_width' } ;
my $ type_graph = $ elem - > { 'type_graph' } ;
my $ label_position = $ elem - > { 'label_position' } ;
my $ border_color = $ elem - > { 'border_color' } ;
my $ fill_color = $ elem - > { 'fill_color' } ;
2017-11-17 13:12:35 +01:00
my $ id_layout_linked_weight = $ elem - > { 'id_layout_linked_weight' } ;
my $ element_group = $ elem - > { 'element_group' } ;
my $ show_on_top = $ elem - > { 'show_on_top' } ;
2017-09-14 13:14:31 +02:00
2017-11-17 13:12:35 +01:00
my $ new_elem_id = db_insert ( $ dbh , 'id' , ' INSERT INTO tlayout_data ( id_layout , pos_x , pos_y , height , width , label , image , type , period , id_agente_modulo , id_agent , id_layout_linked , parent_item , enable_link , id_metaconsole , id_group , id_custom_graph , border_width , type_graph , label_position , border_color , fill_color , show_statistics , id_layout_linked_weight , element_group , show_on_top )
VALUES ( ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? ) ' , $ id , $ pos_x , $ pos_y , $ height , $ width , $ label , $ image , $ type , $ period , $ id_agente_modulo , $ id_agent , $ id_layout_linked , $ parent_item , $ enable_link , $ id_metaconsole , $ id_group , $ id_custom_graph , $ border_width , $ type_graph , $ label_position , $ border_color , $ fill_color , 0 , $ id_layout_linked_weight , $ element_group , $ show_on_top ) ;
2017-09-14 13:14:31 +02:00
print_log "[INFO] New element with id $new_elem_id has been created \n\n" ;
}
}
2017-09-14 12:07:52 +02:00
my $ positions = decode_json ( $ element_square_positions ) ;
my $ pos1X = $ positions - > { 'pos1x' } ;
my $ pos1Y = $ positions - > { 'pos1y' } ;
my $ pos2X = $ positions - > { 'pos2x' } ;
my $ pos2Y = $ positions - > { 'pos2y' } ;
2017-09-14 13:14:31 +02:00
my @ console_elements = get_db_rows ( $ dbh , " SELECT *
FROM tlayout_data
WHERE id_layout = $ id " ) ;
my $ number_of_elements = scalar ( @ console_elements ) ;
2017-09-14 12:07:52 +02:00
my $ x_divider = 4 ;
my $ y_divider = 1 ;
for ( my $ i = 1 ; $ i <= 1000 ; $ i + + ) {
if ( ( $ i * 4 ) < $ number_of_elements ) {
$ y_divider + + ;
}
else {
last ;
}
}
my $ elem_width = ( $ pos2X - $ pos1X ) / $ x_divider ;
my $ elem_height = ( $ pos2Y - $ pos1Y ) / $ y_divider ;
if ( $ number_of_elements < 4 ) {
$ elem_height = ( $ pos2Y - $ pos1Y ) / 3 ;
}
my $ elem_count = 1 ;
my $ pos_helper_x = 0 ;
my $ pos_helper_y = 0 ;
2017-09-14 13:14:31 +02:00
foreach my $ elem ( @ console_elements ) {
my $ new_pos_x = $ pos_helper_x * $ elem_width ;
my $ new_pos_y = $ pos_helper_y * $ elem_height ;
my $ new_elem_width = $ elem_width ;
my $ new_elem_height = $ elem_height ;
2017-09-14 12:07:52 +02:00
2017-09-14 13:14:31 +02:00
db_update ( $ dbh , "UPDATE tlayout_data SET pos_x = " . $ new_pos_x . ", pos_y = " . $ new_pos_y .
", width = " . $ new_elem_width . ", height = " . $ new_elem_height .
" WHERE id = " . $ elem - > { 'id' } ) ;
2017-09-14 12:07:52 +02:00
2017-09-14 13:14:31 +02:00
print_log "[INFO] Recolocate element with id " . $ elem - > { 'id' } . " \n\n" ;
2017-09-14 12:07:52 +02:00
$ elem_count + + ;
if ( $ pos_helper_x == 3 ) {
$ pos_helper_x = 0 ;
$ pos_helper_y + + ;
}
else {
$ pos_helper_x + + ;
}
}
}
}
else {
print_log "[ERROR] Mode parameter must be 'static_objects' or 'auto_creation'.\n\n" ;
exit 1 ;
}
}
}
2017-09-11 16:09:13 +02:00
##############################################################################
# Delete a visual console.
# Related option: --delete_visual_console
##############################################################################
sub cli_delete_visual_console () {
my ( $ id ) = @ ARGV [ 2 ] ;
if ( $ id eq '' ) {
print_log "[ERROR] ID field cannot be empty.\n\n" ;
exit 1 ;
}
print_log "[INFO] Delete visual console with ID '$id' \n\n" ;
my $ delete_layout = db_do ( $ dbh , 'DELETE FROM tlayout WHERE id = ?' , $ id ) ;
if ( $ delete_layout eq 1 ) {
db_do ( $ dbh , 'DELETE FROM tlayout_data WHERE id_layout = ?' , $ id ) ;
2017-09-13 13:27:37 +02:00
print_log "[INFO] Delete visual console elements with console ID '$id' \n\n" ;
2017-09-11 16:09:13 +02:00
}
else {
print_log "[ERROR] Error at remove the visual console.\n\n" ;
exit 1 ;
}
}
2014-05-03 02:57:53 +02:00
2017-09-13 15:19:41 +02:00
##############################################################################
# Delete a visual console objects.
# Related option: --delete_visual_console_objects
##############################################################################
sub cli_delete_visual_console_objects () {
my ( $ id_console , $ mode , $ id_mode ) = @ ARGV [ 2 .. 4 ] ;
if ( $ id_console eq '' ) {
print_log "[ERROR] Console ID field cannot be empty.\n\n" ;
exit 1 ;
}
elsif ( $ mode eq '' ) {
print_log "[ERROR] Mode field cannot be empty.\n\n" ;
exit 1 ;
}
elsif ( $ id_mode eq '' ) {
print_log "[ERROR] Mode index field cannot be empty.\n\n" ;
exit 1 ;
}
if ( ( $ mode eq 'type' ) || ( $ mode eq 'image' ) || ( $ mode eq 'id_agent' ) ||
( $ mode eq 'id_agente_modulo' ) || ( $ mode eq 'id_group' ) || ( $ mode eq 'type_graph' ) ) {
print_log "[INFO] Removind objects with mode '$mode' and id '$id_mode' \n\n" ;
db_do ( $ dbh , 'DELETE FROM tlayout_data WHERE id_layout = ' . $ id_console . ' AND ' . $ mode . ' = "' . $ id_mode . '"' ) ;
}
else {
print_log "[ERROR] Mode is not correct.\n\n" ;
exit 1 ;
}
}
2017-09-13 18:07:45 +02:00
##############################################################################
# Duplicate a visual console.
# Related option: --duplicate_visual_console
##############################################################################
2017-09-13 17:39:17 +02:00
sub cli_duplicate_visual_console () {
2017-09-22 10:18:18 +02:00
my ( $ id_console , $ times , $ prefix ) = @ ARGV [ 2 .. 4 ] ;
2017-09-13 17:39:17 +02:00
if ( $ id_console eq '' ) {
print_log "[ERROR] Console ID field cannot be empty.\n\n" ;
exit 1 ;
}
my $ console = get_db_single_row ( $ dbh , " SELECT *
FROM tlayout
WHERE id = $ id_console " ) ;
my $ name_to_compare = $ console - > { 'name' } ;
my $ new_name = $ console - > { 'name' } . "_1" ;
my $ name_count = 2 ;
if ( $ prefix ne '' ) {
$ new_name = $ prefix ;
$ name_to_compare = $ prefix ;
$ name_count = 1 ;
}
2017-09-22 10:18:18 +02:00
for ( my $ iteration = 0 ; $ iteration < $ times ; $ iteration + + ) {
my $ exist = 1 ;
while ( $ exist == 1 ) {
my $ name_in_db = get_db_single_row ( $ dbh , "SELECT name FROM tlayout WHERE name = '$new_name'" ) ;
if ( defined ( $ name_in_db - > { 'name' } ) && ( $ name_in_db - > { 'name' } eq $ new_name ) ) {
$ new_name = $ name_to_compare . "_" . $ name_count ;
$ name_count + + ;
}
else {
$ exist = 0 ;
}
2017-09-13 17:39:17 +02:00
}
2017-09-22 10:18:18 +02:00
my $ new_console_id = db_insert ( $ dbh , 'id' , ' INSERT INTO tlayout ( name , id_group , background , width , height , background_color )
VALUES ( ? , ? , ? , ? , ? , ? ) ', $new_name, $console->{' id_group '}, $console->{' background '}, $console->{' width '}, $console->{' height '}, $console->{' background_color ' } ) ;
print_log "[INFO] The new visual console '$new_name' has been created. The new ID is '$new_console_id' \n\n" ;
my @ console_elements = get_db_rows ( $ dbh , " SELECT *
FROM tlayout_data
WHERE id_layout = $ id_console " ) ;
foreach my $ element ( @ console_elements ) {
my $ pos_x = $ element - > { 'pos_x' } ;
my $ pos_y = $ element - > { 'pos_y' } ;
my $ width = $ element - > { 'width' } ;
my $ height = $ element - > { 'height' } ;
my $ label = $ element - > { 'label' } ;
my $ image = $ element - > { 'image' } ;
my $ type = $ element - > { 'type' } ;
my $ period = $ element - > { 'period' } ;
my $ id_agente_modulo = $ element - > { 'id_agente_modulo' } ;
my $ id_agent = $ element - > { 'id_agent' } ;
my $ id_layout_linked = $ element - > { 'id_layout_linked' } ;
my $ parent_item = $ element - > { 'parent_item' } ;
my $ enable_link = $ element - > { 'enable_link' } ;
my $ id_metaconsole = $ element - > { 'id_metaconsole' } ;
my $ id_group = $ element - > { 'id_group' } ;
my $ id_custom_graph = $ element - > { 'id_custom_graph' } ;
my $ border_width = $ element - > { 'border_width' } ;
my $ type_graph = $ element - > { 'type_graph' } ;
my $ label_position = $ element - > { 'label_position' } ;
my $ border_color = $ element - > { 'border_color' } ;
my $ fill_color = $ element - > { 'fill_color' } ;
2017-11-17 13:12:35 +01:00
my $ id_layout_linked_weight = $ element - > { 'id_layout_linked_weight' } ;
my $ element_group = $ element - > { 'element_group' } ;
my $ show_on_top = $ element - > { 'show_on_top' } ;
2017-09-22 10:18:18 +02:00
2017-11-17 13:12:35 +01:00
my $ element_id = db_insert ( $ dbh , 'id' , ' INSERT INTO tlayout_data ( id_layout , pos_x , pos_y , height , width , label , image , type , period , id_agente_modulo , id_agent , id_layout_linked , parent_item , enable_link , id_metaconsole , id_group , id_custom_graph , border_width , type_graph , label_position , border_color , fill_color , show_statistics , id_layout_linked_weight , element_group , show_on_top )
VALUES ( ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? , ? ) ' , $ new_console_id , $ pos_x , $ pos_y , $ height , $ width , $ label , $ image , $ type , $ period , $ id_agente_modulo , $ id_agent , $ id_layout_linked , $ parent_item , $ enable_link , $ id_metaconsole , $ id_group , $ id_custom_graph , $ border_width , $ type_graph , $ label_position , $ border_color , $ fill_color , 0 , $ id_layout_linked_weight , $ element_group , $ show_on_top ) ;
2017-09-22 10:18:18 +02:00
print_log "[INFO] Element with ID " . $ element - > { "id" } . " has been duplicated to the new console \n\n" ;
}
2017-09-13 17:39:17 +02:00
}
}
2017-09-13 18:07:45 +02:00
##############################################################################
# Export a visual console elements to json.
# Related option: --export_json_visual_console
##############################################################################
sub cli_export_visual_console () {
2017-09-27 13:15:51 +02:00
my ( $ id , $ path , $ with_id ) = @ ARGV [ 2 .. 4 ] ;
2017-09-13 18:07:45 +02:00
if ( $ id eq '' ) {
print_log "[ERROR] ID field cannot be empty.\n\n" ;
exit 1 ;
}
2017-09-22 10:18:18 +02:00
my $ data_to_json = '' ;
my $ first = 1 ;
2017-09-13 18:07:45 +02:00
print_log "[INFO] Exporting visual console elements with ID '$id' \n\n" ;
2017-09-22 10:18:18 +02:00
my $ console = get_db_single_row ( $ dbh , " SELECT *
FROM tlayout
WHERE id = $ id " ) ;
$ data_to_json . = '"' . safe_output ( $ console - > { 'name' } ) . '"' ;
$ data_to_json . = ' "' . $ console - > { 'background' } . '"' ;
$ data_to_json . = ' ' . $ console - > { 'width' } ;
$ data_to_json . = ' ' . $ console - > { 'height' } ;
$ data_to_json . = ' ' . $ console - > { 'id_group' } ;
$ data_to_json . = ' "static_objects"' ;
$ data_to_json . = ' ""' ;
$ data_to_json . = ' "' . $ console - > { 'background_color' } . '" ' ;
2017-09-13 18:07:45 +02:00
my @ console_elements = get_db_rows ( $ dbh , " SELECT *
FROM tlayout_data
WHERE id_layout = $ id " ) ;
2017-09-27 12:21:33 +02:00
$ data_to_json . = "'[" ;
2017-09-13 18:07:45 +02:00
foreach my $ element ( @ console_elements ) {
2017-09-27 13:15:51 +02:00
my $ id_layout_data = $ element - > { 'id' } ;
2017-09-13 18:07:45 +02:00
my $ pos_x = $ element - > { 'pos_x' } ;
my $ pos_y = $ element - > { 'pos_y' } ;
my $ width = $ element - > { 'width' } ;
my $ height = $ element - > { 'height' } ;
my $ label = $ element - > { 'label' } ;
my $ image = $ element - > { 'image' } ;
my $ type = $ element - > { 'type' } ;
my $ period = $ element - > { 'period' } ;
my $ id_agente_modulo = $ element - > { 'id_agente_modulo' } ;
my $ id_agent = $ element - > { 'id_agent' } ;
my $ id_layout_linked = $ element - > { 'id_layout_linked' } ;
my $ parent_item = $ element - > { 'parent_item' } ;
my $ enable_link = $ element - > { 'enable_link' } ;
my $ id_metaconsole = $ element - > { 'id_metaconsole' } ;
my $ id_group = $ element - > { 'id_group' } ;
my $ id_custom_graph = $ element - > { 'id_custom_graph' } ;
my $ border_width = $ element - > { 'border_width' } ;
my $ type_graph = $ element - > { 'type_graph' } ;
my $ label_position = $ element - > { 'label_position' } ;
my $ border_color = $ element - > { 'border_color' } ;
my $ fill_color = $ element - > { 'fill_color' } ;
2017-11-17 13:12:35 +01:00
my $ id_layout_linked_weight = $ element - > { 'id_layout_linked_weight' } ;
my $ element_group = $ element - > { 'element_group' } ;
my $ show_on_top = $ element - > { 'show_on_top' } ;
2017-09-13 18:07:45 +02:00
if ( $ first == 0 ) {
$ data_to_json . = ','
}
else {
$ first = 0 ;
}
2017-09-22 14:42:26 +02:00
$ label =~ s/"/\\"/g ;
2017-09-27 13:15:51 +02:00
if ( $ with_id == 1 ) {
$ data_to_json . = '{"id":' . $ id_layout_data ;
$ data_to_json . = ',"image":"' . $ image . '"' ;
}
else {
$ data_to_json . = '{"image":"' . $ image . '"' ;
}
2017-09-13 18:07:45 +02:00
$ data_to_json . = ',"pos_y":' . $ pos_y ;
$ data_to_json . = ',"pos_x":' . $ pos_x ;
$ data_to_json . = ',"width":' . $ width ;
$ data_to_json . = ',"height":' . $ height ;
$ data_to_json . = ',"label":"' . $ label . '"' ;
$ data_to_json . = ',"type":' . $ type ;
$ data_to_json . = ',"period":' . $ period ;
$ data_to_json . = ',"id_agente_modulo":' . $ id_agente_modulo ;
$ data_to_json . = ',"id_agent":' . $ id_agent ;
$ data_to_json . = ',"id_layout_linked":' . $ id_layout_linked ;
$ data_to_json . = ',"parent_item":' . $ parent_item ;
$ data_to_json . = ',"enable_link":' . $ enable_link ;
$ data_to_json . = ',"id_metaconsole":' . $ id_metaconsole ;
$ data_to_json . = ',"id_group":' . $ id_group ;
$ data_to_json . = ',"id_custom_graph":' . $ id_custom_graph ;
$ data_to_json . = ',"border_width":' . $ border_width ;
$ data_to_json . = ',"type_graph":"' . $ type_graph . '"' ;
$ data_to_json . = ',"label_position":"' . $ label_position . '"' ;
$ data_to_json . = ',"border_color":"' . $ border_color . '"' ;
$ data_to_json . = ',"fill_color":"' . $ fill_color . '"' ;
2017-11-17 13:12:35 +01:00
$ data_to_json . = ',"id_layout_linked_weight":' . $ id_layout_linked_weight ;
$ data_to_json . = ',"element_group":' . $ element_group ;
$ data_to_json . = ',"show_on_top":' . $ show_on_top ;
2017-09-13 18:07:45 +02:00
$ data_to_json . = '}' ;
}
2017-09-27 12:21:33 +02:00
$ data_to_json . = "]'" ;
2017-09-13 18:07:45 +02:00
2017-09-14 09:37:45 +02:00
if ( $ path eq '' ) {
open ( FicheroJSON , ">console_" . $ id . "_elements" ) ;
}
else {
open ( FicheroJSON , ">" . $ path . "/console_" . $ id . "_elements" ) ;
}
print FicheroJSON $ data_to_json ;
2017-09-13 18:07:45 +02:00
print_log "[INFO] JSON file now contents: \n" . $ data_to_json . "\n\n" ;
}
2014-05-03 02:57:53 +02:00
2018-03-21 16:58:42 +01:00
2011-11-14 14:27:21 +01:00
###############################################################################
###############################################################################
# MAIN
###############################################################################
###############################################################################
sub pandora_manage_main ($$$) {
my ( $ conf , $ dbh , $ history_dbh ) = @ _ ;
my @ args = @ ARGV ;
my $ ltotal = $# args ;
my $ ax ;
# Has read setup file ok ?
if ( $ ltotal == 0 ) {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] No valid arguments\n\n" ;
2011-11-14 14:27:21 +01:00
help_screen ( ) ;
exit ;
}
else {
$ param = $ args [ 1 ] ;
# help!
if ( $ param =~ m/--*h\w*\z/i ) {
$ param = '' ;
help_screen ( ) ;
exit ;
}
elsif ( $ param eq '--disable_alerts' ) {
param_check ( $ ltotal , 0 ) ;
2014-12-15 14:59:22 +01:00
cli_disable_alerts ( $ conf , $ dbh ) ;
}
2011-11-14 14:27:21 +01:00
elsif ( $ param eq '--enable_alerts' ) {
param_check ( $ ltotal , 0 ) ;
2014-12-15 14:59:22 +01:00
cli_enable_alerts ( $ conf , $ dbh ) ;
}
2011-11-14 14:27:21 +01:00
elsif ( $ param eq '--disable_eacl' ) {
param_check ( $ ltotal , 0 ) ;
2014-12-15 14:59:22 +01:00
cli_disable_eacl ( $ conf , $ dbh ) ;
}
2011-11-14 14:27:21 +01:00
elsif ( $ param eq '--enable_eacl' ) {
param_check ( $ ltotal , 0 ) ;
2014-12-15 14:59:22 +01:00
cli_enable_eacl ( $ conf , $ dbh ) ;
}
elsif ( $ param eq '--disable_double_auth' ) {
param_check ( $ ltotal , 1 ) ;
cli_disable_double_auth ( ) ;
}
elsif ( $ param eq '--disable_group' ) {
2011-11-14 14:27:21 +01:00
param_check ( $ ltotal , 1 ) ;
cli_disable_group ( ) ;
}
elsif ( $ param eq '--enable_group' ) {
param_check ( $ ltotal , 1 ) ;
cli_enable_group ( ) ;
}
2022-05-24 10:59:41 +02:00
elsif ( $ param eq '--start_snmptrapd' ) {
#param_check($ltotal, 0);
cli_start_snmptrapd ( ) ;
}
2011-11-14 14:27:21 +01:00
elsif ( $ param eq '--create_agent' ) {
2018-12-10 12:17:12 +01:00
param_check ( $ ltotal , 8 , 4 ) ;
2011-11-14 14:27:21 +01:00
cli_create_agent ( ) ;
}
elsif ( $ param eq '--delete_agent' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 2 , 1 ) ;
2011-11-14 14:27:21 +01:00
cli_delete_agent ( ) ;
}
elsif ( $ param eq '--create_data_module' ) {
2016-10-19 13:48:25 +02:00
param_check ( $ ltotal , 30 , 24 ) ;
2012-01-11 11:09:02 +01:00
cli_create_data_module ( 0 ) ;
2011-11-14 14:27:21 +01:00
}
2016-12-16 10:30:16 +01:00
elsif ( $ param eq '--create_web_module' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 39 , 36 ) ;
2016-12-16 10:30:16 +01:00
cli_create_web_module ( 0 ) ;
}
2018-12-11 14:43:27 +01:00
elsif ( $ param eq '--get_module_group' ) {
param_check ( $ ltotal , 1 , 1 ) ;
cli_get_module_group ( ) ;
}
2016-05-26 12:28:42 +02:00
elsif ( $ param eq '--create_module_group' ) {
param_check ( $ ltotal , 1 , 1 ) ;
cli_create_module_group ( ) ;
}
2018-12-11 14:43:27 +01:00
elsif ( $ param eq '--module_group_synch' ) {
param_check ( $ ltotal , 2 , 1 ) ;
cli_module_group_synch ( ) ;
}
2011-11-14 14:27:21 +01:00
elsif ( $ param eq '--create_network_module' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 33 , 21 ) ;
2012-01-12 17:02:04 +01:00
cli_create_network_module ( 0 ) ;
2011-11-14 14:27:21 +01:00
}
elsif ( $ param eq '--create_snmp_module' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 41 , 29 ) ;
2012-01-12 17:02:04 +01:00
cli_create_snmp_module ( 0 ) ;
2011-11-14 14:27:21 +01:00
}
elsif ( $ param eq '--create_plugin_module' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 35 , 20 ) ;
2012-01-12 17:02:04 +01:00
cli_create_plugin_module ( 0 ) ;
2011-11-14 14:27:21 +01:00
}
elsif ( $ param eq '--delete_module' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 3 , 1 ) ;
2011-11-14 14:27:21 +01:00
cli_delete_module ( ) ;
}
elsif ( $ param eq '--delete_not_policy_modules' ) {
param_check ( $ ltotal , 0 ) ;
cli_delete_not_policy_modules ( ) ;
}
elsif ( $ param eq '--create_template_module' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 4 , 1 ) ;
2011-11-14 14:27:21 +01:00
cli_create_template_module ( ) ;
2010-05-27 18:24:52 +02:00
}
2010-09-22 09:57:43 +02:00
elsif ( $ param eq '--delete_template_module' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 4 , 1 ) ;
2011-11-14 14:27:21 +01:00
cli_delete_template_module ( ) ;
2010-05-27 18:24:52 +02:00
}
2010-09-22 09:57:43 +02:00
elsif ( $ param eq '--create_template_action' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 7 , 3 ) ;
2011-11-14 14:27:21 +01:00
cli_create_template_action ( ) ;
2010-05-27 18:24:52 +02:00
}
2010-09-22 09:57:43 +02:00
elsif ( $ param eq '--delete_template_action' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 5 , 1 ) ;
2011-11-14 14:27:21 +01:00
cli_delete_template_action ( ) ;
2010-05-27 18:24:52 +02:00
}
2010-09-22 09:57:43 +02:00
elsif ( $ param eq '--data_module' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 7 , 2 ) ;
2011-11-14 14:27:21 +01:00
cli_data_module ( ) ;
2010-05-27 18:24:52 +02:00
}
2010-09-22 09:57:43 +02:00
elsif ( $ param eq '--create_user' ) {
2010-05-27 18:24:52 +02:00
param_check ( $ ltotal , 4 , 1 ) ;
2011-11-14 14:27:21 +01:00
cli_create_user ( ) ;
2010-05-27 18:24:52 +02:00
}
2010-09-22 09:57:43 +02:00
elsif ( $ param eq '--delete_user' ) {
2010-05-27 18:24:52 +02:00
param_check ( $ ltotal , 1 ) ;
2011-11-14 14:27:21 +01:00
cli_delete_user ( ) ;
2010-05-27 18:24:52 +02:00
}
2016-06-06 15:18:46 +02:00
elsif ( $ param eq '--add_profile' ) {
2010-05-27 18:24:52 +02:00
param_check ( $ ltotal , 3 ) ;
2016-06-06 15:18:46 +02:00
cli_add_profile ( ) ;
}
elsif ( $ param eq '--create_profile' ) {
param_check ( $ ltotal , 24 ) ;
2011-11-14 14:27:21 +01:00
cli_create_profile ( ) ;
2010-05-27 18:24:52 +02:00
}
2021-04-14 04:07:13 +02:00
elsif ( $ param eq '--update_profile' ) {
param_check ( $ ltotal , 24 ) ;
cli_update_profile ( ) ;
}
2010-09-22 09:57:43 +02:00
elsif ( $ param eq '--delete_profile' ) {
2010-05-27 18:24:52 +02:00
param_check ( $ ltotal , 3 ) ;
2011-11-14 14:27:21 +01:00
cli_delete_profile ( ) ;
2010-05-27 18:24:52 +02:00
}
2010-09-22 09:57:43 +02:00
elsif ( $ param eq '--create_event' ) {
2022-10-31 16:59:38 +01:00
my @ fields = (
{ 'name' = > 'event' } ,
{
'name' = > 'event_type' ,
'values' = > [
'unknown' , 'alert_fired' , 'alert_recovered' , 'alert_ceased' ,
'alert_manual_validation' , 'recon_host_detected' , 'system' ,
2022-12-12 17:01:46 +01:00
'error' , 'new_agent' , 'going_up_warning' , 'going_up_critical' , 'going_down_warning' ,
2022-10-31 16:59:38 +01:00
'going_down_normal' , 'going_down_critical' , 'going_up_normal' , 'configuration_change'
]
} ,
{ 'name' = > 'group_name' } ,
{ 'name' = > 'agent_name' } ,
{ 'name' = > 'module_name' } ,
{
'name' = > 'event_status' ,
2022-12-12 17:01:46 +01:00
'values' = > [ '0' , '1' , '2' ] ,
'text_extra' = > [ '(New)' , '(Validated)' , '(In process)' ]
2022-10-31 16:59:38 +01:00
} ,
{
'name' = > 'severity' ,
'values' = > [ '0' , '1' , '2' , '3' , '4' , '5' , '6' ] ,
'text_extra' = > [
'(Maintenance)' , '(Informational)' , '(Normal)' ,
'(Warning)' , '(Critical)' , '(Minor)' , '(Major)'
]
} ,
{ 'name' = > 'template_name' } ,
{ 'name' = > 'user_name' } ,
{ 'name' = > 'comment' } ,
{ 'name' = > 'source' } ,
{ 'name' = > 'id_extra' } ,
{ 'name' = > 'tags' } ,
{ 'type' = > 'json' , 'name' = > 'custom_data_json' } ,
{
'name' = > 'force_create_agent' ,
'values' = > [ '0' , '1' ]
} ,
{ 'name' = > 'critical_instructions' } ,
{ 'name' = > 'warning_instructions' } ,
{ 'name' = > 'unknown_instructions' } ,
{ 'name' = > 'use_alias' } ,
{ 'name' = > 'metaconsole' }
2022-10-27 09:40:33 +02:00
) ;
2022-03-23 14:24:39 +01:00
param_check ( $ ltotal , 20 , 17 ) ;
2022-10-31 16:59:38 +01:00
check_values ( \ @ fields ) ;
2022-10-27 09:40:33 +02:00
2011-11-14 14:27:21 +01:00
cli_create_event ( ) ;
2022-10-27 09:40:33 +02:00
}
2010-09-22 09:57:43 +02:00
elsif ( $ param eq '--validate_event' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 8 , 7 ) ;
2011-11-14 14:27:21 +01:00
cli_validate_event ( ) ;
2010-05-19 15:40:21 +02:00
}
2012-02-10 10:30:21 +01:00
elsif ( $ param eq '--validate_event_id' ) {
param_check ( $ ltotal , 1 ) ;
cli_validate_event_id ( ) ;
}
2012-02-13 18:35:54 +01:00
elsif ( $ param eq '--get_event_info' ) {
param_check ( $ ltotal , 2 , 1 ) ;
cli_get_event_info ( ) ;
}
2014-08-21 02:39:25 +02:00
elsif ( $ param eq '--add_event_comment' ) {
param_check ( $ ltotal , 3 ) ;
cli_add_event_comment ( ) ;
}
2010-09-22 09:57:43 +02:00
elsif ( $ param eq '--delete_data' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 4 , 2 ) ;
2011-11-14 14:27:21 +01:00
cli_delete_data ( $ ltotal ) ;
2010-09-03 12:59:43 +02:00
}
2010-09-24 13:09:44 +02:00
elsif ( $ param eq '--apply_policy' ) {
2019-01-29 15:30:04 +01:00
param_check ( $ ltotal , 4 , 3 ) ;
2011-11-14 14:27:21 +01:00
cli_apply_policy ( ) ;
2010-09-24 13:09:44 +02:00
}
2011-05-03 18:55:17 +02:00
elsif ( $ param eq '--disable_policy_alerts' ) {
param_check ( $ ltotal , 1 ) ;
2011-11-14 14:27:21 +01:00
cli_disable_policy_alerts ( ) ;
2011-05-03 18:55:17 +02:00
}
2011-12-29 18:12:13 +01:00
elsif ( $ param eq '--create_group' ) {
2012-10-30 10:32:35 +01:00
param_check ( $ ltotal , 4 , 3 ) ;
2011-12-29 18:12:13 +01:00
cli_create_group ( ) ;
}
2016-06-10 13:36:41 +02:00
elsif ( $ param eq '--delete_group' ) {
param_check ( $ ltotal , 1 ) ;
cli_delete_group ( ) ;
}
elsif ( $ param eq '--update_group' ) {
param_check ( $ ltotal , 5 , 4 ) ;
cli_update_group ( ) ;
}
2011-12-29 18:12:13 +01:00
elsif ( $ param eq '--add_agent_to_policy' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 3 , 1 ) ;
2011-12-29 18:12:13 +01:00
cli_policy_add_agent ( ) ;
}
2018-12-17 17:51:30 +01:00
elsif ( $ param eq '--remove_agent_from_policy' ) {
param_check ( $ ltotal , 2 ) ;
cli_policy_delete_agent ( ) ;
}
2012-01-04 16:09:02 +01:00
elsif ( $ param eq '--enable_user' ) {
param_check ( $ ltotal , 1 ) ;
cli_user_enable ( ) ;
}
elsif ( $ param eq '--disable_user' ) {
param_check ( $ ltotal , 1 ) ;
cli_user_disable ( ) ;
}
2012-01-05 13:11:03 +01:00
elsif ( $ param eq '--update_user' ) {
param_check ( $ ltotal , 3 ) ;
cli_user_update ( ) ;
}
elsif ( $ param eq '--add_profile_to_user' ) {
param_check ( $ ltotal , 3 , 1 ) ;
cli_user_add_profile ( ) ;
}
2012-01-05 17:11:11 +01:00
elsif ( $ param eq '--get_module_data' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 5 , 2 ) ;
2012-01-05 17:11:11 +01:00
cli_module_get_data ( ) ;
}
2016-05-26 12:28:42 +02:00
elsif ( $ param eq '--add_collection_to_policy' ) {
param_check ( $ ltotal , 2 , 2 ) ;
cli_add_collection_to_policy ( ) ;
}
elsif ( $ param eq '--create_policy_data_module_from_local_component' ) {
param_check ( $ ltotal , 2 , 2 ) ;
cli_create_policy_data_module_from_local_component ( ) ;
}
elsif ( $ param eq '--create_policy' ) {
param_check ( $ ltotal , 3 , 2 ) ;
cli_create_policy ( ) ;
}
2012-01-11 11:09:02 +01:00
elsif ( $ param eq '--create_policy_data_module' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 29 , 21 ) ;
2012-01-11 11:09:02 +01:00
cli_create_data_module ( 1 ) ;
}
2016-12-16 10:30:16 +01:00
elsif ( $ param eq '--create_policy_web_module' ) {
2018-04-06 15:54:48 +02:00
param_check ( $ ltotal , 37 , 33 ) ;
2016-12-16 10:30:16 +01:00
cli_create_web_module ( 1 ) ;
}
2012-01-12 17:02:04 +01:00
elsif ( $ param eq '--create_policy_network_module' ) {
2016-10-21 11:18:33 +02:00
param_check ( $ ltotal , 30 , 20 ) ;
2012-01-12 17:02:04 +01:00
cli_create_network_module ( 1 ) ;
}
elsif ( $ param eq '--create_policy_snmp_module' ) {
2016-10-21 11:18:33 +02:00
param_check ( $ ltotal , 39 , 27 ) ;
2012-01-12 17:02:04 +01:00
cli_create_snmp_module ( 1 ) ;
}
elsif ( $ param eq '--create_policy_plugin_module' ) {
2016-10-21 11:18:33 +02:00
param_check ( $ ltotal , 33 , 19 ) ;
2012-01-12 17:02:04 +01:00
cli_create_plugin_module ( 1 ) ;
}
2012-01-11 11:09:02 +01:00
elsif ( $ param eq '--create_alert_template' ) {
param_check ( $ ltotal , 19 , 15 ) ;
cli_create_alert_template ( ) ;
}
2012-01-13 10:43:29 +01:00
elsif ( $ param eq '--delete_alert_template' ) {
2018-12-03 17:38:57 +01:00
param_check ( $ ltotal , 7 ) ;
2012-01-13 10:43:29 +01:00
cli_delete_alert_template ( ) ;
}
2018-12-03 17:38:57 +01:00
elsif ( $ param eq '--create_alert_command' ) {
param_check ( $ ltotal , 7 , 2 ) ;
cli_create_alert_command ( ) ;
}
elsif ( $ param eq '--get_alert_commands' ) {
param_check ( $ ltotal , 5 , 5 ) ;
cli_get_alert_commands ( ) ;
2019-01-29 16:07:39 +01:00
}
2018-12-14 17:20:46 +01:00
elsif ( $ param eq '--get_alert_actions' ) {
param_check ( $ ltotal , 3 , 3 ) ;
cli_get_alert_actions ( ) ;
}
elsif ( $ param eq '--get_alert_actions_meta' ) {
param_check ( $ ltotal , 4 , 4 ) ;
cli_get_alert_actions_meta ( ) ;
}
2012-01-13 10:43:29 +01:00
elsif ( $ param eq '--update_alert_template' ) {
param_check ( $ ltotal , 3 ) ;
cli_alert_template_update ( ) ;
}
2012-01-16 15:55:55 +01:00
elsif ( $ param eq '--update_module' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 6 , 2 ) ;
2012-01-16 15:55:55 +01:00
cli_module_update ( ) ;
}
2012-01-17 10:30:52 +01:00
elsif ( $ param eq '--exec_from_file' ) {
cli_exec_from_file ( ) ;
}
2012-01-17 14:10:54 +01:00
elsif ( $ param eq '--stop_downtime' ) {
cli_stop_downtime ( ) ;
}
elsif ( $ param eq '--apply_all_policies' ) {
param_check ( $ ltotal , 0 ) ;
cli_apply_all_policies ( ) ;
}
2012-01-18 12:21:59 +01:00
elsif ( $ param eq '--validate_all_alerts' ) {
param_check ( $ ltotal , 0 ) ;
cli_validate_all_alerts ( ) ;
}
2021-04-06 19:21:56 +02:00
elsif ( $ param eq '--validate_alert' ) {
param_check ( $ ltotal , 5 , 4 ) ;
cli_validate_alert ( ) ;
}
2012-01-18 12:21:59 +01:00
elsif ( $ param eq '--validate_policy_alerts' ) {
param_check ( $ ltotal , 1 ) ;
cli_validate_policy_alerts ( ) ;
}
2016-06-17 08:50:30 +02:00
elsif ( $ param eq '--get_module_id' ) {
param_check ( $ ltotal , 2 ) ;
cli_get_module_id ( ) ;
}
2020-09-17 14:38:01 +02:00
elsif ( $ param eq '--get_module_custom_id' ) {
param_check ( $ ltotal , 1 ) ;
cli_get_module_custom_id ( ) ;
}
elsif ( $ param eq '--set_module_custom_id' ) {
param_check ( $ ltotal , 2 ) ;
cli_set_module_custom_id ( ) ;
}
2012-01-18 12:21:59 +01:00
elsif ( $ param eq '--get_agent_group' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 2 , 1 ) ;
2012-01-18 12:21:59 +01:00
cli_get_agent_group ( ) ;
}
2015-12-29 17:41:39 +01:00
elsif ( $ param eq '--get_agent_group_id' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 2 , 1 ) ;
2015-12-29 17:41:39 +01:00
cli_get_agent_group_id ( ) ;
}
2012-01-18 12:21:59 +01:00
elsif ( $ param eq '--get_agents_module_current_data' ) {
param_check ( $ ltotal , 1 ) ;
cli_get_agents_module_current_data ( ) ;
}
elsif ( $ param eq '--get_agent_modules' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 2 , 1 ) ;
2012-01-18 12:21:59 +01:00
cli_get_agent_modules ( ) ;
}
2020-06-10 08:35:01 +02:00
elsif ( $ param eq '--get_agent_status' ) {
param_check ( $ ltotal , 2 , 1 ) ;
cli_get_agent_status ( ) ;
}
2019-10-10 14:25:17 +02:00
elsif ( $ param eq '--get_agents_id_name_by_alias' ) {
2019-10-18 12:22:20 +02:00
param_check ( $ ltotal , 2 , 1 ) ;
2019-10-10 14:25:17 +02:00
cli_get_agents_id_name_by_alias ( ) ;
}
2012-01-18 12:21:59 +01:00
elsif ( $ param eq '--get_policy_modules' ) {
param_check ( $ ltotal , 1 ) ;
cli_get_policy_modules ( ) ;
}
2012-01-18 13:25:03 +01:00
elsif ( $ param eq '--get_policies' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 2 , 2 ) ;
2012-01-18 13:25:03 +01:00
cli_get_policies ( ) ;
}
2012-01-20 09:52:17 +01:00
elsif ( $ param eq '--get_agents' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 7 , 7 ) ;
2012-01-20 09:52:17 +01:00
cli_get_agents ( ) ;
}
elsif ( $ param eq '--delete_conf_file' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 2 , 1 ) ;
2012-01-20 09:52:17 +01:00
cli_delete_conf_file ( ) ;
}
elsif ( $ param eq '--clean_conf_file' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 2 , 1 ) ;
2012-01-20 09:52:17 +01:00
cli_clean_conf_file ( ) ;
}
elsif ( $ param eq '--update_agent' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 4 , 1 ) ;
2012-01-20 09:52:17 +01:00
cli_agent_update ( ) ;
}
elsif ( $ param eq '--get_bad_conf_files' ) {
param_check ( $ ltotal , 0 ) ;
cli_get_bad_conf_files ( ) ;
}
2012-05-17 11:42:52 +02:00
elsif ( $ param eq '--create_network_module_from_component' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 3 , 1 ) ;
2012-05-17 11:42:52 +02:00
cli_create_network_module_from_component ( ) ;
}
2019-03-20 12:48:44 +01:00
elsif ( $ param eq '--create_network_component' ) {
param_check ( $ ltotal , 24 , 21 ) ;
cli_create_network_component ( ) ;
}
2013-01-16 16:56:31 +01:00
elsif ( $ param eq '--create_netflow_filter' ) {
param_check ( $ ltotal , 5 ) ;
cli_create_netflow_filter ( ) ;
}
2013-02-05 18:09:18 +01:00
elsif ( $ param eq '--create_snmp_trap' ) {
param_check ( $ ltotal , 4 ) ;
cli_create_snmp_trap ( $ conf , $ dbh ) ;
}
2013-01-31 19:02:41 +01:00
elsif ( $ param eq '--set_event_storm_protection' ) {
param_check ( $ ltotal , 1 ) ;
cli_set_event_storm_protection ( ) ;
2014-04-23 11:55:05 +02:00
}
elsif ( $ param eq '--create_custom_graph' ) {
param_check ( $ ltotal , 11 ) ;
cli_create_custom_graph ( ) ;
}
elsif ( $ param eq '--delete_custom_graph' ) {
param_check ( $ ltotal , 1 ) ;
cli_delete_custom_graph ( ) ;
}
elsif ( $ param eq '--edit_custom_graph' ) {
param_check ( $ ltotal , 10 ) ;
cli_edit_custom_graph ( ) ;
}
elsif ( $ param eq '--add_modules_to_graph' ) {
param_check ( $ ltotal , 3 ) ;
cli_add_modules_to_graph ( ) ;
}
elsif ( $ param eq '--delete_modules_to_graph' ) {
param_check ( $ ltotal , 3 ) ;
cli_delete_modules_to_graph ( ) ;
2013-01-31 19:02:41 +01:00
}
2014-05-03 02:57:53 +02:00
elsif ( $ param eq '--create_special_day' ) {
param_check ( $ ltotal , 4 ) ;
cli_create_special_day ( ) ;
}
elsif ( $ param eq '--update_special_day' ) {
param_check ( $ ltotal , 3 ) ;
cli_update_special_day ( ) ;
}
elsif ( $ param eq '--delete_special_day' ) {
param_check ( $ ltotal , 1 ) ;
cli_delete_special_day ( ) ;
}
2014-07-08 15:24:31 +02:00
elsif ( $ param eq '--create_data_module_from_local_component' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 3 , 1 ) ;
2014-07-08 15:24:31 +02:00
cli_create_data_module_from_local_component ( ) ;
}
elsif ( $ param eq '--create_local_component' ) {
param_check ( $ ltotal , 35 , 33 ) ;
cli_create_local_component ( ) ;
}
2014-08-18 15:03:34 +02:00
elsif ( $ param eq '--recreate_collection' ) {
param_check ( $ ltotal , 1 ) ;
cli_recreate_collection ( ) ;
}
2015-03-26 13:41:07 +01:00
elsif ( $ param eq '--create_tag' ) {
param_check ( $ ltotal , 4 , 2 ) ;
cli_create_tag ( ) ;
}
elsif ( $ param eq '--add_tag_to_user_profile' ) {
param_check ( $ ltotal , 4 ) ;
cli_add_tag_to_user_profile ( ) ;
}
elsif ( $ param eq '--add_tag_to_module' ) {
param_check ( $ ltotal , 3 ) ;
cli_add_tag_to_module ( ) ;
}
2015-11-23 09:21:35 +01:00
elsif ( $ param eq '--create_downtime' ) {
2018-11-06 16:42:03 +01:00
param_check ( $ ltotal , 20 ) ;
2015-11-23 09:21:35 +01:00
cli_create_planned_downtime ( ) ;
}
elsif ( $ param eq '--add_item_downtime' ) {
param_check ( $ ltotal , 3 ) ;
cli_add_item_planned_downtime ( ) ;
}
2015-12-02 17:01:28 +01:00
elsif ( $ param eq '--get_all_planned_downtimes' ) {
param_check ( $ ltotal , 5 , 4 ) ;
cli_get_all_planned_downtime ( ) ;
}
elsif ( $ param eq '--get_planned_downtimes_items' ) {
param_check ( $ ltotal , 5 , 4 ) ;
cli_get_planned_downtimes_items ( ) ;
}
2015-12-21 15:56:15 +01:00
elsif ( $ param eq '--create_synthetic' ) {
#aram_check($ltotal, 1);
cli_create_synthetic ( ) ;
}
2015-12-02 17:01:28 +01:00
elsif ( $ param eq '--set_planned_downtimes_deleted' ) {
param_check ( $ ltotal , 1 ) ;
cli_set_delete_planned_downtime ( ) ;
}
2015-12-29 17:41:39 +01:00
elsif ( $ param eq '--locate_agent' ) {
2019-10-17 11:14:42 +02:00
param_check ( $ ltotal , 2 , 1 ) ;
2015-12-29 17:41:39 +01:00
cli_locate_agent ( ) ;
2017-09-11 16:09:13 +02:00
}
elsif ( $ param eq '--create_visual_console' ) {
2017-09-13 13:27:37 +02:00
param_check ( $ ltotal , 9 , 3 ) ;
2017-09-11 16:09:13 +02:00
cli_create_visual_console ( ) ;
}
elsif ( $ param eq '--edit_visual_console' ) {
2017-09-14 12:07:52 +02:00
param_check ( $ ltotal , 10 , 9 ) ;
2017-09-11 16:09:13 +02:00
cli_edit_visual_console ( ) ;
}
elsif ( $ param eq '--delete_visual_console' ) {
param_check ( $ ltotal , 1 ) ;
cli_delete_visual_console ( ) ;
}
elsif ( $ param eq '--delete_visual_console_objects' ) {
param_check ( $ ltotal , 3 ) ;
cli_delete_visual_console_objects ( ) ;
}
elsif ( $ param eq '--duplicate_visual_console' ) {
2017-09-22 10:18:18 +02:00
param_check ( $ ltotal , 3 , 2 ) ;
2017-09-11 16:09:13 +02:00
cli_duplicate_visual_console ( ) ;
}
elsif ( $ param eq '--export_json_visual_console' ) {
2017-09-27 13:15:51 +02:00
param_check ( $ ltotal , 3 , 2 ) ;
2017-09-11 16:09:13 +02:00
cli_export_visual_console ( ) ;
}
2018-02-26 19:10:53 +01:00
elsif ( $ param eq '--apply_module_template' ) {
param_check ( $ ltotal , 2 , 2 ) ;
cli_apply_module_template ( ) ;
2018-03-22 13:33:23 +01:00
}
2018-04-09 11:43:41 +02:00
elsif ( $ param eq '--new_cluster' ) {
param_check ( $ ltotal , 4 , 0 ) ;
cli_new_cluster ( ) ;
}
elsif ( $ param eq '--add_cluster_agent' ) {
param_check ( $ ltotal , 1 , 0 ) ;
cli_add_cluster_agent ( ) ;
}
elsif ( $ param eq '--add_cluster_item' ) {
param_check ( $ ltotal , 1 , 0 ) ;
cli_add_cluster_item ( ) ;
}
elsif ( $ param eq '--delete_cluster' ) {
param_check ( $ ltotal , 1 , 0 ) ;
cli_delete_cluster ( ) ;
}
elsif ( $ param eq '--delete_cluster_agent' ) {
param_check ( $ ltotal , 2 , 0 ) ;
cli_delete_cluster_agent ( ) ;
}
elsif ( $ param eq '--delete_cluster_item' ) {
param_check ( $ ltotal , 1 , 0 ) ;
cli_delete_cluster_item ( ) ;
}
2018-04-23 13:52:16 +02:00
elsif ( $ param eq '--get_cluster_status' ) {
param_check ( $ ltotal , 1 , 0 ) ;
cli_cluster_status ( ) ;
}
2018-03-22 13:33:23 +01:00
elsif ( $ param eq '--migration_agent_queue' ) {
param_check ( $ ltotal , 4 , 1 ) ;
cli_migration_agent_queue ( ) ;
}
elsif ( $ param eq '--migration_agent' ) {
param_check ( $ ltotal , 1 , 0 ) ;
cli_migration_agent ( ) ;
}
2018-09-25 13:42:29 +02:00
elsif ( $ param eq '--set_disabled_and_standby' ) {
param_check ( $ ltotal , 3 , 1 ) ;
cli_set_disabled_and_standby ( ) ;
}
2019-01-18 17:24:32 +01:00
elsif ( $ param eq '--reset_agent_counts' ) {
param_check ( $ ltotal , 1 , 0 ) ;
cli_reset_agent_counts ( ) ;
2020-06-03 15:56:19 +02:00
} elsif ( $ param eq '--event_in_progress' ) {
2020-07-15 23:36:21 +02:00
param_check ( $ ltotal , 1 , 0 ) ;
2020-06-03 15:56:19 +02:00
cli_event_in_progress ( ) ;
2021-07-09 13:58:01 +02:00
} elsif ( $ param eq '--agent_update_custom_fields' ) {
2021-09-30 12:50:59 +02:00
param_check ( $ ltotal , 4 , 5 ) ;
2021-07-09 13:58:01 +02:00
cli_agent_update_custom_fields ( ) ;
2019-01-18 17:24:32 +01:00
}
2022-09-21 17:41:09 +02:00
elsif ( $ param eq '--get_gis_agent' ) {
param_check ( $ ltotal , 1 , 0 ) ;
cli_get_gis_agent ( ) ;
}
elsif ( $ param eq '--insert_gis_data' ) {
2022-10-11 11:46:02 +02:00
param_check ( $ ltotal , 4 , 0 ) ;
2022-09-21 17:41:09 +02:00
cli_insert_gis_data ( ) ;
}
2010-09-20 16:25:44 +02:00
else {
2012-12-28 09:26:49 +01:00
print_log "[ERROR] Invalid option '$param'.\n\n" ;
2010-09-20 16:25:44 +02:00
$ param = '' ;
help_screen ( ) ;
exit ;
}
2010-03-24 14:09:09 +01:00
}
exit ;
}
2014-04-23 11:55:05 +02:00
##############################################################################
# Create a custom graph.
# Related option: --create_custom_graph
##############################################################################
sub cli_create_custom_graph () {
my ( $ name , $ description , $ user , $ idGroup , $ width , $ height , $ events , $ stacked , $ period , $ modules , $ separator ) = @ ARGV [ 2 .. 12 ] ;
$ separator = ( $ separator ne '' ) ? $ separator : ';' ;
my @ module_array = split ( $ separator , $ modules ) ;
$ description = ( $ description ne '' ) ? safe_input ( $ description ) : '' ;
$ width = ( $ width ne '' ) ? $ width : 550 ;
$ height = ( $ height ne '' ) ? $ height : 210 ;
$ period = ( $ period ne '' ) ? $ period : 86400 ;
$ events = ( $ events ne '' ) ? $ events : 0 ;
$ stacked = ( $ stacked ne '' ) ? $ stacked : 0 ;
$ idGroup = ( $ idGroup ne '' ) ? $ idGroup : 0 ;
my $ id_graph = pandora_create_custom_graph ( $ name , $ description , $ user , $ idGroup , $ width , $ height , $ events , $ stacked , $ period , $ dbh ) ;
if ( $ id_graph != 0 ) { #~ insert source
if ( $ modules ne '' ) {
foreach my $ module ( @ module_array ) {
pandora_insert_graph_source ( $ id_graph , $ module , 1 , $ dbh ) ;
}
}
}
}
##############################################################################
# Delete a custom graph.
# Related option: --delete_custom_graph
##############################################################################
sub cli_delete_custom_graph () {
my ( $ id_graph ) = @ ARGV [ 2 ] ;
my $ result = pandora_delete_graph_source ( $ id_graph , $ dbh ) ;
pandora_delete_custom_graph ( $ id_graph , $ dbh ) ;
}
##############################################################################
# Edit a custom graph.
# Related option: --edit_custom_graph
##############################################################################
sub cli_edit_custom_graph () {
my ( $ id_graph , $ name , $ description , $ user , $ idGroup , $ width , $ height , $ events , $ stacked , $ period ) = @ ARGV [ 2 .. 12 ] ;
pandora_edit_custom_graph ( $ id_graph , $ name , $ description , $ user , $ idGroup , $ width , $ height , $ events , $ stacked , $ period , $ dbh ) ;
}
sub cli_add_modules_to_graph () {
my ( $ id_graph , $ modules , $ separator ) = @ ARGV [ 2 .. 4 ] ;
$ separator = ( $ separator ne '' ) ? $ separator : ';' ;
my @ module_array = split ( $ separator , $ modules ) ;
foreach my $ module ( @ module_array ) {
pandora_insert_graph_source ( $ id_graph , $ module , 1 , $ dbh ) ;
}
}
sub cli_delete_modules_to_graph () {
my ( $ id_graph , $ modules , $ separator ) = @ ARGV [ 2 .. 4 ] ;
$ separator = ( $ separator ne '' ) ? $ separator : ';' ;
my @ module_array = split ( $ separator , $ modules ) ;
foreach my $ module ( @ module_array ) {
pandora_delete_graph_source ( $ id_graph , $ dbh , $ module ) ;
}
}
2014-07-08 15:24:31 +02:00
##############################################################################
# Return local component id given the name
##############################################################################
sub pandora_get_local_component_id ($$) {
my ( $ dbh , $ name ) = @ _ ;
my $ lc_id = get_db_value ( $ dbh , 'SELECT id FROM tlocal_component WHERE name = ?' , safe_input ( $ name ) ) ;
return defined ( $ lc_id ) ? $ lc_id : - 1 ;
}
2016-05-26 12:28:42 +02:00
##############################################################################
# Create policy
# Related option: --create_policy
##############################################################################
sub cli_create_policy () {
my ( $ policy_name , $ group_name , $ description ) = @ ARGV [ 2 .. 4 ] ;
my $ policy_id = enterprise_hook ( 'get_policy_id' , [ $ dbh , safe_input ( $ policy_name ) ] ) ;
non_exist_check ( $ policy_id , 'policy' , $ policy_name ) ;
my $ id_group = get_group_id ( $ dbh , $ group_name ) ;
exist_check ( $ id_group , 'group' , $ group_name ) ;
2016-06-21 15:22:00 +02:00
my $ id = enterprise_hook ( 'create_policy' , [ $ dbh , $ policy_name , $ description , $ id_group ] ) ;
2016-05-26 12:28:42 +02:00
return $ id ;
}
##############################################################################
# Add collection to a policy
# Related option: --add_collection_to_policy
##############################################################################
sub cli_add_collection_to_policy () {
my ( $ policy_name , $ collection_name ) = @ ARGV [ 2 .. 3 ] ;
my $ policy_id = enterprise_hook ( 'get_policy_id' , [ $ dbh , safe_input ( $ policy_name ) ] ) ;
exist_check ( $ policy_id , 'policy' , $ policy_name ) ;
my $ collection_id = enterprise_hook ( 'get_collection_id' , [ $ dbh , safe_input ( $ collection_name ) ] ) ;
exist_check ( $ collection_id , 'group' , $ collection_name ) ;
my $ id = enterprise_hook ( 'add_collection_to_policy_db' , [ $ dbh , $ policy_id , $ collection_id ] ) ;
return $ id ;
}
2014-07-08 15:24:31 +02:00
##############################################################################
# Create data module from local component.
# Related option: --create_data_module_from_local_component
##############################################################################
sub cli_create_data_module_from_local_component () {
2019-10-17 11:14:42 +02:00
my ( $ agent_name , $ component_name , $ use_alias ) = @ ARGV [ 2 .. 4 ] ;
my @ id_agents ;
if ( defined $ use_alias and $ use_alias eq 'use_alias' ) {
@ id_agents = get_agent_ids_from_alias ( $ dbh , $ agent_name ) ;
my $ agent_id ;
foreach my $ id ( @ id_agents ) {
$ agent_id = $ id - > { 'id_agente' } ;
exist_check ( $ agent_id , 'agent' , $ agent_name ) ;
my $ lc_id = pandora_get_local_component_id ( $ dbh , $ component_name ) ;
exist_check ( $ lc_id , 'local component' , $ component_name ) ;
my $ module_exists = get_agent_module_id ( $ dbh , $ component_name , $ agent_id ) ;
if ( $ module_exists ne - 1 ) {
next ;
}
# Get local component data
my $ component = get_db_single_row ( $ dbh , 'SELECT * FROM tlocal_component WHERE id = ?' , $ lc_id ) ;
print_log "[INFO] Creating module from local component '$component_name'\n\n" ;
#~ pandora_create_module_from_local_component ($conf, $component, $agent_id, $dbh);
enterprise_hook ( 'pandora_create_module_from_local_component' , [ $ conf , $ component , $ agent_id , $ dbh ] ) ;
}
} else {
my $ agent_id = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ agent_id , 'agent' , $ agent_name ) ;
my $ lc_id = pandora_get_local_component_id ( $ dbh , $ component_name ) ;
exist_check ( $ lc_id , 'local component' , $ component_name ) ;
2014-07-08 15:24:31 +02:00
2019-10-17 11:14:42 +02:00
my $ module_exists = get_agent_module_id ( $ dbh , $ component_name , $ agent_id ) ;
non_exist_check ( $ module_exists , 'module name' , $ component_name ) ;
# Get local component data
my $ component = get_db_single_row ( $ dbh , 'SELECT * FROM tlocal_component WHERE id = ?' , $ lc_id ) ;
print_log "[INFO] Creating module from local component '$component_name'\n\n" ;
#~ pandora_create_module_from_local_component ($conf, $component, $agent_id, $dbh);
enterprise_hook ( 'pandora_create_module_from_local_component' , [ $ conf , $ component , $ agent_id , $ dbh ] ) ;
}
2014-07-08 15:24:31 +02:00
}
2016-05-26 12:28:42 +02:00
##############################################################################
# Create policy data module from local component.
# Related option: --create_policy_data_module_from_local_component
##############################################################################
sub cli_create_policy_data_module_from_local_component () {
my ( $ policy_name , $ component_name ) = @ ARGV [ 2 .. 3 ] ;
my $ policy_id = enterprise_hook ( 'get_policy_id' , [ $ dbh , safe_input ( $ policy_name ) ] ) ;
exist_check ( $ policy_id , 'policy' , $ policy_name ) ;
my $ lc_id = pandora_get_local_component_id ( $ dbh , $ component_name ) ;
exist_check ( $ lc_id , 'local component' , $ component_name ) ;
# Get local component data
my $ component = get_db_single_row ( $ dbh , 'SELECT * FROM tlocal_component WHERE id = ?' , $ lc_id ) ;
enterprise_hook ( 'pandora_create_policy_data_module_from_local_component' , [ $ conf , $ component , $ policy_id , $ dbh ] ) ;
}
2014-07-08 15:24:31 +02:00
##############################################################################
# Create local component.
# Related option: --create_local_component
##############################################################################
sub cli_create_local_component () {
my ( $ component_name , $ data , $ description , $ id_os , $ os_version , $ id_network_component_group , $ type ,
$ min , $ max , $ module_interval , $ id_module_group , $ history_data , $ min_warning , $ max_warning , $ str_warning ,
$ min_critical , $ max_critical , $ str_critical , $ min_ff_event , $ post_process , $ unit , $ wizard_level ,
$ critical_instructions , $ warning_instructions , $ unknown_instructions , $ critical_inverse , $ warning_inverse ,
$ id_category , $ tags , $ disabled_types_event , $ min_ff_event_normal , $ min_ff_event_warning , $ min_ff_event_critical ,
$ each_ff , $ ff_timeout ) = @ ARGV [ 2 .. 37 ] ;
my % parameters ;
$ parameters { 'name' } = safe_input ( $ component_name ) ;
2014-07-08 16:24:55 +02:00
my $ data_aux = safe_input ( $ data ) ;
$ data_aux =~ s/\n/
/g ;
$ parameters { 'data' } = $ data_aux ;
2014-07-08 15:24:31 +02:00
$ parameters { 'description' } = safe_input ( $ description ) unless ! defined ( $ description ) ;
$ parameters { 'id_os' } = $ id_os unless ! defined ( $ id_os ) ;
$ parameters { 'type' } = $ type unless ! defined ( $ type ) ;
if ( defined $ id_network_component_group ) {
$ parameters { 'id_network_component_group' } = $ id_network_component_group ;
} else {
$ parameters { 'id_network_component_group' } = 1 ;
}
$ parameters { 'max' } = $ max unless ! defined ( $ max ) ;
$ parameters { 'min' } = $ min unless ! defined ( $ min ) ;
$ parameters { 'module_interval' } = $ module_interval unless ! defined ( $ module_interval ) ;
$ parameters { 'id_module_group' } = $ id_module_group unless ! defined ( $ id_module_group ) ;
$ parameters { 'history_data' } = safe_input ( $ history_data ) unless ! defined ( $ history_data ) ;
$ parameters { 'min_warning' } = $ min_warning unless ! defined ( $ min_warning ) ;
$ parameters { 'max_warning' } = $ max_warning unless ! defined ( $ max_warning ) ;
$ parameters { 'str_warning' } = $ str_warning unless ! defined ( $ str_warning ) ;
$ parameters { 'min_critical' } = $ min_critical unless ! defined ( $ min_critical ) ;
$ parameters { 'max_critical' } = $ max_critical unless ! defined ( $ max_critical ) ;
$ parameters { 'str_critical' } = $ str_critical unless ! defined ( $ str_critical ) ;
$ parameters { 'min_ff_event' } = $ min_ff_event unless ! defined ( $ min_ff_event ) ;
$ parameters { 'post_process' } = $ post_process unless ! defined ( $ post_process ) ;
$ parameters { 'unit' } = $ unit unless ! defined ( $ unit ) ;
$ parameters { 'wizard_level' } = $ wizard_level unless ! defined ( $ wizard_level ) ;
$ parameters { 'critical_instructions' } = safe_input ( $ critical_instructions ) unless ! defined ( $ critical_instructions ) ;
$ parameters { 'warning_instructions' } = safe_input ( $ warning_instructions ) unless ! defined ( $ warning_instructions ) ;
$ parameters { 'unknown_instructions' } = safe_input ( $ unknown_instructions ) unless ! defined ( $ unknown_instructions ) ;
$ parameters { 'critical_inverse' } = $ critical_inverse unless ! defined ( $ critical_inverse ) ;
$ parameters { 'warning_inverse' } = $ warning_inverse unless ! defined ( $ warning_inverse ) ;
$ parameters { 'id_category' } = $ id_category unless ! defined ( $ id_category ) ;
$ parameters { 'tags' } = safe_input ( $ tags ) unless ! defined ( $ tags ) ;
my $ disabled_types_event_hash = { } ;
if ( $ disabled_types_event ) {
$ disabled_types_event_hash - > { 'going_unknown' } = 0 ;
}
else {
$ disabled_types_event_hash - > { 'going_unknown' } = 1 ;
}
my $ disabled_types_event_json = encode_json ( $ disabled_types_event_hash ) ;
$ parameters { 'disabled_types_event' } = $ disabled_types_event_json unless ! defined ( $ disabled_types_event ) ;
$ parameters { 'min_ff_event_normal' } = $ min_ff_event_normal unless ! defined ( $ min_ff_event_normal ) ;
$ parameters { 'min_ff_event_warning' } = $ min_ff_event_warning unless ! defined ( $ min_ff_event_warning ) ;
$ parameters { 'min_ff_event_critical' } = $ min_ff_event_critical unless ! defined ( $ min_ff_event_critical ) ;
$ parameters { 'each_ff' } = $ each_ff unless ! defined ( $ each_ff ) ;
$ parameters { 'ff_timeout' } = $ ff_timeout unless ! defined ( $ ff_timeout ) ;
my $ component_id = enterprise_hook ( 'pandora_create_local_component_from_hash' , [ $ conf , \ % parameters , $ dbh ] ) ;
2015-03-26 13:41:07 +01:00
}
##############################################################################
# Create a new tag.
##############################################################################
sub cli_create_tag () {
my ( $ tag_name , $ tag_description , $ tag_url , $ tag_email ) = @ ARGV [ 2 .. 5 ] ;
# Call the API.
my $ result = api_call ( \ % conf , 'set' , 'create_tag' , undef , undef , "$tag_name|$tag_description|$tag_url|$tag_email" ) ;
print "\n$result\n" ;
}
##############################################################################
# Add a tag to the specified profile and group.
##############################################################################
sub cli_add_tag_to_user_profile () {
my ( $ user_id , $ tag_name , $ group_name , $ profile_name ) = @ ARGV [ 2 .. 5 ] ;
# Check the user.
my $ user_exists = get_user_exists ( $ dbh , $ user_id ) ;
exist_check ( $ user_exists , 'user' , $ user_id ) ;
# Check the group.
my $ group_id ;
if ( $ group_name eq 'All' ) {
$ group_id = 0 ;
} else {
$ group_id = get_group_id ( $ dbh , $ group_name ) ;
exist_check ( $ group_id , 'group' , $ group_name ) ;
}
# Check the profile.
my $ profile_id = get_profile_id ( $ dbh , $ profile_name ) ;
exist_check ( $ profile_id , 'profile' , $ profile_name ) ;
# Make sure the tag exists.
my $ tag_id = get_tag_id ( $ dbh , $ tag_name ) ;
exist_check ( $ tag_id , 'tag' , $ tag_name ) ;
# Make sure the profile is associated to the user.
my $ user_profile_id = get_user_profile_id ( $ dbh , $ user_id , $ profile_id , $ group_id ) ;
exist_check ( $ user_profile_id , 'given profile and group combination for user' , $ user_id ) ;
# Call the API.
my $ result = api_call ( \ % conf , 'set' , 'tag_user_profile' , $ user_id , $ tag_id , "$group_id|$profile_id" ) ;
print "\n$result\n" ;
}
##############################################################################
# Add a tag to the specified profile and group.
##############################################################################
sub cli_add_tag_to_module () {
my ( $ agent_name , $ module_name , $ tag_name ) = @ ARGV [ 2 .. 4 ] ;
# Check the tag.
my $ tag_id = get_tag_id ( $ dbh , $ tag_name ) ;
exist_check ( $ tag_id , 'tag' , $ tag_name ) ;
# Check the agent.
my $ agent_id = get_agent_id ( $ dbh , $ agent_name ) ;
exist_check ( $ agent_id , 'agent' , $ agent_name ) ;
# Check the module.
my $ module_id = get_agent_module_id ( $ dbh , $ module_name , $ agent_id ) ;
exist_check ( $ module_id , 'module name' , $ module_name ) ;
2014-07-08 15:24:31 +02:00
2015-03-26 13:41:07 +01:00
# Call the API.
my $ result = api_call ( \ % conf , 'set' , 'add_tag_module' , $ module_id , $ tag_id ) ;
print "\n$result\n" ;
2014-07-08 15:24:31 +02:00
}
2018-03-22 13:18:48 +01:00
##############################################################################
# Only meta migrate agent
##############################################################################
sub cli_migration_agent_queue () {
my ( $ id_agent , $ source_name , $ target_name , $ only_db ) = @ ARGV [ 2 .. 5 ] ;
if ( ! defined ( $ id_agent ) || ! defined ( $ source_name ) || ! defined ( $ target_name ) ) {
print "\n0\n" ;
}
if ( ! defined ( $ only_db ) ) {
$ only_db = 0 ;
}
# Call the API.
my $ result = api_call ( $ conf , 'set' , 'migrate_agent' , $ id_agent , 0 , "$source_name|$target_name|$only_db" ) ;
print "\n$result\n" ;
}
##############################################################################
# Only meta is migrate agent
##############################################################################
sub cli_migration_agent () {
my ( $ id_agent ) = @ ARGV [ 2 ] ;
if ( ! defined ( $ id_agent ) ) {
print "\n0\n" ;
}
# Call the API.
my $ result = api_call ( $ conf , 'get' , 'migrate_agent' , $ id_agent ) ;
if ( defined ( $ result ) && "$result" ne "" ) {
print "\n1\n" ;
}
else {
print "\n0\n" ;
}
}
2018-03-22 13:28:18 +01:00
2018-02-26 19:10:53 +01:00
sub cli_apply_module_template () {
my ( $ id_template , $ id_agent ) = @ ARGV [ 2 .. 3 ] ;
my @ row = get_db_rows ( $ dbh , "select * from tagente where id_agente = " . $ id_agent ) ;
return if ( scalar ( @ row ) == 0 ) ;
my $ name_template = get_db_value ( $ dbh , 'select name from tnetwork_profile where id_np = ' . $ id_template ) ;
my @ npc = get_db_rows ( $ dbh , "select * from tnetwork_profile_component where id_np = " . $ id_template ) ;
foreach my $ component ( @ npc ) {
my @ template_values = get_db_rows ( $ dbh , "SELECT * FROM tnetwork_component where id_nc = " . $ component - > { 'id_nc' } ) ;
return if ( scalar ( @ template_values ) == 0 ) ;
foreach my $ element ( @ template_values ) {
my $ agent_values ;
$ agent_values - > { 'id_agente' } = $ id_agent ;
$ agent_values - > { 'id_tipo_modulo' } = $ element - > { "type" } ;
$ agent_values - > { 'descripcion' } = 'Created by template ' . $ name_template . ' ' . $ element - > { "description" } ;
$ agent_values - > { 'max' } = $ element - > { "max" } ;
$ agent_values - > { 'min' } = $ element - > { "min" } ;
$ agent_values - > { 'module_interval' } = $ element - > { "module_interval" } ;
$ agent_values - > { 'tcp_port' } = $ element - > { "tcp_port" } ;
$ agent_values - > { 'tcp_send' } = $ element - > { "tcp_send" } ;
$ agent_values - > { 'tcp_rcv' } = $ element - > { "tcp_rcv" } ;
$ agent_values - > { 'snmp_community' } = $ element - > { "snmp_community" } ;
$ agent_values - > { 'snmp_oid' } = $ element - > { "snmp_oid" } ;
$ agent_values - > { 'ip_target' } = $ row [ 0 ] - > { "direccion" } ;
$ agent_values - > { 'id_module_group' } = $ element - > { "id_module_group" } ;
$ agent_values - > { 'id_modulo' } = $ element - > { "id_modulo" } ;
$ agent_values - > { 'plugin_user' } = $ element - > { "plugin_user" } ;
$ agent_values - > { 'plugin_pass' } = $ element - > { "plugin_pass" } ;
$ agent_values - > { 'plugin_parameter' } = $ element - > { "plugin_parameter" } ;
$ agent_values - > { 'unit' } = $ element - > { "unit" } ;
$ agent_values - > { 'max_timeout' } = $ element - > { "max_timeout" } ;
$ agent_values - > { 'max_retries' } = $ element - > { "max_retries" } ;
$ agent_values - > { 'id_plugin' } = $ element - > { "id_plugin" } ;
$ agent_values - > { 'post_process' } = $ element - > { "post_process" } ;
$ agent_values - > { 'dynamic_interval' } = $ element - > { "dynamic_interval" } ;
$ agent_values - > { 'dynamic_max' } = $ element - > { "dynamic_max" } ;
$ agent_values - > { 'dynamic_min' } = $ element - > { "dynamic_min" } ;
$ agent_values - > { 'dynamic_two_tailed' } = $ element - > { "dynamic_two_tailed" } ;
$ agent_values - > { 'min_warning' } = $ element - > { "min_warning" } ;
$ agent_values - > { 'max_warning' } = $ element - > { "max_warning" } ;
$ agent_values - > { 'str_warning' } = $ element - > { "str_warning" } ;
$ agent_values - > { 'min_critical' } = $ element - > { "min_critical" } ;
$ agent_values - > { 'max_critical' } = $ element - > { "max_critical" } ;
$ agent_values - > { 'str_critical' } = $ element - > { "str_critical" } ;
$ agent_values - > { 'critical_inverse' } = $ element - > { "critical_inverse" } ;
$ agent_values - > { 'warning_inverse' } = $ element - > { "warning_inverse" } ;
$ agent_values - > { 'critical_instructions' } = $ element - > { "critical_instructions" } ;
$ agent_values - > { 'warning_instructions' } = $ element - > { "warning_instructions" } ;
$ agent_values - > { 'unknown_instructions' } = $ element - > { "unknown_instructions" } ;
$ agent_values - > { 'id_category' } = $ element - > { "id_category" } ;
$ agent_values - > { 'macros' } = $ element - > { "macros" } ;
$ agent_values - > { 'each_ff' } = $ element - > { "each_ff" } ;
$ agent_values - > { 'min_ff_event' } = $ element - > { "min_ff_event" } ;
$ agent_values - > { 'min_ff_event_normal' } = $ element - > { "min_ff_event_normal" } ;
$ agent_values - > { 'min_ff_event_warning' } = $ element - > { "min_ff_event_warning" } ;
$ agent_values - > { 'min_ff_event_critical' } = $ element - > { "min_ff_event_critical" } ;
$ agent_values - > { 'nombre' } = $ element - > { "name" } ;
my @ tags ;
if ( $ element - > { "tags" } ne '' ) {
@ tags = split ( ',' , $ element - > { "tags" } ) ;
}
my $ module_name_check = get_db_value ( $ dbh , 'select id_agente_modulo from tagente_modulo where delete_pending = 0 and nombre ="' . $ agent_values - > { 'nombre' } . '" and id_agente = ' . $ id_agent ) ;
if ( ! defined ( $ module_name_check ) ) {
my $ id_agente_modulo = pandora_create_module_from_hash ( \ % conf , $ agent_values , $ dbh ) ;
if ( $ id_agente_modulo != - 1 ) {
foreach my $ tag_name ( @ tags ) {
my $ tag_id = get_db_value ( $ dbh , 'select id_tag from ttag where name = "' . $ tag_name . '"' ) ;
db_do ( $ dbh , 'insert into ttag_module (id_tag,id_agente_modulo) values ("' . $ tag_id . '","' . $ id_agente_modulo . '")' ) ;
}
}
}
}
}
}
2018-04-09 11:43:41 +02:00
##############################################################################
# Create an cluster.
# Related option: --new_cluster
##############################################################################
sub cli_new_cluster () {
my ( $ cluster_name , $ cluster_type , $ description , $ group_id ) = @ ARGV [ 2 .. 5 ] ;
# Call the API.
my $ result = api_call ( $ conf , 'set' , 'new_cluster' , undef , undef , "$cluster_name|$cluster_type|$description|$group_id" ) ;
if ( defined ( $ result ) && "$result" ne "" ) {
print "\n1\n" ;
}
else {
print "\n0\n" ;
}
}
##############################################################################
# Assign an agent to cluster.
# Related option: --add_cluster_agent
##############################################################################
sub cli_add_cluster_agent () {
my ( $ other ) = @ ARGV [ 2 .. 2 ] ;
# Call the API.
my $ result = api_call ( $ conf , 'set' , 'add_cluster_agent' , undef , undef , $ other ) ;
if ( defined ( $ result ) && "$result" ne "" ) {
print "\n1\n" ;
}
else {
print "\n0\n" ;
}
}
##############################################################################
# Add item to cluster.
# Related option: --add_cluster_item
##############################################################################
sub cli_add_cluster_item () {
my ( $ other ) = @ ARGV [ 2 .. 2 ] ;
# Call the API.
my $ result = api_call ( $ conf , 'set' , 'add_cluster_item' , undef , undef , $ other ) ;
if ( defined ( $ result ) && "$result" ne "" ) {
print "\n1\n" ;
}
else {
print "\n0\n" ;
}
}
##############################################################################
# Delete cluster.
# Related option: --delete_cluster
##############################################################################
sub cli_delete_cluster () {
my ( $ id ) = @ ARGV [ 2 .. 2 ] ;
# Call the API.
my $ result = api_call ( $ conf , 'set' , 'delete_cluster' , $ id ) ;
if ( defined ( $ result ) && "$result" ne "" ) {
print "\n1\n" ;
}
else {
print "\n0\n" ;
}
}
##############################################################################
# Delete cluster item.
# Related option: --delete_cluster_item
##############################################################################
sub cli_delete_cluster_agent () {
my ( $ id_agent , $ id_cluster ) = @ ARGV [ 2 .. 3 ] ;
# Call the API.
my $ result = api_call ( $ conf , 'set' , 'delete_cluster_agent' , undef , undef , "$id_agent|$id_cluster" ) ;
if ( defined ( $ result ) && "$result" ne "" ) {
print "\n1\n" ;
}
else {
print "\n0\n" ;
}
}
##############################################################################
# Delete cluster item.
# Related option: --delete_cluster_item
##############################################################################
sub cli_delete_cluster_item () {
my ( $ id ) = @ ARGV [ 2 .. 2 ] ;
# Call the API.
my $ result = api_call ( $ conf , 'set' , 'delete_cluster_item' , $ id ) ;
if ( defined ( $ result ) && "$result" ne "" ) {
print "\n1\n" ;
}
else {
print "\n0\n" ;
}
}
2018-04-23 13:52:16 +02:00
##############################################################################
# get cluster status.
# Related option: --get_cluster_status
##############################################################################
sub cli_get_cluster_status () {
my ( $ id ) = @ ARGV [ 2 .. 2 ] ;
# Call the API.
my $ result = api_call ( $ conf , 'get' , 'cluster_status' , $ id ) ;
if ( defined ( $ result ) && "$result" ne "" ) {
print "\n1\n" ;
}
else {
print "\n0\n" ;
}
2018-09-25 13:42:29 +02:00
}
##############################################################################
# Set an agent disabled and with standby.
# Related option: --set_disabled_and_standby
##############################################################################
sub cli_set_disabled_and_standby () {
my ( $ id , $ id_node , $ value ) = @ ARGV [ 2 .. 4 ] ;
$ id_node = 0 unless defined ( $ id_node ) ;
$ value = 1 unless defined ( $ value ) ; #Set to disabled by default
# Call the API.
my $ result = api_call (
$ conf , 'set' , 'disabled_and_standby' , $ id , $ id_node , $ value
) ;
my $ exit_code = ( defined ( $ result ) && "$result" eq "1" ) ? "1" : "0" ;
print "\n$exit_code\n" ;
2019-01-18 17:24:32 +01:00
}
##############################################################################
# Resets module counts and alert counts in the agents.
# Related option: --reset_agent_counts
##############################################################################
sub cli_reset_agent_counts () {
my $ agent_id = @ ARGV [ 2 ] ;
my $ result = api_call ( \ % conf , 'set' , 'reset_agent_counts' , $ agent_id ) ;
print "$result \n\n " ;
}
2020-06-03 15:56:19 +02:00
##############################################################################
# Set an event in progress.
# Related option: --event_in_progress
##############################################################################
sub cli_event_in_progress () {
2020-07-15 23:36:21 +02:00
my $ event_id = @ ARGV [ 2 ] ;
2020-06-03 15:56:19 +02:00
# Call the API.
my $ result = api_call (
2020-07-15 23:36:21 +02:00
$ conf , 'set' , 'event_in_progress' , $ event_id
2020-06-03 15:56:19 +02:00
) ;
print "\n$result\n" ;
2021-04-06 19:21:56 +02:00
}
##############################################################################
# Validates an alert given id alert, id module, id angent and template name.
##############################################################################
sub pandora_validate_alert_id ($$$$) {
my ( $ id_alert_agent_module , $ agent_id , $ id_agent_module , $ template_name ) = @ _ ;
my $ group_id = get_agent_group ( $ dbh , $ agent_id ) ;
my $ critical_instructions = get_db_value ( $ dbh , 'SELECT critical_instructions from tagente_modulo WHERE id_agente_modulo = ?' , $ agent_id ) ;
my $ warning_instructions = get_db_value ( $ dbh , 'SELECT warning_instructions from tagente_modulo WHERE id_agente_modulo = ?' , $ agent_id ) ;
my $ unknown_instructions = get_db_value ( $ dbh , 'SELECT unknown_instructions from tagente_modulo WHERE id_agente_modulo = ?' , $ agent_id ) ;
my $ parameters = {
'times_fired' = > 0 ,
'internal_counter' = > 0 ,
} ;
my $ result = db_process_update ( $ dbh , 'talert_template_modules' , $ parameters , { 'id' = > $ id_alert_agent_module } ) ;
return 0 unless $ result != 0 ;
my $ module_name = safe_output ( get_db_value ( $ dbh , 'SELECT nombre FROM tagente_modulo WHERE id_agente_modulo = ?' , $ id_agent_module ) ) ;
# Update fired alert count on the agent
db_process_update ( $ dbh , 'tagente' , { 'update_alert_count' = > 1 } , { 'id_agente' = > $ agent_id } ) ;
my $ event = 'Manual validation of alert ' . $ template_name . ' assigned to ' . $ module_name . '' ;
pandora_event (
$ conf ,
$ event ,
$ group_id ,
$ agent_id ,
0 ,
$ id_alert_agent_module ,
$ id_agent_module ,
'alert_manual_validation' ,
1 ,
$ dbh ,
0 ,
'' ,
'' ,
'' ,
'' ,
$ critical_instructions ,
$ warning_instructions ,
$ unknown_instructions ,
''
) ;
return 1 ;
2022-05-31 12:50:43 +02:00
}
2022-09-21 17:41:09 +02:00
##############################################################################
# Get GIS data from agent
##############################################################################
sub cli_get_gis_agent () {
my $ agent_id = @ ARGV [ 2 ] ;
my $ result = api_call ( \ % conf , 'get' , 'gis_agent' , $ agent_id ) ;
print "$result \n\n " ;
}
##############################################################################
# Set GIS data for specified agent
##############################################################################
sub cli_insert_gis_data () {
my ( $ agent_id , $ latitude , $ longitude , $ altitude ) = @ ARGV [ 2 .. 5 ] ;
my $ agent_id = @ ARGV [ 2 ] ;
my @ position = @ ARGV [ 3 .. 5 ] ;
my $ other = join ( '|' , @ position ) ;
my $ result = api_call ( \ % conf , 'set' , 'gis_agent_only_position' , $ agent_id , undef , "$other" ) ;
print "$result \n\n " ;
2022-10-11 11:46:02 +02:00
}