8 |
use LWP::UserAgent; |
use LWP::UserAgent; |
9 |
use JSON; |
use JSON; |
10 |
use Data::Dump qw/dump/; |
use Data::Dump qw/dump/; |
11 |
|
use Time::HiRes qw/time/; |
12 |
|
use Data::Structure::Util qw(unbless); |
13 |
|
use Scalar::Util qw/blessed/; |
14 |
|
use Storable qw/dclone/; |
15 |
|
|
16 |
sub new { |
sub new { |
17 |
my ($class, $host, $port, $options) = @_; |
my ($class, $host, $port, $options) = @_; |
69 |
sub get { |
sub get { |
70 |
my ($self, $url) = @_; |
my ($self, $url) = @_; |
71 |
|
|
72 |
from_json $self->request(GET => $url); |
JSON->new->utf8->decode( $self->request(GET => $url) ); |
73 |
} |
} |
74 |
|
|
75 |
sub put { |
sub put { |
76 |
my ($self, $url, $json) = @_; |
my ($self, $url, $json) = @_; |
|
warn "put $url ",dump($json); |
|
77 |
|
|
78 |
$rev->{$url} ||= eval { $self->get( $url )->{_rev} }; |
if ( ! defined $json->{_rev} ) { |
79 |
|
my $old = eval { $self->get( $url )->{_rev} }; |
80 |
|
$rev->{$url} = $json->{_rev} = $old if defined $old; |
81 |
|
} |
82 |
|
|
83 |
|
my $data = dclone $json; |
84 |
|
$data = unbless $data if blessed $data; |
85 |
|
|
86 |
$json->{_rev} = $rev->{$url} if $rev->{$url}; |
warn dump( $data ); |
87 |
|
|
88 |
$json = to_json $json if $json; |
$json = JSON->new->utf8->encode( $data ); |
89 |
|
|
90 |
$self->request(PUT => $url, $json); |
warn $json; |
91 |
|
|
92 |
|
do { |
93 |
|
eval { $self->request(PUT => $url, $json) }; |
94 |
|
$rev->{$url} = $self->get( $url )->{_rev} if $@; |
95 |
|
} until ! $@; |
96 |
} |
} |
97 |
|
|
98 |
sub post { |
sub post { |
101 |
$self->request(POST => $url, $json); |
$self->request(POST => $url, $json); |
102 |
} |
} |
103 |
|
|
104 |
|
our $audit = __PACKAGE__->new; |
105 |
|
|
106 |
|
sub audit { |
107 |
|
my $data = pop @_; |
108 |
|
|
109 |
|
my $url = join(' ', @_); |
110 |
|
$url =~ s/\s+-\S+//g; # remove command line options |
111 |
|
$url =~ s/\W+/-/g; |
112 |
|
|
113 |
|
my ( $package, $file, $line, $sub ) = caller(1); |
114 |
|
# ( $package, undef, $line ) = caller(0) if $package eq 'main'; |
115 |
|
|
116 |
|
my $time = time(); |
117 |
|
|
118 |
|
$data->{$_} = eval '$' . $_ foreach ( qw/time package line sub/ ); |
119 |
|
|
120 |
|
warn 'audit ', dump($data), "at $file +$line\n"; |
121 |
|
|
122 |
|
$time = int($time); # reduce granularity |
123 |
|
$audit->put( "pxelator/$time.$package.$url", $data ); |
124 |
|
|
125 |
|
} |
126 |
|
|
127 |
1; |
1; |