X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FPlugin%2FSession.pm;h=e9c2a13572ca2c6b41c9302c797be5321446cf69;hb=2842d93853af927a543214ccbe17d659f5ecd181;hp=1e9dd99319d1a2fd3b9b70caff2cc904934a305f;hpb=d423b91c24216b68620c52d0aea176366971760d;p=catagits%2FCatalyst-Plugin-Session.git diff --git a/lib/Catalyst/Plugin/Session.pm b/lib/Catalyst/Plugin/Session.pm index 1e9dd99..e9c2a13 100644 --- a/lib/Catalyst/Plugin/Session.pm +++ b/lib/Catalyst/Plugin/Session.pm @@ -13,7 +13,7 @@ use overload (); use Object::Signature (); use Carp; -our $VERSION = '0.20'; +our $VERSION = '0.19_01'; my @session_data_accessors; # used in delete_session BEGIN { @@ -98,13 +98,15 @@ sub finalize_headers { return $c->NEXT::finalize_headers(@_); } -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->NEXT::finalize_body(@_); } sub finalize_session { @@ -168,12 +170,15 @@ sub _save_flash { my $sid = $c->sessionid; + my $session_data = $c->_session; if (%$flash_data) { - $c->store_session_data( "flash:$sid", $flash_data ); + $session_data->{__flash} = $flash_data; } else { - $c->delete_session_data("flash:$sid"); + delete $session_data->{__flash}; } + $c->_session($session_data); + $c->_save_session; } } @@ -238,8 +243,11 @@ sub _load_flash { $c->_tried_loading_flash_data(1); if ( my $sid = $c->sessionid ) { - if ( my $flash_data = $c->_flash - || $c->_flash( $c->get_session_data("flash:$sid") ) ) + + my $session_data = $c->session; + $c->_flash($session_data->{__flash}); + + if ( my $flash_data = $c->_flash ) { $c->_flash_key_hashes({ map { $_ => Object::Signature::signature( \$flash_data->{$_} ) } keys %$flash_data }); @@ -687,6 +695,8 @@ changed, call C and pass in the keys as arguments. This method is used to invalidate a session. It takes an optional parameter which will be saved in C if provided. +NOTE: This method will B delete your flash data. + =item session_delete_reason This accessor contains a string with the reason a session was deleted. Possible @@ -756,10 +766,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 @@ -1002,10 +1012,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