—=head1 NAME
Mojolicious::Plugin::PlackMiddleware - Plack::Middleware inside Mojolicious
=head1 SYNOPSIS
# Mojolicious
sub startup {
my $self = shift;
$self->plugin(plack_middleware => [
'MyMiddleware1',
'MyMiddleware2', {arg1 => 'some_vale'},
'MyMiddleware3', $condition_code_ref,
'MyMiddleware4', $condition_code_ref, {arg1 => 'some_value'}
]);
}
# Mojolicious::Lite
plugin plack_middleware => [
'MyMiddleware1',
'MyMiddleware2', {arg1 => 'some_vale'},
'MyMiddleware3', $condition_code_ref,
'MyMiddleware4', $condition_code_ref, {arg1 => 'some_value'}
];
package Plack::Middleware::MyMiddleware1;
use strict;
use warnings;
use base qw( Plack::Middleware );
sub call {
my($self, $env) = @_;
# pre-processing $env
my $res = $self->app->($env);
# post-processing $res
return $res;
}
=head1 DESCRIPTION
Mojolicious::Plugin::PlackMiddleware allows you to enable Plack::Middleware
inside Mojolicious using around_dispatch hook so that the portability of your
app covers pre/post process too.
It also aimed at those who used to Mojolicious bundle servers.
Note that if you can run your application on a plack server, there is proper
ways to use middlewares. See L<http://mojolicio.us/perldoc/Mojolicious/Guides/Cookbook#Plack-middleware>.
=head2 OPTIONS
This plugin takes an argument in Array reference which contains some
middlewares. Each middleware can be followed by callback function for
conditional activation, and attributes for middleware.
my $condition = sub {
my $c = shift; # Mojolicious controller
my $env = shift; # PSGI env
if (...) {
return 1; # causes the middleware hooked
}
};
plugin plack_middleware => [
Plack::Middleware::MyMiddleware, $condition, {arg1 => 'some_value'},
];
=head1 METHODS
=head2 register
$plugin->register;
Register plugin hooks in L<Mojolicious> application.
=head2 psgi_env_to_mojo_req
This is a utility method. This is for internal use.
my $mojo_req = psgi_env_to_mojo_req($psgi_env)
=head2 mojo_req_to_psgi_env
This is a utility method. This is for internal use.
my $plack_env = mojo_req_to_psgi_env($mojo_req)
=head2 psgi_res_to_mojo_res
This is a utility method. This is for internal use.
my $mojo_res = psgi_res_to_mojo_res($psgi_res)
=head2 mojo_res_to_psgi_res
This is a utility method. This is for internal use.
my $psgi_res = mojo_res_to_psgi_res($mojo_res)
=head1 Example
Plack::Middleware::Auth::Basic
$self->plugin(plack_middleware => [
'Auth::Basic' => sub {shift->req->url =~ qr{^/?path1/}}, {
authenticator => sub {
my ($user, $pass) = @_;
return $user eq 'user1' && $pass eq 'pass';
}
},
'Auth::Basic' => sub {shift->req->url =~ qr{^/?path2/}}, {
authenticator => sub {
my ($user, $pass) = @_;
return $user eq 'user2' && $pass eq 'pass2';
}
},
]);
Plack::Middleware::ErrorDocument
$self->plugin('plack_middleware', [
ErrorDocument => {
500 => "$FindBin::Bin/errors/500.html"
},
ErrorDocument => {
404 => "/errors/404.html",
subrequest => 1,
},
Static => {
path => qr{^/errors},
root => $FindBin::Bin
},
]);
Plack::Middleware::JSONP
$self->plugin('plack_middleware', [
JSONP => {callback_key => 'json.p'},
]);
=head1 AUTHOR
Sugama Keita, E<lt>sugama@jamadam.comE<gt>
=head1 COPYRIGHT AND LICENSE
Copyright (C) 2011 by Sugama Keita.
This program is free software; you can redistribute it and/or
modify it under the same terms as Perl itself.
=cut