X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=examples%2Fpublic-inbox.psgi;h=53a5970f864df614e1ed4e4b9195aaf2f6029f4c;hb=f9fc5cf2e8cefda4a56d937ed217e47689fd7e49;hp=55c113e425ae0010e77c392f04a733c3d9485f20;hpb=c3509baca0b103a0c9d034de06f3ddc5fc9426fd;p=public-inbox.git
diff --git a/examples/public-inbox.psgi b/examples/public-inbox.psgi
index 55c113e4..53a5970f 100644
--- a/examples/public-inbox.psgi
+++ b/examples/public-inbox.psgi
@@ -1,5 +1,5 @@
#!/usr/bin/perl -w
-# Copyright (C) 2014-2016 all contributors
+# Copyright (C) 2014-2019 all contributors
# License: GPL-3.0+
# Note: this is part of our test suite, update t/plack.t if this changes
# Usage: plackup [OPTIONS] /path/to/this/file
@@ -8,11 +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 {
- enable 'Chunked';
eval {
enable 'Deflater',
content_type => [ qw(
@@ -21,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
@@ -41,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);
+ }
+ };
}