]> Sergey Matveev's repositories - public-inbox.git/commitdiff
httpd: allow running if ReverseProxy is missing
authorEric Wong <e@80x24.org>
Sun, 28 Feb 2016 00:57:11 +0000 (00:57 +0000)
committerEric Wong <e@80x24.org>
Sun, 28 Feb 2016 05:14:59 +0000 (05:14 +0000)
Not everybody will be running this behind a ReverseProxy;
but it's probably the likely configuration.  Anyways,
warn about this and also about Deflater being missing.

examples/public-inbox.psgi
script/public-inbox-httpd

index acceba3deace399b6b801720600bc0e814301fcd..0d11c19fb8395e95097ad4d0bc443971860e3648 100644 (file)
@@ -9,21 +9,27 @@ 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 {
        enable 'Chunked';
-       if ($have_deflater) {
+       eval {
                enable 'Deflater',
-                       content_type => [ 'text/html', 'text/plain',
-                                       'application/atom+xml' ];
-       }
-
+                       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
-       enable 'ReverseProxy';
+       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(@_) };
index 6109af01a62cdad79fdd11a3bdeea9652033f94d..19315bb43972297a71ff4be68df8811763110e6e 100755 (executable)
@@ -24,18 +24,24 @@ my $refresh = sub {
                PublicInbox::WWW->preload;
                my $www = PublicInbox::WWW->new;
                $app = eval {
-                       my $deflate_types = eval {
-                               require Plack::Middleware::Deflater;
-                               [ 'text/html', 'text/plain',
-                                       'application/atom+xml' ]
-                       };
                        builder {
                                enable 'Chunked';
-                               if ($deflate_types) {
+                               eval {
                                        enable 'Deflater',
-                                               content_type => $deflate_types
-                               }
-                               enable 'ReverseProxy';
+                                               content_type => [ qw(
+                                                       text/html
+                                                       text/plain
+                                                       application/atom+xml
+                                                       )]
+                               };
+                               $@ and warn
+"Plack::Middleware::Deflater missing, bandwidth will be wasted\n";
+
+                               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(@_) };
                        };