NAME
WebService::Client - A base role for quickly and easily creating web service clients
VERSION
version 0.0400
SYNOPSIS
{
package WebService::Foo;
use Moo;
with 'WebService::Client';
use Function::Parameters;
has '+base_url' => ( default => 'https://foo.com/v1' );
has auth_token => ( is => 'ro', required => 1 );
method BUILD() {
$self->ua->default_header('X-Auth-Token' => $self->auth_token);
# or if the web service uses http basic/digest authentication:
# $self->ua->credentials( ... );
# or
# $self->ua->default_headers->authorization_basic( ... );
}
method get_widgets() {
return $self->get("/widgets");
}
method get_widget($id) {
return $self->get("/widgets/$id");
}
method create_widget($widget_data) {
return $self->post("/widgets", $widget_data);
}
}
my $client = WebService::Foo->new(
auth_token => 'abc',
logger => Log::Tiny->new('/tmp/foo.log'), # optional
log_method => 'info', # optional, defaults to 'DEBUG'
timeout => 10, # optional, defaults to 10
retries => 0, # optional, defaults to 0
);
my $widget = $client->create_widget({ color => 'blue' });
print $client->get_widget($widget->{id})->{color};
DESCRIPTION
This module is a base role for quickly and easily creating web service clients. Every time I created a web service client, I noticed that I kept rewriting the same boilerplate code independent of the web service. This module does the boring boilerplate for you so you can just focus on the fun part - writing the web service specific code.
METHODS
These are the methods this role composes into your class. The HTTP methods (get, post, put, and delete) will return the deserialized response data, if the response body contained any data. This will usually be a hashref. If the web service responds with a failure, then the corresponding HTTP response object is thrown as an exception. This exception is a HTTP::Response object that has the HTTP::Response::Stringable role so it can be easily logged. GET requests that respond with a status code of 404
or 410
will not throw an exception. Instead, they will simply return undef
.
The http methods get/post/put/delete
can all take the following optional named arguments:
- headers
-
A hashref of custom headers to send for this request. In the future, this may also accept an arrayref. The header values can be any format that HTTP::Headers recognizes, so you can pass
content_type
instead ofContent-Type
. - serializer
-
A coderef that does custom serialization for this request. Set this to
undef
if you don't want any serialization to happen for this request. - deserializer
-
A coderef that does custom deserialization for this request. Set this to
undef
if you want the raw http response body to be returned.
Example:
$client->post(
/widgets,
{ color => 'blue' },
headers => { x_custom_header => 'blah' },
serializer => sub { ... },
deserialized => sub { ... },
}
get
$client->get('/foo');
$client->get('/foo', { query => 'params' });
$client->get('/foo', { query => [qw(array params)] });
Makes an HTTP GET request.
post
$client->post('/foo', { some => 'data' });
$client->post('/foo', { some => 'data' }, headers => { foo => 'bar' });
Makes an HTTP POST request.
put
$client->put('/foo', { some => 'data' });
Makes an HTTP PUT request.
delete
$client->delete('/foo');
Makes an HTTP DELETE request.
req
my $req = HTTP::Request->new(...);
$client->req($req);
This is called internally by the above HTTP methods. You will usually not need to call this explicitly. It is exposed as part of the public interface in case you may want to add a method modifier to it. Here is a contrived example:
around req => sub {
my ($orig, $self, $req) = @_;
$req->authorization_basic($self->login, $self->password);
return $self->$orig($req, @rest);
};
log
Logs a message using the provided logger.
ATTRIBUTES
base_url
This is the only attribute that is required. This is the base url that all request will be made against.
ua
Optional. A proper default LWP::UserAgent will be created for you.
timeout
Optional. Default is 10.
retries
Optional. Default is 0.
logger
Optional.
content_type
Optional. Default is 'application/json'
.
serializer
Optional. A coderef that serializes the request content. Set this to undef
if you don't want any serialization to happen.
deserializer
Optional. A coderef that deserializes the response body. Set this to undef
if you want the raw http response body to be returned.
EXAMPLES
Here are some examples of web service clients built with this role. You can view their source to help you get started.
SEE ALSO
AUTHOR
Naveed Massjouni <naveed@vt.edu>
COPYRIGHT AND LICENSE
This software is copyright (c) 2014 by Naveed Massjouni.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.