manage v18 mibs for sophos xg (#2295)
This commit is contained in:
parent
0f57dd010f
commit
3c0110a5d8
|
@ -23,39 +23,66 @@ package network::cyberoam::snmp::mode::components::service;
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
|
|
||||||
my $map_status = {
|
my $map_v17_status = {
|
||||||
1 => 'untouched', 2 => 'stopped', 3 => 'initializing', 4 => 'running', 5 => 'exiting',
|
1 => 'untouched', 2 => 'stopped', 3 => 'initializing', 4 => 'running', 5 => 'exiting',
|
||||||
6 => 'dead', 7 => 'unregistered',
|
6 => 'dead', 7 => 'unregistered'
|
||||||
|
};
|
||||||
|
my $map_v18_status = {
|
||||||
|
0 => 'untouched', 1 => 'stopped', 2 => 'initializing', 3 => 'running',
|
||||||
|
4 => 'exiting', 5 => 'dead', 6 => 'frozen', 7 => 'unregistered'
|
||||||
};
|
};
|
||||||
|
|
||||||
my $mapping = {
|
my $mapping = {
|
||||||
pop3Service => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.1', map => $map_status, type => 'pop3' },
|
pop3Service => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.1', map => $map_v17_status, type => 'pop3' },
|
||||||
imap4Service => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.2', map => $map_status, type => 'imap4' },
|
imap4Service => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.2', map => $map_v17_status, type => 'imap4' },
|
||||||
smtpService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.3', map => $map_status, type => 'smtp' },
|
smtpService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.3', map => $map_v17_status, type => 'smtp' },
|
||||||
ftpService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.4', map => $map_status, type => 'ftp' },
|
ftpService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.4', map => $map_v17_status, type => 'ftp' },
|
||||||
httpService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.5', map => $map_status, type => 'http' },
|
httpService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.5', map => $map_v17_status, type => 'http' },
|
||||||
avService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.6', map => $map_status, type => 'av' },
|
avService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.6', map => $map_v17_status, type => 'av' },
|
||||||
asService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.7', map => $map_status, type => 'as' },
|
asService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.7', map => $map_v17_status, type => 'as' },
|
||||||
dnsService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.8', map => $map_status, type => 'dns' },
|
dnsService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.8', map => $map_v17_status, type => 'dns' },
|
||||||
haService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.9', map => $map_status, type => 'ha' },
|
haService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.9', map => $map_v17_status, type => 'ha' },
|
||||||
idpService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.10', map => $map_status, type => 'idp' },
|
idpService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.10', map => $map_v17_status, type => 'idp' },
|
||||||
apacheService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.11', map => $map_status, type => 'apache' },
|
apacheService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.11', map => $map_v17_status, type => 'apache' },
|
||||||
ntpService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.12', map => $map_status, type => 'ntp' },
|
ntpService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.12', map => $map_v17_status, type => 'ntp' },
|
||||||
tomcatService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.13', map => $map_status, type => 'tomcat' },
|
tomcatService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.13', map => $map_v17_status, type => 'tomcat' },
|
||||||
sslvpnService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.14', map => $map_status, type => 'sslvpn' },
|
sslvpnService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.14', map => $map_v17_status, type => 'sslvpn' },
|
||||||
DataBaseService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.15', map => $map_status, type => 'database' },
|
DataBaseService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.15', map => $map_v17_status, type => 'database' },
|
||||||
networkService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.16', map => $map_status, type => 'network' },
|
networkService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.16', map => $map_v17_status, type => 'network' },
|
||||||
garnerService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.17', map => $map_status, type => 'garner' },
|
garnerService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.17', map => $map_v17_status, type => 'garner' },
|
||||||
droutingService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.18', map => $map_status, type => 'drouting' },
|
droutingService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.18', map => $map_v17_status, type => 'drouting' },
|
||||||
sshdService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.19', map => $map_status, type => 'sshd' },
|
sshdService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.19', map => $map_v17_status, type => 'sshd' },
|
||||||
dgdService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.20', map => $map_status, type => 'dgd' },
|
dgdService => { oid => '.1.3.6.1.4.1.21067.2.1.2.10.20', map => $map_v17_status, type => 'dgd' },
|
||||||
|
|
||||||
|
sfosPoP3Service => { oid => '.1.3.6.1.4.1.2604.5.1.3.1', map => $map_v18_status, type => 'pop3' },
|
||||||
|
sfosImap4Service => { oid => '.1.3.6.1.4.1.2604.5.1.3.2', map => $map_v18_status, type => 'imap4' },
|
||||||
|
sfosSmtpService => { oid => '.1.3.6.1.4.1.2604.5.1.3.3', map => $map_v18_status, type => 'smtp' },
|
||||||
|
sfosFtpService => { oid => '.1.3.6.1.4.1.2604.5.1.3.4', map => $map_v18_status, type => 'ftp' },
|
||||||
|
sfosHttpService => { oid => '.1.3.6.1.4.1.2604.5.1.3.5', map => $map_v18_status, type => 'http' },
|
||||||
|
sfosAVService => { oid => '.1.3.6.1.4.1.2604.5.1.3.6', map => $map_v18_status, type => 'av' },
|
||||||
|
sfosASService => { oid => '.1.3.6.1.4.1.2604.5.1.3.7', map => $map_v18_status, type => 'as' },
|
||||||
|
sfosDNSService => { oid => '.1.3.6.1.4.1.2604.5.1.3.8', map => $map_v18_status, type => 'dns' },
|
||||||
|
sfosHAService => { oid => '.1.3.6.1.4.1.2604.5.1.3.9', map => $map_v18_status, type => 'ha' },
|
||||||
|
sfosIPSService => { oid => '.1.3.6.1.4.1.2604.5.1.3.10', map => $map_v18_status, type => 'ips' },
|
||||||
|
sfosApacheService => { oid => '.1.3.6.1.4.1.2604.5.1.3.11', map => $map_v18_status, type => 'apache' },
|
||||||
|
sfosNtpService => { oid => '.1.3.6.1.4.1.2604.5.1.3.12', map => $map_v18_status, type => 'ntp' },
|
||||||
|
sfosTomcatService => { oid => '.1.3.6.1.4.1.2604.5.1.3.13', map => $map_v18_status, type => 'tomcat' },
|
||||||
|
sfosSSLVpnService => { oid => '.1.3.6.1.4.1.2604.5.1.3.14', map => $map_v18_status, type => 'sslvpn' },
|
||||||
|
sfosIPSecVpnService => { oid => '.1.3.6.1.4.1.2604.5.1.3.15', map => $map_v18_status, type => 'ipsecvpn' },
|
||||||
|
sfosDatabaseservice => { oid => '.1.3.6.1.4.1.2604.5.1.3.16', map => $map_v18_status, type => 'database' },
|
||||||
|
sfosNetworkService => { oid => '.1.3.6.1.4.1.2604.5.1.3.17', map => $map_v18_status, type => 'network' },
|
||||||
|
sfosGarnerService => { oid => '.1.3.6.1.4.1.2604.5.1.3.18', map => $map_v18_status, type => 'garner' },
|
||||||
|
sfosDroutingService => { oid => '.1.3.6.1.4.1.2604.5.1.3.19', map => $map_v18_status, type => 'drouting' },
|
||||||
|
sfosSSHdService => { oid => '.1.3.6.1.4.1.2604.5.1.3.20', map => $map_v18_status, type => 'sshd' },
|
||||||
|
sfosDgdService => { oid => '.1.3.6.1.4.1.2604.5.1.3.21', map => $map_v18_status, type => 'dgd' }
|
||||||
};
|
};
|
||||||
my $oid_serviceStats = '.1.3.6.1.4.1.21067.2.1.2.10';
|
my $oid_serviceStats = '.1.3.6.1.4.1.21067.2.1.2.10';
|
||||||
|
my $oid_sfosXGServiceStatus = '.1.3.6.1.4.1.2604.5.1.3';
|
||||||
|
|
||||||
sub load {
|
sub load {
|
||||||
my ($self) = @_;
|
my ($self) = @_;
|
||||||
|
|
||||||
push @{$self->{request}}, { oid => $oid_serviceStats };
|
push @{$self->{request}}, { oid => $oid_serviceStats }, { oid => $oid_sfosXGServiceStatus };
|
||||||
}
|
}
|
||||||
|
|
||||||
sub check {
|
sub check {
|
||||||
|
@ -65,9 +92,9 @@ sub check {
|
||||||
$self->{components}->{service} = {name => 'services', total => 0, skip => 0};
|
$self->{components}->{service} = {name => 'services', total => 0, skip => 0};
|
||||||
return if ($self->check_filter(section => 'service'));
|
return if ($self->check_filter(section => 'service'));
|
||||||
|
|
||||||
my $result = $self->{snmp}->map_instance(mapping => $mapping, results => $self->{results}->{$oid_serviceStats}, instance => '0');
|
my $result = $self->{snmp}->map_instance(mapping => $mapping, results => $self->{results}, instance => 0);
|
||||||
|
|
||||||
foreach (keys %{$mapping}) {
|
foreach (keys %$mapping) {
|
||||||
next if (!defined($result->{$_}));
|
next if (!defined($result->{$_}));
|
||||||
next if ($self->check_filter(section => 'service', instance => $mapping->{$_}->{type}));
|
next if ($self->check_filter(section => 'service', instance => $mapping->{$_}->{type}));
|
||||||
|
|
||||||
|
|
|
@ -30,10 +30,9 @@ sub new {
|
||||||
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments => {
|
||||||
{
|
'warning:s' => { name => 'warning' },
|
||||||
"warning:s" => { name => 'warning' },
|
'critical:s' => { name => 'critical' }
|
||||||
"critical:s" => { name => 'critical' },
|
|
||||||
});
|
});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
|
@ -64,11 +63,13 @@ sub run {
|
||||||
threshold => [ { label => 'critical', exit_litteral => 'critical' }, { label => 'warning', exit_litteral => 'warning' } ]);
|
threshold => [ { label => 'critical', exit_litteral => 'critical' }, { label => 'warning', exit_litteral => 'warning' } ]);
|
||||||
$self->{output}->output_add(severity => $exit,
|
$self->{output}->output_add(severity => $exit,
|
||||||
short_msg => sprintf("CPU Usage : %.2f %%", $result->{$oid_cpuPercentUsage}));
|
short_msg => sprintf("CPU Usage : %.2f %%", $result->{$oid_cpuPercentUsage}));
|
||||||
$self->{output}->perfdata_add(label => "cpu", unit => '%',
|
$self->{output}->perfdata_add(
|
||||||
|
label => "cpu", unit => '%',
|
||||||
value => sprintf("%.2f", $result->{$oid_cpuPercentUsage}),
|
value => sprintf("%.2f", $result->{$oid_cpuPercentUsage}),
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning'),
|
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning'),
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical'),
|
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical'),
|
||||||
min => 0);
|
min => 0
|
||||||
|
);
|
||||||
|
|
||||||
$self->{output}->display();
|
$self->{output}->display();
|
||||||
$self->{output}->exit();
|
$self->{output}->exit();
|
||||||
|
|
|
@ -28,18 +28,13 @@ use warnings;
|
||||||
sub custom_usage_perfdata {
|
sub custom_usage_perfdata {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{output}->perfdata_add(label => $self->{result_values}->{label} . '_used', unit => 'B',
|
$self->{output}->perfdata_add(
|
||||||
|
label => $self->{result_values}->{label} . '_used', unit => 'B',
|
||||||
value => $self->{result_values}->{used},
|
value => $self->{result_values}->{used},
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}, total => $self->{result_values}->{total}, cast_int => 1),
|
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}, total => $self->{result_values}->{total}, cast_int => 1),
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label}, total => $self->{result_values}->{total}, cast_int => 1),
|
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label}, total => $self->{result_values}->{total}, cast_int => 1),
|
||||||
min => 0, max => $self->{result_values}->{total});
|
min => 0, max => $self->{result_values}->{total}
|
||||||
}
|
);
|
||||||
|
|
||||||
sub custom_usage_threshold {
|
|
||||||
my ($self, %options) = @_;
|
|
||||||
|
|
||||||
my $exit = $self->{perfdata}->threshold_check(value => $self->{result_values}->{prct_used}, threshold => [ { label => 'critical-' . $self->{result_values}->{label} . '-usage', exit_litteral => 'critical' }, { label => 'warning-' . $self->{result_values}->{label} . '-usage', exit_litteral => 'warning' } ]);
|
|
||||||
return $exit;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_usage_output {
|
sub custom_usage_output {
|
||||||
|
@ -49,11 +44,12 @@ sub custom_usage_output {
|
||||||
my ($total_used_value, $total_used_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{used});
|
my ($total_used_value, $total_used_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{used});
|
||||||
my ($total_free_value, $total_free_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{free});
|
my ($total_free_value, $total_free_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{free});
|
||||||
|
|
||||||
my $msg = sprintf("Total: %s Used: %s (%.2f%%) Free: %s (%.2f%%)",
|
return sprintf(
|
||||||
|
"Total: %s Used: %s (%.2f%%) Free: %s (%.2f%%)",
|
||||||
$total_size_value . " " . $total_size_unit,
|
$total_size_value . " " . $total_size_unit,
|
||||||
$total_used_value . " " . $total_used_unit, $self->{result_values}->{prct_used},
|
$total_used_value . " " . $total_used_unit, $self->{result_values}->{prct_used},
|
||||||
$total_free_value . " " . $total_free_unit, $self->{result_values}->{prct_free});
|
$total_free_value . " " . $total_free_unit, $self->{result_values}->{prct_free}
|
||||||
return $msg;
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_usage_calc {
|
sub custom_usage_calc {
|
||||||
|
@ -68,6 +64,18 @@ sub custom_usage_calc {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub prefix_memory_output {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
return "Physical memory ";
|
||||||
|
}
|
||||||
|
|
||||||
|
sub prefix_swap_output {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
return "Swap memory ";
|
||||||
|
}
|
||||||
|
|
||||||
sub set_counters {
|
sub set_counters {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
@ -82,68 +90,77 @@ sub set_counters {
|
||||||
closure_custom_calc => $self->can('custom_usage_calc'), closure_custom_calc_extra_options => { label_ref => 'physical' },
|
closure_custom_calc => $self->can('custom_usage_calc'), closure_custom_calc_extra_options => { label_ref => 'physical' },
|
||||||
closure_custom_output => $self->can('custom_usage_output'),
|
closure_custom_output => $self->can('custom_usage_output'),
|
||||||
closure_custom_perfdata => $self->can('custom_usage_perfdata'),
|
closure_custom_perfdata => $self->can('custom_usage_perfdata'),
|
||||||
closure_custom_threshold_check => $self->can('custom_usage_threshold'),
|
threshold_use => 'prct_used'
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
|
||||||
];
|
];
|
||||||
|
|
||||||
$self->{maps_counters}->{swap} = [
|
$self->{maps_counters}->{swap} = [
|
||||||
{ label => 'swap-usage', set => {
|
{ label => 'swap-usage', set => {
|
||||||
key_values => [ { name => 'free' }, { name => 'used' } ],
|
key_values => [ { name => 'free' }, { name => 'used' } ],
|
||||||
closure_custom_calc => $self->can('custom_usage_calc'), closure_custom_calc_extra_options => { label_ref => 'swap' },
|
closure_custom_calc => $self->can('custom_usage_calc'), closure_custom_calc_extra_options => { label_ref => 'swap' },
|
||||||
closure_custom_output => $self->can('custom_usage_output'),
|
closure_custom_output => $self->can('custom_usage_output'),
|
||||||
closure_custom_perfdata => $self->can('custom_usage_perfdata'),
|
closure_custom_perfdata => $self->can('custom_usage_perfdata'),
|
||||||
closure_custom_threshold_check => $self->can('custom_usage_threshold'),
|
threshold_use => 'prct_used'
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
sub prefix_memory_output {
|
|
||||||
my ($self, %options) = @_;
|
|
||||||
|
|
||||||
return "Physical memory ";
|
|
||||||
}
|
|
||||||
|
|
||||||
sub prefix_swap_output {
|
|
||||||
my ($self, %options) = @_;
|
|
||||||
|
|
||||||
return "Swap memory ";
|
|
||||||
}
|
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments => {});
|
||||||
{
|
|
||||||
"filter-counters:s" => { name => 'filter_counters' },
|
|
||||||
});
|
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub add_counters {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
return if (!defined($options{result}->{memory_total}));
|
||||||
|
|
||||||
|
my $memory_used = $options{result}->{memory_used_prct} * $options{result}->{memory_total} * 1024 * 1024 / 100;
|
||||||
|
my $swap_used = $options{result}->{swap_used_prct} * $options{result}->{swap_total} * 1024 * 1024 / 100;
|
||||||
|
$self->{memory} = {
|
||||||
|
free => $options{result}->{memory_total} * 1024 * 1024 - $memory_used,
|
||||||
|
used => $memory_used
|
||||||
|
};
|
||||||
|
$self->{swap} = {
|
||||||
|
free => $options{result}->{swap_total} * 1024 * 1024 - $swap_used,
|
||||||
|
used => $swap_used
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $oid_memoryCapacity = '.1.3.6.1.4.1.21067.2.1.2.4.1.0'; # in MB
|
my $mapping = {
|
||||||
my $oid_memoryPercentUsage = '.1.3.6.1.4.1.21067.2.1.2.4.2.0';
|
v17 => {
|
||||||
my $oid_swapCapacity = '.1.3.6.1.4.1.21067.2.1.2.4.3.0'; # in MB
|
memory_total => { oid => '.1.3.6.1.4.1.21067.2.1.2.4.1' }, # memoryCapacity - MB
|
||||||
my $oid_swapPercentUsage = '.1.3.6.1.4.1.21067.2.1.2.4.4.0';
|
memory_used_prct => { oid => '.1.3.6.1.4.1.21067.2.1.2.4.2' }, # memoryPercentUsage
|
||||||
|
swap_total => { oid => '.1.3.6.1.4.1.21067.2.1.2.4.3' }, # swapCapacity - MB
|
||||||
|
swap_used_prct => { oid => '.1.3.6.1.4.1.21067.2.1.2.4.4' } # swapPercentUsage
|
||||||
|
},
|
||||||
|
v18 => {
|
||||||
|
memory_total => { oid => '.1.3.6.1.4.1.2604.5.1.2.5.1' }, # sfosMemoryCapacity - MB
|
||||||
|
memory_used_prct => { oid => '.1.3.6.1.4.1.2604.5.1.2.5.2' }, # sfosMemoryPercentUsage
|
||||||
|
swap_total => { oid => '.1.3.6.1.4.1.2604.5.1.2.5.3' }, # sfosSwapCapacity - MB
|
||||||
|
swap_used_prct => { oid => '.1.3.6.1.4.1.2604.5.1.2.5.4' } # sfosSwapPercentUsage
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
my $result = $options{snmp}->get_leef(oids => [$oid_memoryCapacity, $oid_memoryPercentUsage,
|
my $snmp_result = $options{snmp}->get_leef(
|
||||||
$oid_swapCapacity, $oid_swapPercentUsage],
|
oids => [ map($_->{oid} . '.0', values(%{$mapping->{v17}}), values(%{$mapping->{v18}})) ],
|
||||||
nothing_quit => 1);
|
nothing_quit => 1
|
||||||
my $memory_used = $result->{$oid_memoryPercentUsage} * $result->{$oid_memoryCapacity} * 1024 * 1024 / 100;
|
);
|
||||||
my $swap_used = $result->{$oid_swapPercentUsage} * $result->{$oid_swapCapacity} * 1024 * 1024 / 100;
|
|
||||||
$self->{memory} = {
|
my $result = $options{snmp}->map_instance(mapping => $mapping->{v17}, results => $snmp_result, instance => 0);
|
||||||
free => $result->{$oid_memoryCapacity} * 1024 * 1024 - $memory_used,
|
$self->add_counters(result => $result);
|
||||||
used => $memory_used,
|
$result = $options{snmp}->map_instance(mapping => $mapping->{v18}, results => $snmp_result, instance => 0);
|
||||||
};
|
$self->add_counters(result => $result);
|
||||||
$self->{swap} = {
|
|
||||||
free => $result->{$oid_swapCapacity} * 1024 * 1024 - $swap_used,
|
|
||||||
used => $swap_used,
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
@ -161,14 +178,9 @@ Check memory usages.
|
||||||
Only display some counters (regexp can be used).
|
Only display some counters (regexp can be used).
|
||||||
Example : --filter-counters='^physical-usage$'
|
Example : --filter-counters='^physical-usage$'
|
||||||
|
|
||||||
=item B<--warning-*>
|
=item B<--warning-*> B<--critical-*>
|
||||||
|
|
||||||
Threshold warning.
|
Thresholds.
|
||||||
Can be: 'physical-usage' (%), 'swap-usage' (%).
|
|
||||||
|
|
||||||
=item B<--critical-*>
|
|
||||||
|
|
||||||
Threshold critical.
|
|
||||||
Can be: 'physical-usage' (%), 'swap-usage' (%).
|
Can be: 'physical-usage' (%), 'swap-usage' (%).
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
|
@ -30,64 +30,65 @@ sub set_counters {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{maps_counters_type} = [
|
$self->{maps_counters_type} = [
|
||||||
{ name => 'global', type => 0, cb_prefix_output => 'prefix_output' },
|
{ name => 'global', type => 0, cb_prefix_output => 'prefix_output' }
|
||||||
];
|
];
|
||||||
|
|
||||||
$self->{maps_counters}->{global} = [
|
$self->{maps_counters}->{global} = [
|
||||||
{ label => 'live-users', set => {
|
{ label => 'live-users', set => {
|
||||||
key_values => [ { name => 'live_users' } ],
|
key_values => [ { name => 'live_users' } ],
|
||||||
output_template => 'live users = %s',
|
output_template => 'live users: %s',
|
||||||
perfdatas => [
|
perfdatas => [
|
||||||
{ label => 'live_users', value => 'live_users', template => '%s', min => 0 },
|
{ label => 'live_users', template => '%s', min => 0 }
|
||||||
],
|
]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{ label => 'http-hits', set => {
|
{ label => 'http-hits', set => {
|
||||||
key_values => [ { name => 'http_hits', diff => 1 } ],
|
key_values => [ { name => 'http_hits', diff => 1 } ],
|
||||||
output_template => 'http hits = %s',
|
output_template => 'http hits: %s',
|
||||||
perfdatas => [
|
perfdatas => [
|
||||||
{ label => 'http_hits', value => 'http_hits', template => '%s', min => 0 },
|
{ label => 'http_hits', template => '%s', min => 0 }
|
||||||
],
|
]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{ label => 'ftp-hits', set => {
|
{ label => 'ftp-hits', set => {
|
||||||
key_values => [ { name => 'ftp_hits', diff => 1 } ],
|
key_values => [ { name => 'ftp_hits', diff => 1 } ],
|
||||||
output_template => 'ftp hits = %s',
|
output_template => 'ftp hits: %s',
|
||||||
perfdatas => [
|
perfdatas => [
|
||||||
{ label => 'ftp_hits', value => 'ftp_hits', template => '%s', min => 0 },
|
{ label => 'ftp_hits', template => '%s', min => 0 }
|
||||||
],
|
]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{ label => 'pop3-hits', set => {
|
{ label => 'pop3-hits', set => {
|
||||||
key_values => [ { name => 'pop3_hits', diff => 1 } ],
|
key_values => [ { name => 'pop3_hits', diff => 1 } ],
|
||||||
output_template => 'pop3 hits = %s',
|
output_template => 'pop3 hits: %s',
|
||||||
perfdatas => [
|
perfdatas => [
|
||||||
{ label => 'pop3_hits', value => 'pop3_hits', template => '%s', min => 0 },
|
{ label => 'pop3_hits', template => '%s', min => 0 }
|
||||||
],
|
]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{ label => 'imap-hits', set => {
|
{ label => 'imap-hits', set => {
|
||||||
key_values => [ { name => 'imap_hits', diff => 1 } ],
|
key_values => [ { name => 'imap_hits', diff => 1 } ],
|
||||||
output_template => 'imap hits = %s',
|
output_template => 'imap hits: %s',
|
||||||
perfdatas => [
|
perfdatas => [
|
||||||
{ label => 'imap_hits', value => 'imap_hits', template => '%s', min => 0 },
|
{ label => 'imap_hits', template => '%s', min => 0 }
|
||||||
],
|
]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{ label => 'smtp-hits', set => {
|
{ label => 'smtp-hits', set => {
|
||||||
key_values => [ { name => 'smtp_hits', diff => 1 } ],
|
key_values => [ { name => 'smtp_hits', diff => 1 } ],
|
||||||
output_template => 'smtp hits = %s',
|
output_template => 'smtp hits: %s',
|
||||||
perfdatas => [
|
perfdatas => [
|
||||||
{ label => 'smtp_hits', value => 'smtp_hits', template => '%s', min => 0 },
|
{ label => 'smtp_hits', template => '%s', min => 0 }
|
||||||
],
|
]
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
sub prefix_output {
|
sub prefix_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
return "Requests: ";
|
return 'Requests ';
|
||||||
}
|
}
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
|
@ -101,39 +102,53 @@ sub new {
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub add_counters {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
return if (!defined($options{result}->{live_users}));
|
||||||
|
|
||||||
|
$self->{global} = { %{$options{result}} };
|
||||||
|
}
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
if ($options{snmp}->is_snmpv1()) {
|
if ($options{snmp}->is_snmpv1()) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Need to use SNMP v2c or v3.");
|
$self->{output}->add_option_msg(short_msg => 'Need to use SNMP v2c or v3.');
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
my $oid_liveUsers = '.1.3.6.1.4.1.21067.2.1.2.6.0';
|
my $mapping = {
|
||||||
my $oid_httpHits = '.1.3.6.1.4.1.21067.2.1.2.7.0';
|
v17 => {
|
||||||
my $oid_ftpHits = '.1.3.6.1.4.1.21067.2.1.2.8.0';
|
live_users => { oid => '.1.3.6.1.4.1.21067.2.1.2.6' }, # liveUsers
|
||||||
my $oid_pop3Hits = '.1.3.6.1.4.1.21067.2.1.2.9.1.0';
|
http_hits => { oid => '.1.3.6.1.4.1.21067.2.1.2.7' }, # httpHits
|
||||||
my $oid_imapHits = '.1.3.6.1.4.1.21067.2.1.2.9.2.0';
|
ftp_hits => { oid => '.1.3.6.1.4.1.21067.2.1.2.8' }, # ftpHits
|
||||||
my $oid_smtpHits = '.1.3.6.1.4.1.21067.2.1.2.9.3.0';
|
pop3_hits => { oid => '.1.3.6.1.4.1.21067.2.1.2.9.1' }, # pop3Hits
|
||||||
my $result = $options{snmp}->get_leef(
|
imap_hits => { oid => '.1.3.6.1.4.1.21067.2.1.2.9.2' }, # imapHits
|
||||||
oids => [
|
smtp_hits => { oid => '.1.3.6.1.4.1.21067.2.1.2.9.3' } # smtpHits
|
||||||
$oid_liveUsers, $oid_httpHits, $oid_ftpHits, $oid_pop3Hits,
|
},
|
||||||
$oid_imapHits, $oid_smtpHits
|
v18 => {
|
||||||
],
|
live_users => { oid => '.1.3.6.1.4.1.2604.5.1.2.6' }, # sfosLiveUsersCount
|
||||||
|
http_hits => { oid => '.1.3.6.1.4.1.2604.5.1.2.7' }, # sfosHTTPHits
|
||||||
|
ftp_hits => { oid => '.1.3.6.1.4.1.2604.5.1.2.8' }, # sfosFTPHits
|
||||||
|
pop3_hits => { oid => '.1.3.6.1.4.1.2604.5.1.2.9.1' }, # sfosPOP3Hits
|
||||||
|
imap_hits => { oid => '.1.3.6.1.4.1.2604.5.1.2.9.2' }, # sfosImapHits
|
||||||
|
smtp_hits => { oid => '.1.3.6.1.4.1.2604.5.1.2.9.3' } # sfosSmtpHits
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
my $snmp_result = $options{snmp}->get_leef(
|
||||||
|
oids => [ map($_->{oid} . '.0', values(%{$mapping->{v17}}), values(%{$mapping->{v18}})) ],
|
||||||
nothing_quit => 1
|
nothing_quit => 1
|
||||||
);
|
);
|
||||||
|
|
||||||
$self->{cache_name} = "cyberoam_" . $options{snmp}->get_hostname() . '_' . $options{snmp}->get_port() . '_' . $self->{mode} . '_' .
|
my $result = $options{snmp}->map_instance(mapping => $mapping->{v17}, results => $snmp_result, instance => 0);
|
||||||
(defined($self->{option_results}->{filter_counters}) ? md5_hex($self->{option_results}->{filter_counters}) : md5_hex('all'));
|
$self->add_counters(result => $result);
|
||||||
|
$result = $options{snmp}->map_instance(mapping => $mapping->{v18}, results => $snmp_result, instance => 0);
|
||||||
|
$self->add_counters(result => $result);
|
||||||
|
|
||||||
$self->{global} = {
|
$self->{cache_name} = 'cyberoam_' . $options{snmp}->get_hostname() . '_' . $options{snmp}->get_port() . '_' . $self->{mode} . '_' .
|
||||||
live_users => $result->{$oid_liveUsers},
|
(defined($self->{option_results}->{filter_counters}) ? md5_hex($self->{option_results}->{filter_counters}) : md5_hex('all'));
|
||||||
http_hits => $result->{$oid_httpHits},
|
|
||||||
ftp_hits => $result->{$oid_ftpHits},
|
|
||||||
pop3_hits => $result->{$oid_pop3Hits},
|
|
||||||
imap_hits => $result->{$oid_imapHits},
|
|
||||||
smtp_hits => $result->{$oid_smtpHits}
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
@ -151,14 +166,9 @@ Check request statistics.
|
||||||
Only display some counters (regexp can be used).
|
Only display some counters (regexp can be used).
|
||||||
Example: --filter-counters='http-hits'
|
Example: --filter-counters='http-hits'
|
||||||
|
|
||||||
=item B<--warning-*>
|
=item B<--warning-*> B<--critical-*>
|
||||||
|
|
||||||
Threshold warning.
|
Thresholds.
|
||||||
Can be: live-users, http-hits, ftp-hits, pop3-hits, imap-hits, smtp-hits.
|
|
||||||
|
|
||||||
=item B<--critical-*>
|
|
||||||
|
|
||||||
Threshold critical.
|
|
||||||
Can be: live-users, http-hits, ftp-hits, pop3-hits, imap-hits, smtp-hits.
|
Can be: live-users, http-hits, ftp-hits, pop3-hits, imap-hits, smtp-hits.
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
|
@ -38,7 +38,8 @@ sub set_system {
|
||||||
['running', 'OK'],
|
['running', 'OK'],
|
||||||
['exiting', 'CRITICAL'],
|
['exiting', 'CRITICAL'],
|
||||||
['dead', 'CRITICAL'],
|
['dead', 'CRITICAL'],
|
||||||
['unregistered', 'OK']
|
['unregistered', 'OK'],
|
||||||
|
['frozen', 'CRITICAL']
|
||||||
]
|
]
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -50,12 +51,15 @@ sub snmp_execute {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{snmp} = $options{snmp};
|
$self->{snmp} = $options{snmp};
|
||||||
$self->{results} = $self->{snmp}->get_multiple_table(oids => $self->{request});
|
$self->{results} = $self->{snmp}->get_multiple_table(
|
||||||
|
oids => $self->{request},
|
||||||
|
return_type => 1
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
my $self = $class->SUPER::new(package => __PACKAGE__, %options, no_absent => 1, no_performance => 1);
|
my $self = $class->SUPER::new(package => __PACKAGE__, %options, no_absent => 1, no_performance => 1, force_new_perfdata => 1);
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments => {});
|
$options{options}->add_options(arguments => {});
|
||||||
|
|
|
@ -28,18 +28,13 @@ use warnings;
|
||||||
sub custom_usage_perfdata {
|
sub custom_usage_perfdata {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{output}->perfdata_add(label => 'used', unit => 'B',
|
$self->{output}->perfdata_add(
|
||||||
|
label => 'used', unit => 'B',
|
||||||
value => $self->{result_values}->{used},
|
value => $self->{result_values}->{used},
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}, total => $self->{result_values}->{total}, cast_int => 1),
|
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}, total => $self->{result_values}->{total}, cast_int => 1),
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label}, total => $self->{result_values}->{total}, cast_int => 1),
|
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label}, total => $self->{result_values}->{total}, cast_int => 1),
|
||||||
min => 0, max => $self->{result_values}->{total});
|
min => 0, max => $self->{result_values}->{total}
|
||||||
}
|
);
|
||||||
|
|
||||||
sub custom_usage_threshold {
|
|
||||||
my ($self, %options) = @_;
|
|
||||||
|
|
||||||
my $exit = $self->{perfdata}->threshold_check(value => $self->{result_values}->{prct_used}, threshold => [ { label => 'critical-' . $self->{label}, exit_litteral => 'critical' }, { label => 'warning-' . $self->{label}, exit_litteral => 'warning' } ]);
|
|
||||||
return $exit;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_usage_output {
|
sub custom_usage_output {
|
||||||
|
@ -49,11 +44,12 @@ sub custom_usage_output {
|
||||||
my ($total_used_value, $total_used_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{used});
|
my ($total_used_value, $total_used_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{used});
|
||||||
my ($total_free_value, $total_free_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{free});
|
my ($total_free_value, $total_free_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{free});
|
||||||
|
|
||||||
my $msg = sprintf("Storage Usage Total: %s Used: %s (%.2f%%) Free: %s (%.2f%%)",
|
return sprintf(
|
||||||
|
"Storage Usage Total: %s Used: %s (%.2f%%) Free: %s (%.2f%%)",
|
||||||
$total_size_value . " " . $total_size_unit,
|
$total_size_value . " " . $total_size_unit,
|
||||||
$total_used_value . " " . $total_used_unit, $self->{result_values}->{prct_used},
|
$total_used_value . " " . $total_used_unit, $self->{result_values}->{prct_used},
|
||||||
$total_free_value . " " . $total_free_unit, $self->{result_values}->{prct_free});
|
$total_free_value . " " . $total_free_unit, $self->{result_values}->{prct_free}
|
||||||
return $msg;
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_usage_calc {
|
sub custom_usage_calc {
|
||||||
|
@ -80,9 +76,9 @@ sub set_counters {
|
||||||
closure_custom_calc => $self->can('custom_usage_calc'),
|
closure_custom_calc => $self->can('custom_usage_calc'),
|
||||||
closure_custom_output => $self->can('custom_usage_output'),
|
closure_custom_output => $self->can('custom_usage_output'),
|
||||||
closure_custom_perfdata => $self->can('custom_usage_perfdata'),
|
closure_custom_perfdata => $self->can('custom_usage_perfdata'),
|
||||||
closure_custom_threshold_check => $self->can('custom_usage_threshold'),
|
threshold_use => 'prct_used'
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -91,22 +87,46 @@ sub new {
|
||||||
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments => {
|
||||||
{
|
|
||||||
});
|
});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub add_counters {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
return if (!defined($options{result}->{disk_total}));
|
||||||
|
|
||||||
|
$self->{storage} = {
|
||||||
|
used => $options{result}->{disk_used_prct} * $options{result}->{disk_total} * 1024 * 1024 / 100,
|
||||||
|
total => $options{result}->{disk_total} * 1024 * 1024
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $oid_diskCapacity = '.1.3.6.1.4.1.21067.2.1.2.3.1.0'; # in MB
|
my $mapping = {
|
||||||
my $oid_diskPercentUsage = '.1.3.6.1.4.1.21067.2.1.2.3.2.0';
|
v17 => {
|
||||||
my $result = $options{snmp}->get_leef(oids => [$oid_diskCapacity, $oid_diskPercentUsage],
|
disk_total => { oid => '.1.3.6.1.4.1.21067.2.1.2.3.1' }, # diskCapacity - MB
|
||||||
nothing_quit => 1);
|
disk_used_prct => { oid => '.1.3.6.1.4.1.21067.2.1.2.3.2' } # diskPercentUsage
|
||||||
$self->{storage} = { used => $result->{$oid_diskPercentUsage} * $result->{$oid_diskCapacity} * 1024 * 1024 / 100,
|
},
|
||||||
total => $result->{$oid_diskCapacity} * 1024 * 1024 };
|
v18 => {
|
||||||
|
disk_total => { oid => '.1.3.6.1.4.1.2604.5.1.2.4.1' }, # sfosDiskCapacity - MB
|
||||||
|
disk_used_prct => { oid => '.1.3.6.1.4.1.2604.5.1.2.4.2' } # sfosDiskPercentUsage
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
my $snmp_result = $options{snmp}->get_leef(
|
||||||
|
oids => [ map($_->{oid} . '.0', values(%{$mapping->{v17}}), values(%{$mapping->{v18}})) ],
|
||||||
|
nothing_quit => 1
|
||||||
|
);
|
||||||
|
|
||||||
|
my $result = $options{snmp}->map_instance(mapping => $mapping->{v17}, results => $snmp_result, instance => 0);
|
||||||
|
$self->add_counters(result => $result);
|
||||||
|
$result = $options{snmp}->map_instance(mapping => $mapping->{v18}, results => $snmp_result, instance => 0);
|
||||||
|
$self->add_counters(result => $result);
|
||||||
}
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
|
|
@ -30,15 +30,15 @@ sub new {
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$self->{version} = '0.1';
|
$self->{version} = '0.1';
|
||||||
%{$self->{modes}} = (
|
$self->{modes} = {
|
||||||
'cpu' => 'network::cyberoam::snmp::mode::cpu',
|
'cpu' => 'network::cyberoam::snmp::mode::cpu',
|
||||||
'interfaces' => 'snmp_standard::mode::interfaces',
|
'interfaces' => 'snmp_standard::mode::interfaces',
|
||||||
'list-interfaces' => 'snmp_standard::mode::listinterfaces',
|
'list-interfaces' => 'snmp_standard::mode::listinterfaces',
|
||||||
'memory' => 'network::cyberoam::snmp::mode::memory',
|
'memory' => 'network::cyberoam::snmp::mode::memory',
|
||||||
'requests' => 'network::cyberoam::snmp::mode::requests',
|
'requests' => 'network::cyberoam::snmp::mode::requests',
|
||||||
'services' => 'network::cyberoam::snmp::mode::services',
|
'services' => 'network::cyberoam::snmp::mode::services',
|
||||||
'storage' => 'network::cyberoam::snmp::mode::storage',
|
'storage' => 'network::cyberoam::snmp::mode::storage'
|
||||||
);
|
};
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue