summaryrefslogtreecommitdiff
path: root/lib/Net/HTTP/API/Role/Authentication.pm
diff options
context:
space:
mode:
authorfranck cuny <franck@lumberjaph.net>2010-07-16 16:10:41 +0200
committerfranck cuny <franck@lumberjaph.net>2010-07-16 16:10:41 +0200
commite97449eaa8bd3a408763057f9ca2253d93e2a3d0 (patch)
tree4fd0dc6ed899efe361e314adfc913b9aa6b0a1a4 /lib/Net/HTTP/API/Role/Authentication.pm
parentcheck if auth_method is declared (diff)
downloadnet-http-api-e97449eaa8bd3a408763057f9ca2253d93e2a3d0.tar.gz
rename from mx::net::api to net::http::api
Diffstat (limited to 'lib/Net/HTTP/API/Role/Authentication.pm')
-rw-r--r--lib/Net/HTTP/API/Role/Authentication.pm67
1 files changed, 67 insertions, 0 deletions
diff --git a/lib/Net/HTTP/API/Role/Authentication.pm b/lib/Net/HTTP/API/Role/Authentication.pm
new file mode 100644
index 0000000..27728c3
--- /dev/null
+++ b/lib/Net/HTTP/API/Role/Authentication.pm
@@ -0,0 +1,67 @@
+package Net::HTTP::API::Role::Authentication;
+
+# ABSTRACT: Add authentication informations to request header
+
+use Moose::Role;
+
+has api_username => (
+ is => 'rw',
+ isa => 'Str',
+ predicate => 'has_api_username',
+);
+
+has api_password => (
+ is => 'rw',
+ isa => 'Str',
+ predicate => 'has_api_password',
+);
+
+# ugly :(
+after BUILDALL => sub {
+ my $self = shift;
+
+ for (qw/api_username api_password/) {
+ my $predicate = 'has_' . $_;
+ my $value = $self->meta->get_api_option($_);
+ $self->$_($value) if $value && !$self->$predicate;
+ }
+
+ if ( $self->meta->get_api_option('authentication')
+ || $self->meta->get_api_option('authentication_method'))
+ {
+ my $auth_method = $self->meta->get_api_option('authentication_method');
+ if ($auth_method) {
+ $self->api_useragent->add_handler(
+ request_prepare => sub { $self->$auth_method(@_) });
+ }
+ else {
+ if ($self->has_api_username && $self->has_api_password) {
+ $self->api_useragent->add_handler(
+ request_prepare => sub {
+ my $req = shift;
+ $req->headers->authorization_basic($self->api_username,
+ $self->api_password);
+ }
+ );
+ }
+ }
+ }
+};
+
+1;
+
+=head1 SYNOPSIS
+
+=head1 DESCRIPTION
+
+=head2 ATTRIBUTES
+
+=over 4
+
+=item B<api_password>
+
+=item B<api_username>
+
+=back
+64: hit eof while in pod documentation (no =cut seen)
+ this can cause trouble with some pod utilities