update indent + fix bug with no result
This commit is contained in:
parent
4e780f1e63
commit
6f2ac05fe3
|
@ -39,18 +39,18 @@ sub new {
|
||||||
$options{output}->add_option_msg(short_msg => "Class Custom: Need to specify 'options' argument.");
|
$options{output}->add_option_msg(short_msg => "Class Custom: Need to specify 'options' argument.");
|
||||||
$options{output}->option_exit();
|
$options{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!defined($options{noptions})) {
|
if (!defined($options{noptions})) {
|
||||||
$options{options}->add_options(arguments => {
|
$options{options}->add_options(arguments => {
|
||||||
"hostname:s" => { name => 'hostname' },
|
'hostname:s' => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port' },
|
'port:s' => { name => 'port' },
|
||||||
"proto:s" => { name => 'proto' },
|
'proto:s' => { name => 'proto' },
|
||||||
"username:s" => { name => 'username' },
|
'username:s' => { name => 'username' },
|
||||||
"password:s" => { name => 'password' },
|
'password:s' => { name => 'password' },
|
||||||
"operator-user" => { name => 'operator_user' },
|
'operator-user' => { name => 'operator_user' },
|
||||||
"api-path:s" => { name => 'api_path' },
|
'api-path:s' => { name => 'api_path' },
|
||||||
"timeframe:s" => { name => 'timeframe' },
|
'timeframe:s' => { name => 'timeframe' },
|
||||||
"timeout:s" => { name => 'timeout' },
|
'timeout:s' => { name => 'timeout' },
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
$options{options}->add_help(package => __PACKAGE__, sections => 'REST API OPTIONS', once => 1);
|
$options{options}->add_help(package => __PACKAGE__, sections => 'REST API OPTIONS', once => 1);
|
||||||
|
@ -58,7 +58,7 @@ sub new {
|
||||||
$self->{output} = $options{output};
|
$self->{output} = $options{output};
|
||||||
$self->{mode} = $options{mode};
|
$self->{mode} = $options{mode};
|
||||||
$self->{http} = centreon::plugins::http->new(%options);
|
$self->{http} = centreon::plugins::http->new(%options);
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -94,7 +94,7 @@ sub check_options {
|
||||||
$self->{password} = (defined($self->{option_results}->{password})) ? $self->{option_results}->{password} : undef;
|
$self->{password} = (defined($self->{option_results}->{password})) ? $self->{option_results}->{password} : undef;
|
||||||
$self->{api_path} = (defined($self->{option_results}->{api_path})) ? $self->{option_results}->{api_path} : '/portal/rest';
|
$self->{api_path} = (defined($self->{option_results}->{api_path})) ? $self->{option_results}->{api_path} : '/portal/rest';
|
||||||
$self->{timeout} = (defined($self->{option_results}->{timeout})) ? $self->{option_results}->{timeout} : 10;
|
$self->{timeout} = (defined($self->{option_results}->{timeout})) ? $self->{option_results}->{timeout} : 10;
|
||||||
|
|
||||||
if (!defined($self->{hostname}) || $self->{hostname} eq '') {
|
if (!defined($self->{hostname}) || $self->{hostname} eq '') {
|
||||||
$self->{output}->add_option_msg(short_msg => "Need to specify --hostname option.");
|
$self->{output}->add_option_msg(short_msg => "Need to specify --hostname option.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
|
@ -143,14 +143,14 @@ sub settings {
|
||||||
|
|
||||||
sub get_session_cookie {
|
sub get_session_cookie {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $form_post = { username => $self->{username}, password => $self->{password} };
|
my $form_post = { username => $self->{username}, password => $self->{password} };
|
||||||
my $encoded;
|
my $encoded;
|
||||||
eval {
|
eval {
|
||||||
$encoded = JSON::XS->new->utf8->encode($form_post);
|
$encoded = JSON::XS->new->utf8->encode($form_post);
|
||||||
};
|
};
|
||||||
if ($@) {
|
if ($@) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Cannot encode json request");
|
$self->{output}->add_option_msg(short_msg => 'Cannot encode json request');
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -166,7 +166,7 @@ sub get_session_cookie {
|
||||||
|
|
||||||
my $message = '';
|
my $message = '';
|
||||||
my $session = '';
|
my $session = '';
|
||||||
|
|
||||||
foreach my $cookie (@cookies) {
|
foreach my $cookie (@cookies) {
|
||||||
$message = $1 if ($cookie =~ /^velocloud\.message=(.+?);/);
|
$message = $1 if ($cookie =~ /^velocloud\.message=(.+?);/);
|
||||||
$session = $1 if ($cookie =~ /^velocloud\.session=(.+?);/);
|
$session = $1 if ($cookie =~ /^velocloud\.session=(.+?);/);
|
||||||
|
@ -176,7 +176,7 @@ sub get_session_cookie {
|
||||||
$self->{output}->add_option_msg(short_msg => "Cannot get session cookie: " . $message);
|
$self->{output}->add_option_msg(short_msg => "Cannot get session cookie: " . $message);
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{session_cookie} = $session;
|
$self->{session_cookie} = $session;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -188,7 +188,7 @@ sub get_entreprise_id {
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->settings();
|
$self->settings();
|
||||||
|
|
||||||
my $content = $self->{http}->request(
|
my $content = $self->{http}->request(
|
||||||
method => 'POST',
|
method => 'POST',
|
||||||
url_path => $self->{api_path} . '/enterprise/getEnterprise'
|
url_path => $self->{api_path} . '/enterprise/getEnterprise'
|
||||||
|
@ -202,7 +202,7 @@ sub get_entreprise_id {
|
||||||
$self->{output}->add_option_msg(short_msg => "Cannot decode json response");
|
$self->{output}->add_option_msg(short_msg => "Cannot decode json response");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{entreprise_id} = $decoded->{id};
|
$self->{entreprise_id} = $decoded->{id};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -214,7 +214,7 @@ sub request_api {
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->settings();
|
$self->settings();
|
||||||
|
|
||||||
my $encoded_form_post;
|
my $encoded_form_post;
|
||||||
eval {
|
eval {
|
||||||
$encoded_form_post = JSON::XS->new->utf8->encode($options{query_form_post});
|
$encoded_form_post = JSON::XS->new->utf8->encode($options{query_form_post});
|
||||||
|
@ -257,13 +257,13 @@ sub list_edges {
|
||||||
if (!defined($self->{entreprise_id})) {
|
if (!defined($self->{entreprise_id})) {
|
||||||
$self->get_entreprise_id();
|
$self->get_entreprise_id();
|
||||||
}
|
}
|
||||||
|
|
||||||
my $response = $self->request_api(
|
my $response = $self->request_api(
|
||||||
method => 'POST',
|
method => 'POST',
|
||||||
path => '/enterprise/getEnterpriseEdges',
|
path => '/enterprise/getEnterpriseEdges',
|
||||||
query_form_post => { enterpriseId => $self->{entreprise_id} }
|
query_form_post => { enterpriseId => $self->{entreprise_id} }
|
||||||
);
|
);
|
||||||
|
|
||||||
return $response;
|
return $response;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,7 @@ use warnings;
|
||||||
|
|
||||||
sub set_counters {
|
sub set_counters {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{maps_counters_type} = [
|
$self->{maps_counters_type} = [
|
||||||
{ name => 'edges', type => 3, cb_prefix_output => 'prefix_edge_output', cb_long_output => 'long_output',
|
{ name => 'edges', type => 3, cb_prefix_output => 'prefix_edge_output', cb_long_output => 'long_output',
|
||||||
message_multiple => 'All edges applications usage are ok', indent_long_output => ' ',
|
message_multiple => 'All edges applications usage are ok', indent_long_output => ' ',
|
||||||
|
@ -88,7 +88,7 @@ sub prefix_edge_output {
|
||||||
|
|
||||||
sub prefix_app_output {
|
sub prefix_app_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
return "Application '" . $options{instance_value}->{display} . "' [Id: " . $options{instance_value}->{id} . "] ";
|
return "Application '" . $options{instance_value}->{display} . "' [Id: " . $options{instance_value}->{id} . "] ";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -102,14 +102,14 @@ sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
my $self = $class->SUPER::new(package => __PACKAGE__, %options, force_new_perfdata => 1);
|
my $self = $class->SUPER::new(package => __PACKAGE__, %options, force_new_perfdata => 1);
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments => {
|
$options{options}->add_options(arguments => {
|
||||||
"filter-edge-name:s" => { name => 'filter_edge_name' },
|
'filter-edge-name:s' => { name => 'filter_edge_name' },
|
||||||
"filter-application-name:s" => { name => 'filter_application_name' },
|
'filter-application-name:s' => { name => 'filter_application_name' },
|
||||||
"warning-status:s" => { name => 'warning_status', default => '' },
|
'warning-status:s' => { name => 'warning_status', default => '' },
|
||||||
"critical-status:s" => { name => 'critical_status', default => '' },
|
'critical-status:s' => { name => 'critical_status', default => '' },
|
||||||
});
|
});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -125,10 +125,9 @@ sub check_options {
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{edges} = {};
|
|
||||||
|
|
||||||
my $results = $options{custom}->list_edges;
|
my $results = $options{custom}->list_edges;
|
||||||
|
|
||||||
|
$self->{edges} = {};
|
||||||
foreach my $edge (@{$results}) {
|
foreach my $edge (@{$results}) {
|
||||||
if (defined($self->{option_results}->{filter_edge_name}) && $self->{option_results}->{filter_edge_name} ne '' &&
|
if (defined($self->{option_results}->{filter_edge_name}) && $self->{option_results}->{filter_edge_name} ne '' &&
|
||||||
$edge->{name} !~ /$self->{option_results}->{filter_edge_name}/) {
|
$edge->{name} !~ /$self->{option_results}->{filter_edge_name}/) {
|
||||||
|
@ -167,11 +166,6 @@ sub manage_selection {
|
||||||
$self->{output}->add_option_msg(short_msg => "No edge found.");
|
$self->{output}->add_option_msg(short_msg => "No edge found.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
foreach (keys %{$self->{edges}}) {
|
|
||||||
last if (defined($self->{edges}->{$_}->{apps}));
|
|
||||||
$self->{output}->add_option_msg(short_msg => "No applications found.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
@ -192,15 +186,9 @@ Filter edge by name (Can be a regexp).
|
||||||
|
|
||||||
Filter application by name (Can be a regexp).
|
Filter application by name (Can be a regexp).
|
||||||
|
|
||||||
=item B<--warning-*>
|
=item B<--warning-*> B<--critical-*>
|
||||||
|
|
||||||
Threshold warning.
|
Thresholds.
|
||||||
Can be: 'traffic-in', 'traffic-out',
|
|
||||||
'packets-in', 'packets-out'.
|
|
||||||
|
|
||||||
=item B<--critical-*>
|
|
||||||
|
|
||||||
Threshold critical.
|
|
||||||
Can be: 'traffic-in', 'traffic-out',
|
Can be: 'traffic-in', 'traffic-out',
|
||||||
'packets-in', 'packets-out'.
|
'packets-in', 'packets-out'.
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,7 @@ use warnings;
|
||||||
|
|
||||||
sub set_counters {
|
sub set_counters {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{maps_counters_type} = [
|
$self->{maps_counters_type} = [
|
||||||
{ name => 'edges', type => 3, cb_prefix_output => 'prefix_edge_output', cb_long_output => 'long_output',
|
{ name => 'edges', type => 3, cb_prefix_output => 'prefix_edge_output', cb_long_output => 'long_output',
|
||||||
message_multiple => 'All edges categories usage are ok', indent_long_output => ' ',
|
message_multiple => 'All edges categories usage are ok', indent_long_output => ' ',
|
||||||
|
@ -88,7 +88,7 @@ sub prefix_edge_output {
|
||||||
|
|
||||||
sub prefix_category_output {
|
sub prefix_category_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
return "Category '" . $options{instance_value}->{display} . "' [Id: " . $options{instance_value}->{id} . "] ";
|
return "Category '" . $options{instance_value}->{display} . "' [Id: " . $options{instance_value}->{id} . "] ";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -102,14 +102,14 @@ sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
my $self = $class->SUPER::new(package => __PACKAGE__, %options, force_new_perfdata => 1);
|
my $self = $class->SUPER::new(package => __PACKAGE__, %options, force_new_perfdata => 1);
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments => {
|
$options{options}->add_options(arguments => {
|
||||||
"filter-edge-name:s" => { name => 'filter_edge_name' },
|
'filter-edge-name:s' => { name => 'filter_edge_name' },
|
||||||
"filter-category-name:s" => { name => 'filter_category_name' },
|
'filter-category-name:s' => { name => 'filter_category_name' },
|
||||||
"warning-status:s" => { name => 'warning_status', default => '' },
|
'warning-status:s' => { name => 'warning_status', default => '' },
|
||||||
"critical-status:s" => { name => 'critical_status', default => '' },
|
'critical-status:s' => { name => 'critical_status', default => '' },
|
||||||
});
|
});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -125,10 +125,9 @@ sub check_options {
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{edges} = {};
|
|
||||||
|
|
||||||
my $results = $options{custom}->list_edges;
|
my $results = $options{custom}->list_edges;
|
||||||
|
|
||||||
|
$self->{edges} = {};
|
||||||
foreach my $edge (@{$results}) {
|
foreach my $edge (@{$results}) {
|
||||||
if (defined($self->{option_results}->{filter_edge_name}) && $self->{option_results}->{filter_edge_name} ne '' &&
|
if (defined($self->{option_results}->{filter_edge_name}) && $self->{option_results}->{filter_edge_name} ne '' &&
|
||||||
$edge->{name} !~ /$self->{option_results}->{filter_edge_name}/) {
|
$edge->{name} !~ /$self->{option_results}->{filter_edge_name}/) {
|
||||||
|
@ -167,11 +166,6 @@ sub manage_selection {
|
||||||
$self->{output}->add_option_msg(short_msg => "No edge found.");
|
$self->{output}->add_option_msg(short_msg => "No edge found.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
foreach (keys %{$self->{edges}}) {
|
|
||||||
last if (defined($self->{edges}->{$_}->{categories}));
|
|
||||||
$self->{output}->add_option_msg(short_msg => "No category found.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
@ -192,15 +186,9 @@ Filter edge by name (Can be a regexp).
|
||||||
|
|
||||||
Filter category by name (Can be a regexp).
|
Filter category by name (Can be a regexp).
|
||||||
|
|
||||||
=item B<--warning-*>
|
=item B<--warning-*> B<--critical-*>
|
||||||
|
|
||||||
Threshold warning.
|
Thresholds.
|
||||||
Can be: 'traffic-in', 'traffic-out',
|
|
||||||
'packets-in', 'packets-out'.
|
|
||||||
|
|
||||||
=item B<--critical-*>
|
|
||||||
|
|
||||||
Threshold critical.
|
|
||||||
Can be: 'traffic-in', 'traffic-out',
|
Can be: 'traffic-in', 'traffic-out',
|
||||||
'packets-in', 'packets-out'.
|
'packets-in', 'packets-out'.
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,7 @@ use warnings;
|
||||||
|
|
||||||
sub set_counters {
|
sub set_counters {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{maps_counters_type} = [
|
$self->{maps_counters_type} = [
|
||||||
{ name => 'edges', type => 3, cb_prefix_output => 'prefix_edge_output', cb_long_output => 'long_output',
|
{ name => 'edges', type => 3, cb_prefix_output => 'prefix_edge_output', cb_long_output => 'long_output',
|
||||||
message_multiple => 'All edges links QOE are ok', indent_long_output => ' ',
|
message_multiple => 'All edges links QOE are ok', indent_long_output => ' ',
|
||||||
|
@ -68,6 +68,7 @@ sub set_counters {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
|
||||||
$self->{maps_counters}->{links} = [
|
$self->{maps_counters}->{links} = [
|
||||||
{ label => 'qoe-voice', nlabel => 'link.qoe.voice.count', set => {
|
{ label => 'qoe-voice', nlabel => 'link.qoe.voice.count', set => {
|
||||||
key_values => [ { name => 'voice' }, { name => 'display' }, { name => 'id' } ],
|
key_values => [ { name => 'voice' }, { name => 'display' }, { name => 'id' } ],
|
||||||
|
@ -107,7 +108,7 @@ sub prefix_edge_output {
|
||||||
|
|
||||||
sub prefix_link_output {
|
sub prefix_link_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
return "Link '" . $options{instance_value}->{display} . "' [Id: " . $options{instance_value}->{id} . "] ";
|
return "Link '" . $options{instance_value}->{display} . "' [Id: " . $options{instance_value}->{id} . "] ";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -123,8 +124,8 @@ sub new {
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments => {
|
$options{options}->add_options(arguments => {
|
||||||
"filter-edge-name:s" => { name => 'filter_edge_name' },
|
"filter-edge-name:s' => { name => 'filter_edge_name' },
|
||||||
"filter-link-name:s" => { name => 'filter_link_name' },
|
"filter-link-name:s' => { name => 'filter_link_name' },
|
||||||
});
|
});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
|
@ -135,17 +136,15 @@ sub check_options {
|
||||||
$self->SUPER::check_options(%options);
|
$self->SUPER::check_options(%options);
|
||||||
|
|
||||||
$self->{timeframe} = defined($self->{option_results}->{timeframe}) ? $self->{option_results}->{timeframe} : 900;
|
$self->{timeframe} = defined($self->{option_results}->{timeframe}) ? $self->{option_results}->{timeframe} : 900;
|
||||||
|
|
||||||
$self->change_macros(macros => ['warning_status', 'critical_status']);
|
$self->change_macros(macros => ['warning_status', 'critical_status']);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{edges} = {};
|
|
||||||
|
|
||||||
my $results = $options{custom}->list_edges;
|
my $results = $options{custom}->list_edges;
|
||||||
|
|
||||||
|
$self->{edges} = {};
|
||||||
foreach my $edge (@{$results}) {
|
foreach my $edge (@{$results}) {
|
||||||
if (defined($self->{option_results}->{filter_edge_name}) && $self->{option_results}->{filter_edge_name} ne '' &&
|
if (defined($self->{option_results}->{filter_edge_name}) && $self->{option_results}->{filter_edge_name} ne '' &&
|
||||||
$edge->{name} !~ /$self->{option_results}->{filter_edge_name}/) {
|
$edge->{name} !~ /$self->{option_results}->{filter_edge_name}/) {
|
||||||
|
@ -167,16 +166,16 @@ sub manage_selection {
|
||||||
);
|
);
|
||||||
|
|
||||||
next if (ref($qoes) ne 'HASH');
|
next if (ref($qoes) ne 'HASH');
|
||||||
|
|
||||||
$self->{edges}->{$edge->{name}}->{global} = {
|
$self->{edges}->{$edge->{name}}->{global} = {
|
||||||
voice => $qoes->{overallLinkQuality}->{score}->{0},
|
voice => $qoes->{overallLinkQuality}->{score}->{0},
|
||||||
video => $qoes->{overallLinkQuality}->{score}->{1},
|
video => $qoes->{overallLinkQuality}->{score}->{1},
|
||||||
transactional => $qoes->{overallLinkQuality}->{score}->{2},
|
transactional => $qoes->{overallLinkQuality}->{score}->{2},
|
||||||
};
|
};
|
||||||
|
|
||||||
foreach my $link (@{$links}) {
|
foreach my $link (@{$links}) {
|
||||||
next if (!defined($qoes->{$link->{link}->{internalId}}));
|
next if (!defined($qoes->{$link->{link}->{internalId}}));
|
||||||
|
|
||||||
if (defined($self->{option_results}->{filter_link_name}) && $self->{option_results}->{filter_link_name} ne '' &&
|
if (defined($self->{option_results}->{filter_link_name}) && $self->{option_results}->{filter_link_name} ne '' &&
|
||||||
$link->{link}->{displayName} !~ /$self->{option_results}->{filter_link_name}/) {
|
$link->{link}->{displayName} !~ /$self->{option_results}->{filter_link_name}/) {
|
||||||
$self->{output}->output_add(long_msg => "skipping '" . $edge->{id} . "'.", debug => 1);
|
$self->{output}->output_add(long_msg => "skipping '" . $edge->{id} . "'.", debug => 1);
|
||||||
|
@ -197,11 +196,6 @@ sub manage_selection {
|
||||||
$self->{output}->add_option_msg(short_msg => "No edge found.");
|
$self->{output}->add_option_msg(short_msg => "No edge found.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
foreach (keys %{$self->{edges}}) {
|
|
||||||
last if (defined($self->{edges}->{$_}->{links}));
|
|
||||||
$self->{output}->add_option_msg(short_msg => "No link found.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
@ -222,14 +216,9 @@ Filter edge by name (Can be a regexp).
|
||||||
|
|
||||||
Filter link by name (Can be a regexp).
|
Filter link by name (Can be a regexp).
|
||||||
|
|
||||||
=item B<--warning-*>
|
=item B<--warning-*> B<--critical-*>
|
||||||
|
|
||||||
Threshold warning.
|
Thresholds.
|
||||||
Can be: 'qoe-voice', 'qoe-video', 'qoe-transactional'.
|
|
||||||
|
|
||||||
=item B<--critical-*>
|
|
||||||
|
|
||||||
Threshold critical.
|
|
||||||
Can be: 'qoe-voice', 'qoe-video', 'qoe-transactional'.
|
Can be: 'qoe-voice', 'qoe-video', 'qoe-transactional'.
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
|
@ -29,11 +29,13 @@ use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold)
|
||||||
sub custom_status_output {
|
sub custom_status_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
return sprintf("State is '%s', Service State is '%s', HA State is '%s', Activation State is '%s'",
|
return sprintf(
|
||||||
|
"State is '%s', Service State is '%s', HA State is '%s', Activation State is '%s'",
|
||||||
$self->{result_values}->{edge_state},
|
$self->{result_values}->{edge_state},
|
||||||
$self->{result_values}->{service_state},
|
$self->{result_values}->{service_state},
|
||||||
$self->{result_values}->{ha_state},
|
$self->{result_values}->{ha_state},
|
||||||
$self->{result_values}->{activation_state});
|
$self->{result_values}->{activation_state}
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_status_calc {
|
sub custom_status_calc {
|
||||||
|
@ -43,7 +45,7 @@ sub custom_status_calc {
|
||||||
$self->{result_values}->{service_state} = $options{new_datas}->{$self->{instance} . '_service_state'};
|
$self->{result_values}->{service_state} = $options{new_datas}->{$self->{instance} . '_service_state'};
|
||||||
$self->{result_values}->{ha_state} = $options{new_datas}->{$self->{instance} . '_ha_state'};
|
$self->{result_values}->{ha_state} = $options{new_datas}->{$self->{instance} . '_ha_state'};
|
||||||
$self->{result_values}->{activation_state} = $options{new_datas}->{$self->{instance} . '_activation_state'};
|
$self->{result_values}->{activation_state} = $options{new_datas}->{$self->{instance} . '_activation_state'};
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -99,10 +101,9 @@ sub check_options {
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{edges} = {};
|
|
||||||
|
|
||||||
my $results = $options{custom}->list_edges;
|
my $results = $options{custom}->list_edges;
|
||||||
|
|
||||||
|
$self->{edges} = {};
|
||||||
foreach my $edge (@{$results}) {
|
foreach my $edge (@{$results}) {
|
||||||
if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' &&
|
if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' &&
|
||||||
$edge->{name} !~ /$self->{option_results}->{filter_name}/) {
|
$edge->{name} !~ /$self->{option_results}->{filter_name}/) {
|
||||||
|
|
|
@ -29,7 +29,8 @@ use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold
|
||||||
sub custom_status_output {
|
sub custom_status_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
return sprintf("status is '%s' [vpn state: '%s'] [backup state: '%s']",
|
return sprintf(
|
||||||
|
"status is '%s' [vpn state: '%s'] [backup state: '%s']",
|
||||||
$self->{result_values}->{state},
|
$self->{result_values}->{state},
|
||||||
$self->{result_values}->{vpn_state},
|
$self->{result_values}->{vpn_state},
|
||||||
$self->{result_values}->{backup_state}
|
$self->{result_values}->{backup_state}
|
||||||
|
@ -86,11 +87,11 @@ sub new {
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments => {
|
$options{options}->add_options(arguments => {
|
||||||
"filter-edge-name:s" => { name => 'filter_edge_name' },
|
'filter-edge-name:s' => { name => 'filter_edge_name' },
|
||||||
"filter-link-name:s" => { name => 'filter_link_name' },
|
'filter-link-name:s' => { name => 'filter_link_name' },
|
||||||
"unknown-status:s" => { name => 'unknown_status', default => '' },
|
'unknown-status:s' => { name => 'unknown_status', default => '' },
|
||||||
"warning-status:s" => { name => 'warning_status', default => '' },
|
'warning-status:s' => { name => 'warning_status', default => '' },
|
||||||
"critical-status:s" => { name => 'critical_status', default => '%{state} !~ /STABLE/ || %{vpn_state} !~ /STABLE/' },
|
'critical-status:s' => { name => 'critical_status', default => '%{state} !~ /STABLE/ || %{vpn_state} !~ /STABLE/' },
|
||||||
});
|
});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
|
@ -108,10 +109,9 @@ sub check_options {
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{edges} = {};
|
|
||||||
|
|
||||||
my $results = $options{custom}->list_edges;
|
my $results = $options{custom}->list_edges;
|
||||||
|
|
||||||
|
$self->{edges} = {};
|
||||||
foreach my $edge (@{$results}) {
|
foreach my $edge (@{$results}) {
|
||||||
if (defined($self->{option_results}->{filter_edge_name}) && $self->{option_results}->{filter_edge_name} ne '' &&
|
if (defined($self->{option_results}->{filter_edge_name}) && $self->{option_results}->{filter_edge_name} ne '' &&
|
||||||
$edge->{name} !~ /$self->{option_results}->{filter_edge_name}/) {
|
$edge->{name} !~ /$self->{option_results}->{filter_edge_name}/) {
|
||||||
|
@ -148,11 +148,6 @@ sub manage_selection {
|
||||||
$self->{output}->add_option_msg(short_msg => "No edge found.");
|
$self->{output}->add_option_msg(short_msg => "No edge found.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
foreach (keys %{$self->{edges}}) {
|
|
||||||
last if (defined($self->{edges}->{$_}->{links}));
|
|
||||||
$self->{output}->add_option_msg(short_msg => "No link found.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
|
|
@ -32,12 +32,36 @@ sub set_counters {
|
||||||
{ name => 'edges', type => 3, cb_prefix_output => 'prefix_edge_output', cb_long_output => 'long_output',
|
{ name => 'edges', type => 3, cb_prefix_output => 'prefix_edge_output', cb_long_output => 'long_output',
|
||||||
message_multiple => 'All edges links usage are ok', indent_long_output => ' ',
|
message_multiple => 'All edges links usage are ok', indent_long_output => ' ',
|
||||||
group => [
|
group => [
|
||||||
|
{ name => 'global', cb_prefix_output => 'prefix_global_output', type => 0, skipped_code => { -10 => 1 } },
|
||||||
{ name => 'links', display_long => 1, cb_prefix_output => 'prefix_link_output',
|
{ name => 'links', display_long => 1, cb_prefix_output => 'prefix_link_output',
|
||||||
message_multiple => 'All links status are ok', type => 1 },
|
message_multiple => 'All links status are ok', type => 1 },
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
|
$self->{maps_counters}->{global} = [
|
||||||
|
{ label => 'links-traffic-in', nlabel => 'links.traffic.in.bitspersecond', set => {
|
||||||
|
key_values => [ { name => 'traffic_in' } ],
|
||||||
|
output_template => 'Total Traffic In: %s %s/s',
|
||||||
|
output_change_bytes => 2,
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'traffic_in_absolute', template => '%s',
|
||||||
|
min => 0, unit => 'b/s', label_extra_instance => 1 },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'links-traffic-out', nlabel => 'links.traffic.out.bitspersecond', set => {
|
||||||
|
key_values => [ { name => 'traffic_out' } ],
|
||||||
|
output_template => 'Total Traffic Out: %s %s/s',
|
||||||
|
output_change_bytes => 2,
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'traffic_out_absolute', template => '%s',
|
||||||
|
min => 0, unit => 'b/s', label_extra_instance => 1 },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
$self->{maps_counters}->{links} = [
|
$self->{maps_counters}->{links} = [
|
||||||
{ label => 'traffic-in', nlabel => 'link.traffic.in.bitspersecond', set => {
|
{ label => 'traffic-in', nlabel => 'link.traffic.in.bitspersecond', set => {
|
||||||
key_values => [ { name => 'traffic_in' }, { name => 'display' }, { name => 'id' } ],
|
key_values => [ { name => 'traffic_in' }, { name => 'display' }, { name => 'id' } ],
|
||||||
|
@ -140,8 +164,8 @@ sub new {
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments => {
|
$options{options}->add_options(arguments => {
|
||||||
"filter-edge-name:s" => { name => 'filter_edge_name' },
|
'filter-edge-name:s' => { name => 'filter_edge_name' },
|
||||||
"filter-link-name:s" => { name => 'filter_link_name' },
|
'filter-link-name:s' => { name => 'filter_link_name' },
|
||||||
});
|
});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
|
@ -159,10 +183,9 @@ sub check_options {
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
my $results = $options{custom}->list_edges();
|
||||||
|
|
||||||
$self->{edges} = {};
|
$self->{edges} = {};
|
||||||
|
|
||||||
my $results = $options{custom}->list_edges;
|
|
||||||
|
|
||||||
foreach my $edge (@{$results}) {
|
foreach my $edge (@{$results}) {
|
||||||
if (defined($self->{option_results}->{filter_edge_name}) && $self->{option_results}->{filter_edge_name} ne '' &&
|
if (defined($self->{option_results}->{filter_edge_name}) && $self->{option_results}->{filter_edge_name} ne '' &&
|
||||||
$edge->{name} !~ /$self->{option_results}->{filter_edge_name}/) {
|
$edge->{name} !~ /$self->{option_results}->{filter_edge_name}/) {
|
||||||
|
@ -170,8 +193,12 @@ sub manage_selection {
|
||||||
next;
|
next;
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{edges}->{$edge->{name}}->{id} = $edge->{id};
|
$self->{edges}->{$edge->{name}} = {
|
||||||
$self->{edges}->{$edge->{name}}->{display} = $edge->{name};
|
id => $edge->{id},
|
||||||
|
display => $edge->{name},
|
||||||
|
global => {},
|
||||||
|
links => {}
|
||||||
|
};
|
||||||
|
|
||||||
my $links = $options{custom}->get_links_metrics(
|
my $links = $options{custom}->get_links_metrics(
|
||||||
edge_id => $edge->{id},
|
edge_id => $edge->{id},
|
||||||
|
@ -197,16 +224,17 @@ sub manage_selection {
|
||||||
packet_loss_out => $link->{bestLossPctTx},
|
packet_loss_out => $link->{bestLossPctTx},
|
||||||
packet_loss_in => $link->{bestLossPctRx},
|
packet_loss_in => $link->{bestLossPctRx},
|
||||||
};
|
};
|
||||||
|
if (!defined($self->{edges}->{$edge->{name}}->{global}->{traffic_in})) {
|
||||||
|
$self->{edges}->{$edge->{name}}->{global}->{traffic_in} = 0;
|
||||||
|
$self->{edges}->{$edge->{name}}->{global}->{traffic_out} = 0;
|
||||||
|
}
|
||||||
|
$self->{edges}->{$edge->{name}}->{global}->{traffic_in} += (int($link->{bytesRx} * 8 / $self->{timeframe}));
|
||||||
|
$self->{edges}->{$edge->{name}}->{global}->{traffic_out} += (int($link->{bytesTx} * 8 / $self->{timeframe}));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (scalar(keys %{$self->{edges}}) <= 0) {
|
if (scalar(keys %{$self->{edges}}) <= 0) {
|
||||||
$self->{output}->add_option_msg(short_msg => "No edge found.");
|
$self->{output}->add_option_msg(short_msg => 'no edge found.');
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
foreach (keys %{$self->{edges}}) {
|
|
||||||
last if (defined($self->{edges}->{$_}->{links}));
|
|
||||||
$self->{output}->add_option_msg(short_msg => "No link found.");
|
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -229,17 +257,11 @@ Filter edge by name (Can be a regexp).
|
||||||
|
|
||||||
Filter link by name (Can be a regexp).
|
Filter link by name (Can be a regexp).
|
||||||
|
|
||||||
=item B<--warning-*>
|
=item B<--warning-*> B<--critical-*>
|
||||||
|
|
||||||
Threshold warning.
|
Thresholds.
|
||||||
Can be: 'traffic-in', 'traffic-out', 'latency-in',
|
Can be: 'links-traffic-in', 'links-traffic-out',
|
||||||
'latency-out', 'jitter-in', 'jitter-out',
|
'traffic-in', 'traffic-out', 'latency-in',
|
||||||
'packet-loss-in', 'packet-loss-out'.
|
|
||||||
|
|
||||||
=item B<--critical-*>
|
|
||||||
|
|
||||||
Threshold critical.
|
|
||||||
Can be: 'traffic-in', 'traffic-out', 'latency-in',
|
|
||||||
'latency-out', 'jitter-in', 'jitter-out',
|
'latency-out', 'jitter-in', 'jitter-out',
|
||||||
'packet-loss-in', 'packet-loss-out'.
|
'packet-loss-in', 'packet-loss-out'.
|
||||||
|
|
||||||
|
|
|
@ -29,7 +29,7 @@ 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 => {});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
|
@ -48,7 +48,7 @@ sub manage_selection {
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->manage_selection(%options);
|
$self->manage_selection(%options);
|
||||||
foreach my $edge (@{$self->{edges}}) {
|
foreach my $edge (@{$self->{edges}}) {
|
||||||
$self->{output}->output_add(long_msg => sprintf("[id = %s][name = %s][description = %s][edge_state = %s]" .
|
$self->{output}->output_add(long_msg => sprintf("[id = %s][name = %s][description = %s][edge_state = %s]" .
|
||||||
|
@ -56,18 +56,24 @@ sub run {
|
||||||
$edge->{id}, $edge->{name}, $edge->{description}, $edge->{edgeState}, $edge->{serviceState},
|
$edge->{id}, $edge->{name}, $edge->{description}, $edge->{edgeState}, $edge->{serviceState},
|
||||||
$edge->{haState}, $edge->{activationState}));
|
$edge->{haState}, $edge->{activationState}));
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{output}->output_add(severity => 'OK',
|
$self->{output}->output_add(
|
||||||
short_msg => 'List edges:');
|
severity => 'OK',
|
||||||
|
short_msg => 'List edges:'
|
||||||
|
);
|
||||||
$self->{output}->display(nolabel => 1, force_ignore_perfdata => 1, force_long_output => 1);
|
$self->{output}->display(nolabel => 1, force_ignore_perfdata => 1, force_long_output => 1);
|
||||||
$self->{output}->exit();
|
$self->{output}->exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
sub disco_format {
|
sub disco_format {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{output}->add_disco_format(elements => ['id', 'name', 'description', 'edge_state', 'service_state',
|
$self->{output}->add_disco_format(
|
||||||
'ha_state', 'activation_state']);
|
elements => [
|
||||||
|
'id', 'name', 'description', 'edge_state', 'service_state',
|
||||||
|
'ha_state', 'activation_state'
|
||||||
|
]
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub disco_show {
|
sub disco_show {
|
||||||
|
|
|
@ -29,9 +29,9 @@ 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-edge-name:s" => { name => 'filter_edge_name' },
|
'filter-edge-name:s' => { name => 'filter_edge_name' },
|
||||||
});
|
});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
|
@ -44,9 +44,8 @@ sub check_options {
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $edges = $options{custom}->list_edges;
|
|
||||||
|
|
||||||
|
my $edges = $options{custom}->list_edges;
|
||||||
foreach my $edge (@{$edges}) {
|
foreach my $edge (@{$edges}) {
|
||||||
if (defined($self->{option_results}->{filter_edge_name}) && $self->{option_results}->{filter_edge_name} ne '' &&
|
if (defined($self->{option_results}->{filter_edge_name}) && $self->{option_results}->{filter_edge_name} ne '' &&
|
||||||
$edge->{name} !~ /$self->{option_results}->{filter_edge_name}/) {
|
$edge->{name} !~ /$self->{option_results}->{filter_edge_name}/) {
|
||||||
|
@ -62,26 +61,35 @@ sub manage_selection {
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->manage_selection(%options);
|
$self->manage_selection(%options);
|
||||||
foreach my $link (@{$self->{links}}) {
|
foreach my $link (@{$self->{links}}) {
|
||||||
$self->{output}->output_add(long_msg => sprintf("[id = %s][display_name = %s][name = %s][edge_id = %s]" .
|
$self->{output}->output_add(
|
||||||
"[edge_name = %s][state = %s][vpn_state = %s]",
|
long_msg => sprintf(
|
||||||
$link->{linkId}, $link->{link}->{displayName}, $link->{name}, $link->{link}->{edgeId},
|
"[id = %s][display_name = %s][name = %s][edge_id = %s]" .
|
||||||
$link->{edgeName}, $link->{link}->{state}, $link->{link}->{vpnState}));
|
"[edge_name = %s][state = %s][vpn_state = %s]",
|
||||||
|
$link->{linkId}, $link->{link}->{displayName}, $link->{name}, $link->{link}->{edgeId},
|
||||||
|
$link->{edgeName}, $link->{link}->{state}, $link->{link}->{vpnState}
|
||||||
|
)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{output}->output_add(severity => 'OK',
|
$self->{output}->output_add(
|
||||||
short_msg => 'List links:');
|
severity => 'OK',
|
||||||
|
short_msg => 'List links:'
|
||||||
|
);
|
||||||
$self->{output}->display(nolabel => 1, force_ignore_perfdata => 1, force_long_output => 1);
|
$self->{output}->display(nolabel => 1, force_ignore_perfdata => 1, force_long_output => 1);
|
||||||
$self->{output}->exit();
|
$self->{output}->exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
sub disco_format {
|
sub disco_format {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{output}->add_disco_format(elements => ['id', 'display_name', 'name', 'edge_id', 'edge_name', 'state',
|
$self->{output}->add_disco_format(
|
||||||
'vpn_state']);
|
elements => [
|
||||||
|
'id', 'display_name', 'name', 'edge_id', 'edge_name', 'state', 'vpn_state'
|
||||||
|
]
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub disco_show {
|
sub disco_show {
|
||||||
|
@ -118,4 +126,3 @@ Filter edge by name (Can be a regexp).
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue