Nagios::Plugin::JUNOS, check_junos: Added basic support for excluding targets.
This may be done by prefixing the target name with '~' rather than '+'. For example, this may be combined with @with_description when checking interfaces to exclude some specific interface(s): interfaces,@with_description~ge-0/0/0.
This commit is contained in:
parent
a14dae1e62
commit
864a0e6dcd
|
@ -252,19 +252,20 @@ sub check_interfaces
|
||||||
{
|
{
|
||||||
my $plugin = shift;
|
my $plugin = shift;
|
||||||
my $junos = shift;
|
my $junos = shift;
|
||||||
my @targets = @_;
|
my $targets = shift || [];
|
||||||
|
my $exclude = shift || [];
|
||||||
|
|
||||||
my $opts = {
|
my $opts = {
|
||||||
with_description => 0,
|
with_description => 0,
|
||||||
};
|
};
|
||||||
|
|
||||||
if (grep { m/^\@with_description$/; } @targets) {
|
if (grep { m/^\@with_description$/; } @$targets) {
|
||||||
$opts->{'with_description'} = 1;
|
$opts->{'with_description'} = 1;
|
||||||
|
|
||||||
@targets = grep { ! m/^\@with_description$/; } @targets;
|
@$targets = grep { ! m/^\@with_description$/; } @$targets;
|
||||||
}
|
}
|
||||||
|
|
||||||
my @interfaces = get_interfaces($plugin, $opts, @targets);;
|
my @interfaces = get_interfaces($plugin, $opts, @$targets);;
|
||||||
|
|
||||||
my $down_count = 0;
|
my $down_count = 0;
|
||||||
my @down_ifaces = ();
|
my @down_ifaces = ();
|
||||||
|
@ -277,7 +278,7 @@ sub check_interfaces
|
||||||
foreach my $iface (@interfaces) {
|
foreach my $iface (@interfaces) {
|
||||||
my $name = $plugin->get_query_object_value($iface, 'name');
|
my $name = $plugin->get_query_object_value($iface, 'name');
|
||||||
my $desc = $plugin->get_query_object_value($iface, 'description');
|
my $desc = $plugin->get_query_object_value($iface, 'description');
|
||||||
my $status = check_interface($plugin, $iface, $opts, @targets);
|
my $status = check_interface($plugin, $iface, $opts, @$targets);
|
||||||
|
|
||||||
my $tmp;
|
my $tmp;
|
||||||
|
|
||||||
|
@ -339,15 +340,15 @@ sub check_interfaces
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((! $down_count) && (! $phys_down_count)) {
|
if ((! $down_count) && (! $phys_down_count)) {
|
||||||
if ((! scalar(@targets)) || $opts->{'with_description'}) {
|
if ((! scalar(@$targets)) || $opts->{'with_description'}) {
|
||||||
$plugin->add_message(OK, "all interfaces up"
|
$plugin->add_message(OK, "all interfaces up"
|
||||||
. ($have_lag_ifaces
|
. ($have_lag_ifaces
|
||||||
? " (including all LAG member interfaces)" : ""));
|
? " (including all LAG member interfaces)" : ""));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
$plugin->add_message(OK, "interface"
|
$plugin->add_message(OK, "interface"
|
||||||
. (scalar(@targets) == 1 ? " " : "s ")
|
. (scalar(@$targets) == 1 ? " " : "s ")
|
||||||
. join(", ", @targets) . " up"
|
. join(", ", @$targets) . " up"
|
||||||
. ($have_lag_ifaces
|
. ($have_lag_ifaces
|
||||||
? " (including all LAG member interfaces)" : ""));
|
? " (including all LAG member interfaces)" : ""));
|
||||||
}
|
}
|
||||||
|
@ -358,7 +359,8 @@ sub check_interface_forwarding
|
||||||
{
|
{
|
||||||
my $plugin = shift;
|
my $plugin = shift;
|
||||||
my $junos = shift;
|
my $junos = shift;
|
||||||
my @targets = @_;
|
my $targets = shift || [];
|
||||||
|
my $exclude = shift || [];
|
||||||
|
|
||||||
my $res = $plugin->send_query('show ethernet-switching interfaces brief');
|
my $res = $plugin->send_query('show ethernet-switching interfaces brief');
|
||||||
|
|
||||||
|
@ -369,7 +371,7 @@ sub check_interface_forwarding
|
||||||
'Storm control in effect' => 1,
|
'Storm control in effect' => 1,
|
||||||
);
|
);
|
||||||
|
|
||||||
my %targets = map { my @t = split(':', $_); $t[0] => $t[1]; } @targets;
|
my %targets = map { my @t = split(':', $_); $t[0] => $t[1]; } @$targets;
|
||||||
|
|
||||||
my @failed = ();
|
my @failed = ();
|
||||||
|
|
||||||
|
@ -377,7 +379,7 @@ sub check_interface_forwarding
|
||||||
my $name = $plugin->get_query_object_value($iface, 'interface-name');
|
my $name = $plugin->get_query_object_value($iface, 'interface-name');
|
||||||
my $failed_status = undef;
|
my $failed_status = undef;
|
||||||
|
|
||||||
if (scalar(@targets) && (! exists($targets{$name}))) {
|
if (scalar(@$targets) && (! exists($targets{$name}))) {
|
||||||
next;
|
next;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -418,7 +420,8 @@ sub check_chassis_environment
|
||||||
{
|
{
|
||||||
my $plugin = shift;
|
my $plugin = shift;
|
||||||
my $junos = shift;
|
my $junos = shift;
|
||||||
my @targets = @_;
|
my $targets = shift || [];
|
||||||
|
my $exclude = shift || [];
|
||||||
|
|
||||||
my $res = $plugin->send_query('get_environment_information');
|
my $res = $plugin->send_query('get_environment_information');
|
||||||
|
|
||||||
|
@ -437,7 +440,7 @@ sub check_chassis_environment
|
||||||
foreach my $item ($plugin->get_query_object($res, 'environment-item')) {
|
foreach my $item ($plugin->get_query_object($res, 'environment-item')) {
|
||||||
my $name = $plugin->get_query_object_value($item, 'name');
|
my $name = $plugin->get_query_object_value($item, 'name');
|
||||||
|
|
||||||
if (scalar(@targets) && (! grep { m/^$name$/ } @targets)) {
|
if (scalar(@$targets) && (! grep { m/^$name$/ } @$targets)) {
|
||||||
next;
|
next;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -448,7 +451,7 @@ sub check_chassis_environment
|
||||||
my $status = $plugin->get_query_object_value($item, 'status');
|
my $status = $plugin->get_query_object_value($item, 'status');
|
||||||
|
|
||||||
if ($status eq "Absent") {
|
if ($status eq "Absent") {
|
||||||
if (! scalar(@targets)) {
|
if (! scalar(@$targets)) {
|
||||||
next;
|
next;
|
||||||
}
|
}
|
||||||
# else: check this component
|
# else: check this component
|
||||||
|
@ -515,7 +518,8 @@ sub check_system_storage
|
||||||
{
|
{
|
||||||
my $plugin = shift;
|
my $plugin = shift;
|
||||||
my $junos = shift;
|
my $junos = shift;
|
||||||
my @targets = @_;
|
my $targets = shift || [];
|
||||||
|
my $exclude = shift || [];
|
||||||
|
|
||||||
my $res = $plugin->send_query('get_system_storage');
|
my $res = $plugin->send_query('get_system_storage');
|
||||||
|
|
||||||
|
@ -530,8 +534,8 @@ sub check_system_storage
|
||||||
my $name = $plugin->get_query_object_value($fs, 'filesystem-name');
|
my $name = $plugin->get_query_object_value($fs, 'filesystem-name');
|
||||||
my $mnt_pt = $plugin->get_query_object_value($fs, 'mounted-on');
|
my $mnt_pt = $plugin->get_query_object_value($fs, 'mounted-on');
|
||||||
|
|
||||||
if (scalar(@targets) && (! grep { m/^$name$/ } @targets)
|
if (scalar(@$targets) && (! grep { m/^$name$/ } @$targets)
|
||||||
&& (! grep { m/^$mnt_pt$/ } @targets)) {
|
&& (! grep { m/^$mnt_pt$/ } @$targets)) {
|
||||||
next;
|
next;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -257,7 +257,28 @@ sub _add_single_check
|
||||||
|
|
||||||
$c{'target'} = undef;
|
$c{'target'} = undef;
|
||||||
if (defined($check[1])) {
|
if (defined($check[1])) {
|
||||||
$c{'target'} = [ split(m/\+/, $check[1]) ];
|
my @tmp = split(m/(\+|\~)/, $check[1]);
|
||||||
|
|
||||||
|
$c{'target'} = [];
|
||||||
|
$c{'exclude'} = [];
|
||||||
|
|
||||||
|
for (my $i = 0; $i < scalar(@tmp); ++$i) {
|
||||||
|
my $t = $tmp[$i];
|
||||||
|
|
||||||
|
if ((($t ne "+") && ($t ne "~")) || ($i == $#tmp)) {
|
||||||
|
push @{$c{'target'}}, $t;
|
||||||
|
next;
|
||||||
|
}
|
||||||
|
|
||||||
|
++$i;
|
||||||
|
|
||||||
|
if ($t eq "+") {
|
||||||
|
push @{$c{'target'}}, $tmp[$i];
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
push @{$c{'exclude'}}, $tmp[$i];
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$c{'warning'} = $check[2];
|
$c{'warning'} = $check[2];
|
||||||
|
@ -290,6 +311,7 @@ sub set_checks
|
||||||
$self->{'conf'}->{'checks'}->[0] = {
|
$self->{'conf'}->{'checks'}->[0] = {
|
||||||
name => $self->{'default_check'},
|
name => $self->{'default_check'},
|
||||||
target => [],
|
target => [],
|
||||||
|
exclude => [],
|
||||||
warning => undef,
|
warning => undef,
|
||||||
critical => undef,
|
critical => undef,
|
||||||
};
|
};
|
||||||
|
@ -371,10 +393,15 @@ sub run_checks
|
||||||
my $self = shift;
|
my $self = shift;
|
||||||
|
|
||||||
foreach my $check ($self->get_checks()) {
|
foreach my $check ($self->get_checks()) {
|
||||||
my @targets = ();
|
my $targets = [];
|
||||||
|
my $exclude = [];
|
||||||
|
|
||||||
if (defined $check->{'target'}) {
|
if (defined $check->{'target'}) {
|
||||||
@targets = @{$check->{'target'}};
|
$targets = $check->{'target'};
|
||||||
|
}
|
||||||
|
|
||||||
|
if (defined $check->{'exclude'}) {
|
||||||
|
$exclude = $check->{'exclude'};
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->set_thresholds(
|
$self->set_thresholds(
|
||||||
|
@ -383,7 +410,7 @@ sub run_checks
|
||||||
);
|
);
|
||||||
|
|
||||||
my $sub = $self->get_check_impl($check->{'name'});
|
my $sub = $self->get_check_impl($check->{'name'});
|
||||||
$sub->($self, $self->{'junos'}, @targets);
|
$sub->($self, $self->{'junos'}, $targets, $exclude);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue