add filter-network meraki

This commit is contained in:
garnier-quentin 2019-04-15 10:17:03 +02:00
parent 042db1efb4
commit 690d9abd3a
1 changed files with 31 additions and 18 deletions

View File

@ -29,7 +29,7 @@ use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold)
sub custom_status_output { sub custom_status_output {
my ($self, %options) = @_; my ($self, %options) = @_;
my $msg = 'Status : ' . $self->{result_values}->{status}; my $msg = 'status : ' . $self->{result_values}->{status};
return $msg; return $msg;
} }
@ -175,16 +175,16 @@ sub new {
bless $self, $class; bless $self, $class;
$self->{version} = '1.0'; $self->{version} = '1.0';
$options{options}->add_options(arguments => $options{options}->add_options(arguments => {
{ "filter-name:s" => { name => 'filter_name' },
"filter-name:s" => { name => 'filter_name' }, "filter-interface:s" => { name => 'filter_interface' },
"filter-interface:s" => { name => 'filter_interface' }, "filter-network:s" => { name => 'filter_network' },
"warning-status:s" => { name => 'warning_status', default => '' }, "warning-status:s" => { name => 'warning_status', default => '' },
"critical-status:s" => { name => 'critical_status', default => '%{status} =~ /offline/' }, "critical-status:s" => { name => 'critical_status', default => '%{status} =~ /offline/' },
"speed-in:s" => { name => 'speed_in' }, "speed-in:s" => { name => 'speed_in' },
"speed-out:s" => { name => 'speed_out' }, "speed-out:s" => { name => 'speed_out' },
"units-traffic:s" => { name => 'units_traffic', default => '%' }, "units-traffic:s" => { name => 'units_traffic', default => '%' },
}); });
return $self; return $self;
} }
@ -199,7 +199,7 @@ sub check_options {
sub prefix_device_output { sub prefix_device_output {
my ($self, %options) = @_; my ($self, %options) = @_;
return "Device '" . $options{instance_value}->{display} . "' "; return "Device '" . $options{instance_value}->{display} . "' [network: " . $options{instance_value}->{network} . "] ";
} }
sub prefix_interface_output { sub prefix_interface_output {
@ -216,6 +216,7 @@ my $mapping = {
devName => { oid => '.1.3.6.1.4.1.29671.1.1.4.1.2' }, devName => { oid => '.1.3.6.1.4.1.29671.1.1.4.1.2' },
devStatus => { oid => '.1.3.6.1.4.1.29671.1.1.4.1.3', map => \%map_status }, devStatus => { oid => '.1.3.6.1.4.1.29671.1.1.4.1.3', map => \%map_status },
devClientCount => { oid => '.1.3.6.1.4.1.29671.1.1.4.1.5' }, devClientCount => { oid => '.1.3.6.1.4.1.29671.1.1.4.1.5' },
devNetworkName => { oid => '.1.3.6.1.4.1.29671.1.1.4.1.11' },
}; };
my $mapping2 = { my $mapping2 = {
devInterfaceName => { oid => '.1.3.6.1.4.1.29671.1.1.5.1.3' }, devInterfaceName => { oid => '.1.3.6.1.4.1.29671.1.1.5.1.3' },
@ -230,20 +231,28 @@ sub manage_selection {
$self->{interface} = {}; $self->{interface} = {};
$self->{global} = { total => 0 }; $self->{global} = { total => 0 };
my $snmp_result = $options{snmp}->get_multiple_table(oids => my $snmp_result = $options{snmp}->get_multiple_table(oids => [
[ { oid => $mapping->{devName}->{oid} }, { oid => $mapping->{devName}->{oid} },
{ oid => $mapping2->{devInterfaceName}->{oid} }, { oid => $mapping2->{devInterfaceName}->{oid} },
], nothing_quit => 1); { oid => $mapping->{devNetworkName}->{oid} }
], nothing_quit => 1);
foreach my $oid (keys %{$snmp_result->{ $mapping->{devName}->{oid} }}) { foreach my $oid (keys %{$snmp_result->{ $mapping->{devName}->{oid} }}) {
$oid =~ /^$mapping->{devName}->{oid}\.(.*)$/; $oid =~ /^$mapping->{devName}->{oid}\.(.*)$/;
my $instance = $1; my $instance = $1;
my $dev_name = $snmp_result->{$mapping->{devName}->{oid}}->{$oid}; my $dev_name = $snmp_result->{$mapping->{devName}->{oid}}->{$oid};
my $network = defined($snmp_result->{$mapping->{devNetworkName}->{oid}}->{ $mapping->{devNetworkName}->{oid} . '.' . $instance })
? $snmp_result->{$mapping->{devNetworkName}->{oid}}->{ $mapping->{devNetworkName}->{oid} . '.' . $instance } : 'n/a';
if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' && if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' &&
$dev_name !~ /$self->{option_results}->{filter_name}/) { $dev_name !~ /$self->{option_results}->{filter_name}/) {
$self->{output}->output_add(long_msg => "skipping device '" . $dev_name . "': no matching filter.", debug => 1); $self->{output}->output_add(long_msg => "skipping device '" . $dev_name . "': no matching filter.", debug => 1);
next; next;
} }
if (defined($self->{option_results}->{filter_network}) && $self->{option_results}->{filter_network} ne '' &&
$network !~ /$self->{option_results}->{filter_network}/) {
$self->{output}->output_add(long_msg => "skipping device '" . $dev_name . "': no matching filter.", debug => 1);
next;
}
foreach (keys %{$snmp_result->{ $mapping2->{devInterfaceName}->{oid} }}) { foreach (keys %{$snmp_result->{ $mapping2->{devInterfaceName}->{oid} }}) {
next if (!/^$mapping2->{devInterfaceName}->{oid}\.$instance\.(.*)/); next if (!/^$mapping2->{devInterfaceName}->{oid}\.$instance\.(.*)/);
@ -260,7 +269,7 @@ sub manage_selection {
} }
$self->{global}->{total}++; $self->{global}->{total}++;
$self->{device}->{$instance} = { display => $dev_name }; $self->{device}->{$instance} = { display => $dev_name, network => $network };
} }
if (scalar(keys %{$self->{interface}}) > 0) { if (scalar(keys %{$self->{interface}}) > 0) {
@ -312,6 +321,10 @@ Example: --filter-counters='^clients$'
Filter device name (can be a regexp). Filter device name (can be a regexp).
=item B<--filter-network>
Filter by network name (can be a regexp).
=item B<--filter-interface> =item B<--filter-interface>
Filter interface name (can be a regexp). Filter interface name (can be a regexp).