X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=examples%2Fpublic-inbox.psgi;h=0d11c19fb8395e95097ad4d0bc443971860e3648;hb=1e25da9df6f7721f99c3d4beb8444ce1165c8097;hp=b0b9ae9850bd9620937a15dff753df152588d0df;hpb=e2ed3be62fbb53e16a9248a408a7a069a05842e6;p=public-inbox.git diff --git a/examples/public-inbox.psgi b/examples/public-inbox.psgi index b0b9ae98..0d11c19f 100644 --- a/examples/public-inbox.psgi +++ b/examples/public-inbox.psgi @@ -9,17 +9,28 @@ use PublicInbox::WWW; PublicInbox::WWW->preload; use Plack::Request; use Plack::Builder; -my $have_deflater = eval { require Plack::Middleware::Deflater; 1 }; - +my $www = PublicInbox::WWW->new; builder { - if ($have_deflater) { - enable "Deflater", - content_type => [ 'text/html', 'text/plain', - 'application/atom+xml' ]; - } - enable "Head"; - sub { - my $req = Plack::Request->new(@_); - PublicInbox::WWW::run($req, $req->method); - } + enable 'Chunked'; + eval { + enable 'Deflater', + content_type => [ qw( + text/html + text/plain + application/atom+xml + )] + }; + $@ and warn +"Plack::Middleware::Deflater missing, bandwidth will be wasted\n"; + # Enable to ensure redirects and Atom feed URLs are generated + # properly when running behind a reverse proxy server which + # sets X-Forwarded-For and X-Forwarded-Proto request headers. + # See Plack::Middleware::ReverseProxy documentation for details + eval { enable 'ReverseProxy' }; + $@ and warn +"Plack::Middleware::ReverseProxy missing,\n", +"URL generation for redirects may be wrong if behind a reverse proxy\n"; + + enable 'Head'; + sub { $www->call(@_) }; }