X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Action-REST.git;a=blobdiff_plain;f=lib%2FCatalyst%2FAction%2FDeserialize%2FData%2FSerializer.pm;fp=lib%2FCatalyst%2FAction%2FDeserialize%2FData%2FSerializer.pm;h=0000000000000000000000000000000000000000;hp=8eacc742051d7f7beeeca8ddbfa0ada883167300;hb=1bb213fc84712fcc13431f4e48b0d0ad74aa7dc3;hpb=f10c7e1c7eb3b4cb10401dbb86ca8db3dc38ced2 diff --git a/lib/Catalyst/Action/Deserialize/Data/Serializer.pm b/lib/Catalyst/Action/Deserialize/Data/Serializer.pm deleted file mode 100644 index 8eacc74..0000000 --- a/lib/Catalyst/Action/Deserialize/Data/Serializer.pm +++ /dev/null @@ -1,70 +0,0 @@ -package Catalyst::Action::Deserialize::Data::Serializer; - -use Moose; -use namespace::autoclean; - -extends 'Catalyst::Action'; -use Data::Serializer; -use Safe; -use Scalar::Util qw(openhandle); -my $compartment = Safe->new; -$compartment->permit_only( qw(padany null lineseq const pushmark list anonhash anonlist refgen leaveeval undef) ); - -our $VERSION = '1.07'; -$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(openhandle $body) { - seek($body, 0, 0); # in case something has already read from it - while ( defined( my $line = <$body> ) ) { - $rbody .= $line; - } - } else { - $rbody = $body; - } - - my $rdata; - if ( $serializer eq "Data::Dumper" ) { - # Taken from Data::Serialize::Data::Dumper::deserialize, but run within a Safe compartment - my $code = $rbody =~ /^\{/ ? "+".$rbody : $rbody; - $rdata = $compartment->reval( $code ); - } - else { - my $dso = Data::Serializer->new( serializer => $serializer ); - 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!') - if $c->debug; - } - return 1; -} - -__PACKAGE__->meta->make_immutable; - -1;