X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FAction%2FSerializeBase.pm;h=7892ea4f178978c101299ac119bfc950eb74f24e;hb=f465980c3c25b475d878716b7341d0a4f5c8f823;hp=b7a6765d3186e9657a443efc2464db3380d7fe75;hpb=c0aef9cd678b6b4e4ea557d7fa1e8f43153e00b0;p=catagits%2FCatalyst-Action-REST.git diff --git a/lib/Catalyst/Action/SerializeBase.pm b/lib/Catalyst/Action/SerializeBase.pm index b7a6765..7892ea4 100644 --- a/lib/Catalyst/Action/SerializeBase.pm +++ b/lib/Catalyst/Action/SerializeBase.pm @@ -1,21 +1,22 @@ -# -# Catlyst::Action::SerializeBase.pm -# Created by: Adam Jacob, Marchex, -# -# $Id$ - package Catalyst::Action::SerializeBase; -use strict; -use warnings; +use Moose; +use namespace::autoclean; -use base 'Catalyst::Action'; +extends 'Catalyst::Action'; use Module::Pluggable::Object; -use Data::Dump qw(dump); use Catalyst::Request::REST; +use Catalyst::Utils (); + +our $VERSION = '0.81'; +$VERSION = eval $VERSION; -Catalyst->request_class('Catalyst::Request::REST') - unless Catalyst->request_class->isa('Catalyst::Request::REST'); +sub new { + my $class = shift; + my $config = shift; + Catalyst::Request::REST->_insert_self_into( $config->{class} ); + return $class->SUPER::new($config, @_); +} __PACKAGE__->mk_accessors(qw(_serialize_plugins _loaded_plugins)); @@ -45,26 +46,38 @@ sub _load_content_plugins { my $config; - if ( exists $controller->config->{'serialize'} ) { - $c->log->info("Using deprecated configuration for Catalyst::Action::REST!"); - $c->log->info("Please see perldoc Catalyst::Action::REST for the update guide"); - $config = $controller->config->{'serialize'}; + if ( exists $controller->{'serialize'} ) { + $c->log->info("Catalyst::Action::REST - deprecated use of 'serialize' for configuration."); + $c->log->info("Please see 'CONFIGURATION' in Catalyst::Controller::REST."); + $config = $controller->{'serialize'}; + # if they're using the deprecated config, they may be expecting a + # default mapping too. + $config->{map} ||= $controller->{map}; } else { - $config = $controller->config; + $config = $controller; } $map = $config->{'map'}; - # If we don't have a handler for our preferred content type, try - # the default - my ($content_type) = grep { $map->{$_} } @{$c->request->accepted_content_types}; - - unless ( defined $content_type ) { - if( exists $config->{'default'} ) { - $content_type = $config->{'default'} ; - } else { - return $self->_unsupported_media_type($c, $content_type); - } + # pick preferred content type + my @accepted_types; # priority order, best first + # give top priority to content type specified by stash, if any + my $content_type_stash_key = $config->{content_type_stash_key}; + if ($content_type_stash_key + and my $stashed = $c->stash->{$content_type_stash_key} + ) { + # convert to array if not already a ref + $stashed = [ $stashed ] if not ref $stashed; + push @accepted_types, @$stashed; } + # then content types requested by caller + push @accepted_types, @{ $c->request->accepted_content_types }; + # then the default + push @accepted_types, $config->{'default'} if $config->{'default'}; + # pick the best match that we have a serializer mapping for + my ($content_type) = grep { $map->{$_} } @accepted_types; + + return $self->_unsupported_media_type($c, $content_type) + if not $content_type; # carp about old text/x-json if ($content_type eq 'text/x-json') { @@ -161,15 +174,12 @@ code for L and L. L, L, L, -=head1 AUTHOR +=head1 AUTHORS -Adam Jacob , with lots of help from mst and jrockway. - -Marchex, Inc. paid me while I developed this module. (http://www.marchex.com) +See L for authors. =head1 LICENSE You may distribute this code under the same terms as Perl itself. =cut -