From 110b15e528bb870d32e5efa161bc054c152f655e Mon Sep 17 00:00:00 2001 From: fermin831 Date: Thu, 3 Sep 2015 12:31:53 +0200 Subject: [PATCH] Solved timeout problem in plugin modules --- .../win32/modules/pandora_module_factory.cc | 41 ++++++++++--------- 1 file changed, 22 insertions(+), 19 deletions(-) diff --git a/pandora_agents/win32/modules/pandora_module_factory.cc b/pandora_agents/win32/modules/pandora_module_factory.cc index 338b7505d5..049bf6f152 100644 --- a/pandora_agents/win32/modules/pandora_module_factory.cc +++ b/pandora_agents/win32/modules/pandora_module_factory.cc @@ -36,7 +36,7 @@ #include "pandora_module_tcpcheck.h" #include "pandora_module_regexp.h" #include "pandora_module_plugin.h" -#include "pandora_module_ping.h" +#include "pandora_module_ping.h" #include "pandora_module_snmpget.h" #include "../pandora_strutils.h" #include @@ -97,14 +97,14 @@ using namespace Pandora_Strutils; #define TOKEN_PING ("module_ping ") #define TOKEN_PING_COUNT ("module_ping_count ") #define TOKEN_PING_TIMEOUT ("module_ping_timeout ") -#define TOKEN_SNMPGET ("module_snmpget") -#define TOKEN_SNMPVERSION ("module_snmp_version ") -#define TOKEN_SNMPCOMMUNITY ("module_snmp_community ") -#define TOKEN_SNMPAGENT ("module_snmp_agent ") +#define TOKEN_SNMPGET ("module_snmpget") +#define TOKEN_SNMPVERSION ("module_snmp_version ") +#define TOKEN_SNMPCOMMUNITY ("module_snmp_community ") +#define TOKEN_SNMPAGENT ("module_snmp_agent ") #define TOKEN_SNMPOID ("module_snmp_oid ") #define TOKEN_ADVANCEDOPTIONS ("module_advanced_options ") #define TOKEN_INTENSIVECONDITION ("module_intensive_condition ") -#define TOKEN_UNIT ("module_unit ") +#define TOKEN_UNIT ("module_unit ") #define TOKEN_MODULE_GROUP ("module_group ") #define TOKEN_CUSTOM_ID ("module_custom_id ") #define TOKEN_STR_WARNING ("module_str_warning ") @@ -164,13 +164,13 @@ Pandora_Module_Factory::getModuleFromDefinition (string definition) { string module_crontab, module_cron_interval, module_post_process; string module_min_critical, module_max_critical, module_min_warning, module_max_warning; string module_disabled, module_min_ff_event, module_noseekeof; - string module_ping, module_ping_count, module_ping_timeout; + string module_ping, module_ping_count, module_ping_timeout; string module_snmpget, module_snmp_version, module_snmp_community, module_snmp_agent, module_snmp_oid; string module_advanced_options, module_cooked, module_intensive_condition; string module_unit, module_group, module_custom_id, module_str_warning, module_str_critical; string module_critical_instructions, module_warning_instructions, module_unknown_instructions, module_tags; string module_critical_inverse, module_warning_inverse, module_quiet, module_ff_interval; - string macro; + string macro; Pandora_Module *module; bool numeric; Module_Type type; @@ -226,11 +226,11 @@ Pandora_Module_Factory::getModuleFromDefinition (string definition) { module_ping = ""; module_ping_count = ""; module_ping_timeout = ""; - module_snmpget = ""; - module_snmp_version = ""; - module_snmp_community = ""; - module_snmp_agent = ""; - module_snmp_oid = ""; + module_snmpget = ""; + module_snmp_version = ""; + module_snmp_community = ""; + module_snmp_agent = ""; + module_snmp_oid = ""; module_advanced_options = ""; module_cooked = ""; module_intensive_condition = ""; @@ -428,7 +428,7 @@ Pandora_Module_Factory::getModuleFromDefinition (string definition) { } if (module_snmp_version == "") { module_snmp_version = parseLine (line, TOKEN_SNMPVERSION); - } + } if (module_snmp_community == "") { module_snmp_community = parseLine (line, TOKEN_SNMPCOMMUNITY); } @@ -1143,6 +1143,9 @@ Pandora_Module_Factory::getModuleFromDefinition (string definition) { module = new Pandora_Module_Regexp (module_name, module_regexp, module_pattern, (unsigned char) atoi (module_noseekeof.c_str ())); } else if (module_plugin != "") { module = new Pandora_Module_Plugin (module_name, module_plugin); + if (module_timeout != ""){ + module->setTimeout(atoi(module_timeout.c_str())); + } } else if (module_ping != "") { if (module_ping_count == "") { module_ping_count = "1"; @@ -1154,17 +1157,17 @@ Pandora_Module_Factory::getModuleFromDefinition (string definition) { module = new Pandora_Module_Ping (module_name, module_ping, module_ping_count, module_ping_timeout, module_advanced_options); if (module_timeout != "") { module->setTimeout (atoi (module_timeout.c_str ())); - } - } else if (module_snmpget != "") { + } + } else if (module_snmpget != "") { if (module_snmp_version == "") { module_snmp_version = "1"; - } + } if (module_snmp_community == "") { module_snmp_community = "public"; - } + } if (module_snmp_agent == "") { module_snmp_agent = "localhost"; - } + } module = new Pandora_Module_SNMPGet (module_name, module_snmp_version, module_snmp_community, module_snmp_agent, module_snmp_oid, module_advanced_options); if (module_timeout != "") {