diff --git a/pandora_server/ChangeLog b/pandora_server/ChangeLog index 6fe7ccb7ba..bfb52a0652 100644 --- a/pandora_server/ChangeLog +++ b/pandora_server/ChangeLog @@ -1,3 +1,13 @@ +2012-02-20 Koichiro Kikuchi + + * lib/PandoraFMS/SNMPServer.pm: Parse source field to obtain source + IP address not only when trap version is SNMPv2, but also + snmp_pdu_address set to 1. + + * conf/pandora_server.conf: Fixed comment. + + * FreeBSD/pandora_server.conf: Added missing configuration tokens. + 2012-02-20 Ramon Novoa * conf/pandora_server.conf, diff --git a/pandora_server/FreeBSD/pandora_server.conf b/pandora_server/FreeBSD/pandora_server.conf index 7480b5f930..d086b929cf 100644 --- a/pandora_server/FreeBSD/pandora_server.conf +++ b/pandora_server/FreeBSD/pandora_server.conf @@ -38,6 +38,9 @@ errorlog_file /var/log/pandora/pandora_server.error # daemon 1 +# dbengine: mysql, postgresql or oracle (mysql by default) +#dbengine mysql + # Database credentials. A VERY important configuration. # This must be the same credentials used by your Pandora FMS Console # but could be different if your console is not running in the same @@ -59,6 +62,9 @@ dbpass pandora dbhost localhost +# By default, parent agent will not update +#update_parent 0 + # verbosity: level of detail on errors/messages (0 default, 1 verbose, 2 debug.... 10 noisy) # -v in command line (verbose) or -d (debug). Set this to 10 when try to locate problems and # set to 0 or 1 on production enviroments. @@ -74,6 +80,12 @@ master 1 snmpconsole 1 +# snmptrapd will ignore authenticationFailure traps if set to 1. +snmp_ignore_authfailure 1 + +# snmptrapd will read the PDU source address instead of the agent-addr field is set to 1. +snmp_pdu_address 0 + # Activate (1) Pandora Network Server networkserver 1 @@ -334,3 +346,15 @@ snmp_threads 2 # Block size for block producer/consumer servers, that is, the number of modules # per block (15 by default) (PANDORA FMS ENTERPRISE ONLY). block_size 15 + +# Enable (1) or disable (0) Pandora FMS Netflow Server (PANDORA FMS ENTERPRISE ONLY). +netflowserver 1 + +# Path to the netflow daemon nfcapd. +netflow_daemon /usr/local/bin/nfcapd + +# Netflow file rotation interval in seconds. +netflow_interval 300 + +# Base directory where netflow files will be stored. +netflow_basedir /tmp diff --git a/pandora_server/conf/pandora_server.conf b/pandora_server/conf/pandora_server.conf index e5aced5a8d..539ba4fcf8 100755 --- a/pandora_server/conf/pandora_server.conf +++ b/pandora_server/conf/pandora_server.conf @@ -232,7 +232,7 @@ autocreate 1 max_log_size 65536 -# max_queue_files (250 by default) +# max_queue_files (500 by default) # When server have more than max_queue_files in incoming directory, skips the read # the directory to avoid filesystem overhead. diff --git a/pandora_server/lib/PandoraFMS/SNMPServer.pm b/pandora_server/lib/PandoraFMS/SNMPServer.pm index ccb0e3f4e7..1d8d24a270 100644 --- a/pandora_server/lib/PandoraFMS/SNMPServer.pm +++ b/pandora_server/lib/PandoraFMS/SNMPServer.pm @@ -171,13 +171,6 @@ sub pandora_snmptrapd { ($date, $time, $source, $data) = split(/\[\*\*\]/, $line, 4); my @data = split(/\t/, $data); - # extract IP address from %b part: - # * destination part appears in Net-SNMP > 5.3 - # * protocol name part and bracketted IP addr w/ port number appear in - # Net-SNMP > 5.1 (Net-SNMP 5.1 has IP addr only). - # * port number is signed in Net-SNMP 5.2 - $source =~ s/(?:(?:TCP|UDP):\s*)?\[?([^] ]+)\]?(?::-?\d+)?(?:\s*->.*)?$/$1/; - shift @data; # Drop unused 1st data. $oid = shift @data; @@ -189,6 +182,15 @@ sub pandora_snmptrapd { $data = join("\t", @data); } + if ($trap_ver eq "SNMPv2" || $pa_config->{'snmp_pdu_address'} eq '1' ) { + # extract IP address from %b part: + # * destination part (->[dest_ip]:dest_port) appears in Net-SNMP > 5.3 + # * protocol name (TCP: or UDP:) and bracketted IP addr w/ port number appear in + # Net-SNMP > 5.1 (Net-SNMP 5.1 has IP addr only). + # * port number is signed (often negative) in Net-SNMP 5.2 + $source =~ s/(?:(?:TCP|UDP):\s*)?\[?([^] ]+)\]?(?::-?\d+)?(?:\s*->.*)?$/$1/; + } + my $timestamp = $date . ' ' . $time; my ($custom_oid, $custom_type, $custom_value) = ('', '', '');