This commit is contained in:
Quentin Garnier 2014-08-28 16:55:44 +02:00
commit 2a01333056
6 changed files with 474 additions and 34 deletions

View File

@ -79,7 +79,7 @@ sub new {
$self->{version} = '1.0';
$options{options}->add_options(arguments =>
{
"exclude" => { name => 'exclude' },
"exclude:s" => { name => 'exclude' },
});
return $self;
@ -296,4 +296,4 @@ Exclude some parts (comma seperated list) (Example: --exclude=temperatures,psu).
=back
=cut

View File

@ -70,44 +70,31 @@ sub check_options {
}
}
sub run {
sub check_table_memory {
my ($self, %options) = @_;
# $options{snmp} = snmp object
$self->{snmp} = $options{snmp};
my $oid_ciscoMemoryPoolEntry = '.1.3.6.1.4.1.9.9.48.1.1.1';
my $oid_ciscoMemoryPoolName = '.1.3.6.1.4.1.9.9.48.1.1.1.2';
my $oid_ciscoMemoryPoolUsed = '.1.3.6.1.4.1.9.9.48.1.1.1.5'; # in B
my $oid_ciscoMemoryPoolFree = '.1.3.6.1.4.1.9.9.48.1.1.1.6'; # in B
my $result = $self->{snmp}->get_table(oid => $oid_ciscoMemoryPoolEntry, nothing_quit => 1);
$self->{output}->output_add(severity => 'OK',
short_msg => 'All pool memories are ok.');
foreach my $oid (keys %$result) {
next if ($oid !~ /^$oid_ciscoMemoryPoolName/);
my $checked = 0;
foreach my $oid (keys %{$self->{results}->{$options{entry}}}) {
next if ($oid !~ /^$options{poolName}/);
$oid =~ /\.([0-9]+)$/;
if (defined($self->{option_results}->{filter_pool}) && $self->{option_results}->{filter_pool} ne '' &&
$result->{$oid} !~ /$self->{option_results}->{filter_pool}/) {
$self->{output}->output_add(long_msg => "Skipping pool '" . $result->{$oid} . "'.");
next;
}
my $instance = $1;
my $memory_name = $result->{$oid};
my $memory_used = $result->{$oid_ciscoMemoryPoolUsed . '.' . $instance};
my $memory_free =$result->{$oid_ciscoMemoryPoolFree . '.' . $instance};
my $memory_name = $self->{results}->{$options{entry}}->{$oid};
my $memory_used = $self->{results}->{$options{entry}}->{$options{poolUsed} . '.' . $instance};
my $memory_free = $self->{results}->{$options{entry}}->{$options{poolFree} . '.' . $instance};
next if ($memory_name eq '');
$checked = 1;
my $total_size = $memory_used + $memory_free;
my $prct_used = $memory_used * 100 / $total_size;
my $prct_free = 100 - $prct_used;
my $exit = $self->{perfdata}->threshold_check(value => $prct_used, threshold => [ { label => 'critical', 'exit_litteral' => 'critical' }, { label => 'warning', exit_litteral => 'warning' } ]);
my ($total_value, $total_unit) = $self->{perfdata}->change_bytes(value => $total_size);
my ($used_value, $used_unit) = $self->{perfdata}->change_bytes(value => $memory_used);
my ($free_value, $free_unit) = $self->{perfdata}->change_bytes(value => $memory_free);
$self->{output}->output_add(long_msg => sprintf("Memory '%s' Total: %s Used: %s (%.2f%%) Free: %s (%.2f%%)", $memory_name,
$total_value . " " . $total_unit,
$used_value . " " . $used_unit, $prct_used,
@ -119,7 +106,7 @@ sub run {
$used_value . " " . $used_unit, $prct_used,
$free_value . " " . $free_unit, $prct_free));
}
$self->{output}->perfdata_add(label => "used_" . $memory_name,
value => $memory_used,
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning', total => $total_size),
@ -127,8 +114,76 @@ sub run {
min => 0, max => $total_size);
}
return $checked;
}
sub check_percent_memory {
my ($self, %options) = @_;
my $checked = 0;
foreach my $oid (keys %{$self->{results}->{$options{entry}}}) {
next if ($oid !~ /^$options{memUsage}/);
$oid =~ /\.([0-9]+)$/;
my $instance = $1;
my $memory_usage = $self->{results}->{$options{entry}}->{$oid};
next if ($memory_usage eq '');
$checked = 1;
my $exit = $self->{perfdata}->threshold_check(value => $memory_usage,
threshold => [ { label => 'critical', 'exit_litteral' => 'critical' }, { label => 'warning', exit_litteral => 'warning' } ]);
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
$self->{output}->output_add(severity => $exit,
short_msg => sprintf("Memory used : %.2f%%", $memory_usage));
}
$self->{output}->perfdata_add(label => "utilization",
value => $memory_usage,
unit => "%",
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning'),
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical'),
min => 0, max => 100);
}
return $checked;
}
sub run {
my ($self, %options) = @_;
# $options{snmp} = snmp object
$self->{snmp} = $options{snmp};
my $oid_ciscoMemoryPoolEntry = '.1.3.6.1.4.1.9.9.48.1.1.1';
my $oid_ciscoMemoryPoolName = '.1.3.6.1.4.1.9.9.48.1.1.1.2';
my $oid_ciscoMemoryPoolUsed = '.1.3.6.1.4.1.9.9.48.1.1.1.5'; # in B
my $oid_ciscoMemoryPoolFree = '.1.3.6.1.4.1.9.9.48.1.1.1.6'; # in B
# OIDs for Nexus
my $oid_cseSysMemoryEntry = '.1.3.6.1.4.1.9.9.305.1.1';
my $oid_cseSysMemoryUtilization = '.1.3.6.1.4.1.9.9.305.1.1.2';
$self->{results} = $self->{snmp}->get_multiple_table(oids => [
{ oid => $oid_ciscoMemoryPoolEntry,
start => $oid_ciscoMemoryPoolName, end => $oid_ciscoMemoryPoolFree
},
{ oid => $oid_cseSysMemoryEntry,
start => $oid_cseSysMemoryUtilization, end => $oid_cseSysMemoryUtilization }],
nothing_quit => 1);
$self->{output}->output_add(severity => 'OK',
short_msg => 'Memory is ok.');
if (!$self->check_table_memory(entry => $oid_ciscoMemoryPoolEntry, poolName => $oid_ciscoMemoryPoolName, poolUsed => $oid_ciscoMemoryPoolUsed, poolFree => $oid_ciscoMemoryPoolFree)
&& !$self->check_percent_memory(entry => $oid_cseSysMemoryEntry, memUsage => $oid_cseSysMemoryUtilization)
) {
$self->{output}->output_add(severity => 'UNKNOWN',
short_msg => sprintf("Cannot find Memory informations."));
}
$self->{output}->display();
$self->{output}->exit();
}
1;
@ -137,7 +192,7 @@ __END__
=head1 MODE
Check memory usage (CISCO-MEMORY-POOL-MIB).
Check memory usage (CISCO-MEMORY-POOL-MIB and CISCO-SYSTEM-EXT-MIB).
=over 8
@ -156,4 +211,4 @@ Filter pool to check (can use regexp).
=back
=cut

View File

@ -0,0 +1,305 @@
################################################################################
# Copyright 2005-2013 MERETHIS
# Centreon is developped by : Julien Mathis and Romain Le Merlus under
# GPL Licence 2.0.
#
# This program is free software; you can redistribute it and/or modify it under
# the terms of the GNU General Public License as published by the Free Software
# Foundation ; either version 2 of the License.
#
# This program is distributed in the hope that it will be useful, but WITHOUT ANY
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
# PARTICULAR PURPOSE. See the GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License along with
# this program; if not, see <http://www.gnu.org/licenses>.
#
# Linking this program statically or dynamically with other modules is making a
# combined work based on this program. Thus, the terms and conditions of the GNU
# General Public License cover the whole combination.
#
# As a special exception, the copyright holders of this program give MERETHIS
# permission to link this program with independent modules to produce an executable,
# regardless of the license terms of these independent modules, and to copy and
# distribute the resulting executable under terms of MERETHIS choice, provided that
# MERETHIS also meet, for each linked independent module, the terms and conditions
# of the license of that module. An independent module is a module which is not
# derived from this program. If you modify this program, you may extend this
# exception to your version of the program, but you are not obliged to do so. If you
# do not wish to do so, delete this exception statement from your version.
#
# For more information : contact@centreon.com
# Authors : Quentin Garnier <qgarnier@merethis.com>
#
####################################################################################
package network::cisco::nexus::5000::mode::environment;
use base qw(centreon::plugins::mode);
use strict;
use warnings;
my %map_states_fan = (
1 => ['unknown', 'WARNING'],
2 => ['up', 'OK'],
3 => ['down', 'CRITICAL'],
4 => ['warning', 'WARNING']
);
my %map_states_psu = (
1 => ['offEnvOther', 'WARNING'],
2 => ['on', 'OK'],
3 => ['offAdmin', 'WARNING'],
4 => ['offDenied', 'WARNING'],
5 => ['offEnvPower', 'WARNING'],
6 => ['offEnvTemp', 'WARNING'],
7 => ['offEnvFan', 'WARNING'],
8 => ['failed', 'CRITICAL'],
9 => ['onButFanFail', 'WARNING'],
10 => ['offCooling', 'WARNING'],
11 => ['offConnectorRating', 'WARNING'],
12 => ['onButInlinePowerFail', 'WARNING'],
);
my %map_states_mod = (
1 => ['unknown', 'WARNING'],
2 => ['ok', 'OK'],
3 => ['disabled', 'WARNING'],
4 => ['okButDiagFailed', 'WARNING'],
5 => ['boot', 'WARNING'],
6 => ['selfTest', 'WARNING'],
7 => ['failed', 'CRITICAL'],
8 => ['missing', 'CRITICAL'],
9 => ['mismatchWithParent', 'WARNING'],
10 => ['mismatchConfig', 'WARNING'],
11 => ['diagFailed', 'CRITICAL'],
12 => ['dormant', 'WARNING'],
13 => ['outOfServiceAdmin', 'WARNING'],
14 => ['outOfServiceEnvTemp', 'WARNING'],
15 => ['poweredDown', 'CRITICAL'],
16 => ['poweredUp', 'OK'],
17 => ['powerDenied', 'CRITICAL'],
18 => ['powerCycled', 'WARNING'],
19 => ['okButPowerOverWarning', 'WARNING'],
20 => ['okButPowerOverCritical', 'CRITICAL'],
21 => ['syncInProgress', 'WARNING'],
22 => ['upgrading', 'WARNING'],
23 => ['okButAuthFailed', 'WARNING'],
24 => ['mdr', 'WARNING'],
25 => ['fwMismatchFound', 'WARNING'],
26 => ['fwDownloadSuccess', 'OK'],
27 => ['fwDownloadFailure', 'WARNING'],
);
my %map_states_phy = (
1 => ['other', 'WARNING'],
2 => ['supported', 'OK'],
3 => ['unsupported', 'CRITICAL'],
4 => ['incompatible', 'CRITICAL'],
);
sub new {
my ($class, %options) = @_;
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
bless $self, $class;
$self->{version} = '1.0';
$options{options}->add_options(arguments =>
{
"exclude:s" => { name => 'exclude' },
});
return $self;
}
sub check_options {
my ($self, %options) = @_;
$self->SUPER::init(%options);
}
sub run {
my ($self, %options) = @_;
# $options{snmp} = snmp object
$self->{snmp} = $options{snmp};
$self->{components_fans} = 0;
$self->{components_psus} = 0;
$self->{components_mods} = 0;
$self->{components_phys} = 0;
$self->check_fans();
$self->check_psus();
$self->check_mods();
$self->check_phys();
$self->{output}->output_add(severity => 'OK',
short_msg => sprintf("All %d components [%d fans, %d power supplies, %d modules, %d physical entities] are ok.",
($self->{components_fans} + $self->{components_psus} + $self->{components_mods}, $self->{components_phys}),
$self->{components_fans}, $self->{components_psus}, $self->{components_mods}, $self->{components_phys}));
$self->{output}->display();
$self->{output}->exit();
}
sub check_fans {
my ($self) = @_;
$self->{output}->output_add(long_msg => "Checking fans");
return if ($self->check_exclude('fan'));
my $oid_entPhysicalDescr = '.1.3.6.1.2.1.47.1.1.1.1.2';
my $oid_cefcFanTrayOperStatus = '.1.3.6.1.4.1.9.9.117.1.4.1.1.1';
my $results = $self->{snmp}->get_multiple_table(oids => [
{ oid => $oid_entPhysicalDescr
},
{ oid => $oid_cefcFanTrayOperStatus
}],
nothing_quit => 1);
foreach my $oid (keys %{$results->{$oid_cefcFanTrayOperStatus}}) {
return if (scalar(keys %$results) <= 0);
$oid =~ /\.([0-9]+)$/;
my $instance = $1;
my $fan_descr = $results->{$oid_entPhysicalDescr}->{$oid_entPhysicalDescr . '.' . $instance};
my $fan_state = $results->{$oid_cefcFanTrayOperStatus}->{$oid};
$self->{components_fans}++;
$self->{output}->output_add(long_msg => sprintf("Fan '%s' state is %s.",
$fan_descr, ${$map_states_fan{$fan_state}}[0]));
if (${$map_states_fan{$fan_state}}[1] ne 'OK') {
$self->{output}->output_add(severity => ${$map_states_fan{$fan_state}}[1],
short_msg => sprintf("Fan '%s' state is %s.", $fan_descr, ${$map_states_fan{$fan_state}}[0]));
}
}
}
sub check_psus {
my ($self) = @_;
$self->{output}->output_add(long_msg => "Checking power supplies");
return if ($self->check_exclude('psu'));
my $oid_entPhysicalDescr = '.1.3.6.1.2.1.47.1.1.1.1.2';
my $oid_cefcFRUPowerOperStatus = '.1.3.6.1.4.1.9.9.117.1.1.2.1.2';
my $results = $self->{snmp}->get_multiple_table(oids => [
{ oid => $oid_entPhysicalDescr
},
{ oid => $oid_cefcFRUPowerOperStatus
}],
nothing_quit => 1);
foreach my $oid (keys %{$results->{$oid_cefcFRUPowerOperStatus}}) {
return if (scalar(keys %$results) <= 0);
$oid =~ /\.([0-9]+)$/;
my $instance = $1;
my $psu_descr = $results->{$oid_entPhysicalDescr}->{$oid_entPhysicalDescr . '.' . $instance};
my $psu_state = $results->{$oid_cefcFRUPowerOperStatus}->{$oid};
$self->{components_psus}++;
$self->{output}->output_add(long_msg => sprintf("Power Supply '%s' state is %s.",
$psu_descr, ${$map_states_psu{$psu_state}}[0]));
if (${$map_states_psu{$psu_state}}[1] ne 'OK') {
$self->{output}->output_add(severity => ${$map_states_psu{$psu_state}}[1],
short_msg => sprintf("Power Supply '%s' state is %s.", $psu_descr, ${$map_states_psu{$psu_state}}[0]));
}
}
}
sub check_mods {
my ($self) = @_;
$self->{output}->output_add(long_msg => "Checking modules");
return if ($self->check_exclude('mod'));
my $oid_entPhysicalDescr = '.1.3.6.1.2.1.47.1.1.1.1.2';
my $oid_cefcModuleOperStatus = '.1.3.6.1.4.1.9.9.117.1.2.1.1.2';
my $results = $self->{snmp}->get_multiple_table(oids => [
{ oid => $oid_entPhysicalDescr
},
{ oid => $oid_cefcModuleOperStatus
}],
nothing_quit => 1);
foreach my $oid (keys %{$results->{$oid_cefcModuleOperStatus}}) {
return if (scalar(keys %$results) <= 0);
$oid =~ /\.([0-9]+)$/;
my $instance = $1;
my $mod_descr = $results->{$oid_entPhysicalDescr}->{$oid_entPhysicalDescr . '.' . $instance};
my $mod_state = $results->{$oid_cefcModuleOperStatus}->{$oid};
$self->{components_mods}++;
$self->{output}->output_add(long_msg => sprintf("Module '%s' state is %s.",
$mod_descr, ${$map_states_mod{$mod_state}}[0]));
if (${$map_states_mod{$mod_state}}[1] ne 'OK') {
$self->{output}->output_add(severity => ${$map_states_mod{$mod_state}}[1],
short_msg => sprintf("Power Supply '%s' state is %s.", $mod_descr, ${$map_states_mod{$mod_state}}[0]));
}
}
}
sub check_phys {
my ($self) = @_;
$self->{output}->output_add(long_msg => "Checking modules");
return if ($self->check_exclude('phy'));
my $oid_entPhysicalDescr = '.1.3.6.1.2.1.47.1.1.1.1.2';
my $oid_cefcPhysicalStatus = '.1.3.6.1.4.1.9.9.117.1.5.1.1.1';
my $results = $self->{snmp}->get_multiple_table(oids => [
{ oid => $oid_entPhysicalDescr
},
{ oid => $oid_cefcPhysicalStatus
}],
nothing_quit => 1);
foreach my $oid (keys %{$results->{$oid_cefcPhysicalStatus}}) {
return if (scalar(keys %$results) <= 0);
$oid =~ /\.([0-9]+)$/;
my $instance = $1;
my $phy_descr = $results->{$oid_entPhysicalDescr}->{$oid_entPhysicalDescr . '.' . $instance};
my $phy_state = $results->{$oid_cefcPhysicalStatus}->{$oid};
$self->{components_phys}++;
$self->{output}->output_add(long_msg => sprintf("Physical entity '%s' state is %s.",
$phy_descr, ${$map_states_phy{$phy_state}}[0]));
if (${$map_states_phy{$phy_state}}[1] ne 'OK') {
$self->{output}->output_add(severity => ${$map_states_phy{$phy_state}}[1],
short_msg => sprintf("Power Supply '%s' state is %s.", $phy_descr, ${$map_states_phy{$phy_state}}[0]));
}
}
}
sub check_exclude {
my ($self, $section) = @_;
if (defined($self->{option_results}->{exclude}) && $self->{option_results}->{exclude} =~ /(^|\s|,)$section(\s|,|$)/) {
$self->{output}->output_add(long_msg => sprintf("Skipping $section section."));
return 1;
}
return 0;
}
1;
__END__
=head1 MODE
Check Environment monitor (CISCO-ENTITY-SENSOR-MIB) (Fans, Power Supplies, Modules, Physical Entities).
=over 8
=item B<--exclude>
Exclude some parts (comma seperated list) (Example: --exclude=fan,psu,mod,phy).
=back
=cut

View File

@ -0,0 +1,70 @@
################################################################################
# Copyright 2005-2013 MERETHIS
# Centreon is developped by : Julien Mathis and Romain Le Merlus under
# GPL Licence 2.0.
#
# This program is free software; you can redistribute it and/or modify it under
# the terms of the GNU General Public License as published by the Free Software
# Foundation ; either version 2 of the License.
#
# This program is distributed in the hope that it will be useful, but WITHOUT ANY
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
# PARTICULAR PURPOSE. See the GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License along with
# this program; if not, see <http://www.gnu.org/licenses>.
#
# Linking this program statically or dynamically with other modules is making a
# combined work based on this program. Thus, the terms and conditions of the GNU
# General Public License cover the whole combination.
#
# As a special exception, the copyright holders of this program give MERETHIS
# permission to link this program with independent modules to produce an executable,
# regardless of the license terms of these independent modules, and to copy and
# distribute the resulting executable under terms of MERETHIS choice, provided that
# MERETHIS also meet, for each linked independent module, the terms and conditions
# of the license of that module. An independent module is a module which is not
# derived from this program. If you modify this program, you may extend this
# exception to your version of the program, but you are not obliged to do so. If you
# do not wish to do so, delete this exception statement from your version.
#
# For more information : contact@centreon.com
# Authors : Quentin Garnier <qgarnier@merethis.com>
#
####################################################################################
package network::cisco::nexus::5000::plugin;
use strict;
use warnings;
use base qw(centreon::plugins::script_snmp);
sub new {
my ($class, %options) = @_;
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
bless $self, $class;
# $options->{options} = options object
$self->{version} = '1.0';
%{$self->{modes}} = (
'cpu' => 'network::cisco::common::mode::cpu',
'environment' => 'network::cisco::nexus::5000::mode::environment',
'list-interfaces' => 'snmp_standard::mode::listinterfaces',
'memory' => 'network::cisco::common::mode::memory',
'packet-errors' => 'snmp_standard::mode::packeterrors',
'spanning-tree' => 'snmp_standard::mode::spanningtree',
'traffic' => 'snmp_standard::mode::traffic',
);
return $self;
}
1;
__END__
=head1 PLUGIN DESCRIPTION
Check Cisco Nexus 5000 in SNMP.
=cut

View File

@ -52,6 +52,7 @@ sub new {
"hostname:s" => { name => 'hostname' },
"port:s" => { name => 'port', default => '49000' },
"timeout:s" => { name => 'timeout', default => 30 },
"agent:s" => { name => 'agent', default => 'igdupnp' },
"warning-in:s" => { name => 'warning_in', },
"critical-in:s" => { name => 'critical_in', },
"warning-out:s" => { name => 'warning_out', },
@ -100,7 +101,7 @@ sub run {
my $old_timestamp = $self->{statefile_value}->get(name => 'last_timestamp');
### GET DATA START
network::fritzbox::mode::libgetdata::init($self, pfad => '/upnp/control/WANCommonIFC1',
network::fritzbox::mode::libgetdata::init($self, pfad => '/' . $self->{option_results}->{agent} . '/control/WANCommonIFC1',
uri => 'urn:schemas-upnp-org:service:WANCommonInterfaceConfig:1');
network::fritzbox::mode::libgetdata::call($self, soap_method => 'GetAddonInfos');
my $NewTotalBytesSent = network::fritzbox::mode::libgetdata::value($self, path => '//GetAddonInfosResponse/NewTotalBytesSent');
@ -208,6 +209,10 @@ This Mode needs UPNP.
=over 8
=item B<--agent>
Fritzbox has two different UPNP Agents. upnp or igdupnp. (Default: igdupnp)
=item B<--warning-in>
Threshold warning for 'in' traffic.

View File

@ -53,6 +53,7 @@ sub new {
"hostname:s" => { name => 'hostname' },
"port:s" => { name => 'port', default => '49000' },
"timeout:s" => { name => 'timeout', default => 30 },
"agent:s" => { name => 'agent', default => 'igdupnp' },
"warning:s" => { name => 'warning', },
"critical:s" => { name => 'critical', },
"seconds" => { name => 'seconds', },
@ -83,13 +84,13 @@ sub run {
my ($self, %options) = @_;
my $exit_code;
network::fritzbox::mode::libgetdata::init($self, pfad => '/upnp/control/WANCommonIFC1',
network::fritzbox::mode::libgetdata::init($self, pfad => '/' . $self->{option_results}->{agent} . '/control/WANCommonIFC1',
uri => 'urn:schemas-upnp-org:service:WANCommonInterfaceConfig:1');
network::fritzbox::mode::libgetdata::call($self, soap_method => 'GetCommonLinkProperties');
my $WANAccessType = network::fritzbox::mode::libgetdata::value($self, path => '//GetCommonLinkPropertiesResponse/NewWANAccessType');
my $LinkStatus = network::fritzbox::mode::libgetdata::value($self, path => '//GetCommonLinkPropertiesResponse/NewPhysicalLinkStatus');
network::fritzbox::mode::libgetdata::init($self, pfad => '/upnp/control/WANIPConn1',
network::fritzbox::mode::libgetdata::init($self, pfad => '/' . $self->{option_results}->{agent} . '/control/WANIPConn1',
uri => 'urn:schemas-upnp-org:service:WANIPConnection:1');
network::fritzbox::mode::libgetdata::call($self, soap_method => 'GetStatusInfo');
my $uptime = network::fritzbox::mode::libgetdata::value($self, path => '//GetStatusInfoResponse/NewUptime');
@ -128,6 +129,10 @@ This Mode needs UPNP.
=over 8
=item B<--agent>
Fritzbox has two different UPNP Agents. upnp or igdupnp. (Default: igdupnp)
=item B<--warning>
Threshold warning in seconds.