about summary refs log tree commit homepage
path: root/examples/public-inbox.psgi
diff options
context:
space:
mode:
Diffstat (limited to 'examples/public-inbox.psgi')
-rw-r--r--examples/public-inbox.psgi21
1 files changed, 16 insertions, 5 deletions
diff --git a/examples/public-inbox.psgi b/examples/public-inbox.psgi
index 71592a7a..e97f917f 100644
--- a/examples/public-inbox.psgi
+++ b/examples/public-inbox.psgi
@@ -11,10 +11,11 @@ use PublicInbox::WWW;
 PublicInbox::WWW->preload;
 use Plack::Builder;
 my $www = PublicInbox::WWW->new;
+
+# share the public-inbox code itself:
+my $src = $ENV{SRC_GIT_DIR}; # '/path/to/public-inbox.git'
+
 builder {
-        # Chunked middleware conflicts with Starman:
-        # https://github.com/miyagawa/Starman/issues/23
-        # enable 'Chunked';
         eval {
                 enable 'Deflater',
                         content_type => [ qw(
@@ -28,7 +29,7 @@ builder {
 
         # 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
@@ -43,5 +44,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);
+                }
+        };
 }