You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
704 lines
26 KiB
704 lines
26 KiB
gitweb(1) |
|
========= |
|
|
|
NAME |
|
---- |
|
gitweb - Git web interface (web frontend to Git repositories) |
|
|
|
SYNOPSIS |
|
-------- |
|
To get started with gitweb, run linkgit:git-instaweb[1] from a Git repository. |
|
This would configure and start your web server, and run web browser pointing to |
|
gitweb. |
|
|
|
|
|
DESCRIPTION |
|
----------- |
|
Gitweb provides a web interface to Git repositories. Its features include: |
|
|
|
* Viewing multiple Git repositories with common root. |
|
* Browsing every revision of the repository. |
|
* Viewing the contents of files in the repository at any revision. |
|
* Viewing the revision log of branches, history of files and directories, |
|
see what was changed when, by who. |
|
* Viewing the blame/annotation details of any file (if enabled). |
|
* Generating RSS and Atom feeds of commits, for any branch. |
|
The feeds are auto-discoverable in modern web browsers. |
|
* Viewing everything that was changed in a revision, and step through |
|
revisions one at a time, viewing the history of the repository. |
|
* Finding commits which commit messages matches given search term. |
|
|
|
See http://git.kernel.org/?p=git/git.git;a=tree;f=gitweb[] or |
|
http://repo.or.cz/w/git.git/tree/HEAD:/gitweb/[] for gitweb source code, |
|
browsed using gitweb itself. |
|
|
|
|
|
CONFIGURATION |
|
------------- |
|
Various aspects of gitweb's behavior can be controlled through the configuration |
|
file `gitweb_config.perl` or `/etc/gitweb.conf`. See the linkgit:gitweb.conf[5] |
|
for details. |
|
|
|
Repositories |
|
~~~~~~~~~~~~ |
|
Gitweb can show information from one or more Git repositories. These |
|
repositories have to be all on local filesystem, and have to share common |
|
repository root, i.e. be all under a single parent repository (but see also |
|
"Advanced web server setup" section, "Webserver configuration with multiple |
|
projects' root" subsection). |
|
|
|
----------------------------------------------------------------------- |
|
our $projectroot = '/path/to/parent/directory'; |
|
----------------------------------------------------------------------- |
|
|
|
The default value for `$projectroot` is `/pub/git`. You can change it during |
|
building gitweb via `GITWEB_PROJECTROOT` build configuration variable. |
|
|
|
By default all Git repositories under `$projectroot` are visible and available |
|
to gitweb. The list of projects is generated by default by scanning the |
|
`$projectroot` directory for Git repositories (for object databases to be |
|
more exact; gitweb is not interested in a working area, and is best suited |
|
to showing "bare" repositories). |
|
|
|
The name of the repository in gitweb is the path to its `$GIT_DIR` (its object |
|
database) relative to `$projectroot`. Therefore the repository $repo can be |
|
found at "$projectroot/$repo". |
|
|
|
|
|
Projects list file format |
|
~~~~~~~~~~~~~~~~~~~~~~~~~ |
|
Instead of having gitweb find repositories by scanning filesystem |
|
starting from $projectroot, you can provide a pre-generated list of |
|
visible projects by setting `$projects_list` to point to a plain text |
|
file with a list of projects (with some additional info). |
|
|
|
This file uses the following format: |
|
|
|
* One record (for project / repository) per line; does not support line |
|
continuation (newline escaping). |
|
|
|
* Leading and trailing whitespace are ignored. |
|
|
|
* Whitespace separated fields; any run of whitespace can be used as field |
|
separator (rules for Perl's "`split(" ", $line)`"). |
|
|
|
* Fields use modified URI encoding, defined in RFC 3986, section 2.1 |
|
(Percent-Encoding), or rather "Query string encoding" (see |
|
https://en.wikipedia.org/wiki/Query_string#URL_encoding[]), the difference |
|
being that SP (" ") can be encoded as "{plus}" (and therefore "{plus}" has to be |
|
also percent-encoded). |
|
+ |
|
Reserved characters are: "%" (used for encoding), "{plus}" (can be used to |
|
encode SPACE), all whitespace characters as defined in Perl, including SP, |
|
TAB and LF, (used to separate fields in a record). |
|
|
|
* Currently recognized fields are: |
|
<repository path>:: |
|
path to repository GIT_DIR, relative to `$projectroot` |
|
<repository owner>:: |
|
displayed as repository owner, preferably full name, or email, |
|
or both |
|
|
|
You can generate the projects list index file using the project_index action |
|
(the 'TXT' link on projects list page) directly from gitweb; see also |
|
"Generating projects list using gitweb" section below. |
|
|
|
Example contents: |
|
----------------------------------------------------------------------- |
|
foo.git Joe+R+Hacker+<joe@example.com> |
|
foo/bar.git O+W+Ner+<owner@example.org> |
|
----------------------------------------------------------------------- |
|
|
|
|
|
By default this file controls only which projects are *visible* on projects |
|
list page (note that entries that do not point to correctly recognized Git |
|
repositories won't be displayed by gitweb). Even if a project is not |
|
visible on projects list page, you can view it nevertheless by hand-crafting |
|
a gitweb URL. By setting `$strict_export` configuration variable (see |
|
linkgit:gitweb.conf[5]) to true value you can allow viewing only of |
|
repositories also shown on the overview page (i.e. only projects explicitly |
|
listed in projects list file will be accessible). |
|
|
|
|
|
Generating projects list using gitweb |
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
|
|
|
We assume that GITWEB_CONFIG has its default Makefile value, namely |
|
'gitweb_config.perl'. Put the following in 'gitweb_make_index.perl' file: |
|
---------------------------------------------------------------------------- |
|
read_config_file("gitweb_config.perl"); |
|
$projects_list = $projectroot; |
|
---------------------------------------------------------------------------- |
|
|
|
Then create the following script to get list of project in the format |
|
suitable for GITWEB_LIST build configuration variable (or |
|
`$projects_list` variable in gitweb config): |
|
|
|
---------------------------------------------------------------------------- |
|
#!/bin/sh |
|
|
|
export GITWEB_CONFIG="gitweb_make_index.perl" |
|
export GATEWAY_INTERFACE="CGI/1.1" |
|
export HTTP_ACCEPT="*/*" |
|
export REQUEST_METHOD="GET" |
|
export QUERY_STRING="a=project_index" |
|
|
|
perl -- /var/www/cgi-bin/gitweb.cgi |
|
---------------------------------------------------------------------------- |
|
|
|
Run this script and save its output to a file. This file could then be used |
|
as projects list file, which means that you can set `$projects_list` to its |
|
filename. |
|
|
|
|
|
Controlling access to Git repositories |
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
|
By default all Git repositories under `$projectroot` are visible and |
|
available to gitweb. You can however configure how gitweb controls access |
|
to repositories. |
|
|
|
* As described in "Projects list file format" section, you can control which |
|
projects are *visible* by selectively including repositories in projects |
|
list file, and setting `$projects_list` gitweb configuration variable to |
|
point to it. With `$strict_export` set, projects list file can be used to |
|
control which repositories are *available* as well. |
|
|
|
* You can configure gitweb to only list and allow viewing of the explicitly |
|
exported repositories, via `$export_ok` variable in gitweb config file; see |
|
linkgit:gitweb.conf[5] manpage. If it evaluates to true, gitweb shows |
|
repositories only if this file named by `$export_ok` exists in its object |
|
database (if directory has the magic file named `$export_ok`). |
|
+ |
|
For example linkgit:git-daemon[1] by default (unless `--export-all` option |
|
is used) allows pulling only for those repositories that have |
|
'git-daemon-export-ok' file. Adding |
|
+ |
|
-------------------------------------------------------------------------- |
|
our $export_ok = "git-daemon-export-ok"; |
|
-------------------------------------------------------------------------- |
|
+ |
|
makes gitweb show and allow access only to those repositories that can be |
|
fetched from via `git://` protocol. |
|
|
|
* Finally, it is possible to specify an arbitrary perl subroutine that will |
|
be called for each repository to determine if it can be exported. The |
|
subroutine receives an absolute path to the project (repository) as its only |
|
parameter (i.e. "$projectroot/$project"). |
|
+ |
|
For example, if you use mod_perl to run the script, and have dumb |
|
HTTP protocol authentication configured for your repositories, you |
|
can use the following hook to allow access only if the user is |
|
authorized to read the files: |
|
+ |
|
-------------------------------------------------------------------------- |
|
$export_auth_hook = sub { |
|
use Apache2::SubRequest (); |
|
use Apache2::Const -compile => qw(HTTP_OK); |
|
my $path = "$_[0]/HEAD"; |
|
my $r = Apache2::RequestUtil->request; |
|
my $sub = $r->lookup_file($path); |
|
return $sub->filename eq $path |
|
&& $sub->status == Apache2::Const::HTTP_OK; |
|
}; |
|
-------------------------------------------------------------------------- |
|
|
|
|
|
Per-repository gitweb configuration |
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
|
You can configure individual repositories shown in gitweb by creating file |
|
in the `GIT_DIR` of Git repository, or by setting some repo configuration |
|
variable (in `GIT_DIR/config`, see linkgit:git-config[1]). |
|
|
|
You can use the following files in repository: |
|
|
|
README.html:: |
|
A html file (HTML fragment) which is included on the gitweb project |
|
"summary" page inside `<div>` block element. You can use it for longer |
|
description of a project, to provide links (for example to project's |
|
homepage), etc. This is recognized only if XSS prevention is off |
|
(`$prevent_xss` is false, see linkgit:gitweb.conf[5]); a way to include |
|
a README safely when XSS prevention is on may be worked out in the |
|
future. |
|
|
|
description (or `gitweb.description`):: |
|
Short (shortened to `$projects_list_description_width` in the projects |
|
list page, which is 25 characters by default; see |
|
linkgit:gitweb.conf[5]) single line description of a project (of a |
|
repository). Plain text file; HTML will be escaped. By default set to |
|
+ |
|
------------------------------------------------------------------------------- |
|
Unnamed repository; edit this file to name it for gitweb. |
|
------------------------------------------------------------------------------- |
|
+ |
|
from the template during repository creation, usually installed in |
|
`/usr/share/git-core/templates/`. You can use the `gitweb.description` repo |
|
configuration variable, but the file takes precedence. |
|
|
|
category (or `gitweb.category`):: |
|
Singe line category of a project, used to group projects if |
|
`$projects_list_group_categories` is enabled. By default (file and |
|
configuration variable absent), uncategorized projects are put in the |
|
`$project_list_default_category` category. You can use the |
|
`gitweb.category` repo configuration variable, but the file takes |
|
precedence. |
|
+ |
|
The configuration variables `$projects_list_group_categories` and |
|
`$project_list_default_category` are described in linkgit:gitweb.conf[5] |
|
|
|
cloneurl (or multiple-valued `gitweb.url`):: |
|
File with repository URL (used for clone and fetch), one per line. |
|
Displayed in the project summary page. You can use multiple-valued |
|
`gitweb.url` repository configuration variable for that, but the file |
|
takes precedence. |
|
+ |
|
This is per-repository enhancement / version of global prefix-based |
|
`@git_base_url_list` gitweb configuration variable (see |
|
linkgit:gitweb.conf[5]). |
|
|
|
gitweb.owner:: |
|
You can use the `gitweb.owner` repository configuration variable to set |
|
repository's owner. It is displayed in the project list and summary |
|
page. |
|
+ |
|
If it's not set, filesystem directory's owner is used (via GECOS field, |
|
i.e. real name field from *getpwuid*(3)) if `$projects_list` is unset |
|
(gitweb scans `$projectroot` for repositories); if `$projects_list` |
|
points to file with list of repositories, then project owner defaults to |
|
value from this file for given repository. |
|
|
|
various `gitweb.*` config variables (in config):: |
|
Read description of `%feature` hash for detailed list, and descriptions. |
|
See also "Configuring gitweb features" section in linkgit:gitweb.conf[5] |
|
|
|
|
|
ACTIONS, AND URLS |
|
----------------- |
|
Gitweb can use path_info (component) based URLs, or it can pass all necessary |
|
information via query parameters. The typical gitweb URLs are broken down in to |
|
five components: |
|
|
|
----------------------------------------------------------------------- |
|
.../gitweb.cgi/<repo>/<action>/<revision>:/<path>?<arguments> |
|
----------------------------------------------------------------------- |
|
|
|
repo:: |
|
The repository the action will be performed on. |
|
+ |
|
All actions except for those that list all available projects, |
|
in whatever form, require this parameter. |
|
|
|
action:: |
|
The action that will be run. Defaults to 'projects_list' if repo |
|
is not set, and to 'summary' otherwise. |
|
|
|
revision:: |
|
Revision shown. Defaults to HEAD. |
|
|
|
path:: |
|
The path within the <repository> that the action is performed on, |
|
for those actions that require it. |
|
|
|
arguments:: |
|
Any arguments that control the behaviour of the action. |
|
|
|
Some actions require or allow to specify two revisions, and sometimes even two |
|
pathnames. In most general form such path_info (component) based gitweb URL |
|
looks like this: |
|
|
|
----------------------------------------------------------------------- |
|
.../gitweb.cgi/<repo>/<action>/<revision_from>:/<path_from>..<revision_to>:/<path_to>?<arguments> |
|
----------------------------------------------------------------------- |
|
|
|
|
|
Each action is implemented as a subroutine, and must be present in %actions |
|
hash. Some actions are disabled by default, and must be turned on via feature |
|
mechanism. For example to enable 'blame' view add the following to gitweb |
|
configuration file: |
|
|
|
----------------------------------------------------------------------- |
|
$feature{'blame'}{'default'} = [1]; |
|
----------------------------------------------------------------------- |
|
|
|
|
|
Actions: |
|
~~~~~~~~ |
|
The standard actions are: |
|
|
|
project_list:: |
|
Lists the available Git repositories. This is the default command if no |
|
repository is specified in the URL. |
|
|
|
summary:: |
|
Displays summary about given repository. This is the default command if |
|
no action is specified in URL, and only repository is specified. |
|
|
|
heads:: |
|
remotes:: |
|
Lists all local or all remote-tracking branches in given repository. |
|
+ |
|
The latter is not available by default, unless configured. |
|
|
|
tags:: |
|
List all tags (lightweight and annotated) in given repository. |
|
|
|
blob:: |
|
tree:: |
|
Shows the files and directories in a given repository path, at given |
|
revision. This is default command if no action is specified in the URL, |
|
and path is given. |
|
|
|
blob_plain:: |
|
Returns the raw data for the file in given repository, at given path and |
|
revision. Links to this action are marked 'raw'. |
|
|
|
blobdiff:: |
|
Shows the difference between two revisions of the same file. |
|
|
|
blame:: |
|
blame_incremental:: |
|
Shows the blame (also called annotation) information for a file. On a |
|
per line basis it shows the revision in which that line was last changed |
|
and the user that committed the change. The incremental version (which |
|
if configured is used automatically when JavaScript is enabled) uses |
|
Ajax to incrementally add blame info to the contents of given file. |
|
+ |
|
This action is disabled by default for performance reasons. |
|
|
|
commit:: |
|
commitdiff:: |
|
Shows information about a specific commit in a repository. The 'commit' |
|
view shows information about commit in more detail, the 'commitdiff' |
|
action shows changeset for given commit. |
|
|
|
patch:: |
|
Returns the commit in plain text mail format, suitable for applying with |
|
linkgit:git-am[1]. |
|
|
|
tag:: |
|
Display specific annotated tag (tag object). |
|
|
|
log:: |
|
shortlog:: |
|
Shows log information (commit message or just commit subject) for a |
|
given branch (starting from given revision). |
|
+ |
|
The 'shortlog' view is more compact; it shows one commit per line. |
|
|
|
history:: |
|
Shows history of the file or directory in a given repository path, |
|
starting from given revision (defaults to HEAD, i.e. default branch). |
|
+ |
|
This view is similar to 'shortlog' view. |
|
|
|
rss:: |
|
atom:: |
|
Generates an RSS (or Atom) feed of changes to repository. |
|
|
|
|
|
WEBSERVER CONFIGURATION |
|
----------------------- |
|
This section explains how to configure some common webservers to run gitweb. In |
|
all cases, `/path/to/gitweb` in the examples is the directory you ran installed |
|
gitweb in, and contains `gitweb_config.perl`. |
|
|
|
If you've configured a web server that isn't listed here for gitweb, please send |
|
in the instructions so they can be included in a future release. |
|
|
|
Apache as CGI |
|
~~~~~~~~~~~~~ |
|
Apache must be configured to support CGI scripts in the directory in |
|
which gitweb is installed. Let's assume that it is `/var/www/cgi-bin` |
|
directory. |
|
|
|
----------------------------------------------------------------------- |
|
ScriptAlias /cgi-bin/ "/var/www/cgi-bin/" |
|
|
|
<Directory "/var/www/cgi-bin"> |
|
Options Indexes FollowSymlinks ExecCGI |
|
AllowOverride None |
|
Order allow,deny |
|
Allow from all |
|
</Directory> |
|
----------------------------------------------------------------------- |
|
|
|
With that configuration the full path to browse repositories would be: |
|
|
|
http://server/cgi-bin/gitweb.cgi |
|
|
|
Apache with mod_perl, via ModPerl::Registry |
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
|
You can use mod_perl with gitweb. You must install Apache::Registry |
|
(for mod_perl 1.x) or ModPerl::Registry (for mod_perl 2.x) to enable |
|
this support. |
|
|
|
Assuming that gitweb is installed to `/var/www/perl`, the following |
|
Apache configuration (for mod_perl 2.x) is suitable. |
|
|
|
----------------------------------------------------------------------- |
|
Alias /perl "/var/www/perl" |
|
|
|
<Directory "/var/www/perl"> |
|
SetHandler perl-script |
|
PerlResponseHandler ModPerl::Registry |
|
PerlOptions +ParseHeaders |
|
Options Indexes FollowSymlinks +ExecCGI |
|
AllowOverride None |
|
Order allow,deny |
|
Allow from all |
|
</Directory> |
|
----------------------------------------------------------------------- |
|
|
|
With that configuration the full path to browse repositories would be: |
|
|
|
http://server/perl/gitweb.cgi |
|
|
|
Apache with FastCGI |
|
~~~~~~~~~~~~~~~~~~~ |
|
Gitweb works with Apache and FastCGI. First you need to rename, copy |
|
or symlink gitweb.cgi to gitweb.fcgi. Let's assume that gitweb is |
|
installed in `/usr/share/gitweb` directory. The following Apache |
|
configuration is suitable (UNTESTED!) |
|
|
|
----------------------------------------------------------------------- |
|
FastCgiServer /usr/share/gitweb/gitweb.cgi |
|
ScriptAlias /gitweb /usr/share/gitweb/gitweb.cgi |
|
|
|
Alias /gitweb/static /usr/share/gitweb/static |
|
<Directory /usr/share/gitweb/static> |
|
SetHandler default-handler |
|
</Directory> |
|
----------------------------------------------------------------------- |
|
|
|
With that configuration the full path to browse repositories would be: |
|
|
|
http://server/gitweb |
|
|
|
|
|
ADVANCED WEB SERVER SETUP |
|
------------------------- |
|
All of those examples use request rewriting, and need `mod_rewrite` |
|
(or equivalent; examples below are written for Apache). |
|
|
|
Single URL for gitweb and for fetching |
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
|
If you want to have one URL for both gitweb and your `http://` |
|
repositories, you can configure Apache like this: |
|
|
|
----------------------------------------------------------------------- |
|
<VirtualHost *:80> |
|
ServerName git.example.org |
|
DocumentRoot /pub/git |
|
SetEnv GITWEB_CONFIG /etc/gitweb.conf |
|
|
|
# turning on mod rewrite |
|
RewriteEngine on |
|
|
|
# make the front page an internal rewrite to the gitweb script |
|
RewriteRule ^/$ /cgi-bin/gitweb.cgi |
|
|
|
# make access for "dumb clients" work |
|
RewriteRule ^/(.*\.git/(?!/?(HEAD|info|objects|refs)).*)?$ \ |
|
/cgi-bin/gitweb.cgi%{REQUEST_URI} [L,PT] |
|
</VirtualHost> |
|
----------------------------------------------------------------------- |
|
|
|
The above configuration expects your public repositories to live under |
|
`/pub/git` and will serve them as `http://git.domain.org/dir-under-pub-git`, |
|
both as clonable Git URL and as browseable gitweb interface. If you then |
|
start your linkgit:git-daemon[1] with `--base-path=/pub/git --export-all` |
|
then you can even use the `git://` URL with exactly the same path. |
|
|
|
Setting the environment variable `GITWEB_CONFIG` will tell gitweb to use the |
|
named file (i.e. in this example `/etc/gitweb.conf`) as a configuration for |
|
gitweb. You don't really need it in above example; it is required only if |
|
your configuration file is in different place than built-in (during |
|
compiling gitweb) 'gitweb_config.perl' or `/etc/gitweb.conf`. See |
|
linkgit:gitweb.conf[5] for details, especially information about precedence |
|
rules. |
|
|
|
If you use the rewrite rules from the example you *might* also need |
|
something like the following in your gitweb configuration file |
|
(`/etc/gitweb.conf` following example): |
|
---------------------------------------------------------------------------- |
|
@stylesheets = ("/some/absolute/path/gitweb.css"); |
|
$my_uri = "/"; |
|
$home_link = "/"; |
|
$per_request_config = 1; |
|
---------------------------------------------------------------------------- |
|
Nowadays though gitweb should create HTML base tag when needed (to set base |
|
URI for relative links), so it should work automatically. |
|
|
|
|
|
Webserver configuration with multiple projects' root |
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
|
If you want to use gitweb with several project roots you can edit your |
|
Apache virtual host and gitweb configuration files in the following way. |
|
|
|
The virtual host configuration (in Apache configuration file) should look |
|
like this: |
|
-------------------------------------------------------------------------- |
|
<VirtualHost *:80> |
|
ServerName git.example.org |
|
DocumentRoot /pub/git |
|
SetEnv GITWEB_CONFIG /etc/gitweb.conf |
|
|
|
# turning on mod rewrite |
|
RewriteEngine on |
|
|
|
# make the front page an internal rewrite to the gitweb script |
|
RewriteRule ^/$ /cgi-bin/gitweb.cgi [QSA,L,PT] |
|
|
|
# look for a public_git folder in unix users' home |
|
# http://git.example.org/~<user>/ |
|
RewriteRule ^/\~([^\/]+)(/|/gitweb.cgi)?$ /cgi-bin/gitweb.cgi \ |
|
[QSA,E=GITWEB_PROJECTROOT:/home/$1/public_git/,L,PT] |
|
|
|
# http://git.example.org/+<user>/ |
|
#RewriteRule ^/\+([^\/]+)(/|/gitweb.cgi)?$ /cgi-bin/gitweb.cgi \ |
|
[QSA,E=GITWEB_PROJECTROOT:/home/$1/public_git/,L,PT] |
|
|
|
# http://git.example.org/user/<user>/ |
|
#RewriteRule ^/user/([^\/]+)/(gitweb.cgi)?$ /cgi-bin/gitweb.cgi \ |
|
[QSA,E=GITWEB_PROJECTROOT:/home/$1/public_git/,L,PT] |
|
|
|
# defined list of project roots |
|
RewriteRule ^/scm(/|/gitweb.cgi)?$ /cgi-bin/gitweb.cgi \ |
|
[QSA,E=GITWEB_PROJECTROOT:/pub/scm/,L,PT] |
|
RewriteRule ^/var(/|/gitweb.cgi)?$ /cgi-bin/gitweb.cgi \ |
|
[QSA,E=GITWEB_PROJECTROOT:/var/git/,L,PT] |
|
|
|
# make access for "dumb clients" work |
|
RewriteRule ^/(.*\.git/(?!/?(HEAD|info|objects|refs)).*)?$ \ |
|
/cgi-bin/gitweb.cgi%{REQUEST_URI} [L,PT] |
|
</VirtualHost> |
|
-------------------------------------------------------------------------- |
|
|
|
Here actual project root is passed to gitweb via `GITWEB_PROJECT_ROOT` |
|
environment variable from a web server, so you need to put the following |
|
line in gitweb configuration file (`/etc/gitweb.conf` in above example): |
|
-------------------------------------------------------------------------- |
|
$projectroot = $ENV{'GITWEB_PROJECTROOT'} || "/pub/git"; |
|
-------------------------------------------------------------------------- |
|
*Note* that this requires to be set for each request, so either |
|
`$per_request_config` must be false, or the above must be put in code |
|
referenced by `$per_request_config`; |
|
|
|
These configurations enable two things. First, each unix user (`<user>`) of |
|
the server will be able to browse through gitweb Git repositories found in |
|
`~/public_git/` with the following url: |
|
|
|
http://git.example.org/~<user>/ |
|
|
|
If you do not want this feature on your server just remove the second |
|
rewrite rule. |
|
|
|
If you already use `mod_userdir` in your virtual host or you don't want to |
|
use the \'~' as first character, just comment or remove the second rewrite |
|
rule, and uncomment one of the following according to what you want. |
|
|
|
Second, repositories found in `/pub/scm/` and `/var/git/` will be accessible |
|
through `http://git.example.org/scm/` and `http://git.example.org/var/`. |
|
You can add as many project roots as you want by adding rewrite rules like |
|
the third and the fourth. |
|
|
|
|
|
PATH_INFO usage |
|
~~~~~~~~~~~~~~~ |
|
If you enable PATH_INFO usage in gitweb by putting |
|
---------------------------------------------------------------------------- |
|
$feature{'pathinfo'}{'default'} = [1]; |
|
---------------------------------------------------------------------------- |
|
in your gitweb configuration file, it is possible to set up your server so |
|
that it consumes and produces URLs in the form |
|
|
|
http://git.example.com/project.git/shortlog/sometag |
|
|
|
i.e. without 'gitweb.cgi' part, by using a configuration such as the |
|
following. This configuration assumes that `/var/www/gitweb` is the |
|
DocumentRoot of your webserver, contains the gitweb.cgi script and |
|
complementary static files (stylesheet, favicon, JavaScript): |
|
|
|
---------------------------------------------------------------------------- |
|
<VirtualHost *:80> |
|
ServerAlias git.example.com |
|
|
|
DocumentRoot /var/www/gitweb |
|
|
|
<Directory /var/www/gitweb> |
|
Options ExecCGI |
|
AddHandler cgi-script cgi |
|
|
|
DirectoryIndex gitweb.cgi |
|
|
|
RewriteEngine On |
|
RewriteCond %{REQUEST_FILENAME} !-f |
|
RewriteCond %{REQUEST_FILENAME} !-d |
|
RewriteRule ^.* /gitweb.cgi/$0 [L,PT] |
|
</Directory> |
|
</VirtualHost> |
|
---------------------------------------------------------------------------- |
|
The rewrite rule guarantees that existing static files will be properly |
|
served, whereas any other URL will be passed to gitweb as PATH_INFO |
|
parameter. |
|
|
|
*Notice* that in this case you don't need special settings for |
|
`@stylesheets`, `$my_uri` and `$home_link`, but you lose "dumb client" |
|
access to your project .git dirs (described in "Single URL for gitweb and |
|
for fetching" section). A possible workaround for the latter is the |
|
following: in your project root dir (e.g. `/pub/git`) have the projects |
|
named *without* a .git extension (e.g. `/pub/git/project` instead of |
|
`/pub/git/project.git`) and configure Apache as follows: |
|
---------------------------------------------------------------------------- |
|
<VirtualHost *:80> |
|
ServerAlias git.example.com |
|
|
|
DocumentRoot /var/www/gitweb |
|
|
|
AliasMatch ^(/.*?)(\.git)(/.*)?$ /pub/git$1$3 |
|
<Directory /var/www/gitweb> |
|
Options ExecCGI |
|
AddHandler cgi-script cgi |
|
|
|
DirectoryIndex gitweb.cgi |
|
|
|
RewriteEngine On |
|
RewriteCond %{REQUEST_FILENAME} !-f |
|
RewriteCond %{REQUEST_FILENAME} !-d |
|
RewriteRule ^.* /gitweb.cgi/$0 [L,PT] |
|
</Directory> |
|
</VirtualHost> |
|
---------------------------------------------------------------------------- |
|
|
|
The additional AliasMatch makes it so that |
|
|
|
http://git.example.com/project.git |
|
|
|
will give raw access to the project's Git dir (so that the project can be |
|
cloned), while |
|
|
|
http://git.example.com/project |
|
|
|
will provide human-friendly gitweb access. |
|
|
|
This solution is not 100% bulletproof, in the sense that if some project has |
|
a named ref (branch, tag) starting with `git/`, then paths such as |
|
|
|
http://git.example.com/project/command/abranch..git/abranch |
|
|
|
will fail with a 404 error. |
|
|
|
|
|
BUGS |
|
---- |
|
Please report any bugs or feature requests to git@vger.kernel.org, |
|
putting "gitweb" in the subject of email. |
|
|
|
SEE ALSO |
|
-------- |
|
linkgit:gitweb.conf[5], linkgit:git-instaweb[1] |
|
|
|
`gitweb/README`, `gitweb/INSTALL` |
|
|
|
GIT |
|
--- |
|
Part of the linkgit:git[1] suite
|
|
|