in reply to Stop Catalyst::Plugin::Session from autoextending sessions for certain requests
This is a really good question. I feel like there should be a best practice for it but I don't have one. Here is a handful of suggestions.
If your have your view classes divided properly, this version should be easy. Just put it in your non-Ajax/JSON view class's end. I include Catalyst::Action::RenderView despite the simplistic example as I consider it a best practice and it enables app (or view at least) wide error handling.
sub render : ActionClass("RenderView") {} sub end : Private { my ( $self, $c ) = @_; $c->session_expire_key( __user => 3600 ); # "Expiration" is now 1 +hour. $c->forward("render"); }
Possible variation, untested, might need browser specific tweaks. :(
$c->session_expire_key( __user => 3600 ) unless $c->req->header("X-Requested-With") eq "XMLHttpRequest";
See also, Catalyst::Manual::Cookbook.
|
|---|