mirror of
https://github.com/centreon/centreon-plugins.git
synced 2025-07-26 23:24:27 +02:00
enh(vtom/restapi): metricsv2 (#3267)
This commit is contained in:
parent
95748d4bdd
commit
dc4ffe8e4f
@ -26,7 +26,7 @@ use strict;
|
|||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::misc;
|
use centreon::plugins::misc;
|
||||||
use centreon::plugins::statefile;
|
use centreon::plugins::statefile;
|
||||||
use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold);
|
use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold_ng);
|
||||||
|
|
||||||
sub custom_status_output {
|
sub custom_status_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
@ -74,6 +74,18 @@ sub custom_long_calc {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub prefix_global_output {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
return "Total Job ";
|
||||||
|
}
|
||||||
|
|
||||||
|
sub prefix_job_output {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
return "job '" . $options{instance_value}->{environment} . '/' . $options{instance_value}->{application} . '/' . $options{instance_value}->{name} . "' ";
|
||||||
|
}
|
||||||
|
|
||||||
sub set_counters {
|
sub set_counters {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
@ -83,72 +95,71 @@ sub set_counters {
|
|||||||
];
|
];
|
||||||
|
|
||||||
$self->{maps_counters}->{job} = [
|
$self->{maps_counters}->{job} = [
|
||||||
{ label => 'status', threshold => 0, set => {
|
{
|
||||||
|
label => 'status',
|
||||||
|
type => 2,
|
||||||
|
critical_default => '%{status} =~ /Error/i',
|
||||||
|
set => {
|
||||||
key_values => [ { name => 'status' }, { name => 'name' }, { name => 'environment' },
|
key_values => [ { name => 'status' }, { name => 'name' }, { name => 'environment' },
|
||||||
{ name => 'application' }, { name => 'exit_code' }, { name => 'family' }, { name => 'information' } ],
|
{ name => 'application' }, { name => 'exit_code' }, { name => 'family' }, { name => 'information' } ],
|
||||||
closure_custom_calc => $self->can('custom_status_calc'),
|
closure_custom_calc => $self->can('custom_status_calc'),
|
||||||
closure_custom_output => $self->can('custom_status_output'),
|
closure_custom_output => $self->can('custom_status_output'),
|
||||||
closure_custom_perfdata => sub { return 0; },
|
closure_custom_perfdata => sub { return 0; },
|
||||||
closure_custom_threshold_check => \&catalog_status_threshold,
|
closure_custom_threshold_check => \&catalog_status_threshold_ng,
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{ label => 'long', threshold => 0, set => {
|
{ label => 'long', type => 2, set => {
|
||||||
key_values => [ { name => 'status' }, { name => 'name' }, { name => 'environment' },
|
key_values => [ { name => 'status' }, { name => 'name' }, { name => 'environment' },
|
||||||
{ name => 'application' }, { name => 'elapsed' }, { name => 'family' } ],
|
{ name => 'application' }, { name => 'elapsed' }, { name => 'family' } ],
|
||||||
closure_custom_calc => $self->can('custom_long_calc'),
|
closure_custom_calc => $self->can('custom_long_calc'),
|
||||||
closure_custom_output => $self->can('custom_long_output'),
|
closure_custom_output => $self->can('custom_long_output'),
|
||||||
closure_custom_perfdata => sub { return 0; },
|
closure_custom_perfdata => sub { return 0; },
|
||||||
closure_custom_threshold_check => \&catalog_status_threshold,
|
closure_custom_threshold_check => \&catalog_status_threshold_ng,
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
|
||||||
$self->{maps_counters}->{global} = [
|
$self->{maps_counters}->{global} = [
|
||||||
{ label => 'total-error', set => {
|
{ label => 'total-error', nlabel => 'jobs.errors.total.count', set => {
|
||||||
key_values => [ { name => 'error' }, { name => 'total' } ],
|
key_values => [ { name => 'error' }, { name => 'total' } ],
|
||||||
output_template => 'Error : %s',
|
output_template => 'error : %s',
|
||||||
perfdatas => [
|
perfdatas => [
|
||||||
{ label => 'total_error', value => 'error', template => '%s',
|
{ label => 'total_error', template => '%s', min => 0, max => 'total' }
|
||||||
min => 0, max => 'total' },
|
]
|
||||||
],
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{ label => 'total-running', set => {
|
{ label => 'total-running', nlabel => 'jobs.running.total.count', set => {
|
||||||
key_values => [ { name => 'running' }, { name => 'total' } ],
|
key_values => [ { name => 'running' }, { name => 'total' } ],
|
||||||
output_template => 'Running : %s',
|
output_template => 'running : %s',
|
||||||
perfdatas => [
|
perfdatas => [
|
||||||
{ label => 'total_running', value => 'running', template => '%s',
|
{ label => 'total_running', template => '%s', min => 0, max => 'total' }
|
||||||
min => 0, max => 'total' },
|
]
|
||||||
],
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{ label => 'total-unplanned', set => {
|
{ label => 'total-unplanned', nlabel => 'jobs.unplanned.total.count', set => {
|
||||||
key_values => [ { name => 'unplanned' }, { name => 'total' } ],
|
key_values => [ { name => 'unplanned' }, { name => 'total' } ],
|
||||||
output_template => 'Unplanned : %s',
|
output_template => 'unplanned : %s',
|
||||||
perfdatas => [
|
perfdatas => [
|
||||||
{ label => 'total_unplanned', value => 'unplanned', template => '%s',
|
{ label => 'total_unplanned', template => '%s', min => 0, max => 'total' }
|
||||||
min => 0, max => 'total' },
|
]
|
||||||
],
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{ label => 'total-finished', set => {
|
{ label => 'total-finished', nlabel => 'jobs.finished.total.count', set => {
|
||||||
key_values => [ { name => 'finished' }, { name => 'total' } ],
|
key_values => [ { name => 'finished' }, { name => 'total' } ],
|
||||||
output_template => 'Finished : %s',
|
output_template => 'finished : %s',
|
||||||
perfdatas => [
|
perfdatas => [
|
||||||
{ label => 'total_finished', value => 'finished', template => '%s',
|
{ label => 'total_finished', template => '%s', min => 0, max => 'total' }
|
||||||
min => 0, max => 'total' },
|
]
|
||||||
],
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{ label => 'total-coming', set => {
|
{ label => 'total-coming', nlabel => 'jobs.coming.total.count', set => {
|
||||||
key_values => [ { name => 'coming' }, { name => 'total' } ],
|
key_values => [ { name => 'coming' }, { name => 'total' } ],
|
||||||
output_template => 'Coming : %s',
|
output_template => 'coming : %s',
|
||||||
perfdatas => [
|
perfdatas => [
|
||||||
{ label => 'total_coming', value => 'coming', template => '%s',
|
{ label => 'total_coming', template => '%s', min => 0, max => 'total' },
|
||||||
min => 0, max => 'total' },
|
]
|
||||||
],
|
|
||||||
}
|
}
|
||||||
},
|
}
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -157,18 +168,13 @@ sub new {
|
|||||||
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-application:s" => { name => 'filter_application' },
|
||||||
"filter-application:s" => { name => 'filter_application' },
|
"filter-environment:s" => { name => 'filter_environment' },
|
||||||
"filter-environment:s" => { name => 'filter_environment' },
|
"filter-name:s" => { name => 'filter_name' },
|
||||||
"filter-name:s" => { name => 'filter_name' },
|
"filter-family:s" => { name => 'filter_family' },
|
||||||
"filter-family:s" => { name => 'filter_family' },
|
"reload-cache-time:s" => { name => 'reload_cache_time', default => 180 },
|
||||||
"warning-status:s" => { name => 'warning_status' },
|
});
|
||||||
"critical-status:s" => { name => 'critical_status', default => '%{status} =~ /Error/i' },
|
|
||||||
"warning-long:s" => { name => 'warning_long' },
|
|
||||||
"critical-long:s" => { name => 'critical_long' },
|
|
||||||
"reload-cache-time:s" => { name => 'reload_cache_time', default => 180 },
|
|
||||||
});
|
|
||||||
$self->{statefile_cache_app} = centreon::plugins::statefile->new(%options);
|
$self->{statefile_cache_app} = centreon::plugins::statefile->new(%options);
|
||||||
$self->{statefile_cache_env} = centreon::plugins::statefile->new(%options);
|
$self->{statefile_cache_env} = centreon::plugins::statefile->new(%options);
|
||||||
|
|
||||||
@ -181,19 +187,6 @@ sub check_options {
|
|||||||
|
|
||||||
$self->{statefile_cache_app}->check_options(%options);
|
$self->{statefile_cache_app}->check_options(%options);
|
||||||
$self->{statefile_cache_env}->check_options(%options);
|
$self->{statefile_cache_env}->check_options(%options);
|
||||||
$self->change_macros(macros => ['warning_status', 'critical_status', 'warning_long', 'critical_long']);
|
|
||||||
}
|
|
||||||
|
|
||||||
sub prefix_global_output {
|
|
||||||
my ($self, %options) = @_;
|
|
||||||
|
|
||||||
return "Total Job ";
|
|
||||||
}
|
|
||||||
|
|
||||||
sub prefix_job_output {
|
|
||||||
my ($self, %options) = @_;
|
|
||||||
|
|
||||||
return "job '" . $options{instance_value}->{environment} . '/' . $options{instance_value}->{application} . '/' . $options{instance_value}->{name} . "' ";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
my %mapping_job_status = (
|
my %mapping_job_status = (
|
||||||
|
@ -30,9 +30,9 @@ sub new {
|
|||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$self->{version} = '1.0';
|
$self->{version} = '1.0';
|
||||||
%{$self->{modes}} = (
|
$self->{modes} = {
|
||||||
'job-status' => 'apps::vtom::restapi::mode::jobstatus',
|
'job-status' => 'apps::vtom::restapi::mode::jobstatus'
|
||||||
);
|
};
|
||||||
|
|
||||||
$self->{custom_modes}{api} = 'apps::vtom::restapi::custom::api';
|
$self->{custom_modes}{api} = 'apps::vtom::restapi::custom::api';
|
||||||
return $self;
|
return $self;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user