mirror of
https://github.com/centreon/centreon-plugins.git
synced 2025-07-27 23:54:18 +02:00
enh(ericsson/enm): add some disco options (#3293)
This commit is contained in:
parent
8727964293
commit
6c2e00c3e9
98
centreon-plugins/apps/ericsson/enm/api/mode/listnodes.pm
Normal file
98
centreon-plugins/apps/ericsson/enm/api/mode/listnodes.pm
Normal file
@ -0,0 +1,98 @@
|
|||||||
|
#
|
||||||
|
# Copyright 2021 Centreon (http://www.centreon.com/)
|
||||||
|
#
|
||||||
|
# Centreon is a full-fledged industry-strength solution that meets
|
||||||
|
# the needs in IT infrastructure and application monitoring for
|
||||||
|
# service performance.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
#
|
||||||
|
|
||||||
|
package apps::ericsson::enm::api::mode::listnodes;
|
||||||
|
|
||||||
|
use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
|
||||||
|
sub new {
|
||||||
|
my ($class, %options) = @_;
|
||||||
|
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
||||||
|
bless $self, $class;
|
||||||
|
|
||||||
|
$options{options}->add_options(arguments => {});
|
||||||
|
|
||||||
|
return $self;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub check_options {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
$self->SUPER::init(%options);
|
||||||
|
}
|
||||||
|
|
||||||
|
sub manage_selection {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
my $nodes = $options{custom}->call_nodeSyncState();
|
||||||
|
my $results = [];
|
||||||
|
foreach my $node (@$nodes) {
|
||||||
|
push @$results, { node_id => $node->{NodeId} };
|
||||||
|
}
|
||||||
|
|
||||||
|
return $results;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub run {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
my $results = $self->manage_selection(%options);
|
||||||
|
foreach (@$results) {
|
||||||
|
$self->{output}->output_add(long_msg => sprintf('[node_id: %s]', $_->{node_id}));
|
||||||
|
}
|
||||||
|
$self->{output}->output_add(
|
||||||
|
severity => 'OK',
|
||||||
|
short_msg => 'List nodes:'
|
||||||
|
);
|
||||||
|
|
||||||
|
$self->{output}->display(nolabel => 1, force_ignore_perfdata => 1, force_long_output => 1);
|
||||||
|
$self->{output}->exit();
|
||||||
|
}
|
||||||
|
|
||||||
|
sub disco_format {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
$self->{output}->add_disco_format(elements => ['node_id']);
|
||||||
|
}
|
||||||
|
|
||||||
|
sub disco_show {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
my $results = $self->manage_selection(%options);
|
||||||
|
foreach (@$results) {
|
||||||
|
$self->{output}->add_disco_entry(%$_);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
1;
|
||||||
|
|
||||||
|
__END__
|
||||||
|
|
||||||
|
=head1 MODE
|
||||||
|
|
||||||
|
List nodes.
|
||||||
|
|
||||||
|
=over 8
|
||||||
|
|
||||||
|
=back
|
||||||
|
|
||||||
|
=cut
|
@ -31,7 +31,8 @@ sub new {
|
|||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments => {
|
$options{options}->add_options(arguments => {
|
||||||
'add-extra-attrs' => { name => 'add_extra_attrs' }
|
'add-extra-attrs' => { name => 'add_extra_attrs' },
|
||||||
|
'filter-node-id:s' => { name => 'filter_node_id' }
|
||||||
});
|
});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
@ -48,6 +49,9 @@ sub manage_selection {
|
|||||||
my $cells = $options{custom}->call_EUtranCellTDD();
|
my $cells = $options{custom}->call_EUtranCellTDD();
|
||||||
my $results = [];
|
my $results = [];
|
||||||
foreach my $cell (@$cells) {
|
foreach my $cell (@$cells) {
|
||||||
|
next if (defined($self->{option_results}->{filter_node_id}) && $self->{option_results}->{filter_node_id} ne '' &&
|
||||||
|
$cell->{NodeId} !~ /$self->{option_results}->{filter_node_id}/);
|
||||||
|
|
||||||
my $attr = { node_id => $cell->{NodeId}, cell_tdd_id => $cell->{EUtranCellTDDId} };
|
my $attr = { node_id => $cell->{NodeId}, cell_tdd_id => $cell->{EUtranCellTDDId} };
|
||||||
if (defined($self->{option_results}->{add_extra_attrs})) {
|
if (defined($self->{option_results}->{add_extra_attrs})) {
|
||||||
$attr->{label} = defined($cell->{userLabel}) && $cell->{userLabel} ne 'null' ? $cell->{userLabel} : '';
|
$attr->{label} = defined($cell->{userLabel}) && $cell->{userLabel} ne 'null' ? $cell->{userLabel} : '';
|
||||||
@ -117,6 +121,10 @@ List nodes cells tdd.
|
|||||||
|
|
||||||
=over 8
|
=over 8
|
||||||
|
|
||||||
|
=item B<--filter-node-id>
|
||||||
|
|
||||||
|
Filter tdd cells by node id (can be a regexp).
|
||||||
|
|
||||||
=item B<--add-extra-attrs>
|
=item B<--add-extra-attrs>
|
||||||
|
|
||||||
Display label/administrative_state/availability_status/operational_state.
|
Display label/administrative_state/availability_status/operational_state.
|
||||||
|
@ -31,7 +31,8 @@ sub new {
|
|||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments => {
|
$options{options}->add_options(arguments => {
|
||||||
'add-extra-attrs' => { name => 'add_extra_attrs' }
|
'add-extra-attrs' => { name => 'add_extra_attrs' },
|
||||||
|
'filter-node-id:s' => { name => 'filter_node_id' }
|
||||||
});
|
});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
@ -48,6 +49,9 @@ sub manage_selection {
|
|||||||
my $frus = $options{custom}->call_fruState();
|
my $frus = $options{custom}->call_fruState();
|
||||||
my $results = [];
|
my $results = [];
|
||||||
foreach my $fru (@$frus) {
|
foreach my $fru (@$frus) {
|
||||||
|
next if (defined($self->{option_results}->{filter_node_id}) && $self->{option_results}->{filter_node_id} ne '' &&
|
||||||
|
$fru->{NodeId} !~ /$self->{option_results}->{filter_node_id}/);
|
||||||
|
|
||||||
my $attr = { node_id => $fru->{NodeId}, fru_id => $fru->{FieldReplaceableUnitId} };
|
my $attr = { node_id => $fru->{NodeId}, fru_id => $fru->{FieldReplaceableUnitId} };
|
||||||
if (defined($self->{option_results}->{add_extra_attrs})) {
|
if (defined($self->{option_results}->{add_extra_attrs})) {
|
||||||
$attr->{label} = defined($fru->{userLabel}) && $fru->{userLabel} ne 'null' ? $fru->{userLabel} : '';
|
$attr->{label} = defined($fru->{userLabel}) && $fru->{userLabel} ne 'null' ? $fru->{userLabel} : '';
|
||||||
@ -117,6 +121,10 @@ List nodes field replaceable units.
|
|||||||
|
|
||||||
=over 8
|
=over 8
|
||||||
|
|
||||||
|
=item B<--filter-node-id>
|
||||||
|
|
||||||
|
Filter field replaceable units by node id (can be a regexp).
|
||||||
|
|
||||||
=item B<--add-extra-attrs>
|
=item B<--add-extra-attrs>
|
||||||
|
|
||||||
Display label/administrative_state/availability_status/operational_state.
|
Display label/administrative_state/availability_status/operational_state.
|
||||||
|
@ -252,11 +252,11 @@ Filter nodes by id (can be a regexp).
|
|||||||
|
|
||||||
=item B<--filter-fru-id>
|
=item B<--filter-fru-id>
|
||||||
|
|
||||||
Filter tdd cells by id (can be a regexp).
|
Filter field replaceable units by id (can be a regexp).
|
||||||
|
|
||||||
=item B<--filter-cell-tdd-id>
|
=item B<--filter-cell-tdd-id>
|
||||||
|
|
||||||
Filter field replaceable units by id (can be a regexp).
|
Filter tdd cells by id (can be a regexp).
|
||||||
|
|
||||||
=item B<--unknown-node-sync-status>
|
=item B<--unknown-node-sync-status>
|
||||||
|
|
||||||
|
@ -33,6 +33,7 @@ sub new {
|
|||||||
$self->{modes} = {
|
$self->{modes} = {
|
||||||
'cache' => 'apps::ericsson::enm::api::mode::cache',
|
'cache' => 'apps::ericsson::enm::api::mode::cache',
|
||||||
'discovery' => 'apps::ericsson::enm::api::mode::discovery',
|
'discovery' => 'apps::ericsson::enm::api::mode::discovery',
|
||||||
|
'list-nodes' => 'apps::ericsson::enm::api::mode::listnodes',
|
||||||
'list-nodes-celltdd' => 'apps::ericsson::enm::api::mode::listnodescelltdd',
|
'list-nodes-celltdd' => 'apps::ericsson::enm::api::mode::listnodescelltdd',
|
||||||
'list-nodes-fru' => 'apps::ericsson::enm::api::mode::listnodesfru',
|
'list-nodes-fru' => 'apps::ericsson::enm::api::mode::listnodesfru',
|
||||||
'nodes' => 'apps::ericsson::enm::api::mode::nodes'
|
'nodes' => 'apps::ericsson::enm::api::mode::nodes'
|
||||||
|
Loading…
x
Reference in New Issue
Block a user