X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FAction%2FSerialize%2FJSONP.pm;h=1957108b88495b22bf890b0fade6c2c8754f5b9f;hb=40de934ce925aa9fbf1d2fa15846b5c0de9ec790;hp=5cae844adefa07f105e5a493e6628c6c84ce0fc4;hpb=aeb7a0aed21222c37b22173e0ed000f9cb217b6f;p=catagits%2FCatalyst-Action-REST.git diff --git a/lib/Catalyst/Action/Serialize/JSONP.pm b/lib/Catalyst/Action/Serialize/JSONP.pm index 5cae844..1957108 100644 --- a/lib/Catalyst/Action/Serialize/JSONP.pm +++ b/lib/Catalyst/Action/Serialize/JSONP.pm @@ -1,34 +1,33 @@ package Catalyst::Action::Serialize::JSONP; -use strict; -use warnings; -use MRO::Compat; +use Moose; +use namespace::autoclean; -use base 'Catalyst::Action::Serialize::JSON'; +extends 'Catalyst::Action::Serialize::JSON'; -sub execute { +our $VERSION = '1.01'; +$VERSION = eval $VERSION; + +after 'execute' => sub { my $self = shift; my ($controller, $c) = @_; my $callback_key = ( $controller->{'serialize'} ? $controller->{'serialize'}->{'callback_key'} : - $controller->{'callback_key'} + $controller->{'callback_key'} ) || 'callback'; - if ($c->req->param($callback_key)) { - $self->{_jsonp_callback} = $c->req->param($callback_key); - $c->res->content_type('text/javascript'); + my $callback_value = $c->req->param($callback_key); + if ($callback_value) { + if ($callback_value =~ /^[.\w]+$/) { + $c->res->content_type('text/javascript'); + $c->res->output($callback_value.'('.$c->res->output().');'); + } else { + warn 'Callback: '.$callback_value.' will not generate valid Javascript. Falling back to JSON output'; + } } - $self->next::method($controller, $c); -} +}; -sub serialize { - my $self = shift; - my $json = $self->next::method(@_); - if ($self->{_jsonp_callback}) { - $json = $self->{_jsonp_callback}.'('.$json.');'; - } - return $json; -} +__PACKAGE__->meta->make_immutable; 1;