NAME Catalyst::Action::FromPSGI - Use a PSGI app as a Catalyst action VERSION version 0.001006 SYNOPSIS First, you have a psgi app you wrote and want to use: package MyApp::WS::App; use Web::Simple; has name => ( is => 'ro', required => 1, ); sub dispatch_request { sub (/hi) { [ 200, [ 'Content-type' => 'text/plain' ], [ 'Hello ' . $_[0]->name ] ] }, } 1; Now you want to reuse this app in a Catalyst action: package MyApp::Controller::HelloName; use base 'Catalyst::Controller'; sub say_hi :Path('/say_hi_to') ActionClass('FromPSGI') { my ($self, $c, $name, @args) = @_; MyApp::WS::App->new(name => $name)->to_psgi_app } 1; The above would yield 'Hello fREW' for the request to "/say_hi_to/fREW/hi". Of course the above example is contrived, but keep in mind this will work for any of the myriad PSGI apps out there. DESCRIPTION "Catalyst::Action::FromPSGI" gives you a handy way to mount PSGI apps under Catalyst actions. Note that because Catalyst is in control of the dispatch cycle any limitations you place on it will be placed on the PSGI app as well. So for example: sub foo : Path('/foo') Args(1) ActionClass('FromPSGI') { ... } will never run the PSGI app if the url is "/foo/bar/baz" because the Catalyst dispatcher won't even match for more than one argument. For this reason I recommend leaving "Args" unspecified for "FromPSGI" actions. I actually made this because I'm interested in using Web::Machine instead of Catalyst::Action::REST and possibly even replacing my chaining code with Web::Simple based dispatching. THANKS Matt S. Trout - for pioneering the actual guts of this code. Stevan Little - for porting Web::Machine, my motivation for making this. AUTHOR Arthur Axel "fREW" Schmidt <frioux+cpan@gmail.com> COPYRIGHT AND LICENSE This software is copyright (c) 2014 by Arthur Axel "fREW" Schmidt. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.