]> Sergey Matveev's repositories - public-inbox.git/blob - examples/public-inbox.psgi
examples: disable Chunked response in PSGI example
[public-inbox.git] / examples / public-inbox.psgi
1 #!/usr/bin/perl -w
2 # Copyright (C) 2014-2016 all contributors <meta@public-inbox.org>
3 # License: GPL-3.0+ <https://www.gnu.org/licenses/gpl-3.0.txt>
4 # Note: this is part of our test suite, update t/plack.t if this changes
5 # Usage: plackup [OPTIONS] /path/to/this/file
6 # A startup command for development which monitors changes:
7 #       plackup -I lib -o 127.0.0.1 -R lib -r examples/public-inbox.psgi
8 use strict;
9 use warnings;
10 use PublicInbox::WWW;
11 PublicInbox::WWW->preload;
12 use Plack::Builder;
13 my $www = PublicInbox::WWW->new;
14 builder {
15         # Chunked middleware conflicts with Starman:
16         # https://github.com/miyagawa/Starman/issues/23
17         # enable 'Chunked';
18         eval {
19                 enable 'Deflater',
20                         content_type => [ qw(
21                                 text/html
22                                 text/plain
23                                 application/atom+xml
24                                 )]
25         };
26         $@ and warn
27 "Plack::Middleware::Deflater missing, bandwidth will be wasted\n";
28
29         # Enable to ensure redirects and Atom feed URLs are generated
30         # properly when running behind a reverse proxy server which
31         # sets X-Forwarded-For and X-Forwarded-Proto request headers.
32         # See Plack::Middleware::ReverseProxy documentation for details
33         eval { enable 'ReverseProxy' };
34         $@ and warn
35 "Plack::Middleware::ReverseProxy missing,\n",
36 "URL generation for redirects may be wrong if behind a reverse proxy\n";
37
38         # Optional: Log timing information for requests to track performance.
39         # Logging to STDOUT is recommended since public-inbox-httpd knows
40         # how to reopen it via SIGUSR1 after log rotation.
41         # enable 'AccessLog::Timed',
42         #       logger => sub { syswrite(STDOUT, $_[0]) },
43         #       format => '%t "%r" %>s %b %D';
44
45         enable 'Head';
46         sub { $www->call(@_) };
47 }