From: Jakub Narebski <jnareb@gmail.com>
To: git@vger.kernel.org
Cc: Jakub Narebski <jnareb@gmail.com>, Eric Wong <normalperson@yhbt.net>
Subject: [RFC/PATCH] git-instaweb: Add support for running gitweb via 'plackup'
Date: Wed, 19 May 2010 19:31:38 +0200 [thread overview]
Message-ID: <1274290298-19245-1-git-send-email-jnareb@gmail.com> (raw)
PSGI is an interface between Perl web applications and web servers, and
Plack is a Perl module and toolkit that contains PSGI middleware, helpers
and adapters to web servers; see http://plackperl.org
PSGI and Plack are inspired by Python's WSGI and Ruby's Rack.
Plack core distribution includes HTTP::Server::PSGI, a reference PSGI
standalone web server implementation. plackup is a command line launcher
to run PSGI applications from command line, connecting web app to a web
server; it uses Plack::Runner module. It uses HTTP::Server::PSGI as a web
server by default.
git-instaweb generates gitweb.psgi wrapper, which uses Plack::App::WrapCGI
to compile a CGI script into a PSGI application using CGI::Compile and
CGI::Emulate::PSGI, and runs it with any PSGI server as a PSGI
application.
To run git-instaweb with '--httpd=plackup', you need to have instaled
Plack core, CGI::Emulate::PSGI, CGI::Compile, and available for a Perl
script (e.g. by setting PERL5LIB environment variable).
Signed-off-by: Jakub Narebski <jnareb@gmail.com>
---
Compared to earlier version (only mentioned, but not sent to git
mailing list, if I remember correctly), instead of configuring plackup
from command line (by modifying $httpd variable), the configuration is
embedded in generated gitweb.psgi file. Also instead of using plackup,
the generated gitweb.psgi is made into standalone app, running server
(so $full_httpd is full path to gitweb.psgi).
RFC is because when when running
$ ./git-instaweb --httpd=plackup --browser=lynx
I get the following error
Looking up 127.0.0.1:1234
Making HTTP connection to 127.0.0.1:1234
Alert!: Unable to connect to remote host.
lynx: Can't access startfile http://127.0.0.1:1234/
http://127.0.0.1:1234
But running 'lynx http://127.0.0.1:1234/' after this works correctly
without problems. Running './.git/gitweb/gitweb.psgi' doesn't cause
any problems either. WTF?
HELP!!!
Documentation/git-instaweb.txt | 2 +-
git-instaweb.sh | 52 +++++++++++++++++++++++++++++++++++++--
2 files changed, 50 insertions(+), 4 deletions(-)
diff --git a/Documentation/git-instaweb.txt b/Documentation/git-instaweb.txt
index a1f17df..2c3c4d2 100644
--- a/Documentation/git-instaweb.txt
+++ b/Documentation/git-instaweb.txt
@@ -29,7 +29,7 @@ OPTIONS
The HTTP daemon command-line that will be executed.
Command-line options may be specified here, and the
configuration file will be added at the end of the command-line.
- Currently apache2, lighttpd, mongoose and webrick are supported.
+ Currently apache2, lighttpd, mongoose, plackup and webrick are supported.
(Default: lighttpd)
-m::
diff --git a/git-instaweb.sh b/git-instaweb.sh
index f608014..dd82955 100755
--- a/git-instaweb.sh
+++ b/git-instaweb.sh
@@ -46,6 +46,13 @@ resolve_full_httpd () {
httpd="$httpd -f"
fi
;;
+ *plackup*)
+ # Plack::Runner etc must be in $PERL5LIB of user, currently
+ # server is started by running via generated gitweb.psgi in $fqgitdir/gitweb
+ bind=
+ full_httpd="$fqgitdir/gitweb/gitweb.psgi"
+ return
+ ;;
esac
httpd_only="$(echo $httpd | cut -f1 -d' ')"
@@ -83,9 +90,9 @@ start_httpd () {
# don't quote $full_httpd, there can be arguments to it (-f)
case "$httpd" in
- *mongoose*)
- #The mongoose server doesn't have a daemon mode so we'll have to fork it
- $full_httpd "$fqgitdir/gitweb/httpd.conf" &
+ *mongoose*|*plackup*)
+ #The mongoose server and plackup don't have a daemon mode so we'll have to fork it
+ $full_httpd "$fqgitdir/gitweb/httpd.conf" 2>"$fqgitdir/error_log" &
#Save the pid before doing anything else (we'll print it later)
pid=$!
@@ -370,6 +377,42 @@ mime_types .gz=application/x-gzip,.tar.gz=application/x-tgz,.tgz=application/x-t
EOF
}
+plackup_conf () {
+ cat > "$fqgitdir/gitweb/gitweb.psgi" <<GITWEB_PSGI_EOF
+#!$PERL
+
+# gitweb - simple web interface to track changes in git repositories
+# PSGI wrapper (see http://plackperl.org)
+
+use strict;
+
+use Plack::Builder;
+use Plack::App::WrapCGI;
+use CGI::Emulate::PSGI 0.07; # minimum version required to work with gitweb
+
+my \$app = builder {
+ # serve static files, i.e. stylesheet, images, script
+ enable 'Static',
+ path => sub { m!\.(js|css|png)\$! && s!^/gitweb/!! },
+ root => "$fqgitdir/gitweb/";
+ # convert CGI application to PSGI app
+ Plack::App::WrapCGI->new(script => "$fqgitdir/gitweb/gitweb.cgi")->to_app;
+};
+
+# make it runnable as standalone app, like via plackup
+if (__FILE__ eq \$0) {
+ require Plack::Runner;
+
+ my \$runner = Plack::Runner->new();
+ \$runner->parse_options(qw(--port $port),
+ "$local" ? qw(--host 127.0.0.1) : ());
+ \$runner->run(\$app);
+}
+GITWEB_PSGI_EOF
+
+ chmod a+x "$fqgitdir/gitweb/gitweb.psgi"
+ rm -f "$fqgitdir/gitweb/gitweb.psgi.tmp" "$conf"
+}
script='
s#^(my|our) \$projectroot =.*#$1 \$projectroot = "'$(dirname "$fqgitdir")'";#;
@@ -419,6 +462,9 @@ webrick)
*mongoose*)
mongoose_conf
;;
+*plackup*)
+ plackup_conf
+ ;;
*)
echo "Unknown httpd specified: $httpd"
exit 1
--
1.7.0.1
next reply other threads:[~2010-05-19 17:31 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-05-19 17:31 Jakub Narebski [this message]
2010-05-19 20:52 ` [RFC/PATCH] git-instaweb: Add support for running gitweb via 'plackup' Jakub Narebski
2010-05-20 11:56 ` [PATCHv2 (RFC)] " Jakub Narebski
2010-05-20 21:55 ` [RFC/PATCHv3] " Jakub Narebski
2010-05-22 21:30 ` Jakub Narebski
2010-05-23 9:19 ` Eric Wong
2010-05-23 11:17 ` Jakub Narebski
2010-05-23 12:38 ` Ævar Arnfjörð Bjarmason
2010-05-25 0:11 ` Jakub Narebski
2010-05-25 9:02 ` Jakub Narebski
2010-05-23 9:31 ` [RFC/PATCH] " Eric Wong
2010-05-23 20:21 ` Jakub Narebski
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1274290298-19245-1-git-send-email-jnareb@gmail.com \
--to=jnareb@gmail.com \
--cc=git@vger.kernel.org \
--cc=normalperson@yhbt.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).