File Coverage

blib/lib/API/MailboxOrg/APIBase.pm
Criterion Covered Total %
statement 48 55 87.2
branch 5 12 41.6
condition 1 3 33.3
subroutine 11 11 100.0
pod n/a
total 65 81 80.2


line stmt bran cond sub pod time code
1              
2             # ABSTRACT: Base class for all entity classes
3              
4             use v5.24;
5 2     2   1027  
  2         7  
6             use strict;
7 2     2   9 use warnings;
  2         3  
  2         37  
8 2     2   7  
  2         3  
  2         47  
9             use Carp;
10 2     2   8 use Moo;
  2         22  
  2         99  
11 2     2   11 use Params::ValidationCompiler qw(validation_for);
  2         3  
  2         10  
12 2     2   608 use Types::Mojo qw(:all);
  2         3  
  2         77  
13 2     2   11 use Types::Standard qw(Str Object Int);
  2         2  
  2         16  
14 2     2   5701  
  2         4  
  2         11  
15             use feature 'signatures';
16 2     2   1507 no warnings 'experimental::signatures';
  2         3  
  2         158  
17 2     2   10  
  2         4  
  2         698  
18             our $VERSION = '1.0.2'; # VERSION
19              
20             has api => ( is => 'ro', isa => Object, required => 1 );
21             has json_rpc => ( is => 'ro', isa => Str, default => sub { '2.0' } );
22              
23             state $request_id = 1;
24              
25             my $rpc_data = {
26 1     1   1 jsonrpc => $self->json_rpc,
  1         3  
  1         1  
  1         3  
  1         2  
  1         1  
27 1         8 id => $request_id++,
28             method => $method,
29             };
30              
31             $rpc_data->{params} = $params->%* ? $params : "";
32              
33 1 50       5 my $api = $self->api;
34              
35 1         4 if ( $opts->{needs_auth} && !$api->token ) {
36             my $auth_result = $api->base->auth(
37 1 50 33     4 user => $api->user,
38 0         0 pass => $api->password,
39             );
40              
41             my $token = ref $auth_result ?
42             $auth_result->{session} :
43             croak 'Could not login: ' . $auth_result;
44              
45 0 0       0 $api->_set_token( $token );
46             }
47 0         0  
48             my %header = ( 'Content-Type' => 'application/json' );
49             $header{'HPLS-AUTH'} = $api->token if $api->token;
50 1         4  
51 1 50       6 my $uri = join '/',
52             $api->host,
53 1         6 $api->base_uri;
54              
55             my $tx = $api->client->post(
56             $uri,
57 1         374 \%header,
58             json => $rpc_data,
59             );
60              
61             my $response = $tx->res;
62              
63 1         388997 if ( $tx->error ) {
64             carp $tx->error->{message};
65 1 50       6 return;
66 0         0 }
67 0         0  
68             my $data = $response->json;
69              
70 1         24 if ( $data->{error} ) {
71             carp $data->{error}->{message};
72 1 50       244 return;
73 0         0 }
74 0         0  
75             return $data->{result};
76             }
77 1         11  
78             1;
79              
80              
81             =pod
82              
83             =encoding UTF-8
84              
85             =head1 NAME
86              
87             API::MailboxOrg::APIBase - Base class for all entity classes
88              
89             =head1 VERSION
90              
91             version 1.0.2
92              
93             =head1 ATTRIBUTES
94              
95             =over 4
96              
97             =item * json_rpc
98              
99             I<(optional)> The version of JSON-RPC used. Defaults to C<2.0>.
100              
101             =item * api
102              
103             I<mandatory> An L<API::MailboxOrg> object.
104              
105             =back
106              
107             =head1 METHODS
108              
109             =head2 request
110              
111             This method builds the API request. If a method is called that needs authentification
112             and there's no session, then the C<auth> method is called.
113              
114             =head1 AUTHOR
115              
116             Renee Baecker <reneeb@cpan.org>
117              
118             =head1 COPYRIGHT AND LICENSE
119              
120             This software is Copyright (c) 2022 by Renee Baecker.
121              
122             This is free software, licensed under:
123              
124             The Artistic License 2.0 (GPL Compatible)
125              
126             =cut