]> Sergey Matveev's repositories - public-inbox.git/blobdiff - examples/public-inbox.psgi
treewide: run update-copyrights from gnulib for 2019
[public-inbox.git] / examples / public-inbox.psgi
index 876fc76226d651d60dbe2901f89332fabcfd0f06..b9817e83a064be0d404704bceafbb63b74fdef00 100644 (file)
@@ -1,5 +1,5 @@
 #!/usr/bin/perl -w
-# Copyright (C) 2014-2016 all contributors <meta@public-inbox.org>
+# Copyright (C) 2014-2020 all contributors <meta@public-inbox.org>
 # License: GPL-3.0+ <https://www.gnu.org/licenses/gpl-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
@@ -8,15 +8,15 @@
 use strict;
 use warnings;
 use PublicInbox::WWW;
-PublicInbox::WWW->preload;
 use Plack::Builder;
 my $www = PublicInbox::WWW->new;
+$www->preload;
+
+# share the public-inbox code itself:
+my $src = $ENV{SRC_GIT_DIR}; # '/path/to/public-inbox.git'
+$src = PublicInbox::Git->new($src) if defined $src;
+
 builder {
-       # Chunked middleware conflicts with Starman:
-       # https://github.com/miyagawa/Starman/issues/23
-       # However, it is strongly recommended to enable it if using
-       # public-inbox-httpd to allow persistent connections
-       # enable 'Chunked';
        eval {
                enable 'Deflater',
                        content_type => [ qw(
@@ -25,12 +25,10 @@ builder {
                                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.
+       # sets the X-Forwarded-Proto request header.
        # See Plack::Middleware::ReverseProxy documentation for details
        eval { enable 'ReverseProxy' };
        $@ and warn
@@ -45,5 +43,15 @@ builder {
        #       format => '%t "%r" %>s %b %D';
 
        enable 'Head';
-       sub { $www->call(@_) };
+       sub {
+               my ($env) = @_;
+               # share public-inbox.git code!
+               if ($src && $env->{PATH_INFO} =~
+                               m!\A/(?:public-inbox(?:\.git)?/)?
+                               ($PublicInbox::GitHTTPBackend::ANY)\z!xo) {
+                       PublicInbox::GitHTTPBackend::serve($env, $src, $1);
+               } else {
+                       $www->call($env);
+               }
+       };
 }