X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FAction%2FDeserialize%2FData%2FSerializer.pm;h=3ac3a18e874cfe7758aae445ad83a6ef58413074;hb=96a61a601b093754a99bb61b57e41dbfc3228ad7;hp=35917ec7d3b01ec4c75a4fd4e8dcbf209a190c69;hpb=7ad87df957f65463dba321ebe616e2581b7ff58f;p=catagits%2FCatalyst-Action-REST.git diff --git a/lib/Catalyst/Action/Deserialize/Data/Serializer.pm b/lib/Catalyst/Action/Deserialize/Data/Serializer.pm index 35917ec..3ac3a18 100644 --- a/lib/Catalyst/Action/Deserialize/Data/Serializer.pm +++ b/lib/Catalyst/Action/Deserialize/Data/Serializer.pm @@ -1,38 +1,54 @@ -# -# Catalyst::Action::Deserialize::Data::Serializer.pm -# Created by: Adam Jacob, Marchex, -# Created on: 10/12/2006 03:00:32 PM PDT -# -# $Id$ - package Catalyst::Action::Deserialize::Data::Serializer; -use strict; -use warnings; +use Moose; +use namespace::autoclean; -use base 'Catalyst::Action'; +extends 'Catalyst::Action'; use Data::Serializer; +our $VERSION = '0.84'; +$VERSION = eval $VERSION; + sub execute { my $self = shift; my ( $controller, $c, $serializer ) = @_; - + + my $sp = $serializer; + $sp =~ s/::/\//g; + $sp .= ".pm"; + eval { + require $sp + }; + if ($@) { + $c->log->debug("Could not load $serializer, refusing to serialize: $@") + if $c->debug; + return 0; + } my $body = $c->request->body; if ($body) { my $rbody; - if (-f $c->request->body) { - open(BODY, "<", $c->request->body); - while (my $line = ) { + if ( -f $c->request->body ) { + open( BODY, "<", $c->request->body ); + while ( my $line = ) { $rbody .= $line; } close(BODY); } - my $dso = Data::Serializer->new(serializer => $serializer); - my $rdata = $dso->raw_deserialize($rbody); + my $dso = Data::Serializer->new( serializer => $serializer ); + my $rdata; + eval { + $rdata = $dso->raw_deserialize($rbody); + }; + if ($@) { + return $@; + } $c->request->data($rdata); } else { - $c->log->debug('I would have deserialized, but there was nothing in the body!'); + $c->log->debug( + 'I would have deserialized, but there was nothing in the body!') + if $c->debug; } -}; + return 1; +} 1;