X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=examples%2Fpublic-inbox.psgi;h=f57491228e55fb7f00164c0df4878e8902285ddf;hb=8665c69c48a88960ffb0aa6a9bacc380fa86f83d;hp=8eb67eb182fb01641565dd0932258760709b366c;hpb=dd4f0e17f40a9d77c48bb0e868efdc744401dc0c;p=public-inbox.git diff --git a/examples/public-inbox.psgi b/examples/public-inbox.psgi index 8eb67eb1..f5749122 100644 --- a/examples/public-inbox.psgi +++ b/examples/public-inbox.psgi @@ -1,13 +1,46 @@ #!/usr/bin/perl -w -# Copyright (C) 2014, Eric Wong and all contributors +# Copyright (C) 2014-2015 all contributors # License: AGPLv3 or later (https://www.gnu.org/licenses/agpl-3.0.txt) # Note: this is part of our test suite, update t/plack.t if this changes # Usage: plackup [OPTIONS] /path/to/this/file +# A startup command for development which monitors changes: +# plackup -I lib -o 127.0.0.1 -R lib -r examples/public-inbox.psgi use strict; use warnings; -require PublicInbox::WWW; -require Plack::Request; -sub { - my $req = Plack::Request->new(@_); - PublicInbox::WWW::run($req, $req->method); -}; +use PublicInbox::WWW; +PublicInbox::WWW->preload; +use Plack::Request; +use Plack::Builder; +my $www = PublicInbox::WWW->new; +builder { + 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"; + + # Optional: Log timing information for requests to track performance. + # Logging to STDOUT is recommended since public-inbox-httpd knows + # how to reopen it via SIGUSR1 after log rotation. + # enable 'AccessLog::Timed', + # logger => sub { syswrite(STDOUT, $_[0]) }, + # format => '%t "%r" %>s %b %D'; + + enable 'Head'; + sub { $www->call(@_) }; +}