X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FAction%2FDeserialize%2FJSON.pm;h=46fdf085e29a0fafed346d0e7aa2aa9697c87bd1;hb=8d507a2fdb74a618a20c2d7bcac3f29d13703f60;hp=82002df29bba8912092053fe36b118a558924107;hpb=be3c588afb1dd6d6c8e6171c01c3d38afa75d6d5;p=catagits%2FCatalyst-Action-REST.git diff --git a/lib/Catalyst/Action/Deserialize/JSON.pm b/lib/Catalyst/Action/Deserialize/JSON.pm index 82002df..46fdf08 100644 --- a/lib/Catalyst/Action/Deserialize/JSON.pm +++ b/lib/Catalyst/Action/Deserialize/JSON.pm @@ -1,33 +1,44 @@ -# -# Catlyst::Action::Deserialize::JSON.pm -# Created by: Adam Jacob, Marchex, -# Created on: 10/12/2006 03:00:32 PM PDT -# -# $Id$ - package Catalyst::Action::Deserialize::JSON; -use strict; -use warnings; +use Moose; +use namespace::autoclean; +use Scalar::Util qw(openhandle); +BEGIN { + $ENV{'PERL_JSON_BACKEND'} = 2; # Always use compiled JSON::XS +} + +extends 'Catalyst::Action'; +use JSON; -use base 'Catalyst::Action'; -use JSON::Syck; +our $VERSION = '1.00'; +$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; } } if ( $rbody ) { - my $rdata = eval { JSON::Syck::Load( $rbody ); }; + my $json = JSON->new->utf8; + if (my $options = $controller->{json_options}) { + foreach my $opt (keys %$options) { + $json->$opt( $options->{$opt} ); + } + } + my $rdata = eval { $json->decode( $rbody ) }; if ($@) { return $@; } @@ -40,4 +51,6 @@ sub execute { return 1; } +__PACKAGE__->meta->make_immutable; + 1;