X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=examples%2Fpublic-inbox.psgi;h=11e2a6e73a51115db0442600bd96650804cdc176;hb=50b0c766e5d9b3fac17d7fe0f2089a89af1aa777;hp=876fc76226d651d60dbe2901f89332fabcfd0f06;hpb=12232b34a53165cb07cf94aa00fde8a59bbacd0e;p=public-inbox.git diff --git a/examples/public-inbox.psgi b/examples/public-inbox.psgi index 876fc762..11e2a6e7 100644 --- a/examples/public-inbox.psgi +++ b/examples/public-inbox.psgi @@ -11,12 +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 - # 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( @@ -45,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); + } + }; }