Merge pull request #2388 from UrBnW/idracstatus

enh(idrac) Add systemModelName to status output
This commit is contained in:
qgarnier 2020-12-01 10:46:41 +01:00 committed by GitHub
commit 50d7141f21
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 18 additions and 15 deletions

View File

@ -87,12 +87,12 @@ sub new {
bless $self, $class; bless $self, $class;
$options{options}->add_options(arguments => { $options{options}->add_options(arguments => {
"unknown-status:s" => { name => 'unknown_status', default => '%{status} =~ /^unknown/i' }, "unknown-status:s" => { name => 'unknown_status', default => '%{status} =~ /unknown/' },
"warning-status:s" => { name => 'warning_status', default => '%{status} =~ /nonRecoverable|non critical|other/i' }, "warning-status:s" => { name => 'warning_status', default => '%{status} =~ /nonCritical|other/' },
"critical-status:s" => { name => 'critical_status', default => '%{status} =~ /^critical/i' }, "critical-status:s" => { name => 'critical_status', default => '%{status} =~ /critical|nonRecoverable/' },
"unknown-storage-status:s" => { name => 'unknown_storage_status', default => '%{status} =~ /^unknown/i' }, "unknown-storage-status:s" => { name => 'unknown_storage_status', default => '%{status} =~ /unknown/' },
"warning-storage-status:s" => { name => 'warning_storage_status', default => '%{status} =~ /nonRecoverable|non critical|other/i' }, "warning-storage-status:s" => { name => 'warning_storage_status', default => '%{status} =~ /nonCritical|other/' },
"critical-storage-status:s" => { name => 'critical_storage_status', default => '%{status} =~ /^critical/i' }, "critical-storage-status:s" => { name => 'critical_storage_status', default => '%{status} =~ /critical|nonRecoverable/' },
}); });
return $self; return $self;
@ -102,7 +102,7 @@ sub new {
sub prefix_global_output { sub prefix_global_output {
my ($self, %options) = @_; my ($self, %options) = @_;
return "Card '" . $self->{global}->{display} . "' : "; return "'" . $self->{global}->{display} . "' : ";
} }
sub check_options { sub check_options {
@ -119,7 +119,7 @@ my %states = (
1 => 'other', 1 => 'other',
2 => 'unknown', 2 => 'unknown',
3 => 'ok', 3 => 'ok',
4 => 'non critical', 4 => 'nonCritical',
5 => 'critical', 5 => 'critical',
6 => 'nonRecoverable', 6 => 'nonRecoverable',
); );
@ -129,11 +129,12 @@ sub manage_selection {
my $oid_racShortName = '.1.3.6.1.4.1.674.10892.5.1.1.2.0'; my $oid_racShortName = '.1.3.6.1.4.1.674.10892.5.1.1.2.0';
my $oid_racVersion = '.1.3.6.1.4.1.674.10892.5.1.1.5.0'; my $oid_racVersion = '.1.3.6.1.4.1.674.10892.5.1.1.5.0';
my $oid_systemModelName = '.1.3.6.1.4.1.674.10892.5.1.3.12.0';
my $oid_drsGlobalSystemStatus = '.1.3.6.1.4.1.674.10892.2.2.1.0'; my $oid_drsGlobalSystemStatus = '.1.3.6.1.4.1.674.10892.2.2.1.0';
my $oid_globalSystemStatus = '.1.3.6.1.4.1.674.10892.5.2.1.0'; my $oid_globalSystemStatus = '.1.3.6.1.4.1.674.10892.5.2.1.0';
my $oid_globalStorageStatus = '.1.3.6.1.4.1.674.10892.5.2.3.0'; my $oid_globalStorageStatus = '.1.3.6.1.4.1.674.10892.5.2.3.0';
my $result = $options{snmp}->get_leef(oids => [ my $result = $options{snmp}->get_leef(oids => [
$oid_racShortName, $oid_racVersion, $oid_drsGlobalSystemStatus, $oid_globalSystemStatus, $oid_globalStorageStatus $oid_racShortName, $oid_racVersion, $oid_systemModelName, $oid_drsGlobalSystemStatus, $oid_globalSystemStatus, $oid_globalStorageStatus
], nothing_quit => 1); ], nothing_quit => 1);
my ($global_status, $storage_status); my ($global_status, $storage_status);
@ -149,6 +150,8 @@ sub manage_selection {
if (defined($result->{$oid_racShortName})); if (defined($result->{$oid_racShortName}));
$display .= '.' . $result->{$oid_racVersion} $display .= '.' . $result->{$oid_racVersion}
if (defined($result->{$oid_racVersion})); if (defined($result->{$oid_racVersion}));
$display .= '@' . $result->{$oid_systemModelName}
if (defined($result->{$oid_systemModelName}));
$self->{global} = { $self->{global} = {
display => $display, display => $display,
status => $global_status, status => $global_status,
@ -168,32 +171,32 @@ Check the overall status of iDrac card.
=item B<--unknown-status> =item B<--unknown-status>
Set warning threshold for status (Default: '%{status} =~ /^unknown/i'). Set warning threshold for status (Default: '%{status} =~ /unknown/').
Can used special variables like: %{status} Can used special variables like: %{status}
=item B<--warning-status> =item B<--warning-status>
Set warning threshold for status (Default: '%{status} =~ /nonRecoverable|non critical|other/i'). Set warning threshold for status (Default: '%{status} =~ /nonCritical|other/').
Can used special variables like: %{status} Can used special variables like: %{status}
=item B<--critical-status> =item B<--critical-status>
Set critical threshold for status (Default: '%{status} =~ /^critical/i'). Set critical threshold for status (Default: '%{status} =~ /critical|nonRecoverable/').
Can used special variables like: %{status} Can used special variables like: %{status}
=item B<--unknown-storage-status> =item B<--unknown-storage-status>
Set warning threshold for status (Default: '%{status} =~ /^unknown/i'). Set warning threshold for status (Default: '%{status} =~ /unknown/').
Can used special variables like: %{status} Can used special variables like: %{status}
=item B<--warning-storage-status> =item B<--warning-storage-status>
Set warning threshold for status (Default: '%{status} =~ /nonRecoverable|non critical|other/i'). Set warning threshold for status (Default: '%{status} =~ /nonCritical|other/').
Can used special variables like: %{status} Can used special variables like: %{status}
=item B<--critical-storage-status> =item B<--critical-storage-status>
Set critical threshold for status (Default: '%{status} =~ /^critical/i'). Set critical threshold for status (Default: '%{status} =~ /critical|nonRecoverable/').
Can used special variables like: %{status} Can used special variables like: %{status}
=back =back