2014-01-08 19:45:29 +01:00
|
|
|
cgit - CGI for Git
|
|
|
|
==================
|
2006-12-10 22:31:36 +01:00
|
|
|
|
2014-01-08 19:45:29 +01:00
|
|
|
This is an attempt to create a fast web interface for the Git SCM, using a
|
|
|
|
built-in cache to decrease server I/O pressure.
|
2006-12-13 02:06:29 +01:00
|
|
|
|
2007-01-28 13:18:23 +01:00
|
|
|
Installation
|
2014-01-08 19:45:29 +01:00
|
|
|
------------
|
2007-01-28 13:18:23 +01:00
|
|
|
|
2014-01-08 19:45:29 +01:00
|
|
|
Building cgit involves building a proper version of Git. How to do this
|
2007-09-04 11:49:40 +02:00
|
|
|
depends on how you obtained the cgit sources:
|
|
|
|
|
|
|
|
a) If you're working in a cloned cgit repository, you first need to
|
2014-01-08 19:45:29 +01:00
|
|
|
initialize and update the Git submodule:
|
2007-09-04 11:49:40 +02:00
|
|
|
|
2014-01-08 19:45:29 +01:00
|
|
|
$ git submodule init # register the Git submodule in .git/config
|
|
|
|
$ $EDITOR .git/config # if you want to specify a different url for git
|
|
|
|
$ git submodule update # clone/fetch and checkout correct git version
|
2007-09-04 11:49:40 +02:00
|
|
|
|
|
|
|
b) If you're building from a cgit tarball, you can download a proper git
|
|
|
|
version like this:
|
2007-01-28 13:18:23 +01:00
|
|
|
|
2014-01-08 19:45:29 +01:00
|
|
|
$ make get-git
|
2007-02-04 23:57:34 +01:00
|
|
|
|
2007-09-04 11:49:40 +02:00
|
|
|
When either a) or b) has been performed, you can build and install cgit like
|
|
|
|
this:
|
2007-02-04 23:57:34 +01:00
|
|
|
|
2014-01-08 19:45:29 +01:00
|
|
|
$ make
|
|
|
|
$ sudo make install
|
2007-05-11 12:13:15 +02:00
|
|
|
|
2014-01-08 19:45:29 +01:00
|
|
|
This will install `cgit.cgi` and `cgit.css` into `/var/www/htdocs/cgit`. You
|
|
|
|
can configure this location (and a few other things) by providing a `cgit.conf`
|
2007-09-04 11:49:40 +02:00
|
|
|
file (see the Makefile for details).
|
2007-05-11 12:13:15 +02:00
|
|
|
|
2014-01-14 03:48:23 +01:00
|
|
|
If you'd like to compile without Lua support, you may use:
|
|
|
|
|
|
|
|
$ make NO_LUA=1
|
|
|
|
|
|
|
|
And if you'd like to specify a Lua implementation, you may use:
|
|
|
|
|
|
|
|
$ make LUA_IMPLEMENTATION=JIT
|
|
|
|
|
|
|
|
for using the LuaJIT project. Or:
|
|
|
|
|
|
|
|
$ make LUA_IMPLEMENTATION=VANILLA
|
|
|
|
|
|
|
|
for the mainline Lua project. If you specify neither implementation, it will
|
|
|
|
be auto-detected, preferring LuaJIT if both are present.
|
|
|
|
|
|
|
|
|
2014-01-08 19:45:29 +01:00
|
|
|
Dependencies
|
|
|
|
------------
|
2007-05-11 12:13:15 +02:00
|
|
|
|
2014-01-09 19:44:27 +01:00
|
|
|
* libzip
|
|
|
|
* libcrypto (OpenSSL)
|
|
|
|
* libssl (OpenSSL)
|
2014-01-13 14:18:51 +01:00
|
|
|
* optional: luajit or lua
|
2007-05-11 12:13:15 +02:00
|
|
|
|
|
|
|
Apache configuration
|
2014-01-08 19:45:29 +01:00
|
|
|
--------------------
|
2007-05-11 12:13:15 +02:00
|
|
|
|
2014-01-08 19:45:29 +01:00
|
|
|
A new `Directory` section must probably be added for cgit, possibly something
|
2007-05-11 12:13:15 +02:00
|
|
|
like this:
|
2007-02-04 23:57:34 +01:00
|
|
|
|
2014-01-08 19:45:29 +01:00
|
|
|
<Directory "/var/www/htdocs/cgit/">
|
|
|
|
AllowOverride None
|
|
|
|
Options +ExecCGI
|
|
|
|
Order allow,deny
|
|
|
|
Allow from all
|
|
|
|
</Directory>
|
2007-01-28 13:18:23 +01:00
|
|
|
|
2006-12-13 02:06:29 +01:00
|
|
|
|
2007-01-28 13:18:23 +01:00
|
|
|
Runtime configuration
|
2014-01-08 19:45:29 +01:00
|
|
|
---------------------
|
2006-12-13 02:06:29 +01:00
|
|
|
|
2014-01-08 19:45:29 +01:00
|
|
|
The file `/etc/cgitrc` is read by cgit before handling a request. In addition
|
2011-06-13 13:24:46 +00:00
|
|
|
to runtime parameters, this file may also contain a list of repositories
|
2014-01-08 19:45:29 +01:00
|
|
|
displayed by cgit (see `cgitrc.5.txt` for further details).
|
2006-12-13 02:06:29 +01:00
|
|
|
|
2007-01-28 13:18:23 +01:00
|
|
|
The cache
|
2014-01-08 19:45:29 +01:00
|
|
|
---------
|
2007-01-28 13:18:23 +01:00
|
|
|
|
2014-01-08 19:45:29 +01:00
|
|
|
When cgit is invoked it looks for a cache file matching the request and
|
|
|
|
returns it to the client. If no such cache file exists (or if it has expired),
|
|
|
|
the content for the request is written into the proper cache file before the
|
2007-01-28 13:18:23 +01:00
|
|
|
file is returned.
|
|
|
|
|
2014-01-08 19:45:29 +01:00
|
|
|
If the cache file has expired but cgit is unable to obtain a lock for it, the
|
|
|
|
stale cache file is returned to the client. This is done to favour page
|
2007-01-28 13:18:23 +01:00
|
|
|
throughput over page freshness.
|
2006-12-13 02:06:29 +01:00
|
|
|
|
2007-01-28 13:18:23 +01:00
|
|
|
The generated content contains the complete response to the client, including
|
2014-01-08 19:45:29 +01:00
|
|
|
the HTTP headers `Modified` and `Expires`.
|
2007-05-11 12:13:15 +02:00
|
|
|
|
2011-06-13 13:24:46 +00:00
|
|
|
Online presence
|
2014-01-08 19:45:29 +01:00
|
|
|
---------------
|
2007-05-11 12:13:15 +02:00
|
|
|
|
2013-05-27 21:56:57 +02:00
|
|
|
* The cgit homepage is hosted by cgit at <http://git.zx2c4.com/cgit/about/>
|
2007-05-11 12:13:15 +02:00
|
|
|
|
2014-01-08 19:45:29 +01:00
|
|
|
* Patches, bug reports, discussions and support should go to the cgit
|
2013-05-13 14:00:50 +02:00
|
|
|
mailing list: <cgit@lists.zx2c4.com>. To sign up, visit
|
|
|
|
<http://lists.zx2c4.com/mailman/listinfo/cgit>
|