line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
1
|
|
|
1
|
|
427
|
use strict; |
|
1
|
|
|
|
|
1
|
|
|
1
|
|
|
|
|
23
|
|
2
|
1
|
|
|
1
|
|
3
|
use warnings; |
|
1
|
|
|
|
|
1
|
|
|
1
|
|
|
|
|
42
|
|
3
|
|
|
|
|
|
|
package Exception::Reporter::Summarizer::PlackRequest; |
4
|
|
|
|
|
|
|
$Exception::Reporter::Summarizer::PlackRequest::VERSION = '0.001'; |
5
|
1
|
|
|
1
|
|
336
|
use parent 'Exception::Reporter::Summarizer'; |
|
1
|
|
|
|
|
196
|
|
|
1
|
|
|
|
|
5
|
|
6
|
|
|
|
|
|
|
# ABSTRACT: a summarizer for Plack::Request objects |
7
|
|
|
|
|
|
|
|
8
|
1
|
|
|
1
|
|
996
|
use Plack::Request; |
|
1
|
|
|
|
|
48095
|
|
|
1
|
|
|
|
|
29
|
|
9
|
|
|
|
|
|
|
|
10
|
|
|
|
|
|
|
#pod =head1 OVERVIEW |
11
|
|
|
|
|
|
|
#pod |
12
|
|
|
|
|
|
|
#pod If added as a summarizer to an L, this plugin will |
13
|
|
|
|
|
|
|
#pod summarize L objects, adding a summary for the request. |
14
|
|
|
|
|
|
|
#pod |
15
|
|
|
|
|
|
|
#pod =cut |
16
|
|
|
|
|
|
|
|
17
|
1
|
|
|
1
|
|
395
|
use Try::Tiny; |
|
1
|
|
|
|
|
1448
|
|
|
1
|
|
|
|
|
284
|
|
18
|
|
|
|
|
|
|
|
19
|
|
|
|
|
|
|
sub new { |
20
|
1
|
|
|
1
|
0
|
308
|
my ($class, $arg) = @_; |
21
|
1
|
|
50
|
|
|
7
|
$arg ||= {}; |
22
|
|
|
|
|
|
|
|
23
|
1
|
|
|
|
|
5
|
return bless { } => $class; |
24
|
|
|
|
|
|
|
} |
25
|
|
|
|
|
|
|
|
26
|
|
|
|
|
|
|
sub can_summarize { |
27
|
0
|
|
|
0
|
0
|
|
my ($self, $entry) = @_; |
28
|
0
|
|
|
0
|
|
|
return try { $entry->[1]->isa('Plack::Request') }; |
|
0
|
|
|
|
|
|
|
29
|
|
|
|
|
|
|
} |
30
|
|
|
|
|
|
|
|
31
|
|
|
|
|
|
|
sub summarize { |
32
|
0
|
|
|
0
|
0
|
|
my ($self, $entry) = @_; |
33
|
0
|
|
|
|
|
|
my ($name, $req, $arg) = @$entry; |
34
|
|
|
|
|
|
|
|
35
|
0
|
|
|
|
|
|
my @summaries; |
36
|
|
|
|
|
|
|
|
37
|
0
|
|
|
|
|
|
push @summaries, $self->summarize_request($req); |
38
|
|
|
|
|
|
|
|
39
|
0
|
|
|
|
|
|
return @summaries; |
40
|
|
|
|
|
|
|
} |
41
|
|
|
|
|
|
|
|
42
|
|
|
|
|
|
|
sub summarize_request { |
43
|
0
|
|
|
0
|
0
|
|
my ($self, $req) = @_; |
44
|
|
|
|
|
|
|
|
45
|
|
|
|
|
|
|
my %to_dump = map { |
46
|
0
|
0
|
|
|
|
|
$_ => defined($req->$_) ? ($req->$_ . "") : undef, |
|
0
|
|
|
|
|
|
|
47
|
|
|
|
|
|
|
} qw( |
48
|
|
|
|
|
|
|
address |
49
|
|
|
|
|
|
|
content_length |
50
|
|
|
|
|
|
|
content_type |
51
|
|
|
|
|
|
|
content_encoding |
52
|
|
|
|
|
|
|
remote_host |
53
|
|
|
|
|
|
|
protocol |
54
|
|
|
|
|
|
|
method |
55
|
|
|
|
|
|
|
port |
56
|
|
|
|
|
|
|
user |
57
|
|
|
|
|
|
|
request_uri |
58
|
|
|
|
|
|
|
path_info |
59
|
|
|
|
|
|
|
path |
60
|
|
|
|
|
|
|
query_string |
61
|
|
|
|
|
|
|
referer |
62
|
|
|
|
|
|
|
user_agent |
63
|
|
|
|
|
|
|
script_name |
64
|
|
|
|
|
|
|
scheme |
65
|
|
|
|
|
|
|
secure |
66
|
|
|
|
|
|
|
); |
67
|
|
|
|
|
|
|
|
68
|
0
|
|
|
|
|
|
$to_dump{upload} = [ $req->upload ]; |
69
|
0
|
|
|
|
|
|
$to_dump{cookies} = $req->cookies; |
70
|
|
|
|
|
|
|
|
71
|
|
|
|
|
|
|
return { |
72
|
|
|
|
|
|
|
filename => 'request.txt', |
73
|
0
|
|
|
|
|
|
%{ $self->dump(\%to_dump, { basename => 'request' }) }, |
|
0
|
|
|
|
|
|
|
74
|
|
|
|
|
|
|
ident => 'plack request', |
75
|
|
|
|
|
|
|
}; |
76
|
|
|
|
|
|
|
} |
77
|
|
|
|
|
|
|
|
78
|
|
|
|
|
|
|
1; |
79
|
|
|
|
|
|
|
|
80
|
|
|
|
|
|
|
__END__ |