X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FAction%2FDeserialize%2FJSON.pm;h=7f80636f886387d7d8fe45a762e4d39d74f8a9ba;hb=1f22d6b363c1287923ac8333ebc67b6d0d735786;hp=252b78534b5998c43aa5853ba16c3075e36bb700;hpb=a9e5f3d2aa58a89ffd70ec22a5485fdbd4b7a3d6;p=catagits%2FCatalyst-Action-REST.git diff --git a/lib/Catalyst/Action/Deserialize/JSON.pm b/lib/Catalyst/Action/Deserialize/JSON.pm index 252b785..7f80636 100644 --- a/lib/Catalyst/Action/Deserialize/JSON.pm +++ b/lib/Catalyst/Action/Deserialize/JSON.pm @@ -2,23 +2,29 @@ package Catalyst::Action::Deserialize::JSON; use Moose; use namespace::autoclean; +use Scalar::Util qw(openhandle); extends 'Catalyst::Action'; use JSON; -our $VERSION = '0.88'; +our $VERSION = '0.97'; $VERSION = eval $VERSION; sub execute { my $self = shift; my ( $controller, $c, $test ) = @_; - my $body = $c->request->body; my $rbody; - if ($body) { - while (my $line = <$body>) { - $rbody .= $line; + # could be a string or a FH + if ( my $body = $c->request->body ) { + if(openhandle $body) { + seek($body, 0, 0); # in case something has already read from it + while ( defined( my $line = <$body> ) ) { + $rbody .= $line; + } + } else { + $rbody = $body; } } @@ -42,4 +48,6 @@ sub execute { return 1; } +__PACKAGE__->meta->make_immutable; + 1;