X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=examples%2Fpublic-inbox.psgi;h=4dd3306b669bde49f0a2d7c08b869366563c33b0;hb=be4d92e74dd0b1c8de85bc08c3c522af2d8d8656;hp=f57491228e55fb7f00164c0df4878e8902285ddf;hpb=0449c3c4ac1a60dde24225d648546362c3bc3fa1;p=public-inbox.git
diff --git a/examples/public-inbox.psgi b/examples/public-inbox.psgi
index f5749122..4dd3306b 100644
--- a/examples/public-inbox.psgi
+++ b/examples/public-inbox.psgi
@@ -1,6 +1,6 @@
#!/usr/bin/perl -w
-# Copyright (C) 2014-2015 all contributors
-# License: AGPLv3 or later (https://www.gnu.org/licenses/agpl-3.0.txt)
+# Copyright (C) 2014-2018 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
# A startup command for development which monitors changes:
@@ -9,11 +9,14 @@ use strict;
use warnings;
use PublicInbox::WWW;
PublicInbox::WWW->preload;
-use Plack::Request;
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'
+$src = PublicInbox::Git->new($src) if defined $src;
+
builder {
- enable 'Chunked';
eval {
enable 'Deflater',
content_type => [ qw(
@@ -27,7 +30,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
@@ -42,5 +45,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);
+ }
+ };
}