X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FPlugin%2FSession.pm;h=9cdf6281c86b07614e610259969ddd153e845b60;hb=fff59d60cf54ef8d5040df21b36324b07df0cc36;hp=8b66e786a684534a96a2e60ee515b0106122fd3a;hpb=eb250519802344a677c86103e5bba640dc40d59f;p=catagits%2FCatalyst-Plugin-Session.git diff --git a/lib/Catalyst/Plugin/Session.pm b/lib/Catalyst/Plugin/Session.pm index 8b66e78..9cdf628 100644 --- a/lib/Catalyst/Plugin/Session.pm +++ b/lib/Catalyst/Plugin/Session.pm @@ -1,23 +1,24 @@ #!/usr/bin/perl package Catalyst::Plugin::Session; -use base qw/Class::Accessor::Fast/; use strict; use warnings; -use NEXT; +use Moose; +with 'MooseX::Emulate::Class::Accessor::Fast'; +use MRO::Compat; use Catalyst::Exception (); use Digest (); use overload (); use Object::Signature (); use Carp; -our $VERSION = '0.20'; +our $VERSION = '0.21'; my @session_data_accessors; # used in delete_session -BEGIN { - __PACKAGE__->mk_accessors( + +__PACKAGE__->mk_accessors( "_session_delete_reason", @session_data_accessors = qw/ _sessionid @@ -33,13 +34,13 @@ BEGIN { _tried_loading_session_expires _tried_loading_flash_data / - ); -} +); + sub setup { my $c = shift; - $c->NEXT::setup(@_); + $c->maybe::next::method(@_); $c->check_session_plugin_requirements; $c->setup_session; @@ -73,7 +74,7 @@ sub setup_session { %$cfg, ); - $c->NEXT::setup_session(); + $c->maybe::next::method(); } sub prepare_action { @@ -86,7 +87,7 @@ sub prepare_action { @{ $c->stash }{ keys %$flash_data } = values %$flash_data; } - $c->NEXT::prepare_action(@_); + $c->maybe::next::method(@_); } sub finalize_headers { @@ -95,22 +96,24 @@ sub finalize_headers { # fix cookie before we send headers $c->_save_session_expires; - return $c->NEXT::finalize_headers(@_); + return $c->maybe::next::method(@_); } -sub finalize { +sub finalize_body { my $c = shift; - my $ret = $c->NEXT::finalize(@_); - # then finish the rest + # We have to finalize our session *before* $c->engine->finalize_xxx is called, + # because we do not want to send the HTTP response before the session is stored/committed to + # the session database (or whatever Session::Store you use). $c->finalize_session; - return $ret; + + return $c->maybe::next::method(@_); } sub finalize_session { my $c = shift; - $c->NEXT::finalize_session; + $c->maybe::next::method(@_); $c->_save_session_id; $c->_save_session; @@ -271,7 +274,7 @@ sub _expire_session_keys { sub _clear_session_instance_data { my $c = shift; $c->$_(undef) for @session_data_accessors; - $c->NEXT::_clear_session_instance_data; # allow other plugins to hook in on this + $c->maybe::next::method(@_); # allow other plugins to hook in on this } sub delete_session { @@ -514,7 +517,7 @@ sub dump_these { my $c = shift; ( - $c->NEXT::dump_these(), + $c->maybe::next::method(), $c->sessionid ? ( [ "Session ID" => $c->sessionid ], [ Session => $c->session ], ) @@ -523,10 +526,10 @@ sub dump_these { } -sub get_session_id { shift->NEXT::get_session_id(@_) } -sub set_session_id { shift->NEXT::set_session_id(@_) } -sub delete_session_id { shift->NEXT::delete_session_id(@_) } -sub extend_session_id { shift->NEXT::extend_session_id(@_) } +sub get_session_id { shift->maybe::next::method(@_) } +sub set_session_id { shift->maybe::next::method(@_) } +sub delete_session_id { shift->maybe::next::method(@_) } +sub extend_session_id { shift->maybe::next::method(@_) } __PACKAGE__; @@ -764,10 +767,10 @@ prepare time. This method is extended and will extend the expiry time before sending the response. -=item finalize +=item finalize_body -This method is extended and will call finalize_session after the other -finalizes run. Here we persist the session data if a session exists. +This method is extended and will call finalize_session before the other +finalize_body methods run. Here we persist the session data if a session exists. =item initialize_session_data @@ -1010,10 +1013,14 @@ Andy Grundman Christian Hansen -Yuval Kogman, C (current maintainer) +Yuval Kogman, C Sebastian Riedel +Tomas Doran (t0m) C (current maintainer) + +Sergio Salvi + And countless other contributers from #catalyst. Thanks guys! =head1 COPYRIGHT & LICENSE