From f844a4f3fbd994c719f014f70902b6e6f2df3213 Mon Sep 17 00:00:00 2001 From: Simon Bomm Date: Wed, 26 Jul 2017 17:13:30 +0200 Subject: [PATCH] + allow json data to be 'file' or 'raw' Fix https://github.com/centreon/centreon-plugins/issues/715 --- apps/protocols/http/mode/jsoncontent.pm | 28 +++++++++++++++---------- 1 file changed, 17 insertions(+), 11 deletions(-) diff --git a/apps/protocols/http/mode/jsoncontent.pm b/apps/protocols/http/mode/jsoncontent.pm index 196ef980f..b9354c1e3 100644 --- a/apps/protocols/http/mode/jsoncontent.pm +++ b/apps/protocols/http/mode/jsoncontent.pm @@ -63,7 +63,6 @@ sub new { "unknown-status:s" => { name => 'unknown_status' }, "warning-status:s" => { name => 'warning_status' }, "critical-status:s" => { name => 'critical_status' }, - "warning-numeric:s" => { name => 'warning_numeric' }, "critical-numeric:s" => { name => 'critical_numeric' }, "warning-string:s" => { name => 'warning_string' }, @@ -121,17 +120,24 @@ sub load_request { my ($self, %options) = @_; $self->{method} = 'GET'; - if (defined($self->{option_results}->{data})) { - local $/ = undef; - if (!open(FILE, "<", $self->{option_results}->{data})) { - $self->{output}->output_add(severity => 'UNKNOWN', - short_msg => sprintf("Could not read file '%s': %s", $self->{option_results}->{data}, $!)); - $self->{output}->display(); - $self->{output}->exit(); - } - $self->{json_request} = ; - close FILE; + if (defined($self->{option_results}->{data}) && $self->{option_results}->{data} ne '') { $self->{method} = 'POST'; + if (-f $self->{option_results}->{data} and -r $self->{option_results}->{data}) { + $self->{json_request} = do { + local $/; + my $fh; + if (!open($fh, "<:encoding(UTF-8)", $self->{option_results}->{data})) { + $self->{output}->output_add(severity => 'UNKNOWN', + short_msg => sprintf("Could not read file '%s': %s", $self->{option_results}->{data}, $!)); + $self->{output}->display(); + $self->{output}->exit(); + } + }; + $self->{json_request} = ; + close FILE; + } else { + $self->{json_request} = $self->{option_results}->{data}; + } } }