File Coverage

blib/lib/Paws/Net/EC2Caller.pm
Criterion Covered Total %
statement 59 59 100.0
branch 15 18 83.3
condition n/a
subroutine 7 7 100.0
pod 0 3 0.0
total 81 87 93.1


line stmt bran cond sub pod time code
1             package Paws::Net::EC2Caller;
2 7     7   4888 use Moose::Role;
  7         17  
  7         60  
3 7     7   38454 use HTTP::Request::Common;
  7         27646  
  7         553  
4 7     7   51 use POSIX qw(strftime);
  7         16  
  7         60  
5              
6             sub array_flatten_string {
7 11     11 0 14 my $self = shift;
8 11 50       33 return ($self->flattened_arrays)?'%s.%d':'%s.member.%d';
9             }
10              
11             # converts the objects that represent the call into parameters that the API can understand
12             sub _to_querycaller_params {
13 28     28   82 my ($self, $params) = @_;
14 28         58 my %p;
15 28         133 foreach my $att (grep { $_ !~ m/^_/ } $params->meta->get_attribute_list) {
  169         1315  
16 169         259 my $key;
17 169 100       418 if ($params->meta->get_attribute($att)->does('Paws::API::Attribute::Trait::NameInRequest')){
18 156         40241 $key = $params->meta->get_attribute($att)->request_name;
19             } else {
20 13         1092 $key = $att;
21             }
22            
23             # This is due to code found in serialize.py (EC2Serializer)
24 169         600 substr($key,0,1) = uc(substr($key,0,1));
25              
26 169 100       4831 if (defined $params->$att) {
27 19         42 my $att_type = $params->meta->get_attribute($att)->type_constraint;
28              
29 19 100       976 if ($self->_is_internal_type($att_type)) {
    100          
30 14 100       784 if ($att_type eq 'Bool') {
31 1 50       34 $p{ $key } = ($params->{$att} == 1) ? 'true' : 'false';
32             } else {
33 13         410 $p{ $key } = $params->{$att};
34             }
35             } elsif ($att_type =~ m/^ArrayRef\[(.*)\]/) {
36 3 100       525 if ($self->_is_internal_type("$1")){
37 1         3 my $i = 1;
38 1         2 foreach my $value (@{ $params->$att }){
  1         28  
39 2         6 $p{ sprintf($self->array_flatten_string, $key, $i) } = $value;
40 2         5 $i++
41             }
42             } else {
43 2         4 my $i = 1;
44 2         3 foreach my $value (@{ $params->$att }){
  2         44  
45 4         14 my %complex_value = $self->_to_querycaller_params($value);
46 4         11 map { $p{ sprintf($self->array_flatten_string . ".%s", $key, $i, $_) } = $complex_value{$_} } keys %complex_value;
  9         21  
47 4         17 $i++
48             }
49             }
50             } else {
51 2         373 my %complex_value = $self->_to_querycaller_params($params->$att);
52 2         5 map { $p{ "$key.$_" } = $complex_value{$_} } keys %complex_value;
  2         11  
53             }
54             }
55             }
56 28         816 return %p;
57             }
58              
59             sub generate_content_from_parameters {
60 22     22 0 64 my ($self, $request) = @_;
61              
62 22         558 $request->headers->content_type('application/x-www-form-urlencoded');
63 22         402 my $url = URI->new('http:');
64 22         2403 $url->query_form($request->parameters);
65 22         2964 my $content = $url->query;
66             # HTML/4.01 says that line breaks are represented as "CR LF" pairs (i.e., `%0D%0A')
67 22 50       278 $content =~ s/(?<!%0D)%0A/%0D%0A/g if (defined $content);
68 22         679 return $content;
69             }
70              
71             sub prepare_request_for_call {
72 22     22 0 67 my ($self, $call) = @_;
73              
74 22         343 my $request = Paws::Net::APIRequest->new();
75              
76 22         15819 $request->url($self->_api_endpoint . '/');
77 22         626 $request->uri('/');
78 22         613 $request->method('POST');
79              
80 22         658 $request->parameters({ Action => $call->_api_call,
81             Version => $self->version,
82             $self->_to_querycaller_params($call)
83             });
84              
85 22         98 $request->content($self->generate_content_from_parameters($request));
86              
87 22         134 $self->sign($request);
88              
89 22         791 return $request;
90             }
91             1;