+ add Net::SNMP in mode

This commit is contained in:
garnier-quentin 2017-01-17 10:23:38 +01:00
parent c46f2bba9b
commit 1bc7b14e8d
1 changed files with 45 additions and 3 deletions

View File

@ -23,6 +23,7 @@ package apps::centreon::local::mode::downtimetrap;
use base qw(centreon::plugins::mode); use base qw(centreon::plugins::mode);
my $use_module_snmp; my $use_module_snmp;
my $use_module_netsnmp;
BEGIN { BEGIN {
eval { eval {
@ -31,6 +32,14 @@ BEGIN {
}; };
if ($@) { if ($@) {
$use_module_snmp = 0; $use_module_snmp = 0;
eval {
require Net::SNMP;
};
if ($@) {
$use_module_netsnmp = 0;
} else {
$use_module_netsnmp = 1;
}
} else { } else {
$use_module_snmp = 1; $use_module_snmp = 1;
} }
@ -100,7 +109,7 @@ sub snmp_build_args {
} }
} }
sub send_trap_module { sub send_trap_snmp {
my ($self, %options) = @_; my ($self, %options) = @_;
$SNMP::auto_init_mib = 0; $SNMP::auto_init_mib = 0;
@ -121,6 +130,37 @@ sub send_trap_module {
$varlist); $varlist);
} }
sub send_trap_netsnmp {
my ($self, %options) = @_;
$self->snmp_build_args();
my ($snmp_session, $error) = Net::SNMP->session(-hostname => $self->{option_results}->{centreon_server},
-community => "public",
-port => 162,
-version => "snmpv2c",
-translate => [-all => 0]);
if (!defined($snmp_session)) {
$self->{output}->add_option_msg(short_msg => "SNMP Session : $error");
$self->{output}->option_exit();
}
my $args = [];
push @$args, ('1.3.6.1.2.1.1.3.0', Net::SNMP::TIMETICKS, time());
push @$args, ('1.3.6.1.6.3.1.1.4.1.0', Net::SNMP::OBJECT_IDENTIFIER, $self->{option_results}->{oid_trap});
foreach (('hostname', 'start', 'end', 'author', 'comment', 'duration')) {
my $type = $self->{snmp_args}->{$_}->{type};
$type = 'OCTET_STRING' if ($type eq 'OCTETSTR');
my $result;
my $ltmp = "\$result = Net::SNMP::$type;";
eval $ltmp;
push @$args, ($self->{snmp_args}->{$_}->{oid} . '.' . $self->{snmp_args}->{$_}->{instance}, $result, $self->{snmp_args}->{$_}->{val});
}
$snmp_session->snmpv2_trap(-varbindlist => $args);
$snmp_session->close();
}
sub send_trap_cmd { sub send_trap_cmd {
my ($self, %options) = @_; my ($self, %options) = @_;
@ -150,8 +190,10 @@ sub run {
my ($self, %options) = @_; my ($self, %options) = @_;
if ($use_module_snmp == 1 && !defined($self->{option_results}->{display_options})) { if ($use_module_snmp == 1 && !defined($self->{option_results}->{display_options})) {
$self->send_trap_module(); $self->send_trap_snmp();
} else { } elsif ($use_module_netsnmp == 1 && !defined($self->{option_results}->{display_options})) {
$self->send_trap_netsnmp();
} else {
$self->send_trap_cmd(); $self->send_trap_cmd();
} }