@ -24,6 +24,7 @@ restart restart the web server
fqgitdir="$GIT_DIR"
fqgitdir="$GIT_DIR"
local="$(git config --bool --get instaweb.local)"
local="$(git config --bool --get instaweb.local)"
httpd="$(git config --get instaweb.httpd)"
httpd="$(git config --get instaweb.httpd)"
root="$(git config --get instaweb.gitwebdir)"
port=$(git config --get instaweb.port)
port=$(git config --get instaweb.port)
module_path="$(git config --get instaweb.modulepath)"
module_path="$(git config --get instaweb.modulepath)"
@ -34,6 +35,9 @@ conf="$GIT_DIR/gitweb/httpd.conf"
# if installed, it doesn't need further configuration (module_path)
# if installed, it doesn't need further configuration (module_path)
test -z "$httpd" && httpd='lighttpd -f'
test -z "$httpd" && httpd='lighttpd -f'
# Default is @@GITWEBDIR@@
test -z "$root" && root='@@GITWEBDIR@@'
# any untaken local port will do...
# any untaken local port will do...
test -z "$port" && port=1234
test -z "$port" && port=1234
@ -57,7 +61,7 @@ resolve_full_httpd () {
# these days and those are not in most users $PATHs
# these days and those are not in most users $PATHs
# in addition, we may have generated a server script
# in addition, we may have generated a server script
# in $fqgitdir/gitweb.
# in $fqgitdir/gitweb.
for i in /usr/local/sbin /usr/sbin "$fqgitdir/gitweb"
for i in /usr/local/sbin /usr/sbin "$root" "$fqgitdir/gitweb"
do
do
if test -x "$i/$httpd_only"
if test -x "$i/$httpd_only"
then
then
@ -159,8 +163,8 @@ done
mkdir -p "$GIT_DIR/gitweb/tmp"
mkdir -p "$GIT_DIR/gitweb/tmp"
GIT_EXEC_PATH="$(git --exec-path)"
GIT_EXEC_PATH="$(git --exec-path)"
GIT_DIR="$fqgitdir"
GIT_DIR="$fqgitdir"
export GIT_EXEC_PATH GIT_DIR
GITWEB_CONFIG="$fqgitdir/gitweb/gitweb_config.perl"
export GIT_EXEC_PATH GIT_DIR GITWEB_CONFIG
webrick_conf () {
webrick_conf () {
# generate a standalone server script in $fqgitdir/gitweb.
# generate a standalone server script in $fqgitdir/gitweb.
@ -192,7 +196,7 @@ EOF
cat >"$conf" <<EOF
cat >"$conf" <<EOF
:Port: $port
:Port: $port
:DocumentRoot: "$fqgitdir/gitweb"
:DocumentRoot: "$root"
:DirectoryIndex: ["gitweb.cgi"]
:DirectoryIndex: ["gitweb.cgi"]
:PidFile: "$fqgitdir/pid"
:PidFile: "$fqgitdir/pid"
EOF
EOF
@ -201,7 +205,7 @@ EOF
lighttpd_conf () {
lighttpd_conf () {
cat > "$conf" <<EOF
cat > "$conf" <<EOF
server.document-root = "$fqgitdir/gitweb"
server.document-root = "$root"
server.port = $port
server.port = $port
server.modules = ( "mod_setenv", "mod_cgi" )
server.modules = ( "mod_setenv", "mod_cgi" )
server.indexfiles = ( "gitweb.cgi" )
server.indexfiles = ( "gitweb.cgi" )
@ -212,7 +216,7 @@ server.errorlog = "$fqgitdir/gitweb/$httpd_only/error.log"
# variable above and uncomment this
# variable above and uncomment this
#accesslog.filename = "$fqgitdir/gitweb/$httpd_only/access.log"
#accesslog.filename = "$fqgitdir/gitweb/$httpd_only/access.log"
setenv.add-environment = ( "PATH" => env.PATH )
setenv.add-environment = ( "PATH" => env.PATH, "GITWEB_CONFIG" => env.GITWEB_CONFIG )
cgi.assign = ( ".cgi" => "" )
cgi.assign = ( ".cgi" => "" )
@ -282,8 +286,8 @@ apache2_conf () {
echo 'text/css css' > "$fqgitdir/mime.types"
echo 'text/css css' > "$fqgitdir/mime.types"
cat > "$conf" <<EOF
cat > "$conf" <<EOF
ServerName "git-instaweb"
ServerName "git-instaweb"
ServerRoot "$fqgitdir/gitweb"
ServerRoot "$root"
DocumentRoot "$fqgitdir/gitweb"
DocumentRoot "$root"
ErrorLog "$fqgitdir/gitweb/$httpd_only/error.log"
ErrorLog "$fqgitdir/gitweb/$httpd_only/error.log"
CustomLog "$fqgitdir/gitweb/$httpd_only/access.log" combined
CustomLog "$fqgitdir/gitweb/$httpd_only/access.log" combined
PidFile "$fqgitdir/pid"
PidFile "$fqgitdir/pid"
@ -304,13 +308,14 @@ EOF
# check to see if Dennis Stosberg's mod_perl compatibility patch
# check to see if Dennis Stosberg's mod_perl compatibility patch
# (<20060621130708.Gcbc6e5c@leonov.stosberg.net>) has been applied
# (<20060621130708.Gcbc6e5c@leonov.stosberg.net>) has been applied
if test -f "$module_path/mod_perl.so" &&
if test -f "$module_path/mod_perl.so" &&
sane_grep 'MOD_PERL' "$GIT_DIR/gitweb/gitweb.cgi" >/dev/null
sane_grep 'MOD_PERL' "$root/gitweb.cgi" >/dev/null
then
then
# favor mod_perl if available
# favor mod_perl if available
cat >> "$conf" <<EOF
cat >> "$conf" <<EOF
LoadModule perl_module $module_path/mod_perl.so
LoadModule perl_module $module_path/mod_perl.so
PerlPassEnv GIT_DIR
PerlPassEnv GIT_DIR
PerlPassEnv GIT_EXEC_DIR
PerlPassEnv GIT_EXEC_DIR
PerlPassEnv GITWEB_CONFIG
<Location /gitweb.cgi>
<Location /gitweb.cgi>
SetHandler perl-script
SetHandler perl-script
PerlResponseHandler ModPerl::Registry
PerlResponseHandler ModPerl::Registry
@ -354,7 +359,7 @@ mongoose_conf() {
# For detailed description of every option, visit
# For detailed description of every option, visit
# http://code.google.com/p/mongoose/wiki/MongooseManual
# http://code.google.com/p/mongoose/wiki/MongooseManual
root $fqgitdir/gitweb
root $root
ports $port
ports $port
index_files gitweb.cgi
index_files gitweb.cgi
#ssl_cert $fqgitdir/gitweb/ssl_cert.pem
#ssl_cert $fqgitdir/gitweb/ssl_cert.pem
@ -362,7 +367,7 @@ error_log $fqgitdir/gitweb/$httpd_only/error.log
access_log $fqgitdir/gitweb/$httpd_only/access.log
access_log $fqgitdir/gitweb/$httpd_only/access.log
#cgi setup
#cgi setup
cgi_env PATH=$PATH,GIT_DIR=$GIT_DIR,GIT_EXEC_PATH=$GIT_EXEC_PATH
cgi_env PATH=$PATH,GIT_DIR=$GIT_DIR,GIT_EXEC_PATH=$GIT_EXEC_PATH,GITWEB_CONFIG=$GITWEB_CONFIG
cgi_interp $PERL
cgi_interp $PERL
cgi_ext cgi,pl
cgi_ext cgi,pl
@ -371,41 +376,16 @@ mime_types .gz=application/x-gzip,.tar.gz=application/x-tgz,.tgz=application/x-t
EOF
EOF
}
}
gitweb_conf() {
script='
cat > "$fqgitdir/gitweb/gitweb_config.perl" <<EOF
s#^(my|our) \$projectroot =.*#$1 \$projectroot = "'$(dirname "$fqgitdir")'";#;
#!/usr/bin/perl
s#(my|our) \$gitbin =.*#$1 \$gitbin = "'$GIT_EXEC_PATH'";#;
our \$projectroot = "$(dirname "$fqgitdir")";
s#(my|our) \$projects_list =.*#$1 \$projects_list = \$projectroot;#;
our \$git_temp = "$fqgitdir/gitweb/tmp";
s#(my|our) \$git_temp =.*#$1 \$git_temp = "'$fqgitdir/gitweb/tmp'";#;'
our \$projects_list = \$projectroot;
EOF
gitweb_cgi () {
cat > "$1.tmp" <<\EOFGITWEB
@@GITWEB_CGI@@
EOFGITWEB
# Use the configured full path to perl to match the generated
# scripts' 'hashpling' line
"$PERL" -p -e "$script" "$1.tmp" > "$1"
chmod +x "$1"
rm -f "$1.tmp"
}
gitweb_css () {
cat > "$1" <<\EOFGITWEB
@@GITWEB_CSS@@
EOFGITWEB
}
gitweb_js () {
cat > "$1" <<\EOFGITWEB
@@GITWEB_JS@@
EOFGITWEB
}
}
gitweb_cgi "$GIT_DIR/gitweb/gitweb.cgi"
gitweb_conf
gitweb_css "$GIT_DIR/@@GITWEB_CSS_NAME@@"
gitweb_js "$GIT_DIR/@@GITWEB_JS_NAME@@"
resolve_full_httpd
resolve_full_httpd
mkdir -p "$fqgitdir/gitweb/$httpd_only"
mkdir -p "$fqgitdir/gitweb/$httpd_only"