2007-08-02 19:53:07 +02:00
package PandoraFMS::DB ;
##########################################################################
2008-07-22 17:52:34 +02:00
# Database Package
# Pandora FMS. the Flexible Monitoring System. http://www.pandorafms.org
2007-08-02 19:53:07 +02:00
##########################################################################
2023-07-03 17:20:25 +02:00
# Copyright (c) 2005-2023 Pandora FMS
2007-08-02 19:53:07 +02:00
#
2008-02-20 03:09:36 +01:00
# This program is free software; you can redistribute it and/or
2009-01-12 03:44:39 +01:00
# modify it under the terms of the GNU Lesser General Public License
2008-02-20 03:09:36 +01:00
# as published by the Free Software Foundation; version 2
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
2007-08-02 19:53:07 +02:00
##########################################################################
2009-01-16 12:22:56 +01:00
use strict ;
2007-08-02 19:53:07 +02:00
use warnings ;
2022-11-07 19:56:24 +01:00
use threads ;
2007-08-02 19:53:07 +02:00
use DBI ;
2020-03-16 23:52:20 +01:00
use Carp qw/croak/ ;
2019-02-22 18:12:01 +01:00
2021-04-15 17:56:02 +02:00
BEGIN { push @ INC , '/usr/lib/perl5' ; }
2012-07-24 15:23:27 +02:00
use PandoraFMS::Tools ;
#use Data::Dumper;
2007-08-02 19:53:07 +02:00
require Exporter ;
our @ ISA = ( "Exporter" ) ;
our % EXPORT_TAGS = ( 'all' = > [ qw( ) ] ) ;
our @ EXPORT_OK = ( @ { $ EXPORT_TAGS { 'all' } } ) ;
2011-06-28 12:04:45 +02:00
our @ EXPORT = qw(
add_address
add_new_address_agent
2011-12-01 17:11:42 +01:00
db_concat
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
db_connect
2018-03-13 16:35:13 +01:00
db_history_connect
2015-07-22 15:36:46 +02:00
db_delete_limit
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
db_disconnect
2009-01-15 13:51:26 +01:00
db_do
2013-05-07 17:38:11 +02:00
db_get_lock
2022-03-28 20:56:05 +02:00
db_get_pandora_lock
2011-04-13 Ramon Novoa <rnovoa@artica.es>
* lib/PandoraFMS/SNMPServer.pm,
lib/PandoraFMS/Config.pm,
lib/PandoraFMS/NetworkServer.pm,
lib/PandoraFMS/WMIServer.pm,
lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/DB.pm,
lib/PandoraFMS/ProducerConsumerServer.pm,
lib/PandoraFMS/PredictionServer.pm,
lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm,
bin/pandora_server,
util/pandora_db.pl,
util/pandora_manage.pl,
util/recon_scripts/snmpdevices.pl: Adding support for PostgreSQL and
Oracle (not complete).
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4213 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 18:28:59 +02:00
db_insert
2013-03-01 15:27:52 +01:00
db_insert_get_values
2018-03-13 16:35:13 +01:00
db_insert_from_array_hash
2018-03-12 19:39:28 +01:00
db_insert_from_hash
2010-09-23 10:16:44 +02:00
db_process_insert
2010-11-04 18:35:37 +01:00
db_process_update
2013-05-07 17:38:11 +02:00
db_release_lock
2022-03-28 20:56:05 +02:00
db_release_pandora_lock
2011-04-13 Ramon Novoa <rnovoa@artica.es>
* lib/PandoraFMS/SNMPServer.pm,
lib/PandoraFMS/Config.pm,
lib/PandoraFMS/NetworkServer.pm,
lib/PandoraFMS/WMIServer.pm,
lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/DB.pm,
lib/PandoraFMS/ProducerConsumerServer.pm,
lib/PandoraFMS/PredictionServer.pm,
lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm,
bin/pandora_server,
util/pandora_db.pl,
util/pandora_manage.pl,
util/recon_scripts/snmpdevices.pl: Adding support for PostgreSQL and
Oracle (not complete).
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4213 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 18:28:59 +02:00
db_string
2011-04-18 18:42:18 +02:00
db_text
2010-10-21 16:26:46 +02:00
db_update
2020-06-17 13:14:22 +02:00
db_update_hash
2013-03-01 15:27:52 +01:00
db_update_get_values
2018-07-04 18:39:06 +02:00
set_update_agent
2020-06-17 13:14:22 +02:00
set_update_agentmodule
2010-05-25 18:23:07 +02:00
get_action_id
2023-06-15 19:22:29 +02:00
get_action_name
2011-06-28 12:04:45 +02:00
get_addr_id
2012-04-12 12:04:35 +02:00
get_agent_addr_id
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
get_agent_id
2019-10-17 11:14:42 +02:00
get_agent_ids_from_alias
2011-05-12 13:11:37 +02:00
get_agent_address
2017-06-12 14:34:03 +02:00
get_agent_alias
2011-06-10 14:50:56 +02:00
get_agent_group
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
get_agent_name
2010-05-25 15:43:25 +02:00
get_agent_module_id
2023-06-29 17:06:59 +02:00
get_agent_module_id_by_name
2011-05-09 11:42:01 +02:00
get_alert_template_module_id
2011-06-08 13:07:39 +02:00
get_alert_template_name
2018-12-03 17:38:57 +01:00
get_command_id
2021-06-10 21:36:54 +02:00
get_console_api_url
2022-11-07 19:56:24 +01:00
get_db_nodes
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
get_db_rows
2015-06-08 18:32:49 +02:00
get_db_rows_limit
2022-11-07 19:56:24 +01:00
get_db_rows_node
get_db_rows_parallel
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
get_db_single_row
get_db_value
2015-05-05 11:20:41 +02:00
get_db_value_limit
2012-12-13 18:07:23 +01:00
get_first_server_name
2010-05-25 15:43:25 +02:00
get_group_id
2009-11-04 18:49:42 +01:00
get_group_name
2011-05-23 13:55:08 +02:00
get_module_agent_id
2010-10-18 18:21:13 +02:00
get_module_group_id
2011-10-06 04:46:55 +02:00
get_module_group_name
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
get_module_id
2010-05-25 15:43:25 +02:00
get_module_name
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
get_nc_profile_name
2020-03-25 18:02:58 +01:00
get_pen_templates
get_nc_profile_advanced
2010-05-25 13:56:37 +02:00
get_os_id
2017-03-17 09:37:10 +01:00
get_os_name
2010-10-18 18:21:13 +02:00
get_plugin_id
2010-05-26 11:54:21 +02:00
get_profile_id
2012-05-10 14:18:43 +02:00
get_priority_name
2010-05-25 15:43:25 +02:00
get_server_id
2015-03-26 13:41:07 +01:00
get_tag_id
2021-04-14 22:36:56 +02:00
get_tag_name
2023-06-15 19:22:29 +02:00
get_template_id
get_template_name
2015-03-26 13:41:07 +01:00
get_group_name
2010-05-25 15:16:34 +02:00
get_template_id
get_template_module_id
2012-01-04 16:09:02 +01:00
get_user_disabled
2012-01-05 13:11:03 +01:00
get_user_exists
2015-03-26 13:41:07 +01:00
get_user_profile_id
2020-07-06 12:06:12 +02:00
get_group_children
2020-09-17 14:38:01 +02:00
get_agentmodule_custom_id
set_agentmodule_custom_id
2011-06-28 17:41:13 +02:00
is_agent_address
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
is_group_disabled
2012-07-24 15:23:27 +02:00
get_agent_status
get_agent_modules
get_agentmodule_status
2013-09-12 10:16:35 +02:00
get_agentmodule_status_str
2012-07-27 11:05:16 +02:00
get_agentmodule_data
2021-05-17 13:12:42 +02:00
set_ssl_opts
2022-10-17 16:04:45 +02:00
db_synch_insert
2022-10-18 12:49:51 +02:00
db_synch_update
db_synch_delete
db_synch
2013-03-01 15:27:52 +01:00
$ RDBMS
$ RDBMS_QUOTE
2014-07-25 15:15:24 +02:00
$ RDBMS_QUOTE_STRING
2008-03-13 19:33:44 +01:00
) ;
2007-08-02 19:53:07 +02:00
2013-03-01 15:27:52 +01:00
# Relational database management system in use
our $ RDBMS = '' ;
2014-07-25 15:15:24 +02:00
# For fields, character used to quote reserved words in the current RDBMS
2013-03-01 15:27:52 +01:00
our $ RDBMS_QUOTE = '' ;
2014-07-25 15:15:24 +02:00
# For strings, Character used to quote in the current RDBMS
our $ RDBMS_QUOTE_STRING = '' ;
2021-05-17 13:12:42 +02:00
# SSL options.
my $ SSL_OPTS = '' ;
2008-04-16 13:03:03 +02:00
##########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
## Connect to the DB.
2008-04-16 13:03:03 +02:00
##########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
sub db_connect ($$$$$$) {
my ( $ rdbms , $ db_name , $ db_host , $ db_port , $ db_user , $ db_pass ) = @ _ ;
2012-07-24 15:23:27 +02:00
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
if ( $ rdbms eq 'mysql' ) {
2011-04-13 Ramon Novoa <rnovoa@artica.es>
* lib/PandoraFMS/SNMPServer.pm,
lib/PandoraFMS/Config.pm,
lib/PandoraFMS/NetworkServer.pm,
lib/PandoraFMS/WMIServer.pm,
lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/DB.pm,
lib/PandoraFMS/ProducerConsumerServer.pm,
lib/PandoraFMS/PredictionServer.pm,
lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm,
bin/pandora_server,
util/pandora_db.pl,
util/pandora_manage.pl,
util/recon_scripts/snmpdevices.pl: Adding support for PostgreSQL and
Oracle (not complete).
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4213 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 18:28:59 +02:00
$ RDBMS = 'mysql' ;
2013-03-01 15:27:52 +01:00
$ RDBMS_QUOTE = '`' ;
2014-07-25 15:15:24 +02:00
$ RDBMS_QUOTE_STRING = '"' ;
2009-05-04 14:16:52 +02:00
# Connect to MySQL
2021-05-17 13:12:42 +02:00
my $ dbh = DBI - > connect ( "DBI:mysql:$db_name:$db_host:$db_port;$SSL_OPTS" , $ db_user , $ db_pass , { RaiseError = > 1 , AutoCommit = > 1 } ) ;
2009-05-04 14:16:52 +02:00
return undef unless defined ( $ dbh ) ;
# Enable auto reconnect
$ dbh - > { 'mysql_auto_reconnect' } = 1 ;
2012-07-24 15:23:27 +02:00
2011-04-10 03:18:01 +02:00
# Enable character semantics
$ dbh - > { 'mysql_enable_utf8' } = 1 ;
2012-07-24 15:23:27 +02:00
2011-04-13 Ramon Novoa <rnovoa@artica.es>
* lib/PandoraFMS/SNMPServer.pm,
lib/PandoraFMS/Config.pm,
lib/PandoraFMS/NetworkServer.pm,
lib/PandoraFMS/WMIServer.pm,
lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/DB.pm,
lib/PandoraFMS/ProducerConsumerServer.pm,
lib/PandoraFMS/PredictionServer.pm,
lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm,
bin/pandora_server,
util/pandora_db.pl,
util/pandora_manage.pl,
util/recon_scripts/snmpdevices.pl: Adding support for PostgreSQL and
Oracle (not complete).
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4213 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 18:28:59 +02:00
return $ dbh ;
2012-07-24 15:23:27 +02:00
}
elsif ( $ rdbms eq 'postgresql' ) {
2011-04-13 Ramon Novoa <rnovoa@artica.es>
* lib/PandoraFMS/SNMPServer.pm,
lib/PandoraFMS/Config.pm,
lib/PandoraFMS/NetworkServer.pm,
lib/PandoraFMS/WMIServer.pm,
lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/DB.pm,
lib/PandoraFMS/ProducerConsumerServer.pm,
lib/PandoraFMS/PredictionServer.pm,
lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm,
bin/pandora_server,
util/pandora_db.pl,
util/pandora_manage.pl,
util/recon_scripts/snmpdevices.pl: Adding support for PostgreSQL and
Oracle (not complete).
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4213 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 18:28:59 +02:00
$ RDBMS = 'postgresql' ;
2013-03-01 15:27:52 +01:00
$ RDBMS_QUOTE = '"' ;
2014-07-25 15:15:24 +02:00
$ RDBMS_QUOTE_STRING = "'" ;
2011-04-13 Ramon Novoa <rnovoa@artica.es>
* lib/PandoraFMS/SNMPServer.pm,
lib/PandoraFMS/Config.pm,
lib/PandoraFMS/NetworkServer.pm,
lib/PandoraFMS/WMIServer.pm,
lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/DB.pm,
lib/PandoraFMS/ProducerConsumerServer.pm,
lib/PandoraFMS/PredictionServer.pm,
lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm,
bin/pandora_server,
util/pandora_db.pl,
util/pandora_manage.pl,
util/recon_scripts/snmpdevices.pl: Adding support for PostgreSQL and
Oracle (not complete).
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4213 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 18:28:59 +02:00
# Connect to PostgreSQL
2012-04-20 05:56:09 +02:00
my $ dbh = DBI - > connect ( "DBI:Pg:dbname=$db_name;host=$db_host;port=$db_port" , $ db_user , $ db_pass , { RaiseError = > 1 , AutoCommit = > 1 } ) ;
2011-04-13 Ramon Novoa <rnovoa@artica.es>
* lib/PandoraFMS/SNMPServer.pm,
lib/PandoraFMS/Config.pm,
lib/PandoraFMS/NetworkServer.pm,
lib/PandoraFMS/WMIServer.pm,
lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/DB.pm,
lib/PandoraFMS/ProducerConsumerServer.pm,
lib/PandoraFMS/PredictionServer.pm,
lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm,
bin/pandora_server,
util/pandora_db.pl,
util/pandora_manage.pl,
util/recon_scripts/snmpdevices.pl: Adding support for PostgreSQL and
Oracle (not complete).
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4213 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 18:28:59 +02:00
return undef unless defined ( $ dbh ) ;
2011-04-18 18:42:18 +02:00
return $ dbh ;
2014-07-25 15:15:24 +02:00
}
elsif ( $ rdbms eq 'oracle' ) {
2011-04-18 18:42:18 +02:00
$ RDBMS = 'oracle' ;
2013-03-01 15:27:52 +01:00
$ RDBMS_QUOTE = '"' ;
2015-04-30 10:51:47 +02:00
$ RDBMS_QUOTE_STRING = '\'' ;
2011-04-18 18:42:18 +02:00
# Connect to Oracle
2015-05-05 11:20:41 +02:00
my $ dbh = DBI - > connect ( "DBI:Oracle:dbname=$db_name;host=$db_host;port=$db_port;sid=$db_name" , $ db_user , $ db_pass , { RaiseError = > 1 , AutoCommit = > 1 } ) ;
2011-04-18 18:42:18 +02:00
return undef unless defined ( $ dbh ) ;
# Set date format
$ dbh - > do ( "ALTER SESSION SET NLS_TIMESTAMP_FORMAT='YYYY-MM-DD HH24:MI:SS'" ) ;
2016-01-19 09:58:48 +01:00
$ dbh - > do ( "ALTER SESSION SET NLS_DATE_FORMAT='YYYY-MM-DD HH24:MI:SS'" ) ;
2011-04-19 17:32:11 +02:00
$ dbh - > do ( "ALTER SESSION SET NLS_NUMERIC_CHARACTERS='.,'" ) ;
2015-05-12 18:19:08 +02:00
# Configuration to avoid errors when working with CLOB columns
$ dbh - > { 'LongReadLen' } = 66000 ;
$ dbh - > { 'LongTruncOk' } = 1 ;
2009-05-04 14:16:52 +02:00
return $ dbh ;
2009-01-15 13:51:26 +01:00
}
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
return undef ;
2008-04-16 13:03:03 +02:00
}
2018-03-13 16:35:13 +01:00
##########################################################################
## Connect to a history DB associated to given dbh.
##########################################################################
sub db_history_connect {
my ( $ dbh , $ pa_config ) = @ _ ;
my % conf ;
$ conf { 'history_db_enabled' } = get_db_value ( $ dbh , "SELECT value FROM tconfig WHERE token = ?" , "history_db_enabled" ) ;
$ conf { 'history_db_host' } = get_db_value ( $ dbh , "SELECT value FROM tconfig WHERE token = ?" , "history_db_host" ) ;
$ conf { 'history_db_port' } = get_db_value ( $ dbh , "SELECT value FROM tconfig WHERE token = ?" , "history_db_port" ) ;
$ conf { 'history_db_name' } = get_db_value ( $ dbh , "SELECT value FROM tconfig WHERE token = ?" , "history_db_name" ) ;
$ conf { 'history_db_user' } = get_db_value ( $ dbh , "SELECT value FROM tconfig WHERE token = ?" , "history_db_user" ) ;
$ conf { 'history_db_pass' } = get_db_value ( $ dbh , "SELECT value FROM tconfig WHERE token = ?" , "history_db_pass" ) ;
my $ history_dbh = ( $ conf { 'history_db_enabled' } eq '1' ) ? db_connect ( $ pa_config - > { 'dbengine' } , $ conf { 'history_db_name' } ,
$ conf { 'history_db_host' } , $ conf { 'history_db_port' } , $ conf { 'history_db_user' } , $ conf { 'history_db_pass' } ) : undef ;
return $ history_dbh ;
}
2012-07-25 17:14:36 +02:00
########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
## Disconnect from the DB.
2012-07-25 17:14:36 +02:00
########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
sub db_disconnect ($) {
my $ dbh = shift ;
2008-04-16 13:03:03 +02:00
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
$ dbh - > disconnect ( ) ;
2007-08-02 19:53:07 +02:00
}
2021-06-10 21:36:54 +02:00
########################################################################
## Return local console API url.
########################################################################
sub get_console_api_url ($$) {
my ( $ pa_config , $ dbh ) = @ _ ;
# Only if console_api_url was not defined
if ( ! defined ( $ pa_config - > { "console_api_url" } ) ) {
my $ console_api_url = PandoraFMS::Config:: pandora_get_tconfig_token (
$ dbh , 'public_url' , ''
) ;
my $ include_api = 'include/api.php' ;
# If public_url is empty in database
if ( $ console_api_url eq '' ) {
$ pa_config - > { "console_api_url" } = 'http://127.0.0.1/pandora_console/' . $ include_api ;
logger ( $ pa_config , "Assuming default path for API url: " . $ pa_config - > { "console_api_url" } , 3 ) ;
} else {
2021-08-23 12:17:03 +02:00
if ( $ console_api_url !~ /\/$/ ) {
$ console_api_url . = '/' ;
}
2021-06-10 21:36:54 +02:00
$ pa_config - > { "console_api_url" } = $ console_api_url . $ include_api ;
}
}
return $ pa_config - > { 'console_api_url' } ;
}
2012-07-25 17:14:36 +02:00
########################################################################
2023-06-15 19:22:29 +02:00
## Return the ID of an alert action given its name.
2012-07-25 17:14:36 +02:00
########################################################################
2010-05-25 18:23:07 +02:00
sub get_action_id ($$) {
my ( $ dbh , $ action_name ) = @ _ ;
2023-06-15 19:22:29 +02:00
my $ rc = get_db_value ( $ dbh , " SELECT id FROM talert_actions
WHERE name = ? " , safe_input ( $ action_name ) ) ;
2010-05-25 18:23:07 +02:00
return defined ( $ rc ) ? $ rc : - 1 ;
}
2023-06-15 19:22:29 +02:00
########################################################################
## Return the name of an alert action given its ID.
########################################################################
sub get_action_name ($$) {
my ( $ dbh , $ action_id ) = @ _ ;
my $ rc = get_db_value ( $ dbh , " SELECT name FROM talert_actions
WHERE id = ? " , safe_input ( $ action_id ) ) ;
return defined ( $ rc ) ? $ rc : - 1 ;
}
2018-12-03 17:38:57 +01:00
########################################################################
## Return command ID given the command name.
########################################################################
sub get_command_id ($$) {
my ( $ dbh , $ command_name ) = @ _ ;
my $ rc = get_db_value ( $ dbh , "SELECT id FROM talert_commands WHERE name = ?" , safe_input ( $ command_name ) ) ;
return defined ( $ rc ) ? $ rc : - 1 ;
}
2012-07-25 17:14:36 +02:00
########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
## Return agent ID given the agent name.
2012-07-25 17:14:36 +02:00
########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
sub get_agent_id ($$) {
my ( $ dbh , $ agent_name ) = @ _ ;
2021-04-27 12:14:32 +02:00
my $ is_meta = get_db_value ( $ dbh , "SELECT value FROM tconfig WHERE token like 'metaconsole'" ) ;
my $ rc ;
if ( $ is_meta == 1 ) {
2021-09-06 13:32:17 +02:00
$ rc = get_db_value ( $ dbh , "SELECT id_agente FROM tmetaconsole_agent WHERE nombre = ?" , safe_input ( $ agent_name ) ) ;
2021-04-27 12:14:32 +02:00
} else {
2021-09-06 13:32:17 +02:00
$ rc = get_db_value ( $ dbh , "SELECT id_agente FROM tagente WHERE nombre = ?" , safe_input ( $ agent_name ) ) ;
2021-04-27 12:14:32 +02:00
}
2008-03-27 18:38:10 +01:00
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
return defined ( $ rc ) ? $ rc : - 1 ;
2008-03-27 18:38:10 +01:00
}
2019-10-17 11:14:42 +02:00
########################################################################
## Return agent IDs given an agent alias.
########################################################################
sub get_agent_ids_from_alias ($$) {
my ( $ dbh , $ agent_alias ) = @ _ ;
my @ rc = get_db_rows ( $ dbh , "SELECT id_agente, nombre FROM tagente WHERE alias = ?" , safe_input ( $ agent_alias ) ) ;
return @ rc ;
}
2023-06-15 19:22:29 +02:00
########################################################################
## Return the ID of an alert template given its name.
########################################################################
sub get_template_id ($$) {
my ( $ dbh , $ template_name ) = @ _ ;
my $ rc = get_db_value ( $ dbh , " SELECT id FROM talert_templates
WHERE name = ? " , safe_input ( $ template_name ) ) ;
return defined ( $ rc ) ? $ rc : - 1 ;
}
########################################################################
## Return the name of an alert template given its ID.
########################################################################
sub get_template_name ($$) {
my ( $ dbh , $ template_id ) = @ _ ;
my $ rc = get_db_value ( $ dbh , " SELECT name FROM talert_templates
WHERE id = ? " , safe_input ( $ template_id ) ) ;
return defined ( $ rc ) ? $ rc : - 1 ;
}
2012-07-25 17:14:36 +02:00
########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
## Return server ID given the name of server.
2012-07-25 17:14:36 +02:00
########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
sub get_server_id ($$$) {
my ( $ dbh , $ server_name , $ server_type ) = @ _ ;
2008-03-27 18:38:10 +01:00
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
my $ rc = get_db_value ( $ dbh , " SELECT id_server FROM tserver
2017-06-13 12:42:21 +02:00
WHERE BINARY name = ? AND server_type = ? " ,
2010-12-27 23:39:02 +01:00
$ server_name , $ server_type ) ;
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
return defined ( $ rc ) ? $ rc : - 1 ;
2008-03-27 18:38:10 +01:00
}
2015-03-26 13:41:07 +01:00
########################################################################
## Return the ID of a tag given the tag name.
########################################################################
sub get_tag_id ($$) {
my ( $ dbh , $ tag_name ) = @ _ ;
my $ rc = get_db_value ( $ dbh , " SELECT id_tag FROM ttag
WHERE name = ? " ,
safe_input ( $ tag_name ) ) ;
return defined ( $ rc ) ? $ rc : - 1 ;
}
2021-04-14 22:36:56 +02:00
########################################################################
## Return the name of a tag given its id.
########################################################################
sub get_tag_name ($$) {
my ( $ dbh , $ id ) = @ _ ;
my $ rc = get_db_value (
$ dbh , " SELECT name FROM ttag
WHERE id_tag = ? " ,
safe_input ( $ id )
) ;
return $ rc ;
}
2012-12-13 18:07:23 +01:00
########################################################################
## Return the first enabled server name found.
########################################################################
sub get_first_server_name ($) {
my ( $ dbh ) = @ _ ;
my $ rc = get_db_value ( $ dbh , "SELECT name FROM tserver" ) ;
return defined ( $ rc ) ? $ rc : "" ;
}
2012-07-25 17:14:36 +02:00
########################################################################
2010-05-25 13:56:37 +02:00
## Return group ID given the group name.
2012-07-25 17:14:36 +02:00
########################################################################
2010-05-25 13:56:37 +02:00
sub get_group_id ($$) {
my ( $ dbh , $ group_name ) = @ _ ;
2011-05-03 16:24:51 +02:00
my $ rc = get_db_value ( $ dbh , 'SELECT id_grupo FROM tgrupo WHERE ' . db_text ( 'nombre' ) . ' = ?' , safe_input ( $ group_name ) ) ;
2010-05-25 13:56:37 +02:00
return defined ( $ rc ) ? $ rc : - 1 ;
}
2020-07-06 12:06:12 +02:00
########################################################################
# Return a array of groups, children of given parent.
########################################################################
sub get_group_children ( $ $ $ ; $ ) ;
sub get_group_children ($$$;$) {
my ( $ dbh , $ parent , $ ignorePropagate , $ href_groups ) = @ _ ;
if ( is_empty ( $ href_groups ) ) {
2020-07-07 13:54:06 +02:00
my @ groups = get_db_rows ( $ dbh , 'SELECT * FROM tgrupo' ) ;
2020-07-06 12:06:12 +02:00
2020-07-07 17:19:02 +02:00
my % groups = map {
2020-07-06 12:06:12 +02:00
$ _ - > { 'id_grupo' } = > $ _
2020-07-07 17:19:02 +02:00
} @ groups ;
2020-07-06 12:06:12 +02:00
2020-07-07 17:19:02 +02:00
$ href_groups = \ % groups ;
2020-07-06 12:06:12 +02:00
}
my $ return = { } ;
foreach my $ id_grupo ( keys % { $ href_groups } ) {
if ( $ id_grupo eq 0 ) {
next ;
}
my $ g = $ href_groups - > { $ id_grupo } ;
if ( $ ignorePropagate || $ parent eq 0 || $ href_groups - > { $ parent } { 'propagate' } ) {
if ( $ g - > { 'parent' } eq $ parent ) {
$ return - > { $ g - > { 'id_grupo' } } = $ g ;
if ( $ g - > { 'propagate' } || $ ignorePropagate ) {
$ return = add_hashes (
$ return ,
get_group_children ( $ dbh , $ g - > { 'id_grupo' } , $ ignorePropagate , $ href_groups )
) ;
}
}
}
}
return $ return ;
}
2012-07-25 17:14:36 +02:00
########################################################################
2010-05-25 13:56:37 +02:00
## Return OS ID given the OS name.
2012-07-25 17:14:36 +02:00
########################################################################
2010-05-25 13:56:37 +02:00
sub get_os_id ($$) {
my ( $ dbh , $ os_name ) = @ _ ;
my $ rc = get_db_value ( $ dbh , "SELECT id_os FROM tconfig_os WHERE name = ?" , $ os_name ) ;
return defined ( $ rc ) ? $ rc : - 1 ;
}
2017-03-17 09:37:10 +01:00
########################################################################
## Return OS name given the OS id.
########################################################################
sub get_os_name ($$) {
my ( $ dbh , $ os_id ) = @ _ ;
my $ rc = get_db_value ( $ dbh , "SELECT name FROM tconfig_os WHERE id_os = ?" , $ os_id ) ;
return defined ( $ rc ) ? $ rc : - 1 ;
}
2011-06-10 14:50:56 +02:00
##########################################################################
## SUB get_agent_name (agent_id)
## Return agent group id, given "agent_id"
##########################################################################
sub get_agent_group ($$) {
my ( $ dbh , $ agent_id ) = @ _ ;
2012-07-24 15:23:27 +02:00
my $ group_id = get_db_value ( $ dbh , " SELECT id_grupo
FROM tagente
WHERE id_agente = ? " , $ agent_id ) ;
2011-06-10 14:50:56 +02:00
return 0 unless defined ( $ group_id ) ;
return $ group_id ;
}
2012-07-24 15:23:27 +02:00
########################################################################
2011-05-12 13:11:37 +02:00
## SUB get_agent_name (agent_id)
## Return agent name, given "agent_id"
2012-07-24 15:23:27 +02:00
########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
sub get_agent_name ($$) {
my ( $ dbh , $ agent_id ) = @ _ ;
2008-10-20 12:43:21 +02:00
2012-07-24 15:23:27 +02:00
return get_db_value ( $ dbh , " SELECT nombre
FROM tagente
WHERE id_agente = ? " , $ agent_id ) ;
2007-08-02 19:53:07 +02:00
}
2017-06-12 14:34:03 +02:00
########################################################################
## SUB get_agent_alias (agent_id)
## Return agent alias, given "agent_id"
########################################################################
sub get_agent_alias ($$) {
my ( $ dbh , $ agent_id ) = @ _ ;
return get_db_value ( $ dbh , " SELECT alias
FROM tagente
WHERE id_agente = ? " , $ agent_id ) ;
}
2012-07-24 15:23:27 +02:00
########################################################################
## SUB agents_get_modules (agent_id, fields, filters)
## Return the list of modules, given "agent_id"
########################################################################
sub get_agent_modules ($$$$$) {
my ( $ pa_config , $ dbh , $ agent_id , $ fields , $ filters ) = @ _ ;
my $ str_filter = '' ;
2012-07-29 02:24:35 +02:00
foreach my $ key ( keys %$ filters ) {
2012-07-24 15:23:27 +02:00
$ str_filter . = ' AND ' . $ key . " = " . $ filters - > { $ key } ;
}
my @ rows = get_db_rows ( $ dbh , " SELECT *
FROM tagente_modulo
WHERE id_agente = ? " . $ str_filter , $ agent_id ) ;
return @ rows ;
}
########################################################################
2012-07-27 11:05:16 +02:00
## SUB get_agentmodule_data (id_agent_module, period, date)
## Return The data for module in a period of time.
########################################################################
sub get_agentmodule_data ($$$$$) {
my ( $ pa_config , $ dbh , $ id_agent_module , $ period , $ date ) = @ _ ;
if ( $ date < 1 ) {
# Get current timestamp
$ date = time ( ) ;
}
my $ datelimit = $ date - $ period ;
my @ rows = get_db_rows ( $ dbh ,
" SELECT datos AS data , utimestamp
FROM tagente_datos
WHERE id_agente_modulo = ?
AND utimestamp > ? AND utimestamp <= ?
ORDER BY utimestamp ASC " ,
$ id_agent_module , $ datelimit , $ date ) ;
#logger($pa_config, "SELECT datos AS data, utimestamp
# FROM tagente_datos
# WHERE id_agente_modulo = " . $id_agent_module . "
# AND utimestamp > " . $datelimit . " AND utimestamp <= " . $date . "
# ORDER BY utimestamp ASC", 1);
return @ rows ;
}
2020-09-17 14:38:01 +02:00
##########################################################################
## Return module custom ID given the module id.
##########################################################################
sub get_agentmodule_custom_id ($$) {
my ( $ dbh , $ id_agent_module ) = @ _ ;
my $ rc = get_db_value (
$ dbh ,
"SELECT custom_id FROM tagente_modulo WHERE id_agente_modulo = ?" ,
safe_input ( $ id_agent_module )
) ;
return defined ( $ rc ) ? $ rc : undef ;
}
##########################################################################
## Updates module custom ID given the module id and custom Id.
##########################################################################
sub set_agentmodule_custom_id ($$$) {
my ( $ dbh , $ id_agent_module , $ custom_id ) = @ _ ;
my $ rc = db_update (
$ dbh ,
"UPDATE tagente_modulo SET custom_id = ? WHERE id_agente_modulo = ?" ,
safe_input ( $ custom_id ) ,
safe_input ( $ id_agent_module )
) ;
return defined ( $ rc ) ? ( $ rc eq '0E0' ? 0 : $ rc ) : - 1 ;
}
2012-07-27 11:05:16 +02:00
########################################################################
2012-07-24 15:23:27 +02:00
## SUB get_agentmodule_status (agent_module_id)
## Return agent module status. given "agent_module_id"
########################################################################
sub get_agentmodule_status ($$$) {
my ( $ pa_config , $ dbh , $ agent_module_id ) = @ _ ;
my $ status = get_db_value ( $ dbh , ' SELECT estado
FROM tagente_estado
WHERE id_agente_modulo = ? ' , $ agent_module_id ) ;
return $ status ;
}
2013-09-12 10:16:35 +02:00
########################################################################
## Return the status of an agent module as a string.
########################################################################
sub get_agentmodule_status_str ($$$) {
my ( $ pa_config , $ dbh , $ agent_module_id ) = @ _ ;
my $ status = get_db_value ( $ dbh , ' SELECT estado
FROM tagente_estado
WHERE id_agente_modulo = ? ' , $ agent_module_id ) ;
2022-03-02 12:20:47 +01:00
return 'N/A' unless defined ( $ status ) ;
2013-09-12 10:16:35 +02:00
return 'Normal' if ( $ status == 0 ) ;
return 'Critical' if ( $ status == 1 ) ;
return 'Warning' if ( $ status == 2 ) ;
return 'Unknown' if ( $ status == 3 ) ;
return 'Not init' if ( $ status == 4 ) ;
return 'N/A' ;
}
2012-07-24 15:23:27 +02:00
########################################################################
## SUB get_get_status (agent_id)
## Return agent status, given "agent_id"
########################################################################
sub get_agent_status ($$$) {
my ( $ pa_config , $ dbh , $ agent_id ) = @ _ ;
my @ modules = get_agent_modules ( $ pa_config , $ dbh ,
$ agent_id , 'id_agente_modulo' , { 'disabled' = > 0 } ) ;
#logger($pa_config, Dumper(@modules), 5);
# The status are:
# 3 -> AGENT_MODULE_STATUS_UNKNOW
# 4 -> AGENT_MODULE_STATUS_CRITICAL_ALERT
# 1 -> AGENT_MODULE_STATUS_CRITICAL_BAD
# 2 -> AGENT_MODULE_STATUS_WARNING
# 0 -> AGENT_MODULE_STATUS_NORMAL
2023-03-06 18:52:35 +01:00
my $ module_status = 4 ;
2012-07-24 15:23:27 +02:00
my $ modules_async = 0 ;
foreach my $ module ( @ modules ) {
my $ m_status = get_agentmodule_status ( $ pa_config , $ dbh ,
$ module - > { 'id_agente_modulo' } ) ;
#This is the order to check
# AGENT_MODULE_STATUS_CRITICAL_BAD
# AGENT_MODULE_STATUS_WARNING
2013-11-25 23:03:07 +01:00
# AGENT_MODULE_STATUS_UNKNOWN
2012-07-24 15:23:27 +02:00
# AGENT_MODULE_STATUS_NORMAL
2023-03-06 18:52:35 +01:00
if ( $ m_status == MODULE_CRITICAL ) {
$ module_status = MODULE_CRITICAL ;
2012-07-24 15:23:27 +02:00
}
2023-03-06 18:52:35 +01:00
elsif ( $ module_status != MODULE_CRITICAL ) {
if ( $ m_status == MODULE_WARNING ) {
$ module_status = MODULE_WARNING ;
2012-07-24 15:23:27 +02:00
}
2023-03-06 18:52:35 +01:00
elsif ( $ module_status != MODULE_WARNING ) {
if ( $ m_status == MODULE_UNKNOWN ) {
$ module_status = MODULE_UNKNOWN ;
2012-07-24 15:23:27 +02:00
}
2023-03-06 18:52:35 +01:00
elsif ( $ module_status != MODULE_UNKNOWN ) {
if ( $ m_status == MODULE_NORMAL ) {
$ module_status = MODULE_NORMAL ;
2023-01-31 09:57:55 +01:00
}
2023-03-06 18:52:35 +01:00
elsif ( $ module_status != MODULE_NORMAL ) {
if ( $ m_status == MODULE_NOTINIT ) {
$ module_status = MODULE_NOTINIT ;
2023-01-31 09:57:55 +01:00
}
2012-07-24 15:23:27 +02:00
}
}
}
}
2023-03-06 18:52:35 +01:00
2012-07-24 15:23:27 +02:00
my $ module_type = get_db_value ( $ dbh , ' SELECT id_tipo_modulo
FROM tagente_modulo
WHERE id_agente_modulo = ? ', $module->{' id_agente_modulo ' } ) ;
if ( ( $ module_type >= 21 && $ module_type <= 23 ) ||
$ module_type == 100 ) {
$ modules_async + + ;
}
}
my $ count_modules = scalar ( @ modules ) ;
# If all the modules are asynchronous or keep alive, the group cannot be unknown
if ( $ modules_async < $ count_modules ) {
my $ last_contact = get_db_value ( $ dbh ,
' SELECT ( UNIX_TIMESTAMP ( ultimo_contacto ) + ( intervalo * 2 ) ) AS last_contact
2023-08-29 15:42:15 +02:00
FROM tagente WHERE id_agente = ? AND UNIX_TIMESTAMP ( ultimo_contacto ) > 0 ' , $ agent_id ) ;
2012-07-24 15:23:27 +02:00
2023-08-29 15:42:15 +02:00
if ( defined ( $ last_contact ) && $ last_contact < time ( ) ) {
2012-07-24 15:23:27 +02:00
return 3 ;
}
}
2023-01-30 17:16:20 +01:00
2012-07-24 15:23:27 +02:00
return $ module_status ;
}
########################################################################
2011-05-23 13:55:08 +02:00
## SUB get_module_agent_id (agent_module_id)
## Return agent id, given "agent_module_id"
2012-07-24 15:23:27 +02:00
########################################################################
2011-05-23 13:55:08 +02:00
sub get_module_agent_id ($$) {
my ( $ dbh , $ agent_module_id ) = @ _ ;
return get_db_value ( $ dbh , "SELECT id_agente FROM tagente_modulo WHERE id_agente_modulo = ?" , $ agent_module_id ) ;
}
2012-07-24 15:23:27 +02:00
########################################################################
2011-05-12 13:11:37 +02:00
## SUB get_agent_address (id_agente)
## Return agent address, given "agent_id"
2012-07-24 15:23:27 +02:00
########################################################################
2011-05-12 13:11:37 +02:00
sub get_agent_address ($$) {
my ( $ dbh , $ agent_id ) = @ _ ;
return get_db_value ( $ dbh , "SELECT direccion FROM tagente WHERE id_agente = ?" , $ agent_id ) ;
}
2012-07-24 15:23:27 +02:00
########################################################################
2010-02-15 14:07:52 +01:00
## SUB get_module_name(module_id)
## Return the module name, given "module_id"
2012-07-24 15:23:27 +02:00
########################################################################
2010-02-15 14:07:52 +01:00
sub get_module_name ($$) {
my ( $ dbh , $ module_id ) = @ _ ;
return get_db_value ( $ dbh , "SELECT nombre FROM tagente_modulo WHERE id_agente_modulo = ?" , $ module_id ) ;
}
2012-07-24 15:23:27 +02:00
########################################################################
2010-05-25 13:56:37 +02:00
## Return module id given the module name and agent id.
2012-07-24 15:23:27 +02:00
########################################################################
2010-05-25 13:56:37 +02:00
sub get_agent_module_id ($$$) {
my ( $ dbh , $ module_name , $ agent_id ) = @ _ ;
2012-01-16 15:55:55 +01:00
my $ rc = get_db_value ( $ dbh , "SELECT id_agente_modulo FROM tagente_modulo WHERE delete_pending = 0 AND nombre = ? AND id_agente = ?" , safe_input ( $ module_name ) , $ agent_id ) ;
2010-05-25 13:56:37 +02:00
return defined ( $ rc ) ? $ rc : - 1 ;
}
2023-06-29 17:06:59 +02:00
########################################################################
## Return module id given the module name and agent name.
########################################################################
sub get_agent_module_id_by_name ($$$) {
my ( $ dbh , $ module_name , $ agent_name ) = @ _ ;
my $ rc = get_db_value (
$ dbh ,
' SELECT id_agente_modulo
FROM tagente_modulo tam LEFT JOIN tagente ta ON tam . id_agente = ta . id_agente
WHERE tam . nombre = ? AND ta . nombre = ? ' , safe_input ( $ module_name ) , $ agent_name ) ;
return defined ( $ rc ) ? $ rc : - 1 ;
}
2010-05-25 15:16:34 +02:00
##########################################################################
## Return the module template id given the module id and the template id.
##########################################################################
sub get_template_module_id ($$$) {
my ( $ dbh , $ module_id , $ template_id ) = @ _ ;
my $ rc = get_db_value ( $ dbh , "SELECT id FROM talert_template_modules WHERE id_agent_module = ? AND id_alert_template = ?" , $ module_id , $ template_id ) ;
return defined ( $ rc ) ? $ rc : - 1 ;
}
2007-08-02 19:53:07 +02:00
##########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
## Returns true if the given group is disabled, false otherwise.
2007-08-02 19:53:07 +02:00
##########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
sub is_group_disabled ($$) {
my ( $ dbh , $ group_id ) = @ _ ;
2012-07-24 15:23:27 +02:00
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
return get_db_value ( $ dbh , "SELECT disabled FROM tgrupo WHERE id_grupo = ?" , $ group_id ) ;
2007-08-02 19:53:07 +02:00
}
##########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
## Return module ID given the module name.
2007-08-02 19:53:07 +02:00
##########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
sub get_module_id ($$) {
my ( $ dbh , $ module_name ) = @ _ ;
2012-07-24 15:23:27 +02:00
2010-11-02 18:26:34 +01:00
my $ rc = get_db_value ( $ dbh , "SELECT id_tipo FROM ttipo_modulo WHERE nombre = ?" , safe_input ( $ module_name ) ) ;
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
return defined ( $ rc ) ? $ rc : - 1 ;
}
2007-08-02 19:53:07 +02:00
2012-01-04 16:09:02 +01:00
##########################################################################
## Return disabled bit frin a user.
##########################################################################
sub get_user_disabled ($$) {
my ( $ dbh , $ user_id ) = @ _ ;
2012-07-24 15:23:27 +02:00
2012-01-04 16:09:02 +01:00
my $ rc = get_db_value ( $ dbh , "SELECT disabled FROM tusuario WHERE id_user = ?" , safe_input ( $ user_id ) ) ;
return defined ( $ rc ) ? $ rc : - 1 ;
}
2012-01-05 13:11:03 +01:00
##########################################################################
## Return 1 if user exists or -1 if not
##########################################################################
sub get_user_exists ($$) {
my ( $ dbh , $ user_id ) = @ _ ;
2012-07-24 15:23:27 +02:00
2012-01-05 13:11:03 +01:00
my $ rc = get_db_value ( $ dbh , "SELECT id_user FROM tusuario WHERE id_user = ?" , safe_input ( $ user_id ) ) ;
return defined ( $ rc ) ? 1 : - 1 ;
}
2010-10-18 18:21:13 +02:00
##########################################################################
## Return plugin ID given the plugin name.
##########################################################################
sub get_plugin_id ($$) {
my ( $ dbh , $ plugin_name ) = @ _ ;
2012-07-24 15:23:27 +02:00
2010-11-02 18:26:34 +01:00
my $ rc = get_db_value ( $ dbh , "SELECT id FROM tplugin WHERE name = ?" , safe_input ( $ plugin_name ) ) ;
2010-10-18 18:21:13 +02:00
return defined ( $ rc ) ? $ rc : - 1 ;
}
##########################################################################
## Return module group ID given the module group name.
##########################################################################
sub get_module_group_id ($$) {
my ( $ dbh , $ module_group_name ) = @ _ ;
2012-07-24 15:23:27 +02:00
if ( ! defined ( $ module_group_name ) || $ module_group_name eq '' ) {
2010-10-18 18:21:13 +02:00
return 0 ;
}
2010-11-02 18:26:34 +01:00
my $ rc = get_db_value ( $ dbh , "SELECT id_mg FROM tmodule_group WHERE name = ?" , safe_input ( $ module_group_name ) ) ;
2010-10-18 18:21:13 +02:00
return defined ( $ rc ) ? $ rc : - 1 ;
}
2011-10-06 04:46:55 +02:00
##########################################################################
## Return module group name given the module group id.
##########################################################################
sub get_module_group_name ($$) {
my ( $ dbh , $ module_group_id ) = @ _ ;
2012-07-24 15:23:27 +02:00
2011-10-06 04:46:55 +02:00
return get_db_value ( $ dbh , "SELECT name FROM tmodule_group WHERE id_mg = ?" , $ module_group_id ) ;
}
2007-08-02 19:53:07 +02:00
##########################################################################
2009-11-04 18:49:42 +01:00
## Return a network component's profile name given its ID.
2007-08-02 19:53:07 +02:00
##########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
sub get_nc_profile_name ($$) {
my ( $ dbh , $ nc_id ) = @ _ ;
2009-03-04 18:15:39 +01:00
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
return get_db_value ( $ dbh , "SELECT * FROM tnetwork_profile WHERE id_np = ?" , $ nc_id ) ;
2007-08-02 19:53:07 +02:00
}
2020-03-25 18:02:58 +01:00
##########################################################################
## Return all network component's profile ids matching given PEN.
##########################################################################
sub get_pen_templates ($$) {
my ( $ dbh , $ pen ) = @ _ ;
my @ results = get_db_rows (
$ dbh ,
' SELECT t . `id_np`
FROM `tnetwork_profile` t
2020-04-02 17:56:17 +02:00
INNER JOIN `tnetwork_profile_pen` pp ON pp . `id_np` = t . `id_np`
INNER JOIN `tpen` p ON pp . pen = p . pen
2020-03-25 18:02:58 +01:00
WHERE p . `pen` = ? ' ,
$ pen
) ;
2020-04-06 18:04:53 +02:00
@ results = map {
if ( ref ( $ _ ) eq 'HASH' ) { $ _ - > { 'id_np' } }
else { }
} @ results ;
2020-03-25 18:02:58 +01:00
return @ results ;
}
##########################################################################
## Return a network component's profile data and pen list, given its ID.
##########################################################################
sub get_nc_profile_advanced ($$) {
my ( $ dbh , $ id_nc ) = @ _ ;
return get_db_single_row (
$ dbh ,
' SELECT t . * , GROUP_CONCAT ( p . pen ) AS "pen"
2020-04-02 17:56:17 +02:00
FROM `tnetwork_profile` t
LEFT JOIN `tnetwork_profile_pen` pp ON t . id_np = pp . id_np
LEFT JOIN `tpen` p ON pp . pen = p . pen
2020-03-25 18:02:58 +01:00
WHERE t . `id_np` = ?
GROUP BY t . `id_np` ' ,
$ id_nc
) ;
}
2010-05-26 11:54:21 +02:00
##########################################################################
2015-03-26 13:41:07 +01:00
## Return user profile ID given the user id, group id and profile id.
##########################################################################
sub get_user_profile_id ($$$$) {
my ( $ dbh , $ user_id , $ profile_id , $ group_id ) = @ _ ;
my $ rc = get_db_value ( $ dbh , " SELECT id_up FROM tusuario_perfil
WHERE id_usuario = ?
AND id_perfil = ?
AND id_grupo = ? " ,
safe_input ( $ user_id ) ,
$ profile_id ,
$ group_id ) ;
return defined ( $ rc ) ? $ rc : - 1 ;
}
2010-05-26 11:54:21 +02:00
##########################################################################
## Return profile ID given the profile name.
##########################################################################
sub get_profile_id ($$) {
my ( $ dbh , $ profile_name ) = @ _ ;
2012-07-24 15:23:27 +02:00
2010-11-02 18:26:34 +01:00
my $ rc = get_db_value ( $ dbh , "SELECT id_perfil FROM tperfil WHERE name = ?" , safe_input ( $ profile_name ) ) ;
2010-05-26 11:54:21 +02:00
return defined ( $ rc ) ? $ rc : - 1 ;
}
2009-11-04 18:49:42 +01:00
##########################################################################
## Return a group's name given its ID.
##########################################################################
sub get_group_name ($$) {
my ( $ dbh , $ group_id ) = @ _ ;
return get_db_value ( $ dbh , "SELECT nombre FROM tgrupo WHERE id_grupo = ?" , $ group_id ) ;
}
2012-07-24 15:23:27 +02:00
########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
## Get a single column returned by an SQL query as a hash reference.
2012-07-24 15:23:27 +02:00
########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
sub get_db_value ($$;@) {
2012-07-24 15:23:27 +02:00
my ( $ dbh , $ query , @ values ) = @ _ ;
# Cache statements
my $ sth = $ dbh - > prepare_cached ( $ query ) ;
$ sth - > execute ( @ values ) ;
# Save returned rows
while ( my $ row = $ sth - > fetchrow_arrayref ( ) ) {
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
$ sth - > finish ( ) ;
2012-07-24 15:23:27 +02:00
return defined ( $ row - > [ 0 ] ) ? $ row - > [ 0 ] : undef ;
}
$ sth - > finish ( ) ;
return undef ;
2007-08-02 19:53:07 +02:00
}
2015-05-05 11:20:41 +02:00
########################################################################
## Get a single column returned by an SQL query with a LIMIT statement
## as a hash reference.
########################################################################
sub get_db_value_limit ($$$;@) {
my ( $ dbh , $ query , $ limit , @ values ) = @ _ ;
# Cache statements
my $ sth ;
if ( $ RDBMS ne 'oracle' ) {
2015-07-22 15:36:46 +02:00
$ sth = $ dbh - > prepare_cached ( $ query . ' LIMIT ' . int ( $ limit ) ) ;
2015-05-05 11:20:41 +02:00
} else {
2015-07-22 15:36:46 +02:00
$ sth = $ dbh - > prepare_cached ( 'SELECT * FROM (' . $ query . ') WHERE ROWNUM <= ' . int ( $ limit ) ) ;
2015-05-05 11:20:41 +02:00
}
$ sth - > execute ( @ values ) ;
# Save returned rows
while ( my $ row = $ sth - > fetchrow_arrayref ( ) ) {
$ sth - > finish ( ) ;
return defined ( $ row - > [ 0 ] ) ? $ row - > [ 0 ] : undef ;
}
$ sth - > finish ( ) ;
return undef ;
}
2007-08-02 19:53:07 +02:00
##########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
## Get a single row returned by an SQL query as a hash reference. Returns
2021-09-01 17:56:14 +02:00
## hash or undef on error.
2007-08-02 19:53:07 +02:00
##########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
sub get_db_single_row ($$;@) {
2012-07-24 15:23:27 +02:00
my ( $ dbh , $ query , @ values ) = @ _ ;
#my @rows;
# Cache statements
my $ sth = $ dbh - > prepare_cached ( $ query ) ;
$ sth - > execute ( @ values ) ;
# Save returned rows
while ( my $ row = $ sth - > fetchrow_hashref ( ) ) {
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
$ sth - > finish ( ) ;
2012-07-24 15:23:27 +02:00
return { map { lc ( $ _ ) = > $ row - > { $ _ } } keys ( % { $ row } ) } if ( $ RDBMS eq 'oracle' ) ;
return $ row ;
}
$ sth - > finish ( ) ;
return undef ;
2007-08-02 19:53:07 +02:00
}
2022-11-07 19:56:24 +01:00
##########################################################################
## Get DB information for all known Pandora FMS nodes.
##########################################################################
sub get_db_nodes ($$) {
my ( $ dbh , $ pa_config ) = @ _ ;
my $ dbh_nodes = [] ;
# Insert the current node first.
push ( @ { $ dbh_nodes } ,
{ 'dbengine' = > $ pa_config - > { 'dbengine' } ,
'dbname' = > $ pa_config - > { 'dbname' } ,
'dbhost' = > $ pa_config - > { 'dbhost' } ,
'dbport' = > $ pa_config - > { 'dbport' } ,
'dbuser' = > $ pa_config - > { 'dbuser' } ,
'dbpass' = > $ pa_config - > { 'dbpass' } } ) ;
# Look for additional nodes.
2022-11-14 09:16:54 +01:00
my @ nodes = get_db_rows ( $ dbh , 'SELECT * FROM tmetaconsole_setup WHERE disabled = 0' ) ;
2022-11-07 19:56:24 +01:00
foreach my $ node ( @ nodes ) {
2023-04-25 19:16:30 +02:00
# Check and decrypy passwords if necessary.
if ( defined ( $ pa_config - > { 'encryption_passphrase' } ) ) {
$ pa_config - > { 'encryption_key' } = enterprise_hook ( 'pandora_get_encryption_key' , [ $ pa_config , $ pa_config - > { 'encryption_passphrase' } ] ) ;
$ node - > { 'dbpass' } = PandoraFMS::Core:: pandora_output_password ( $ pa_config , $ node - > { 'dbpass' } ) ;
}
2022-11-07 19:56:24 +01:00
push ( @ { $ dbh_nodes } ,
{ 'dbengine' = > $ pa_config - > { 'dbengine' } ,
'dbname' = > $ node - > { 'dbname' } ,
'dbhost' = > $ node - > { 'dbhost' } ,
'dbport' = > $ node - > { 'dbport' } ,
'dbuser' = > $ node - > { 'dbuser' } ,
'dbpass' = > $ node - > { 'dbpass' } } ) ;
}
return $ dbh_nodes ;
}
2007-08-02 19:53:07 +02:00
##########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
## Get all rows returned by an SQL query as a hash reference array.
2007-08-02 19:53:07 +02:00
##########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
sub get_db_rows ($$;@) {
2012-07-24 15:23:27 +02:00
my ( $ dbh , $ query , @ values ) = @ _ ;
my @ rows ;
# Cache statements
my $ sth = $ dbh - > prepare_cached ( $ query ) ;
$ sth - > execute ( @ values ) ;
# Save returned rows
while ( my $ row = $ sth - > fetchrow_hashref ( ) ) {
2022-11-07 19:56:24 +01:00
push ( @ rows , $ row ) ;
2012-07-24 15:23:27 +02:00
}
$ sth - > finish ( ) ;
return @ rows ;
2007-08-02 19:53:07 +02:00
}
2022-11-07 19:56:24 +01:00
##########################################################################
## Connect to the given node and run get_db_rows.
##########################################################################
2023-04-25 19:16:30 +02:00
sub get_db_rows_node ($$$;@) {
my ( $ pa_config , $ node , $ query , @ values ) = @ _ ;
2022-11-07 19:56:24 +01:00
my $ dbh ;
my @ rows ;
eval {
$ dbh = db_connect ( $ node - > { 'dbengine' } ,
$ node - > { 'dbname' } ,
$ node - > { 'dbhost' } ,
$ node - > { 'dbport' } ,
$ node - > { 'dbuser' } ,
$ node - > { 'dbpass' } ) ;
@ rows = get_db_rows ( $ dbh , $ query , @ values ) ;
} ;
2023-04-25 19:16:30 +02:00
if ( $@ ) {
# Reconnect to meta db.
my $ dbh = db_connect ( $ pa_config - > { 'dbengine' } ,
$ pa_config - > { 'dbname' } ,
$ pa_config - > { 'dbhost' } ,
$ pa_config - > { 'dbport' } ,
$ pa_config - > { 'dbuser' } ,
$ pa_config - > { 'dbpass' } ) ;
2023-05-05 14:32:49 +02:00
my $ msg = "Cannot connect to node database: " . $ node - > { 'dbhost' } . ". Please check node credentials." ;
2023-04-25 19:16:30 +02:00
logger ( $ pa_config , "[ERROR] " . $ msg , 3 ) ;
PandoraFMS::Core:: pandora_event ( $ pa_config , $ msg , 0 , 0 , 4 , 0 , 0 , 'error' , 0 , $ dbh ) ;
db_disconnect ( $ dbh ) if defined ( $ dbh ) ;
exit 0 ;
}
2022-11-07 19:56:24 +01:00
db_disconnect ( $ dbh ) if defined ( $ dbh ) ;
return \ @ rows ;
}
##########################################################################
## Run get_db_rows on all known Pandora FMS nodes in parallel.
##########################################################################
2023-04-25 19:16:30 +02:00
sub get_db_rows_parallel ($$$;@) {
my ( $ pa_config , $ nodes , $ query , @ values ) = @ _ ;
2022-11-07 19:56:24 +01:00
# Launch the queries.
my @ threads ;
{
# Calling DESTROY would make the server restart.
no warnings 'redefine' ;
local * PandoraFMS::ProducerConsumerServer:: DESTROY = sub { } ;
local * PandoraFMS::BlockProducerConsumerServer:: DESTROY = sub { } ;
2022-12-02 11:46:06 +01:00
local * PandoraFMS::SNMPServer:: DESTROY = sub { } ;
2022-11-07 19:56:24 +01:00
# Query the nodes.
foreach my $ node ( @ { $ nodes } ) {
2023-04-25 19:16:30 +02:00
my $ thr = threads - > create ( \ & get_db_rows_node , $ pa_config , $ node , $ query , @ values ) ;
2022-11-07 19:56:24 +01:00
push ( @ threads , $ thr ) if defined ( $ thr ) ;
}
}
# Retrieve the results.
my @ combined_res ;
foreach my $ thr ( @ threads ) {
my $ res = $ thr - > join ( ) ;
push ( @ combined_res , @ { $ res } ) if defined ( $ res ) ;
}
return @ combined_res ;
}
2015-06-08 18:32:49 +02:00
########################################################################
## Get all rows (with a limit clause) returned by an SQL query
## as a hash reference array.
########################################################################
sub get_db_rows_limit ($$$;@) {
my ( $ dbh , $ query , $ limit , @ values ) = @ _ ;
my @ rows ;
# Cache statements
my $ sth ;
if ( $ RDBMS ne 'oracle' ) {
$ sth = $ dbh - > prepare_cached ( $ query . ' LIMIT ' . $ limit ) ;
} else {
$ sth = $ dbh - > prepare_cached ( 'SELECT * FROM (' . $ query . ') WHERE ROWNUM <= ' . $ limit ) ;
}
$ sth - > execute ( @ values ) ;
# Save returned rows
while ( my $ row = $ sth - > fetchrow_hashref ( ) ) {
if ( $ RDBMS eq 'oracle' ) {
push ( @ rows , { map { lc ( $ _ ) = > $ row - > { $ _ } } keys ( % { $ row } ) } ) ;
}
else {
push ( @ rows , $ row ) ;
}
}
$ sth - > finish ( ) ;
return @ rows ;
}
2018-07-04 18:39:06 +02:00
##########################################################################
2020-06-17 13:14:22 +02:00
## Updates using hashed data.
## $dbh database connector (active)
## $tablename table name
## $id hashref as { 'primary_key_id' => "value" }
## $data hashref as { 'field1' => "value", 'field2' => "value"}
2018-07-04 18:39:06 +02:00
##########################################################################
2020-06-17 13:14:22 +02:00
sub db_update_hash {
my ( $ dbh , $ tablename , $ id , $ data ) = @ _ ;
2018-07-04 18:39:06 +02:00
2020-06-17 13:14:22 +02:00
return undef unless ( defined ( $ tablename ) && $ tablename ne "" ) ;
2018-07-04 18:39:06 +02:00
return undef unless ( ref ( $ data ) eq "HASH" ) ;
# Build update query
2020-06-17 13:14:22 +02:00
my $ query = 'UPDATE `' . $ tablename . '` SET ' ;
2018-07-04 18:39:06 +02:00
my @ values ;
foreach my $ field ( keys % { $ data } ) {
push @ values , $ data - > { $ field } ;
$ query . = ' ' . $ field . ' = ?,' ;
}
chop ( $ query ) ;
2020-06-17 13:14:22 +02:00
my @ keys = keys % { $ id } ;
my $ k = shift @ keys ;
$ query . = ' WHERE ' . $ k . ' = ? ' ;
push @ values , $ id - > { $ k } ;
2018-07-04 18:39:06 +02:00
return db_update ( $ dbh , $ query , @ values ) ;
}
2020-06-17 13:14:22 +02:00
##########################################################################
## Updates agent fields using field => value
## Be careful, no filter is done.
##########################################################################
sub set_update_agent {
my ( $ dbh , $ agent_id , $ data ) = @ _ ;
return undef unless ( defined ( $ agent_id ) && $ agent_id > 0 ) ;
return undef unless ( ref ( $ data ) eq "HASH" ) ;
return db_update_hash (
$ dbh ,
'tagente' ,
{ 'id_agente' = > $ agent_id } ,
$ data
) ;
}
##########################################################################
## Updates agent fields using field => value
## Be careful, no filter is done.
##########################################################################
sub set_update_agentmodule {
my ( $ dbh , $ agentmodule_id , $ data ) = @ _ ;
return undef unless ( defined ( $ agentmodule_id ) && $ agentmodule_id > 0 ) ;
return undef unless ( ref ( $ data ) eq "HASH" ) ;
return db_update_hash (
$ dbh ,
'tagente_modulo' ,
{ 'id_agente_modulo' = > $ agentmodule_id } ,
$ data
) ;
}
2018-07-04 18:39:06 +02:00
2015-07-22 15:36:46 +02:00
##########################################################################
## SQL delete with a LIMIT clause.
##########################################################################
sub db_delete_limit ($$$$;@) {
my ( $ dbh , $ from , $ where , $ limit , @ values ) = @ _ ;
my $ sth ;
# MySQL
if ( $ RDBMS eq 'mysql' ) {
$ sth = $ dbh - > prepare_cached ( "DELETE FROM $from WHERE $where LIMIT " . int ( $ limit ) ) ;
}
# PostgreSQL
elsif ( $ RDBMS eq 'postgresql' ) {
$ sth = $ dbh - > prepare_cached ( "DELETE FROM $from WHERE $where LIMIT " . int ( $ limit ) ) ;
}
# Oracle
elsif ( $ RDBMS eq 'oracle' ) {
$ sth = $ dbh - > prepare_cached ( "DELETE FROM (SELECT * FROM $from WHERE $where) WHERE ROWNUM <= " . int ( $ limit ) ) ;
}
$ sth - > execute ( @ values ) ;
}
2007-08-02 19:53:07 +02:00
##########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
## SQL insert. Returns the ID of the inserted row.
2007-08-02 19:53:07 +02:00
##########################################################################
2011-04-13 Ramon Novoa <rnovoa@artica.es>
* lib/PandoraFMS/SNMPServer.pm,
lib/PandoraFMS/Config.pm,
lib/PandoraFMS/NetworkServer.pm,
lib/PandoraFMS/WMIServer.pm,
lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/DB.pm,
lib/PandoraFMS/ProducerConsumerServer.pm,
lib/PandoraFMS/PredictionServer.pm,
lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm,
bin/pandora_server,
util/pandora_db.pl,
util/pandora_manage.pl,
util/recon_scripts/snmpdevices.pl: Adding support for PostgreSQL and
Oracle (not complete).
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4213 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 18:28:59 +02:00
sub db_insert ($$$;@) {
my ( $ dbh , $ index , $ query , @ values ) = @ _ ;
my $ insert_id = undef ;
2017-10-18 10:45:55 +02:00
eval {
2011-04-13 Ramon Novoa <rnovoa@artica.es>
* lib/PandoraFMS/SNMPServer.pm,
lib/PandoraFMS/Config.pm,
lib/PandoraFMS/NetworkServer.pm,
lib/PandoraFMS/WMIServer.pm,
lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/DB.pm,
lib/PandoraFMS/ProducerConsumerServer.pm,
lib/PandoraFMS/PredictionServer.pm,
lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm,
bin/pandora_server,
util/pandora_db.pl,
util/pandora_manage.pl,
util/recon_scripts/snmpdevices.pl: Adding support for PostgreSQL and
Oracle (not complete).
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4213 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 18:28:59 +02:00
$ dbh - > do ( $ query , undef , @ values ) ;
$ insert_id = $ dbh - > { 'mysql_insertid' } ;
2017-10-18 10:45:55 +02:00
} ;
if ( $@ ) {
my $ exception = @ _ ;
2018-11-16 10:28:49 +01:00
if ( $ DBI:: err == 1213 || $ DBI:: err == 1205 ) {
2017-10-18 10:45:55 +02:00
$ dbh - > do ( $ query , undef , @ values ) ;
$ insert_id = $ dbh - > { 'mysql_insertid' } ;
}
else {
2020-03-16 23:52:20 +01:00
croak ( join ( ', ' , @ _ ) ) ;
2011-04-18 18:42:18 +02:00
}
2011-04-13 Ramon Novoa <rnovoa@artica.es>
* lib/PandoraFMS/SNMPServer.pm,
lib/PandoraFMS/Config.pm,
lib/PandoraFMS/NetworkServer.pm,
lib/PandoraFMS/WMIServer.pm,
lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/DB.pm,
lib/PandoraFMS/ProducerConsumerServer.pm,
lib/PandoraFMS/PredictionServer.pm,
lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm,
bin/pandora_server,
util/pandora_db.pl,
util/pandora_manage.pl,
util/recon_scripts/snmpdevices.pl: Adding support for PostgreSQL and
Oracle (not complete).
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4213 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 18:28:59 +02:00
}
2012-07-24 15:23:27 +02:00
2011-04-13 Ramon Novoa <rnovoa@artica.es>
* lib/PandoraFMS/SNMPServer.pm,
lib/PandoraFMS/Config.pm,
lib/PandoraFMS/NetworkServer.pm,
lib/PandoraFMS/WMIServer.pm,
lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/DB.pm,
lib/PandoraFMS/ProducerConsumerServer.pm,
lib/PandoraFMS/PredictionServer.pm,
lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm,
bin/pandora_server,
util/pandora_db.pl,
util/pandora_manage.pl,
util/recon_scripts/snmpdevices.pl: Adding support for PostgreSQL and
Oracle (not complete).
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4213 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 18:28:59 +02:00
return $ insert_id ;
2007-08-02 19:53:07 +02:00
}
2010-10-21 16:26:46 +02:00
##########################################################################
## SQL update. Returns the number of updated rows.
##########################################################################
sub db_update ($$;@) {
my ( $ dbh , $ query , @ values ) = @ _ ;
2017-10-18 10:45:55 +02:00
my $ rows ;
eval {
$ rows = $ dbh - > do ( $ query , undef , @ values ) ;
} ;
if ( $@ ) {
my $ exception = @ _ ;
2018-11-16 10:28:49 +01:00
if ( $ DBI:: err == 1213 || $ DBI:: err == 1205 ) {
2017-10-18 10:45:55 +02:00
$ rows = $ dbh - > do ( $ query , undef , @ values ) ;
}
else {
2020-03-16 23:52:20 +01:00
croak ( join ( ', ' , @ _ ) ) ;
2017-10-18 10:45:55 +02:00
}
}
2010-10-21 16:26:46 +02:00
return $ rows ;
}
2011-05-09 11:42:01 +02:00
##########################################################################
## Return alert template-module ID given the module and template ids.
##########################################################################
2022-10-20 16:42:26 +02:00
sub get_alert_template_module_id ($$$$) {
my ( $ dbh , $ id_module , $ id_template , $ id_policy_alerts ) = @ _ ;
2012-07-24 15:23:27 +02:00
2022-10-20 16:42:26 +02:00
my $ rc = get_db_value ( $ dbh , "SELECT id FROM talert_template_modules WHERE id_agent_module = ? AND id_alert_template = ? AND id_policy_alerts = ?" , $ id_module , $ id_template , $ id_policy_alerts ) ;
2011-05-09 11:42:01 +02:00
return defined ( $ rc ) ? $ rc : - 1 ;
}
2014-07-25 15:15:24 +02:00
########################################################################
2010-09-23 10:16:44 +02:00
## SQL insert. Returns the ID of the inserted row.
2014-07-25 15:15:24 +02:00
########################################################################
2011-04-13 Ramon Novoa <rnovoa@artica.es>
* lib/PandoraFMS/SNMPServer.pm,
lib/PandoraFMS/Config.pm,
lib/PandoraFMS/NetworkServer.pm,
lib/PandoraFMS/WMIServer.pm,
lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/DB.pm,
lib/PandoraFMS/ProducerConsumerServer.pm,
lib/PandoraFMS/PredictionServer.pm,
lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm,
bin/pandora_server,
util/pandora_db.pl,
util/pandora_manage.pl,
util/recon_scripts/snmpdevices.pl: Adding support for PostgreSQL and
Oracle (not complete).
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4213 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 18:28:59 +02:00
sub db_process_insert ($$$$;@) {
my ( $ dbh , $ index , $ table , $ parameters , @ values ) = @ _ ;
2012-07-24 15:23:27 +02:00
2010-09-23 10:16:44 +02:00
my @ columns_array = keys %$ parameters ;
my @ values_array = values %$ parameters ;
2012-07-24 15:23:27 +02:00
if ( ! defined ( $ table ) || $# columns_array == - 1 ) {
2010-09-23 10:16:44 +02:00
return - 1 ;
exit ;
}
2010-11-04 18:35:37 +01:00
# Generate the '?' simbols to the Query like '(?,?,?,?,?)'
my $ wildcards = '' ;
2010-09-23 13:29:08 +02:00
for ( my $ i = 0 ; $ i <= $# values_array ; $ i + + ) {
2012-07-24 15:23:27 +02:00
if ( ! defined ( $ values_array [ $ i ] ) ) {
2010-09-23 13:29:08 +02:00
$ values_array [ $ i ] = '' ;
}
2012-07-24 15:23:27 +02:00
if ( $ i > 0 && $ i <= $# values_array ) {
2010-11-04 18:35:37 +01:00
$ wildcards = $ wildcards . ',' ;
}
$ wildcards = $ wildcards . '?' ;
2012-07-24 15:23:27 +02:00
}
2010-11-04 18:35:37 +01:00
$ wildcards = '(' . $ wildcards . ')' ;
2012-07-24 15:23:27 +02:00
2015-10-09 12:38:15 +02:00
# Escape column names that are reserved words
for ( my $ i = 0 ; $ i < scalar ( @ columns_array ) ; $ i + + ) {
if ( $ columns_array [ $ i ] eq 'interval' ) {
$ columns_array [ $ i ] = "${RDBMS_QUOTE}interval${RDBMS_QUOTE}" ;
}
}
2015-05-05 15:34:03 +02:00
my $ columns_string = join ( ',' , @ columns_array ) ;
2019-10-17 11:14:42 +02:00
2014-07-25 15:15:24 +02:00
my $ res = db_insert ( $ dbh ,
$ index ,
2015-05-05 15:34:03 +02:00
"INSERT INTO $table ($columns_string) VALUES " . $ wildcards , @ values_array ) ;
2010-11-04 18:35:37 +01:00
2012-07-24 15:23:27 +02:00
2010-11-04 18:35:37 +01:00
return $ res ;
}
2018-03-12 19:39:28 +01:00
########################################################################
## SQL insert from hash
## 1st: dbh
2018-03-13 16:35:13 +01:00
## 2nd: index
## 3rd: table name,
## 4th: {field => value} ref
2018-03-12 19:39:28 +01:00
########################################################################
sub db_insert_from_hash {
my ( $ dbh , $ index , $ table , $ data ) = @ _ ;
my $ values_prep = "" ;
2018-03-13 16:35:13 +01:00
my @ fields = keys % { $ data } ;
2018-03-12 19:39:28 +01:00
my @ values = values % { $ data } ;
my $ nfields = scalar @ fields ;
for ( my $ i = 0 ; $ i < $ nfields ; $ i + + ) {
$ values_prep . = "?," ;
}
$ values_prep =~ s/,$// ;
return db_insert ( $ dbh , $ index , "INSERT INTO " . $ table . " (" . join ( "," , @ fields ) . ") VALUES ($values_prep)" , @ values ) ;
2018-03-13 16:35:13 +01:00
}
########################################################################
## SQL insert from hash
## 1st: dbh
## 2nd: index
## 3rd: table name,
## 4th: array({field => value},{field => value}) array ref
##
## Returns: An array with the inserted indexes
########################################################################
sub db_insert_from_array_hash {
my ( $ dbh , $ index , $ table , $ data ) = @ _ ;
if ( ( ! defined ( $ data ) || ref ( $ data ) ne "ARRAY" ) ) {
return ( ) ;
}
my @ inserted_keys ;
eval {
foreach my $ row ( @ { $ data } ) {
push @ inserted_keys , db_insert_from_hash ( $ dbh , $ index , $ table , $ row ) ;
}
} ;
if ( $@ ) {
return undef ;
}
2018-03-12 19:39:28 +01:00
2018-03-13 16:35:13 +01:00
return @ inserted_keys ;
2018-03-12 19:39:28 +01:00
}
2012-07-25 17:14:36 +02:00
########################################################################
2010-11-04 18:35:37 +01:00
## SQL update.
2012-07-25 17:14:36 +02:00
########################################################################
2015-04-06 15:26:26 +02:00
sub db_process_update ($$$$) {
my ( $ dbh , $ table , $ parameters , $ conditions ) = @ _ ;
2012-07-24 15:23:27 +02:00
2010-11-04 18:35:37 +01:00
my @ columns_array = keys %$ parameters ;
my @ values_array = values %$ parameters ;
2015-04-06 15:26:26 +02:00
my @ where_columns = keys %$ conditions ;
my @ where_values = values %$ conditions ;
2012-07-24 15:23:27 +02:00
2015-04-06 15:26:26 +02:00
if ( ! defined ( $ table ) || $# columns_array == - 1 || $# where_columns == - 1 ) {
2010-11-04 18:35:37 +01:00
return - 1 ;
exit ;
}
2010-09-23 10:16:44 +02:00
2015-04-06 15:26:26 +02:00
# VALUES...
2010-11-04 18:35:37 +01:00
my $ fields = '' ;
2012-07-25 17:14:36 +02:00
for ( my $ i = 0 ; $ i <= $# values_array ; $ i + + ) {
2012-07-24 15:23:27 +02:00
if ( ! defined ( $ values_array [ $ i ] ) ) {
2010-11-04 18:35:37 +01:00
$ values_array [ $ i ] = '' ;
}
2012-07-24 15:23:27 +02:00
if ( $ i > 0 && $ i <= $# values_array ) {
2010-11-04 18:35:37 +01:00
$ fields = $ fields . ',' ;
}
2015-06-08 18:32:49 +02:00
# Avoid the use of quotes on the column names in oracle, cause the quotes
# force the engine to be case sensitive and the column names created without
# quotes are stores in uppercase.
# The quotes should be introduced manually for every item created with it.
if ( $ RDBMS eq 'oracle' ) {
$ fields = $ fields . " " . $ columns_array [ $ i ] . " = ?" ;
}
else {
$ fields = $ fields . " " . $ RDBMS_QUOTE . "$columns_array[$i]" . $ RDBMS_QUOTE . " = ?" ;
}
2012-07-24 15:23:27 +02:00
}
2015-04-06 15:26:26 +02:00
# WHERE...
my $ where = '' ;
for ( my $ i = 0 ; $ i <= $# where_columns ; $ i + + ) {
if ( ! defined ( $ where_values [ $ i ] ) ) {
$ where_values [ $ i ] = '' ;
}
if ( $ i > 0 && $ i <= $# where_values ) {
$ where = $ where . ' AND ' ;
}
2015-06-08 18:32:49 +02:00
# Avoid the use of quotes on the column names in oracle, cause the quotes
# force the engine to be case sensitive and the column names created without
# quotes are stores in uppercase.
# The quotes should be introduced manually for every item created with it.
if ( $ RDBMS eq 'oracle' ) {
$ where = $ where . " " . $ where_columns [ $ i ] . " = ?" ;
}
else {
$ where = $ where . " " . $ RDBMS_QUOTE . "$where_columns[$i]" . $ RDBMS_QUOTE . " = ?" ;
}
2015-04-06 15:26:26 +02:00
}
2012-07-25 17:14:36 +02:00
my $ res = db_update ( $ dbh , " UPDATE $ table
SET $ fields
2015-04-06 15:26:26 +02:00
WHERE $ where " , @ values_array , @ where_values ) ;
2012-07-24 15:23:27 +02:00
2010-11-04 18:35:37 +01:00
return $ res ;
2010-09-23 10:16:44 +02:00
}
2014-07-25 15:15:24 +02:00
########################################################################
2011-06-28 12:04:45 +02:00
# Add the given address to taddress.
2014-07-25 15:15:24 +02:00
########################################################################
2011-06-28 12:04:45 +02:00
sub add_address ($$) {
my ( $ dbh , $ ip_address ) = @ _ ;
2014-07-25 15:15:24 +02:00
2011-06-28 12:04:45 +02:00
return db_insert ( $ dbh , 'id_a' , 'INSERT INTO taddress (ip) VALUES (?)' , $ ip_address ) ;
}
2014-07-25 15:15:24 +02:00
########################################################################
2011-06-28 12:04:45 +02:00
# Assign the new address to the agent
2014-07-25 15:15:24 +02:00
########################################################################
2011-06-28 12:04:45 +02:00
sub add_new_address_agent ($$$) {
my ( $ dbh , $ addr_id , $ agent_id ) = @ _ ;
2015-05-05 15:34:03 +02:00
db_do ( $ dbh , ' INSERT INTO taddress_agent ( id_a , id_agent )
VALUES ( ? , ? ) ' , $ addr_id , $ agent_id ) ;
2011-06-28 12:04:45 +02:00
}
2014-07-25 15:15:24 +02:00
########################################################################
2011-06-28 12:04:45 +02:00
# Return the ID of the given address, -1 if it does not exist.
2014-07-25 15:15:24 +02:00
########################################################################
2011-06-28 12:04:45 +02:00
sub get_addr_id ($$) {
my ( $ dbh , $ addr ) = @ _ ;
2012-07-24 15:23:27 +02:00
my $ addr_id = get_db_value ( $ dbh ,
' SELECT id_a
FROM taddress
WHERE ip = ? ' , $ addr ) ;
2011-06-28 12:04:45 +02:00
return ( defined ( $ addr_id ) ? $ addr_id : - 1 ) ;
}
2012-04-12 12:04:35 +02:00
##########################################################################
# Return the agent address ID for the given agent ID and address ID, -1 if
# it does not exist.
##########################################################################
sub get_agent_addr_id ($$$) {
my ( $ dbh , $ addr_id , $ agent_id ) = @ _ ;
2012-07-24 15:23:27 +02:00
my $ agent_addr_id = get_db_value ( $ dbh ,
' SELECT id_ag
FROM taddress_agent
WHERE id_a = ?
AND id_agent = ? ' , $ addr_id , $ agent_id ) ;
2012-07-25 17:14:36 +02:00
2012-04-12 12:04:35 +02:00
return ( defined ( $ agent_addr_id ) ? $ agent_addr_id : - 1 ) ;
}
2012-07-25 17:14:36 +02:00
########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
## Generic SQL sentence.
2012-07-25 17:14:36 +02:00
########################################################################
2009-04-14 Ramon Novoa <rnovoa@artica.es>
* pandora_ctl, pandora_network, pandora_wmi, pandora_plugin,
pandora_prediction, bin/pandora_wmi, bin/pandora_plugin,
bin/pandora_prediction, bin/pandora_snmpconsole, bin/pandora_recon,
bin/pandora_network, pandora_recon, pandora_snmpconsole: Deleted
from repository. Old server code and startup scripts.
* Makefile.PL, pandora_server_installer, lib/PandoraFMS/Config.pm
lib/PandoraFMS/DB.pm, lib/PandoraFMS/Tools.pm, bin/pandora_server,
pandora_package_installer, pandora_server: Updated to work with the
new code, removed unneeded dependencies, fixed some bugs etc.
* lib/PandoraFMS/SNMPServer.pm, lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/ProducerConsumerServer.pm, lib/PandoraFMS/Server.pm,
lib/PandoraFMS/PredictionServer.pm, lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm, lib/PandoraFMS/DataServer.pm,
lib/PandoraFMS/NetworkServer.pm, lib/PandoraFMS/WMIServer.pm: Added
to repository. New server code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1620 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-04-14 21:13:16 +02:00
sub db_do ($$;@) {
my ( $ dbh , $ query , @ values ) = @ _ ;
2012-07-24 15:23:27 +02:00
2010-02-15 14:07:52 +01:00
#DBI->trace( 3, '/tmp/dbitrace.log' );
2017-10-18 10:45:55 +02:00
eval {
$ dbh - > do ( $ query , undef , @ values ) ;
} ;
if ( $@ ) {
my $ exception = @ _ ;
2018-11-16 10:28:49 +01:00
if ( $ DBI:: err == 1213 || $ DBI:: err == 1205 ) {
2017-10-18 10:45:55 +02:00
$ dbh - > do ( $ query , undef , @ values ) ;
}
else {
2020-03-16 23:52:20 +01:00
croak ( join ( ', ' , @ _ ) ) ;
2017-10-18 10:45:55 +02:00
}
}
2009-02-11 19:21:24 +01:00
}
2012-07-25 17:14:36 +02:00
########################################################################
2011-06-28 17:41:13 +02:00
# Return the ID of the taddress agent with the given IP.
2012-07-25 17:14:36 +02:00
########################################################################
2011-06-28 17:41:13 +02:00
sub is_agent_address ($$$) {
my ( $ dbh , $ id_agent , $ id_addr ) = @ _ ;
2012-07-24 15:23:27 +02:00
my $ id_ag = get_db_value ( $ dbh , ' SELECT id_ag
FROM taddress_agent
WHERE id_a = ?
AND id_agent = ? ' , $ id_addr , $ id_agent ) ;
2011-06-28 17:41:13 +02:00
return ( defined ( $ id_ag ) ) ? $ id_ag : 0 ;
}
2014-07-25 15:15:24 +02:00
########################################################################
2011-04-13 Ramon Novoa <rnovoa@artica.es>
* lib/PandoraFMS/SNMPServer.pm,
lib/PandoraFMS/Config.pm,
lib/PandoraFMS/NetworkServer.pm,
lib/PandoraFMS/WMIServer.pm,
lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/DB.pm,
lib/PandoraFMS/ProducerConsumerServer.pm,
lib/PandoraFMS/PredictionServer.pm,
lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm,
bin/pandora_server,
util/pandora_db.pl,
util/pandora_manage.pl,
util/recon_scripts/snmpdevices.pl: Adding support for PostgreSQL and
Oracle (not complete).
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4213 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 18:28:59 +02:00
## Quote the given string.
2014-07-25 15:15:24 +02:00
########################################################################
2011-04-13 Ramon Novoa <rnovoa@artica.es>
* lib/PandoraFMS/SNMPServer.pm,
lib/PandoraFMS/Config.pm,
lib/PandoraFMS/NetworkServer.pm,
lib/PandoraFMS/WMIServer.pm,
lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/DB.pm,
lib/PandoraFMS/ProducerConsumerServer.pm,
lib/PandoraFMS/PredictionServer.pm,
lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm,
bin/pandora_server,
util/pandora_db.pl,
util/pandora_manage.pl,
util/recon_scripts/snmpdevices.pl: Adding support for PostgreSQL and
Oracle (not complete).
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4213 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 18:28:59 +02:00
sub db_string ($) {
my $ string = shift ;
# MySQL and PostgreSQL
2011-04-18 18:42:18 +02:00
#return "'" . $string . "'" if ($RDBMS eq 'mysql' || $RDBMS eq 'postgresql' || $RDBMS eq 'oracle');
return "'" . $ string . "'" ;
}
2012-07-25 17:14:36 +02:00
########################################################################
2011-04-18 18:42:18 +02:00
## Convert TEXT to string when necessary
2012-07-25 17:14:36 +02:00
########################################################################
2011-04-18 18:42:18 +02:00
sub db_text ($) {
my $ string = shift ;
#return $string;
return " dbms_lob.substr(" . $ string . ", 4000, 1)" if ( $ RDBMS eq 'oracle' ) ;
2011-04-13 Ramon Novoa <rnovoa@artica.es>
* lib/PandoraFMS/SNMPServer.pm,
lib/PandoraFMS/Config.pm,
lib/PandoraFMS/NetworkServer.pm,
lib/PandoraFMS/WMIServer.pm,
lib/PandoraFMS/PluginServer.pm,
lib/PandoraFMS/DB.pm,
lib/PandoraFMS/ProducerConsumerServer.pm,
lib/PandoraFMS/PredictionServer.pm,
lib/PandoraFMS/Core.pm,
lib/PandoraFMS/ReconServer.pm,
bin/pandora_server,
util/pandora_db.pl,
util/pandora_manage.pl,
util/recon_scripts/snmpdevices.pl: Adding support for PostgreSQL and
Oracle (not complete).
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4213 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 18:28:59 +02:00
return $ string ;
}
2012-07-25 17:14:36 +02:00
########################################################################
2011-06-08 13:07:39 +02:00
## SUB get_alert_template_name(alert_id)
## Return the alert template name, given "alert_id"
2012-07-25 17:14:36 +02:00
########################################################################
2011-06-08 13:07:39 +02:00
sub get_alert_template_name ($$) {
my ( $ dbh , $ alert_id ) = @ _ ;
2014-07-25 15:15:24 +02:00
return get_db_value ( $ dbh , " SELECT name
FROM talert_templates , talert_template_modules
WHERE talert_templates . id = talert_template_modules . id_alert_template
AND talert_template_modules . id = ? " , $ alert_id ) ;
2011-06-08 13:07:39 +02:00
}
2012-07-25 17:14:36 +02:00
########################################################################
2011-12-01 17:11:42 +01:00
## Concat two strings
2012-07-25 17:14:36 +02:00
########################################################################
2011-12-01 17:11:42 +01:00
sub db_concat ($$) {
my ( $ element1 , $ element2 ) = @ _ ;
2012-07-24 15:23:27 +02:00
return " " . $ element1 . " || ' ' || " . $ element2 . " " if ( $ RDBMS eq 'oracle' or $ RDBMS eq 'postgresql' ) ;
2014-07-28 18:24:40 +02:00
return " concat(" . $ element1 . ", ' '," . $ element2 . ") " ;
2011-12-01 17:11:42 +01:00
}
2012-07-25 17:14:36 +02:00
########################################################################
2012-05-10 14:18:43 +02:00
## Get priority/severity name from the associated ID
2012-07-25 17:14:36 +02:00
########################################################################
2012-05-10 14:18:43 +02:00
sub get_priority_name ($) {
my ( $ priority_id ) = @ _ ;
2020-09-08 11:51:17 +02:00
return '' unless defined ( $ priority_id ) ;
2012-05-10 14:18:43 +02:00
2012-07-24 15:23:27 +02:00
if ( $ priority_id == 0 ) {
2012-05-10 14:18:43 +02:00
return 'Maintenance' ;
}
2012-07-24 15:23:27 +02:00
elsif ( $ priority_id == 1 ) {
2012-05-10 14:18:43 +02:00
return 'Informational' ;
}
2012-07-24 15:23:27 +02:00
elsif ( $ priority_id == 2 ) {
2012-05-10 14:18:43 +02:00
return 'Normal' ;
}
2012-07-24 15:23:27 +02:00
elsif ( $ priority_id == 3 ) {
2012-05-10 14:18:43 +02:00
return 'Warning' ;
}
2012-07-24 15:23:27 +02:00
elsif ( $ priority_id == 4 ) {
2012-05-10 14:18:43 +02:00
return 'Critical' ;
}
2012-07-24 15:23:27 +02:00
elsif ( $ priority_id == 5 ) {
2012-05-10 14:18:43 +02:00
return 'Minor' ;
}
2012-07-24 15:23:27 +02:00
elsif ( $ priority_id == 6 ) {
2012-05-10 14:18:43 +02:00
return 'Major' ;
}
return '' ;
}
2013-03-01 15:27:52 +01:00
########################################################################
## Get the set string and array of values to perform un update from a hash.
########################################################################
sub db_update_get_values ($) {
my ( $ set_ref ) = @ _ ;
2014-07-25 15:15:24 +02:00
2013-03-01 15:27:52 +01:00
my $ set = '' ;
my @ values ;
while ( my ( $ key , $ value ) = each ( % { $ set_ref } ) ) {
2014-07-25 15:15:24 +02:00
# Not value for the given column
next if ( ! defined ( $ value ) ) ;
$ set . = "$key = ?," ;
push ( @ values , $ value ) ;
2013-03-01 15:27:52 +01:00
}
2014-07-25 15:15:24 +02:00
2013-03-01 15:27:52 +01:00
# Remove the last ,
chop ( $ set ) ;
return ( $ set , \ @ values ) ;
}
########################################################################
## Get the string and array of values to perform an insert from a hash.
########################################################################
sub db_insert_get_values ($) {
my ( $ insert_ref ) = @ _ ;
2014-07-25 15:15:24 +02:00
2013-03-01 15:27:52 +01:00
my $ columns = '(' ;
my @ values ;
while ( my ( $ key , $ value ) = each ( % { $ insert_ref } ) ) {
2014-07-25 15:15:24 +02:00
# Not value for the given column
next if ( ! defined ( $ value ) ) ;
2015-05-05 15:34:03 +02:00
$ columns . = $ key . "," ;
2014-07-25 15:15:24 +02:00
push ( @ values , $ value ) ;
2013-03-01 15:27:52 +01:00
}
2014-07-25 15:15:24 +02:00
2013-03-01 15:27:52 +01:00
# Remove the last , and close the parentheses
chop ( $ columns ) ;
$ columns . = ')' ;
2014-07-25 15:15:24 +02:00
# No columns
2013-03-01 15:27:52 +01:00
if ( $ columns eq '()' ) {
return ;
}
2014-07-25 15:15:24 +02:00
2013-03-01 15:27:52 +01:00
# Add placeholders for the values
$ columns . = ' VALUES (' . ( "?," x ( $# values + 1 ) ) ;
2014-07-25 15:15:24 +02:00
2013-03-01 15:27:52 +01:00
# Remove the last , and close the parentheses
chop ( $ columns ) ;
$ columns . = ')' ;
2014-07-25 15:15:24 +02:00
2013-03-01 15:27:52 +01:00
return ( $ columns , \ @ values ) ;
}
2013-05-07 17:38:11 +02:00
########################################################################
## Try to obtain the given lock.
########################################################################
2022-08-04 15:11:51 +02:00
sub db_get_lock ($$;$$) {
my ( $ dbh , $ lock_name , $ lock_timeout , $ do_not_wait_lock ) = @ _ ;
2015-07-22 15:36:46 +02:00
# Only supported in MySQL.
return 1 unless ( $ RDBMS eq 'mysql' ) ;
2013-05-07 17:38:11 +02:00
# Set a default lock timeout of 1 second
$ lock_timeout = 1 if ( ! defined ( $ lock_timeout ) ) ;
2022-08-04 15:11:51 +02:00
if ( $ do_not_wait_lock ) {
if ( ! db_is_free_lock ( $ dbh , $ lock_name ) ) {
return 0 ;
}
}
2013-05-07 17:38:11 +02:00
# Attempt to get the lock!
my $ sth = $ dbh - > prepare ( 'SELECT GET_LOCK(?, ?)' ) ;
$ sth - > execute ( $ lock_name , $ lock_timeout ) ;
my ( $ lock ) = $ sth - > fetchrow ;
2014-07-25 15:15:24 +02:00
2013-05-07 17:38:11 +02:00
# Something went wrong
return 0 if ( ! defined ( $ lock ) ) ;
return $ lock ;
}
2022-08-04 15:11:51 +02:00
########################################################################
## Check is lock is free.
########################################################################
sub db_is_free_lock ($$) {
my ( $ dbh , $ lock_name ) = @ _ ;
# Only supported in MySQL.
return 1 unless ( $ RDBMS eq 'mysql' ) ;
# Attempt to get the lock!
my $ sth = $ dbh - > prepare ( 'SELECT IS_FREE_LOCK(?)' ) ;
$ sth - > execute ( $ lock_name ) ;
my ( $ lock ) = $ sth - > fetchrow ;
# Something went wrong
return 0 if ( ! defined ( $ lock ) ) ;
return $ lock ;
}
2013-05-07 17:38:11 +02:00
########################################################################
## Release the given lock.
########################################################################
sub db_release_lock ($$) {
my ( $ dbh , $ lock_name ) = @ _ ;
2015-07-22 15:36:46 +02:00
# Only supported in MySQL.
return unless ( $ RDBMS eq 'mysql' ) ;
2013-05-07 17:38:11 +02:00
my $ sth = $ dbh - > prepare ( 'SELECT RELEASE_LOCK(?)' ) ;
$ sth - > execute ( $ lock_name ) ;
my ( $ lock ) = $ sth - > fetchrow ;
}
2022-03-28 20:56:05 +02:00
########################################################################
## Try to obtain a persistent lock using Pandora FMS's database.
########################################################################
sub db_get_pandora_lock ($$;$) {
my ( $ dbh , $ lock_name , $ lock_timeout ) = @ _ ;
my $ rv ;
# Lock.
my $ lock = db_get_lock ( $ dbh , $ lock_name , $ lock_timeout ) ;
if ( $ lock != 0 ) {
my $ lock_value = get_db_value ( $ dbh , "SELECT `value` FROM tconfig WHERE token = 'pandora_lock_$lock_name'" ) ;
if ( ! defined ( $ lock_value ) ) {
my $ sth = $ dbh - > prepare ( 'INSERT INTO tconfig (`token`, `value`) VALUES (?, ?)' ) ;
$ rv = $ sth - > execute ( 'pandora_lock_' . $ lock_name , '1' ) ;
} elsif ( $ lock_value == 0 ) {
my $ sth = $ dbh - > prepare ( 'UPDATE tconfig SET `value`=? WHERE `token`=?' ) ;
$ rv = $ sth - > execute ( '1' , 'pandora_lock_' . $ lock_name ) ;
}
db_release_lock ( $ dbh , $ lock_name ) ;
}
# Lock acquired.
if ( $ rv ) {
return 1 ;
}
# Something went wrong.
return 0 ;
}
########################################################################
## Release a persistent lock.
########################################################################
sub db_release_pandora_lock ($$;$) {
my ( $ dbh , $ lock_name , $ lock_timeout ) = @ _ ;
my $ rv ;
# Lock.
my $ lock = db_get_lock ( $ dbh , $ lock_name , $ lock_timeout ) ;
if ( $ lock != 0 ) {
my $ sth = $ dbh - > prepare ( 'UPDATE tconfig SET `value`=? WHERE `token`=?' ) ;
$ rv = $ sth - > execute ( '0' , 'pandora_lock_' . $ lock_name ) ;
db_release_lock ( $ dbh , $ lock_name ) ;
}
}
2021-05-17 13:12:42 +02:00
########################################################################
## Set SSL options globally for the module.
########################################################################
sub set_ssl_opts ($) {
my ( $ pa_config ) = @ _ ;
# SSL is disabled for the DB.
if ( ! defined ( $ pa_config - > { 'dbssl' } ) || $ pa_config - > { 'dbssl' } == 0 ) {
return ;
}
# Enable SSL.
2022-09-30 11:03:33 +02:00
$ SSL_OPTS = "mysql_ssl=1;mysql_ssl_optional=1" ;
2021-05-17 13:12:42 +02:00
# Set additional SSL options.
2022-09-30 10:35:47 +02:00
if ( defined ( $ pa_config - > { 'verify_mysql_ssl_cert' } ) && $ pa_config - > { 'verify_mysql_ssl_cert' } ne "" ) {
2022-09-30 11:04:36 +02:00
$ SSL_OPTS . = ";mysql_ssl_verify_server_cert=" . $ pa_config - > { 'verify_mysql_ssl_cert' } ;
2022-09-30 10:35:47 +02:00
}
2021-05-17 13:12:42 +02:00
if ( defined ( $ pa_config - > { 'dbsslcapath' } ) && $ pa_config - > { 'dbsslcapath' } ne "" ) {
$ SSL_OPTS . = ";mysql_ssl_ca_path=" . $ pa_config - > { 'dbsslcapath' } ;
}
if ( defined ( $ pa_config - > { 'dbsslcafile' } ) && $ pa_config - > { 'dbsslcafile' } ne "" ) {
$ SSL_OPTS . = ";mysql_ssl_ca_file=" . $ pa_config - > { 'dbsslcafile' } ;
}
}
2022-10-17 16:04:45 +02:00
########################################################################
## Synch insert query with nodes.
########################################################################
sub db_synch_insert ($$$$$@) {
my ( $ dbh , $ pa_config , $ table , $ query , $ result , @ values ) = @ _ ;
my $ substr = "\"\%s\"" ;
$ query =~ s/\?/$substr/g ;
my $ query_string = sprintf ( $ query , @ values ) ;
2022-10-18 12:49:51 +02:00
db_synch ( $ dbh , $ pa_config , 'INSERT INTO' , $ table , $ query_string , $ result ) ;
}
########################################################################
## Synch update query with nodes.
########################################################################
sub db_synch_update ($$$$$@) {
my ( $ dbh , $ pa_config , $ table , $ query , $ result , @ values ) = @ _ ;
my $ substr = "\"\%s\"" ;
$ query =~ s/\?/$substr/g ;
my $ query_string = sprintf ( $ query , @ values ) ;
db_synch ( $ dbh , $ pa_config , 'UPDATE' , $ table , $ query_string , $ result ) ;
}
########################################################################
## Synch delete query with nodes.
########################################################################
sub db_synch_delete ($$$$@) {
my ( $ dbh , $ pa_config , $ table , $ result , @ parameters ) = @ _ ;
#Build query string.
my $ query = $ dbh - > { Statement } ;
my $ substr = "\"\%s\"" ;
$ query =~ s/\?/$substr/g ;
my $ query_string = sprintf ( $ query , @ parameters ) ;
db_synch ( $ dbh , $ pa_config , 'DELETE FROM' , $ table , $ query_string , $ result ) ;
}
########################################################################
## Synch queries with nodes.
########################################################################
sub db_synch ($$$$$$) {
my ( $ dbh , $ pa_config , $ type , $ table , $ query , $ result ) = @ _ ;
2022-10-17 16:04:45 +02:00
my @ nodes = get_db_rows ( $ dbh , 'SELECT * FROM tmetaconsole_setup' ) ;
foreach my $ node ( @ nodes ) {
eval {
local $ SIG { __DIE__ } ;
my @ values_queue = (
2022-10-18 12:49:51 +02:00
safe_input ( $ query ) ,
2022-10-17 16:04:45 +02:00
$ node - > { 'id' } ,
time ( ) ,
2022-10-18 12:49:51 +02:00
$ type ,
2022-10-17 16:04:45 +02:00
$ table ,
'' ,
$ result
) ;
my $ query_queue = 'INSERT INTO tsync_queue (`sql`, `target`, `utimestamp`, `operation`, `table`, `error`, `result`) VALUES (?, ?, ?, ?, ?, ?, ?)' ;
db_insert ( $ dbh , 'id' , $ query_queue , @ values_queue ) ;
} ;
if ( $@ ) {
logger ( $ pa_config , "Error add sync_queue: $@" , 10 ) ;
return ;
}
}
}
2007-08-02 19:53:07 +02:00
# End of function declaration
# End of defined Code
1 ;
__END__