NAME
WebService::BitbucketServer::Response - A response object for Bitbucket Server REST APIs
VERSION
version 0.605
SYNOPSIS
# Normal response with blocking user agent:
my $response = $core->get_application_properties;
my $app_info = $response->data;
print "Making API calls to: $app_info->{displayName} $app_info->{version}\n";
# Normal reponse with non-blocking user agent:
my $future = $core->get_application_properties;
$future->on_done(sub {
my $response = shift;
my $app_info = $response->data;
print "Making API calls to: $app_info->{displayName} $app_info->{version}\n";
});
# Paged response with blocking user agent:
my $response = $core->get_projects;
do {
last if $response->error;
for my $project_info (@{ $response->values }) {
print "$project_info->{key}\t$project_info->{name}\n"
}
} while ($response = $response->next);
# Paged response with non-blocking user agent:
my $future;
my $print_projects;
$print_projects = sub {
my $response = shift;
for my $project_info (@{ $response->values }) {
print "$project_info->{key}\t$project_info->{name}\n"
}
$future = $response->next; # get more projects
$future->on_done($print_projects) if $future;
};
$future = $core->get_projects; # get first page of projects
$future->on_done($print_projects);
DESCRIPTION
This module represents a response from a Bitbucket Server API call. It has various convenient accessors and provides a mechanism to handle paging.
ATTRIBUTES
context
A WebService::BitbucketServer object.
request_args
A hashref of the request arguments originally provided to "call" in WebService::BitbucketServer.
raw
The raw response from the server in a hashref structure similar to an HTTP::Tiny response (regardless of which user agent was used to get the response).
decoded_content
Get the decoded response content which may include page info if this is a paged response. Consider using "data", "page_info", etc. before this.
json
Get the JSON::XS (or compatible) object used for encoding and decoding documents.
METHODS
new
$response = WebService::BitbucketServer::Response->new(
context => $webservice_bitbucketserver_obj,
request_args => $data,
raw => $response,
);
Create a new response.
is_success
Get whether or not the response is a success.
status
Get the HTTP status code.
error
Get the error message or structure if this response represents an error (i.e. "is_success" is false), or undef if this response is not an error.
data
Get the decoded response content. If this is a paged response (see "is_paged"), this will be an arrayref of values.
Aliases: info
, value
, values
is_paged
Get whether or not the response is a page of values.
page_info
Get a hashref of page info or undef if this is not a paged response.
filter
is_last_page
limit
next_page_start
size
start
next
$next_response = $response->next;
Get the next page of results or undef if no more results. As with "call" in WebService::BitbucketServer, the returned response may be a WebService::BitbucketServer::Response or a Future.
wrap
$subresponse = $response->wrap($field);
Sometimes the response doesn't include the page information in the root object, typically when the response has an envelope with other non-repeated information. In such cases, "is_paged" is false and "page_info" is undef. You can use this method to easily create a paged response by specifying the field name of the object that contains the page info.
BUGS
Please report any bugs or feature requests on the bugtracker website https://github.com/chazmcgarvey/WebService-BitbucketServer/issues
When submitting a bug or request, please include a test-file or a patch to an existing test-file that illustrates the bug or desired feature.
AUTHOR
Charles McGarvey <chazmcgarvey@brokenzipper.com>
COPYRIGHT AND LICENSE
This software is copyright (c) 2018 by Charles McGarvey.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.