enh(paloalto/ssh): mode system - manage threat date time missing (#3248)
This commit is contained in:
parent
708e4893f1
commit
4261f049f8
|
@ -78,7 +78,7 @@ sub check_options {
|
||||||
sub get_hostname {
|
sub get_hostname {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
return $self->{option_results}->{hostname};
|
return defined($self->{option_results}->{hostname}) ? $self->{option_results}->{hostname} : 'local';
|
||||||
}
|
}
|
||||||
|
|
||||||
##############
|
##############
|
||||||
|
|
|
@ -38,20 +38,82 @@ sub custom_status_output {
|
||||||
sub custom_av_output {
|
sub custom_av_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
my $update = $self->{result_values}->{av_lastupdate_time};
|
||||||
|
if ($update ne 'unknown') {
|
||||||
|
$update = centreon::plugins::misc::change_seconds(value => $self->{result_values}->{av_lastupdate_time})
|
||||||
|
}
|
||||||
return sprintf(
|
return sprintf(
|
||||||
"antivirus version '%s', last update %s",
|
"antivirus version '%s', last update %s",
|
||||||
$self->{result_values}->{av_version},
|
$self->{result_values}->{av_version},
|
||||||
centreon::plugins::misc::change_seconds(value => $self->{result_values}->{av_lastupdate_time})
|
$update
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
sub custom_av_perfdata {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
return if ($self->{result_values}->{av_lastupdate_time} eq 'unknown');
|
||||||
|
$self->{output}->perfdata_add(
|
||||||
|
nlabel => $self->{nlabel},
|
||||||
|
unit => 's',
|
||||||
|
value => $self->{result_values}->{av_lastupdate_time},
|
||||||
|
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{thlabel}),
|
||||||
|
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{thlabel}),
|
||||||
|
min => 0
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
sub custom_av_threshold {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
return 'ok' if ($self->{result_values}->{av_lastupdate_time} eq 'unknown');
|
||||||
|
return $self->{perfdata}->threshold_check(
|
||||||
|
value => $self->{result_values}->{av_lastupdate_time},
|
||||||
|
threshold => [
|
||||||
|
{ label => 'critical-' . $self->{thlabel}, exit_litteral => 'critical' },
|
||||||
|
{ label => 'warning-' . $self->{thlabel}, exit_litteral => 'warning' }
|
||||||
|
]
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_threat_output {
|
sub custom_threat_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
my $update = $self->{result_values}->{threat_lastupdate_time};
|
||||||
|
if ($update ne 'unknown') {
|
||||||
|
$update = centreon::plugins::misc::change_seconds(value => $self->{result_values}->{threat_lastupdate_time})
|
||||||
|
}
|
||||||
return sprintf(
|
return sprintf(
|
||||||
"threat version '%s', last update %s",
|
"threat version '%s', last update %s",
|
||||||
$self->{result_values}->{threat_version},
|
$self->{result_values}->{threat_version},
|
||||||
centreon::plugins::misc::change_seconds(value => $self->{result_values}->{threat_lastupdate_time})
|
$update
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
sub custom_threat_perfdata {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
return if ($self->{result_values}->{threat_lastupdate_time} eq 'unknown');
|
||||||
|
$self->{output}->perfdata_add(
|
||||||
|
nlabel => $self->{nlabel},
|
||||||
|
unit => 's',
|
||||||
|
value => $self->{result_values}->{threat_lastupdate_time},
|
||||||
|
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{thlabel}),
|
||||||
|
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{thlabel}),
|
||||||
|
min => 0
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
sub custom_threat_threshold {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
return 'ok' if ($self->{result_values}->{threat_lastupdate_time} eq 'unknown');
|
||||||
|
return $self->{perfdata}->threshold_check(
|
||||||
|
value => $self->{result_values}->{threat_lastupdate_time},
|
||||||
|
threshold => [
|
||||||
|
{ label => 'critical-' . $self->{thlabel}, exit_litteral => 'critical' },
|
||||||
|
{ label => 'warning-' . $self->{thlabel}, exit_litteral => 'warning' }
|
||||||
|
]
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -73,17 +135,15 @@ sub set_counters {
|
||||||
{ label => 'av-update', nlabel => 'system.antivirus.lastupdate.time.seconds', set => {
|
{ label => 'av-update', nlabel => 'system.antivirus.lastupdate.time.seconds', set => {
|
||||||
key_values => [ { name => 'av_lastupdate_time' }, { name => 'av_version' } ],
|
key_values => [ { name => 'av_lastupdate_time' }, { name => 'av_version' } ],
|
||||||
closure_custom_output => $self->can('custom_av_output'),
|
closure_custom_output => $self->can('custom_av_output'),
|
||||||
perfdatas => [
|
closure_custom_perfdata => $self->can('custom_av_perfdata'),
|
||||||
{ template => '%d', min => 0, unit => 's' }
|
closure_custom_threshold_check => $self->can('custom_av_threshold')
|
||||||
]
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{ label => 'threat-update', nlabel => 'system.threat.lastupdate.time.seconds', set => {
|
{ label => 'threat-update', nlabel => 'system.threat.lastupdate.time.seconds', set => {
|
||||||
key_values => [ { name => 'threat_lastupdate_time' }, { name => 'threat_version' } ],
|
key_values => [ { name => 'threat_lastupdate_time' }, { name => 'threat_version' } ],
|
||||||
closure_custom_output => $self->can('custom_threat_output'),
|
closure_custom_output => $self->can('custom_threat_output'),
|
||||||
perfdatas => [
|
closure_custom_perfdata => $self->can('custom_threat_perfdata'),
|
||||||
{ template => '%d', min => 0, unit => 's' }
|
closure_custom_threshold_check => $self->can('custom_threat_threshold')
|
||||||
]
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{ label => 'sessions-traffic', nlabel => 'system.sessions.traffic.count', set => {
|
{ label => 'sessions-traffic', nlabel => 'system.sessions.traffic.count', set => {
|
||||||
|
@ -129,7 +189,7 @@ sub get_diff_time {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
# '2019/10/15 12:03:58 BST'
|
# '2019/10/15 12:03:58 BST'
|
||||||
return if ($options{time} !~ /^\s*(\d{4})\/(\d{2})\/(\d{2})\s+(\d+):(\d+):(\d+)\s+(\S+)/);
|
return 'unknown' if ($options{time} !~ /^\s*(\d{4})\/(\d{2})\/(\d{2})\s+(\d+):(\d+):(\d+)\s+(\S+)/);
|
||||||
|
|
||||||
my $tz = centreon::plugins::misc::set_timezone(name => $self->{option_results}->{timezone});
|
my $tz = centreon::plugins::misc::set_timezone(name => $self->{option_results}->{timezone});
|
||||||
my $dt = DateTime->new(
|
my $dt = DateTime->new(
|
||||||
|
@ -150,11 +210,11 @@ sub manage_selection {
|
||||||
my $result = $options{custom}->execute_command(command => 'show system info');
|
my $result = $options{custom}->execute_command(command => 'show system info');
|
||||||
|
|
||||||
$self->{system} = {
|
$self->{system} = {
|
||||||
av_lastupdate_time => $self->get_diff_time(time => $result->{system}->{'av-release-date'}),
|
av_lastupdate_time => defined($result->{system}->{'av-release-date'}) ? $self->get_diff_time(time => $result->{system}->{'av-release-date'}) : 'unknown',
|
||||||
threat_lastupdate_time => $self->get_diff_time(time => $result->{system}->{'threat-release-date'}),
|
threat_lastupdate_time => defined($result->{system}->{'threat-release-date'}) ? $self->get_diff_time(time => $result->{system}->{'threat-release-date'}) : 'unknown',
|
||||||
av_version => $result->{system}->{'av-version'},
|
av_version => $result->{system}->{'av-version'},
|
||||||
threat_version => $result->{system}->{'threat-version'},
|
threat_version => $result->{system}->{'threat-version'},
|
||||||
oper_mode => $result->{system}->{'operational-mode'},
|
oper_mode => $result->{system}->{'operational-mode'}
|
||||||
};
|
};
|
||||||
|
|
||||||
#Device is up : 40 days 5 hours 53 mins 12 sec
|
#Device is up : 40 days 5 hours 53 mins 12 sec
|
||||||
|
@ -172,7 +232,7 @@ sub manage_selection {
|
||||||
$self->{system}->{active_sessions} = $1;
|
$self->{system}->{active_sessions} = $1;
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{cache_name} = "paloalto_" . $self->{mode} . '_' . $options{custom}->get_hostname() . '_' .
|
$self->{cache_name} = 'paloalto_' . $self->{mode} . '_' . $options{custom}->get_hostname() . '_' .
|
||||||
(defined($self->{option_results}->{filter_counters}) ? md5_hex($self->{option_results}->{filter_counters}) : md5_hex('all'));
|
(defined($self->{option_results}->{filter_counters}) ? md5_hex($self->{option_results}->{filter_counters}) : md5_hex('all'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue