NAME Catalyst::Action::RenderView - Sensible default end action. SYNOPSIS sub end : ActionClass('RenderView') {} DESCRIPTION This action implements a sensible default end action, which will forward to the first available view, unless "$c->res->status" is a 3xx code (redirection, not modified, etc.), 204 (no content), or "$c->res->body" has already been set. It also allows you to pass "dump_info=1" to the url in order to force a debug screen, while in debug mode. If you have more than one view, you can specify which one to use with the "default_view" config setting and the "current_view" and "current_view_instance" stash keys (see Catalyst's "$c->view($name)" method -- this module simply calls "$c->view" with no argument). METHODS end The default "end" action. You can override this as required in your application class; normal inheritance applies. INTERNAL METHODS execute Dispatches control to superclasses, then forwards to the default View. See "METHODS/action" in Catalyst::Action. SCRUBBING OUTPUT When you force debug with dump_info=1, RenderView is capable of removing classes from the objects in your stash. By default it will replace any DBIx::Class ResultSource objects with the class name, which cleans up the debug output considerably, but you can change what gets scrubbed by setting a list of classes in $c->config->{'Action::RenderView'}->{ignore_classes}. For instance: $c->config->{'Action::RenderView'}->{ignore_classes} = []; To disable the functionality. You can also set config->{'Action::RenderView'}->{scrubber_func} to change what it does with the classes. For instance, this will undef it instead of putting in the class name: $c->config->{'Action::RenderView'}->{scrubber_func} = sub { undef $_ }; Deprecation notice This plugin used to be configured by setting "$c->config->{debug}". That configuration key is still supported in this release, but is deprecated, please use the 'Action::RenderView' namespace as shown above for configuration in new code. EXTENDING To add something to an "end" action that is called before rendering, simply place it in the "end" method: sub end : ActionClass('RenderView') { my ( $self, $c ) = @_; # do stuff here; the RenderView action is called afterwards } To add things to an "end" action that are called *after* rendering, you can set it up like this: sub render : ActionClass('RenderView') { } sub end : Private { my ( $self, $c ) = @_; $c->forward('render'); # do stuff here } AUTHORS * Marcus Ramberg <marcus@thefeed.no> * Florian Ragwitz <rafl@debian.org> CONTRIBUTOR Graham Knop <haarg@haarg.org> COPYRIGHT AND LICENSE This software is copyright (c) 2006 - 2009 by Marcus Ramberg and Florian Ragwitz. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.