better response handling of azure apis
This commit is contained in:
parent
86b997f3b4
commit
5cbce02f28
|
@ -181,18 +181,23 @@ sub get_access_token {
|
||||||
full_url => $self->{login_endpoint} . '/' . $self->{tenant} . '/oauth2/token',
|
full_url => $self->{login_endpoint} . '/' . $self->{tenant} . '/oauth2/token',
|
||||||
hostname => '');
|
hostname => '');
|
||||||
|
|
||||||
|
if (!defined($content) || $content eq '' || $self->{http}->get_header(name => 'content-length') == 0) {
|
||||||
|
$self->{output}->add_option_msg(short_msg => "Login endpoint API returns empty content [code: '" . $self->{http}->get_code() . "'] [message: '" . $self->{http}->get_message() . "']");
|
||||||
|
$self->{output}->option_exit();
|
||||||
|
}
|
||||||
|
|
||||||
my $decoded;
|
my $decoded;
|
||||||
eval {
|
eval {
|
||||||
$decoded = JSON::XS->new->utf8->decode($content);
|
$decoded = JSON::XS->new->utf8->decode($content);
|
||||||
};
|
};
|
||||||
if ($@) {
|
if ($@) {
|
||||||
$self->{output}->output_add(long_msg => $content, debug => 1);
|
$self->{output}->output_add(long_msg => $content, debug => 1);
|
||||||
$self->{output}->add_option_msg(short_msg => "Cannot decode json response");
|
$self->{output}->add_option_msg(short_msg => "Cannot decode response (add --debug option to display returned content)");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (defined($decoded->{error})) {
|
if (defined($decoded->{error})) {
|
||||||
$self->{output}->output_add(long_msg => "Error message : " . $decoded->{error_description}, debug => 1);
|
$self->{output}->output_add(long_msg => "Error message : " . $decoded->{error_description}, debug => 1);
|
||||||
$self->{output}->add_option_msg(short_msg => "Login endpoint API return error code '" . $decoded->{error} . "' (add --debug option for detailed message)");
|
$self->{output}->add_option_msg(short_msg => "Login endpoint API returns error code '" . $decoded->{error} . "' (add --debug option for detailed message)");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -217,18 +222,28 @@ sub request_api {
|
||||||
|
|
||||||
my $content = $self->{http}->request(%options);
|
my $content = $self->{http}->request(%options);
|
||||||
|
|
||||||
|
if (!defined($content) || $content eq '' || $self->{http}->get_header(name => 'content-length') == 0) {
|
||||||
|
$self->{output}->add_option_msg(short_msg => "Management endpoint API returns empty content [code: '" . $self->{http}->get_code() . "'] [message: '" . $self->{http}->get_message() . "']");
|
||||||
|
$self->{output}->option_exit();
|
||||||
|
}
|
||||||
|
|
||||||
my $decoded;
|
my $decoded;
|
||||||
eval {
|
eval {
|
||||||
$decoded = JSON::XS->new->utf8->decode($content);
|
$decoded = JSON::XS->new->utf8->decode($content);
|
||||||
};
|
};
|
||||||
if ($@) {
|
if ($@) {
|
||||||
$self->{output}->output_add(long_msg => $content, debug => 1);
|
$self->{output}->output_add(long_msg => $content, debug => 1);
|
||||||
$self->{output}->add_option_msg(short_msg => "Cannot decode json response: $@");
|
$self->{output}->add_option_msg(short_msg => "Cannot decode response (add --debug option to display returned content)");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (defined($decoded->{error})) {
|
if (defined($decoded->{error})) {
|
||||||
$self->{output}->output_add(long_msg => "Error message : " . $decoded->{error}->{message}, debug => 1);
|
$self->{output}->output_add(long_msg => "Error message : " . $decoded->{error}->{message}, debug => 1);
|
||||||
$self->{output}->add_option_msg(short_msg => "Management endpoint API return error code '" . $decoded->{error}->{code} . "' (add --debug option for detailed message)");
|
$self->{output}->add_option_msg(short_msg => "Management endpoint API returns error code '" . $decoded->{error}->{code} . "' (add --debug option for detailed message)");
|
||||||
|
$self->{output}->option_exit();
|
||||||
|
}
|
||||||
|
if (defined($decoded->{code})) {
|
||||||
|
$self->{output}->output_add(long_msg => "Message : " . $decoded->{message}, debug => 1);
|
||||||
|
$self->{output}->add_option_msg(short_msg => "Management endpoint API returns code '" . $decoded->{code} . "' (add --debug option for detailed message)");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -40,23 +40,22 @@ sub new {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!defined($options{noptions})) {
|
if (!defined($options{noptions})) {
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments => {
|
||||||
{
|
"subscription:s" => { name => 'subscription' },
|
||||||
"subscription:s" => { name => 'subscription' },
|
"tenant:s" => { name => 'tenant' },
|
||||||
"tenant:s" => { name => 'tenant' },
|
"client-id:s" => { name => 'client_id' },
|
||||||
"client-id:s" => { name => 'client_id' },
|
"client-secret:s" => { name => 'client_secret' },
|
||||||
"client-secret:s" => { name => 'client_secret' },
|
"timeframe:s" => { name => 'timeframe' },
|
||||||
"timeframe:s" => { name => 'timeframe' },
|
"interval:s" => { name => 'interval' },
|
||||||
"interval:s" => { name => 'interval' },
|
"aggregation:s@" => { name => 'aggregation' },
|
||||||
"aggregation:s@" => { name => 'aggregation' },
|
"zeroed" => { name => 'zeroed' },
|
||||||
"zeroed" => { name => 'zeroed' },
|
"timeout:s" => { name => 'timeout', default => 50 },
|
||||||
"timeout:s" => { name => 'timeout', default => 50 },
|
"sudo" => { name => 'sudo' },
|
||||||
"sudo" => { name => 'sudo' },
|
"command:s" => { name => 'command', default => 'az' },
|
||||||
"command:s" => { name => 'command', default => 'az' },
|
"command-path:s" => { name => 'command_path' },
|
||||||
"command-path:s" => { name => 'command_path' },
|
"command-options:s" => { name => 'command_options', default => '' },
|
||||||
"command-options:s" => { name => 'command_options', default => '' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
});
|
||||||
});
|
|
||||||
}
|
}
|
||||||
$options{options}->add_help(package => __PACKAGE__, sections => 'AZCLI OPTIONS', once => 1);
|
$options{options}->add_help(package => __PACKAGE__, sections => 'AZCLI OPTIONS', once => 1);
|
||||||
|
|
||||||
|
@ -129,7 +128,8 @@ sub execute {
|
||||||
$raw_results = JSON::XS->new->utf8->decode($response);
|
$raw_results = JSON::XS->new->utf8->decode($response);
|
||||||
};
|
};
|
||||||
if ($@) {
|
if ($@) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Cannot decode json response: $@");
|
$self->{output}->output_add(long_msg => $response, debug => 1);
|
||||||
|
$self->{output}->add_option_msg(short_msg => "Cannot decode response (add --debug option to display returned content)");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue