This commit is contained in:
qgarnier 2020-12-28 17:08:31 +01:00 committed by GitHub
parent ca7f950f49
commit 29eba8cbc3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 40 additions and 46 deletions

View File

@ -188,7 +188,9 @@ sub get_auth_token {
method => 'POST',
url_path => $self->{url_path} . '/Login',
query_form_post => $encoded,
warning_status => '', unknown_status => '', critical_status => ''
warning_status => '',
unknown_status => '',
critical_status => ''
);
if ($self->{http}->get_code() != 200) {
@ -222,7 +224,6 @@ sub request_internal {
}
my $content = $self->{http}->request(
method => 'GET',
url_path => $self->{url_path} . $options{endpoint},
get_param => $options{get_param},
warning_status => '',

View File

@ -118,8 +118,10 @@ sub load_response {
my ($self, %options) = @_;
if ($self->{response_type} eq 'xml') {
centreon::plugins::misc::mymodule_load(output => $self->{output}, module => 'XML::XPath',
error_msg => "Cannot load module 'XML::XPath'.");
centreon::plugins::misc::mymodule_load(
output => $self->{output}, module => 'XML::XPath',
error_msg => "Cannot load module 'XML::XPath'."
);
eval {
$self->{xpath_response} = XML::XPath->new(xml => $options{response});
};

View File

@ -123,7 +123,6 @@ sub settings {
$self->{http}->add_header(key => 'Accept', value => 'application/json');
if (defined($self->{auth_token})) {
$self->{http}->add_header(key => 'Centreon-Auth-Token', value => $self->{auth_token});
$self->{http}->add_header(key => 'Content-Type', value => 'application/json');
}
$self->{http}->set_options(%{$self->{option_results}});
}
@ -190,7 +189,10 @@ sub request_api {
method => $options{method},
url_path => $options{url_path},
query_form_post => $encoded_form_post,
critical_status => '', warning_status => '', unknown_status => ''
header => $options{header},
critical_status => '',
warning_status => '',
unknown_status => ''
);
my $decoded;
@ -211,7 +213,8 @@ sub submit_result {
my ($response, $raw) = $self->request_api(
method => 'POST',
url_path => $self->{api_path} . '?action=submit&object=centreon_submit_results',
query_form_post => $options{post_data}
query_form_post => $options{post_data},
header => ['Content-Type: application/json']
);
return ($response, $raw);

View File

@ -37,26 +37,26 @@ sub set_counters {
key_values => [ { name => '202' } ],
output_template => '202: %d',
perfdatas => [
{ value => '202', template => '%d', min => 0 },
],
{ template => '%d', min => 0 }
]
}
},
{ label => 'results-400', nlabel => 'results.400.count', set => {
key_values => [ { name => '400' } ],
output_template => '400: %d',
perfdatas => [
{ value => '400', template => '%d', min => 0 },
],
{ template => '%d', min => 0 }
]
}
},
{ label => 'results-404', nlabel => 'results.404.count', set => {
key_values => [ { name => '404' } ],
output_template => '404: %d',
perfdatas => [
{ value => '404', template => '%d', min => 0 },
],
{ template => '%d', min => 0 }
]
}
},
}
];
}
@ -72,21 +72,16 @@ sub new {
bless $self, $class;
$options{options}->add_options(arguments => {
"host:s@" => { name => 'host' },
"service:s@" => { name => 'service' },
"status:s@" => { name => 'status' },
"output:s@" => { name => 'output' },
"perfdata:s@" => { name => 'perfdata' },
'host:s@' => { name => 'host' },
'service:s@' => { name => 'service' },
'status:s@' => { name => 'status' },
'output:s@' => { name => 'output' },
'perfdata:s@' => { name => 'perfdata' }
});
return $self;
}
sub check_options {
my ($self, %options) = @_;
$self->SUPER::init(%options);
}
sub manage_selection {
my ($self, %options) = @_;

View File

@ -115,7 +115,6 @@ sub settings {
return if (defined($self->{settings_done}));
$self->build_options_for_httplib();
$self->{http}->add_header(key => 'Accept', value => 'application/json');
$self->{http}->add_header(key => 'Content-Type', value => 'application/json');
$self->{http}->set_options(%{$self->{option_results}});
$self->{settings_done} = 1;
}

View File

@ -161,10 +161,6 @@ sub set_method {
$self->curl_setopt(option => $self->{constant_cb}->(name => 'CURLOPT_POSTFIELDS'), parameter => undef);
$self->curl_setopt(option => $self->{constant_cb}->(name => 'CURLOPT_HTTPGET'), parameter => 1);
if ($options{request}->{method} eq 'GET') {
return ;
}
if ($options{content_type_forced} == 1) {
$self->curl_setopt(option => $self->{constant_cb}->(name => 'CURLOPT_POSTFIELDS'), parameter => $options{request}->{query_form_post})
if (defined($options{request}->{query_form_post}));
@ -175,6 +171,10 @@ sub set_method {
$self->curl_setopt(option => $self->{constant_cb}->(name => 'CURLOPT_POSTFIELDS'), parameter => $uri_post->query);
}
if ($options{request}->{method} eq 'GET') {
return ;
}
if ($options{request}->{method} eq 'POST') {
$self->curl_setopt(option => $self->{constant_cb}->(name => 'CURLOPT_POST'), parameter => 1);
}

View File

@ -191,27 +191,21 @@ sub request {
}
$req = HTTP::Request->new($request_options->{method}, $uri);
my $content_type_forced;
my $content_type_forced = 0;
foreach my $key (keys %{$request_options->{headers}}) {
if ($key !~ /content-type/i) {
$req->header($key => $request_options->{headers}->{$key});
} else {
$content_type_forced = $request_options->{headers}->{$key};
$req->header($key => $request_options->{headers}->{$key});
if ($key =~ /content-type/i) {
$content_type_forced = 1;
}
}
if ($request_options->{method} ne 'GET') {
if (defined($content_type_forced)) {
$req->content_type($content_type_forced);
$req->content($request_options->{query_form_post});
} else {
my $uri_post = URI->new();
if (defined($request_options->{post_params})) {
$uri_post->query_form($request_options->{post_params});
}
$req->content_type('application/x-www-form-urlencoded');
$req->content($uri_post->query);
}
if ($content_type_forced == 1) {
$req->content($request_options->{query_form_post});
} elsif (defined($options{request}->{post_params})) {
my $uri_post = URI->new();
$uri_post->query_form($request_options->{post_params});
$req->content_type('application/x-www-form-urlencoded');
$req->content($uri_post->query);
}
if (defined($request_options->{credentials}) && defined($request_options->{ntlmv2})) {