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.

Emulate logout by clearing user from $c->session

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.