blob: 52caed0dfbc178e690c262d490d4b746af0c23f0 [file] [log] [blame]
Loui Chang676d17b2009-09-14 01:21:10 -04001:man source: cgit
2:man manual: cgit
3
Matt McCormick (thewtex)9f9ede32009-02-11 23:06:05 -06004CGITRC(5)
5========
Lars Hjemlidf461232008-10-05 18:55:49 +02006
7
8NAME
9----
Lars Hjemlic54f8a52009-02-12 10:12:05 +010010cgitrc - runtime configuration for cgit
Lars Hjemlidf461232008-10-05 18:55:49 +020011
12
Matt McCormick (thewtex)9f9ede32009-02-11 23:06:05 -060013SYNOPSIS
14--------
Lars Hjemlidf461232008-10-05 18:55:49 +020015Cgitrc contains all runtime settings for cgit, including the list of git
16repositories, formatted as a line-separated list of NAME=VALUE pairs. Blank
17lines, and lines starting with '#', are ignored.
18
19
Lars Hjemlifcc60562009-08-10 18:58:29 +020020LOCATION
21--------
22The default location of cgitrc, defined at compile time, is /etc/cgitrc. At
23runtime, cgit will consult the environment variable CGIT_CONFIG and, if
24defined, use its value instead.
25
26
Lars Hjemlidf461232008-10-05 18:55:49 +020027GLOBAL SETTINGS
28---------------
Lars Hjemli537c05f2009-08-09 13:27:21 +020029about-filter::
30 Specifies a command which will be invoked to format the content of
31 about pages (both top-level and for each repository). The command will
Jason A. Donenfeld2a1ead32013-05-25 20:30:57 +020032 get the content of the about-file on its STDIN, the name of the file
33 as the first argument, and the STDOUT from the command will be
34 included verbatim on the about page. Default value: none. See
35 also: "FILTER API".
Lars Hjemli537c05f2009-08-09 13:27:21 +020036
Lars Hjemlid3b29332009-02-12 09:58:28 +010037agefile::
Lars Hjemlidf461232008-10-05 18:55:49 +020038 Specifies a path, relative to each repository path, which can be used
39 to specify the date and time of the youngest commit in the repository.
40 The first line in the file is used as input to the "parse_date"
41 function in libgit. Recommended timestamp-format is "yyyy-mm-dd
Christian Hesse820df9c2013-07-22 09:13:39 +020042 hh:mm:ss". You may want to generate this file from a post-receive
43 hook. Default value: "info/web/last-modified".
Lars Hjemlidf461232008-10-05 18:55:49 +020044
Jason A. Donenfeld389cc172013-04-08 16:57:12 +020045branch-sort::
46 Flag which, when set to "age", enables date ordering in the branch ref
47 list, and when set to "name" enables ordering by branch name. Default
48 value: "name".
49
Lars Hjemlid3b29332009-02-12 09:58:28 +010050cache-root::
Lars Hjemlidf461232008-10-05 18:55:49 +020051 Path used to store the cgit cache entries. Default value:
Lars Hjemlief13e5e2011-06-13 21:58:39 +000052 "/var/cache/cgit". See also: "MACRO EXPANSION".
Lars Hjemlidf461232008-10-05 18:55:49 +020053
Jason A. Donenfeld61ff1002013-05-28 16:33:30 +020054cache-static-ttl::
55 Number which specifies the time-to-live, in minutes, for the cached
56 version of repository pages accessed with a fixed SHA1. Negative
57 values have infinite ttl. Default value: -1".
58
Lars Hjemlid3b29332009-02-12 09:58:28 +010059cache-dynamic-ttl::
Lars Hjemlidf461232008-10-05 18:55:49 +020060 Number which specifies the time-to-live, in minutes, for the cached
Jason A. Donenfeld61ff1002013-05-28 16:33:30 +020061 version of repository pages accessed without a fixed SHA1. Negative
62 values have infinite ttl. Default value: "5".
Lars Hjemlidf461232008-10-05 18:55:49 +020063
Lars Hjemlid3b29332009-02-12 09:58:28 +010064cache-repo-ttl::
Lars Hjemlidf461232008-10-05 18:55:49 +020065 Number which specifies the time-to-live, in minutes, for the cached
Jason A. Donenfeld61ff1002013-05-28 16:33:30 +020066 version of the repository summary page. Negative values have infinite
67 ttl. Default value: "5".
Lars Hjemlidf461232008-10-05 18:55:49 +020068
Lars Hjemlid3b29332009-02-12 09:58:28 +010069cache-root-ttl::
Lars Hjemlidf461232008-10-05 18:55:49 +020070 Number which specifies the time-to-live, in minutes, for the cached
Jason A. Donenfeld61ff1002013-05-28 16:33:30 +020071 version of the repository index page. Negative values have infinite
72 ttl. Default value: "5".
Lars Hjemlidf461232008-10-05 18:55:49 +020073
Lars Hjemlib4dc93d2009-08-20 17:42:14 +020074cache-scanrc-ttl::
75 Number which specifies the time-to-live, in minutes, for the result
Jason A. Donenfeld61ff1002013-05-28 16:33:30 +020076 of scanning a path for git repositories. Negative values have infinite
77 ttl. Default value: "15".
78
79cache-about-ttl::
80 Number which specifies the time-to-live, in minutes, for the cached
81 version of the repository about page. Negative values have infinite
82 ttl. Default value: "15".
Lars Hjemlib4dc93d2009-08-20 17:42:14 +020083
Lars Hjemlid3b29332009-02-12 09:58:28 +010084cache-size::
Lars Hjemlidf461232008-10-05 18:55:49 +020085 The maximum number of entries in the cgit cache. Default value: "0"
86 (i.e. caching is disabled).
87
Jason A. Donenfeld184c5652012-07-12 19:13:39 +020088case-sensitive-sort::
89 Sort items in the repo list case sensitively. Default value: "1".
Tobias Bieniek7a4e7c82012-10-09 20:53:29 +020090 See also: repository-sort, section-sort.
Jason A. Donenfeld184c5652012-07-12 19:13:39 +020091
Lars Hjemlid3b29332009-02-12 09:58:28 +010092clone-prefix::
Lars Hjemlidf461232008-10-05 18:55:49 +020093 Space-separated list of common prefixes which, when combined with a
94 repository url, generates valid clone urls for the repository. This
95 setting is only used if `repo.clone-url` is unspecified. Default value:
96 none.
97
Lars Hjemlia1429db2011-06-06 20:49:13 +000098clone-url::
99 Space-separated list of clone-url templates. This setting is only
100 used if `repo.clone-url` is unspecified. Default value: none. See
101 also: "MACRO EXPANSION", "FILTER API".
102
Lars Hjemlif35db1c2009-07-31 17:42:57 +0200103commit-filter::
104 Specifies a command which will be invoked to format commit messages.
105 The command will get the message on its STDIN, and the STDOUT from the
106 command will be included verbatim as the commit message, i.e. this can
107 be used to implement bugtracker integration. Default value: none.
Ferry Hubertsb2cf6302011-03-23 11:57:44 +0100108 See also: "FILTER API".
Lars Hjemlif35db1c2009-07-31 17:42:57 +0200109
Jason A. Donenfeld389cc172013-04-08 16:57:12 +0200110commit-sort::
111 Flag which, when set to "date", enables strict date ordering in the
112 commit log, and when set to "topo" enables strict topological
113 ordering. If unset, the default ordering of "git log" is used. Default
114 value: unset.
115
Lars Hjemlid3b29332009-02-12 09:58:28 +0100116css::
Lars Hjemlidf461232008-10-05 18:55:49 +0200117 Url which specifies the css document to include in all cgit pages.
118 Default value: "/cgit.css".
119
Lars Hjemli286a9052009-07-25 12:29:22 +0200120embedded::
Lars Hjemli86b753c2009-07-25 12:23:30 +0200121 Flag which, when set to "1", will make cgit generate a html fragment
122 suitable for embedding in other html pages. Default value: none. See
123 also: "noheader".
Johan Herland9a8d39c2010-11-15 18:39:50 +0100124
125enable-commit-graph::
126 Flag which, when set to "1", will make cgit print an ASCII-art commit
127 history graph to the left of the commit messages in the repository
128 log page. Default value: "0".
129
Lars Hjemli2273c2c2009-08-24 08:53:21 +0200130enable-filter-overrides::
131 Flag which, when set to "1", allows all filter settings to be
132 overridden in repository-specific cgitrc files. Default value: none.
133
Dan McGee42231322011-01-12 12:06:07 -0600134enable-http-clone::
135 If set to "1", cgit will act as an dumb HTTP endpoint for git clones.
Přemysl Janouch4f6fb322013-09-11 20:10:14 +0200136 You can add "http://$HTTP_HOST$SCRIPT_NAME/$CGIT_REPO_URL" to clone-url
137 to expose this feature. If you use an alternate way of serving git
138 repositories, you may wish to disable this. Default value: "1".
Dan McGee42231322011-01-12 12:06:07 -0600139
Lars Hjemlid3b29332009-02-12 09:58:28 +0100140enable-index-links::
Lars Hjemlidf461232008-10-05 18:55:49 +0200141 Flag which, when set to "1", will make cgit generate extra links for
142 each repo in the repository index (specifically, to the "summary",
143 "commit" and "tree" pages). Default value: "0".
144
Florian Pritzb1e172a2013-02-01 10:59:13 +0100145enable-index-owner::
146 Flag which, when set to "1", will make cgit display the owner of
147 each repo in the repository index. Default value: "1".
148
Lars Hjemlid3b29332009-02-12 09:58:28 +0100149enable-log-filecount::
Lars Hjemlidf461232008-10-05 18:55:49 +0200150 Flag which, when set to "1", will make cgit print the number of
151 modified files for each commit on the repository log page. Default
152 value: "0".
153
Lars Hjemlid3b29332009-02-12 09:58:28 +0100154enable-log-linecount::
Lars Hjemlidf461232008-10-05 18:55:49 +0200155 Flag which, when set to "1", will make cgit print the number of added
156 and removed lines for each commit on the repository log page. Default
157 value: "0".
158
Lars Hjemli41934a32009-11-07 19:10:58 +0100159enable-remote-branches::
160 Flag which, when set to "1", will make cgit display remote branches
161 in the summary and refs views. Default value: "0". See also:
162 "repo.enable-remote-branches".
163
Lars Hjemli581a0c22010-02-27 13:12:55 +0100164enable-subject-links::
165 Flag which, when set to "1", will make cgit use the subject of the
166 parent commit as link text when generating links to parent commits
167 in commit view. Default value: "0". See also:
168 "repo.enable-subject-links".
169
Lars Hjemlib0f946b2009-08-21 14:26:52 +0200170enable-tree-linenumbers::
171 Flag which, when set to "1", will make cgit generate linenumber links
172 for plaintext blobs printed in the tree view. Default value: "1".
173
Jason A. Donenfeld521e10c2012-10-09 06:56:14 -0400174enable-git-config::
175 Flag which, when set to "1", will allow cgit to use git config to set
176 any repo specific settings. This option is used in conjunction with
Jason A. Donenfelda8d613e2013-04-10 14:42:49 +0200177 "scan-path", and must be defined prior, to augment repo-specific
178 settings. The keys gitweb.owner, gitweb.category, and gitweb.description
179 will map to the cgit keys repo.owner, repo.section, and repo.desc,
Přemysl Janouch88028ad2013-09-11 20:10:10 +0200180 respectively. All git config keys that begin with "cgit." will be mapped
Jason A. Donenfelda8d613e2013-04-10 14:42:49 +0200181 to the corresponding "repo." key in cgit. Default value: "0". See also:
182 scan-path, section-from-path.
Jason A. Donenfeld521e10c2012-10-09 06:56:14 -0400183
Lars Hjemlid3b29332009-02-12 09:58:28 +0100184favicon::
Christian Hesse830eb6f2013-07-22 08:56:50 +0200185 Url used as link to a shortcut icon for cgit. It is suggested to use
186 the value "/favicon.ico" since certain browsers will ignore other
187 values. Default value: "/favicon.ico".
Lars Hjemlidf461232008-10-05 18:55:49 +0200188
Lars Hjemlid3b29332009-02-12 09:58:28 +0100189footer::
Lars Hjemlidf461232008-10-05 18:55:49 +0200190 The content of the file specified with this option will be included
191 verbatim at the bottom of all pages (i.e. it replaces the standard
192 "generated by..." message. Default value: none.
193
Lars Hjemlif618e8f2009-07-25 12:03:54 +0200194head-include::
195 The content of the file specified with this option will be included
196 verbatim in the html HEAD section on all pages. Default value: none.
197
Lars Hjemlid3b29332009-02-12 09:58:28 +0100198header::
Lars Hjemlib1159552009-01-29 21:27:39 +0100199 The content of the file specified with this option will be included
200 verbatim at the top of all pages. Default value: none.
201
Lars Hjemlid3b29332009-02-12 09:58:28 +0100202include::
Lars Hjemlidf461232008-10-05 18:55:49 +0200203 Name of a configfile to include before the rest of the current config-
Lars Hjemlief13e5e2011-06-13 21:58:39 +0000204 file is parsed. Default value: none. See also: "MACRO EXPANSION".
Lars Hjemlidf461232008-10-05 18:55:49 +0200205
Lars Hjemlid3b29332009-02-12 09:58:28 +0100206index-header::
Lars Hjemlidf461232008-10-05 18:55:49 +0200207 The content of the file specified with this option will be included
208 verbatim above the repository index. This setting is deprecated, and
209 will not be supported by cgit-1.0 (use root-readme instead). Default
210 value: none.
211
Lars Hjemlid3b29332009-02-12 09:58:28 +0100212index-info::
Lars Hjemlidf461232008-10-05 18:55:49 +0200213 The content of the file specified with this option will be included
214 verbatim below the heading on the repository index page. This setting
215 is deprecated, and will not be supported by cgit-1.0 (use root-desc
216 instead). Default value: none.
217
Lars Hjemlid3b29332009-02-12 09:58:28 +0100218local-time::
Lars Hjemlidf461232008-10-05 18:55:49 +0200219 Flag which, if set to "1", makes cgit print commit and tag times in the
220 servers timezone. Default value: "0".
221
Lars Hjemlid3b29332009-02-12 09:58:28 +0100222logo::
Lars Hjemlidf461232008-10-05 18:55:49 +0200223 Url which specifies the source of an image which will be used as a logo
Lars Hjemli92f9b532009-08-10 18:14:12 +0200224 on all cgit pages. Default value: "/cgit.png".
Lars Hjemlidf461232008-10-05 18:55:49 +0200225
Lars Hjemlid3b29332009-02-12 09:58:28 +0100226logo-link::
Lars Hjemlidf461232008-10-05 18:55:49 +0200227 Url loaded when clicking on the cgit logo image. If unspecified the
228 calculated url of the repository index page will be used. Default
229 value: none.
230
Aaron Griffin80476b02010-02-04 18:08:16 -0600231max-atom-items::
232 Specifies the number of items to display in atom feeds view. Default
233 value: "10".
234
Lars Hjemlid3b29332009-02-12 09:58:28 +0100235max-commit-count::
Lars Hjemlidf461232008-10-05 18:55:49 +0200236 Specifies the number of entries to list per page in "log" view. Default
237 value: "50".
238
Lars Hjemlid3b29332009-02-12 09:58:28 +0100239max-message-length::
Lars Hjemlidf461232008-10-05 18:55:49 +0200240 Specifies the maximum number of commit message characters to display in
241 "log" view. Default value: "80".
242
Lars Hjemlid3b29332009-02-12 09:58:28 +0100243max-repo-count::
Lars Hjemlidf461232008-10-05 18:55:49 +0200244 Specifies the number of entries to list per page on the repository
245 index page. Default value: "50".
246
Lars Hjemlid3b29332009-02-12 09:58:28 +0100247max-repodesc-length::
Lars Hjemlidf461232008-10-05 18:55:49 +0200248 Specifies the maximum number of repo description characters to display
249 on the repository index page. Default value: "80".
250
Georg Lukasef07ccc2009-11-28 03:44:33 +0100251max-blob-size::
252 Specifies the maximum size of a blob to display HTML for in KBytes.
253 Default value: "0" (limit disabled).
254
Lars Hjemlid3b29332009-02-12 09:58:28 +0100255max-stats::
Lars Hjemlifb2f3f62008-12-07 13:17:21 +0100256 Set the default maximum statistics period. Valid values are "week",
257 "month", "quarter" and "year". If unspecified, statistics are
258 disabled. Default value: none. See also: "repo.max-stats".
259
Lars Hjemlic4d46c72009-02-13 20:43:30 +0100260mimetype.<ext>::
261 Set the mimetype for the specified filename extension. This is used
262 by the `plain` command when returning blob content.
263
Ferry Hubertsd01c6002011-07-19 10:51:58 +0200264mimetype-file::
265 Specifies the file to use for automatic mimetype lookup. If specified
266 then this field is used as a fallback when no "mimetype.<ext>" match is
267 found. If unspecified then no such lookup is performed. The typical file
Jason A. Donenfeldc6f5bc72012-11-15 17:21:47 +0100268 to use on a Linux system is /etc/mime.types. The format of the file must
269 comply to:
Ferry Hubertsd01c6002011-07-19 10:51:58 +0200270 - a comment line is an empty line or a line starting with a hash (#),
271 optionally preceded by whitespace
272 - a non-comment line starts with the mimetype (like image/png), followed
273 by one or more file extensions (like jpg), all separated by whitespace
Jason A. Donenfeldab9805a2012-11-15 01:26:06 +0100274 Default value: none. See also: "mimetype.<ext>".
Ferry Hubertsd01c6002011-07-19 10:51:58 +0200275
Lars Hjemlid3b29332009-02-12 09:58:28 +0100276module-link::
Lars Hjemlidf461232008-10-05 18:55:49 +0200277 Text which will be used as the formatstring for a hyperlink when a
278 submodule is printed in a directory listing. The arguments for the
279 formatstring are the path and SHA1 of the submodule commit. Default
Lars Hjemli3fbaf092011-06-15 10:13:15 +0200280 value: none.
Lars Hjemlidf461232008-10-05 18:55:49 +0200281
Lars Hjemlid3b29332009-02-12 09:58:28 +0100282nocache::
Lars Hjemlidf461232008-10-05 18:55:49 +0200283 If set to the value "1" caching will be disabled. This settings is
284 deprecated, and will not be honored starting with cgit-1.0. Default
285 value: "0".
286
Martin Szulecki2f56e392009-08-07 14:05:17 +0200287noplainemail::
Jason A. Donenfeldcf152602013-08-16 13:15:17 -0600288 If set to "1" showing full author email addresses will be disabled.
Martin Szulecki2f56e392009-08-07 14:05:17 +0200289 Default value: "0".
290
Lars Hjemli286a9052009-07-25 12:29:22 +0200291noheader::
Lars Hjemli86b753c2009-07-25 12:23:30 +0200292 Flag which, when set to "1", will make cgit omit the standard header
293 on all pages. Default value: none. See also: "embedded".
294
Jason A. Donenfeld35165022010-07-29 17:52:29 +0200295project-list::
296 A list of subdirectories inside of scan-path, relative to it, that
297 should loaded as git repositories. This must be defined prior to
Lars Hjemlief13e5e2011-06-13 21:58:39 +0000298 scan-path. Default value: none. See also: scan-path, "MACRO
299 EXPANSION".
Jason A. Donenfeld35165022010-07-29 17:52:29 +0200300
Lars Hjemli515edb02010-08-21 15:08:01 +0200301readme::
Jason A. Donenfeld2a1ead32013-05-25 20:30:57 +0200302 Text which will be used as default value for "repo.readme". Multiple
Jason A. Donenfelddcbc0432013-05-26 15:20:02 +0200303 config keys may be specified, and cgit will use the first found file
304 in this list. This is useful in conjunction with scan-path. Default
305 value: none. See also: scan-path, repo.readme.
Lars Hjemli515edb02010-08-21 15:08:01 +0200306
Jason A. Donenfeld2e4a9412010-07-29 19:47:50 +0200307remove-suffix::
308 If set to "1" and scan-path is enabled, if any repositories are found
309 with a suffix of ".git", this suffix will be removed for the url and
Jason A. Donenfelda8d613e2013-04-10 14:42:49 +0200310 name. This must be defined prior to scan-path. Default value: "0".
311 See also: scan-path.
Jason A. Donenfeld2e4a9412010-07-29 19:47:50 +0200312
Lars Hjemlid3b29332009-02-12 09:58:28 +0100313renamelimit::
Lars Hjemlidf461232008-10-05 18:55:49 +0200314 Maximum number of files to consider when detecting renames. The value
315 "-1" uses the compiletime value in git (for further info, look at
316 `man git-diff`). Default value: "-1".
317
Lars Hjemlid3b29332009-02-12 09:58:28 +0100318repo.group::
Lars Hjemli007df982009-08-24 07:51:48 +0200319 Legacy alias for "section". This option is deprecated and will not be
320 supported in cgit-1.0.
Lars Hjemlidf461232008-10-05 18:55:49 +0200321
Jason A. Donenfeld389cc172013-04-08 16:57:12 +0200322repository-sort::
323 The way in which repositories in each section are sorted. Valid values
324 are "name" for sorting by the repo name or "age" for sorting by the
325 most recently updated repository. Default value: "name". See also:
326 section, case-sensitive-sort, section-sort.
327
Lars Hjemlid3b29332009-02-12 09:58:28 +0100328robots::
Lars Hjemlidf461232008-10-05 18:55:49 +0200329 Text used as content for the "robots" meta-tag. Default value:
330 "index, nofollow".
331
Lars Hjemlid3b29332009-02-12 09:58:28 +0100332root-desc::
Lars Hjemlidf461232008-10-05 18:55:49 +0200333 Text printed below the heading on the repository index page. Default
334 value: "a fast webinterface for the git dscm".
335
Lars Hjemlid3b29332009-02-12 09:58:28 +0100336root-readme::
Lars Hjemlidf461232008-10-05 18:55:49 +0200337 The content of the file specified with this option will be included
338 verbatim below the "about" link on the repository index page. Default
339 value: none.
340
Lars Hjemlid3b29332009-02-12 09:58:28 +0100341root-title::
Lars Hjemlidf461232008-10-05 18:55:49 +0200342 Text printed as heading on the repository index page. Default value:
343 "Git Repository Browser".
344
Johan Herlanddf522792010-11-15 20:41:00 +0100345scan-hidden-path::
346 If set to "1" and scan-path is enabled, scan-path will recurse into
347 directories whose name starts with a period ('.'). Otherwise,
348 scan-path will stay away from such directories (considered as
349 "hidden"). Note that this does not apply to the ".git" directory in
350 non-bare repos. This must be defined prior to scan-path.
351 Default value: 0. See also: scan-path.
352
Lars Hjemli00466372009-08-23 19:35:56 +0200353scan-path::
354 A path which will be scanned for repositories. If caching is enabled,
355 the result will be cached as a cgitrc include-file in the cache
Jason A. Donenfeld35165022010-07-29 17:52:29 +0200356 directory. If project-list has been defined prior to scan-path,
357 scan-path loads only the directories listed in the file pointed to by
Julius Plenzfacca562011-03-10 17:03:24 +0100358 project-list. Be advised that only the global settings taken
359 before the scan-path directive will be applied to each repository.
Lars Hjemlief13e5e2011-06-13 21:58:39 +0000360 Default value: none. See also: cache-scanrc-ttl, project-list,
361 "MACRO EXPANSION".
Lars Hjemli00466372009-08-23 19:35:56 +0200362
Lars Hjemli007df982009-08-24 07:51:48 +0200363section::
Lars Hjemlie7af0022009-08-23 22:58:39 +0200364 The name of the current repository section - all repositories defined
365 after this option will inherit the current section name. Default value:
366 none.
367
Tobias Bieniek7a4e7c82012-10-09 20:53:29 +0200368section-sort::
369 Flag which, when set to "1", will sort the sections on the repository
370 listing by name. Set this flag to "0" if the order in the cgitrc file should
371 be preserved. Default value: "1". See also: section,
372 case-sensitive-sort, repository-sort.
Jason A. Donenfeld184c5652012-07-12 19:13:39 +0200373
Lars Hjemli797110e2010-08-21 15:44:09 +0200374section-from-path::
Jason A. Donenfelda8d613e2013-04-10 14:42:49 +0200375 A number which, if defined prior to scan-path, specifies how many
Lars Hjemli797110e2010-08-21 15:44:09 +0200376 path elements from each repo path to use as a default section name.
377 If negative, cgit will discard the specified number of path elements
Jason A. Donenfeld184c5652012-07-12 19:13:39 +0200378 above the repo directory. Default value: "0".
Lars Hjemli797110e2010-08-21 15:44:09 +0200379
Ragnar Ouchterlonyc358aa32009-09-14 20:19:02 +0200380side-by-side-diffs::
381 If set to "1" shows side-by-side diffs instead of unidiffs per
382 default. Default value: "0".
383
Lars Hjemlid3b29332009-02-12 09:58:28 +0100384snapshots::
Lars Hjemlib44c40e2009-08-24 08:00:37 +0200385 Text which specifies the default set of snapshot formats generated by
386 cgit. The value is a space-separated list of zero or more of the
Lars Hjemli4d2a3032011-03-26 13:40:20 +0100387 values "tar", "tar.gz", "tar.bz2", "tar.xz" and "zip". Default value:
388 none.
Lars Hjemlidf461232008-10-05 18:55:49 +0200389
Lars Hjemli46b7abe2009-07-31 16:55:27 +0200390source-filter::
391 Specifies a command which will be invoked to format plaintext blobs
392 in the tree view. The command will get the blob content on its STDIN
393 and the name of the blob as its only command line argument. The STDOUT
394 from the command will be included verbatim as the blob contents, i.e.
395 this can be used to implement e.g. syntax highlighting. Default value:
Ferry Hubertsb2cf6302011-03-23 11:57:44 +0100396 none. See also: "FILTER API".
Lars Hjemli46b7abe2009-07-31 16:55:27 +0200397
Lars Hjemlid3b29332009-02-12 09:58:28 +0100398summary-branches::
Lars Hjemlidf461232008-10-05 18:55:49 +0200399 Specifies the number of branches to display in the repository "summary"
400 view. Default value: "10".
401
Lars Hjemlid3b29332009-02-12 09:58:28 +0100402summary-log::
Lars Hjemlidf461232008-10-05 18:55:49 +0200403 Specifies the number of log entries to display in the repository
404 "summary" view. Default value: "10".
405
Lars Hjemlid3b29332009-02-12 09:58:28 +0100406summary-tags::
Lars Hjemlidf461232008-10-05 18:55:49 +0200407 Specifies the number of tags to display in the repository "summary"
408 view. Default value: "10".
409
Felix Hanleye0c6f232010-11-08 19:41:13 +0100410strict-export::
411 Filename which, if specified, needs to be present within the repository
412 for cgit to allow access to that repository. This can be used to emulate
413 gitweb's EXPORT_OK and STRICT_EXPORT functionality and limit cgit's
Jason A. Donenfelda8d613e2013-04-10 14:42:49 +0200414 repositories to match those exported by git-daemon. This option must
415 be defined prior to scan-path.
Felix Hanleye0c6f232010-11-08 19:41:13 +0100416
Lars Hjemlid3b29332009-02-12 09:58:28 +0100417virtual-root::
Lars Hjemlidf461232008-10-05 18:55:49 +0200418 Url which, if specified, will be used as root for all cgit links. It
419 will also cause cgit to generate 'virtual urls', i.e. urls like
420 '/cgit/tree/README' as opposed to '?r=cgit&p=tree&path=README'. Default
421 value: none.
422 NOTE: cgit has recently learned how to use PATH_INFO to achieve the
423 same kind of virtual urls, so this option will probably be deprecated.
424
Jason A. Donenfeld521e10c2012-10-09 06:56:14 -0400425
Lars Hjemlidf461232008-10-05 18:55:49 +0200426REPOSITORY SETTINGS
427-------------------
Lars Hjemli537c05f2009-08-09 13:27:21 +0200428repo.about-filter::
Lars Hjemli2273c2c2009-08-24 08:53:21 +0200429 Override the default about-filter. Default value: none. See also:
Ferry Hubertsb2cf6302011-03-23 11:57:44 +0100430 "enable-filter-overrides". See also: "FILTER API".
Lars Hjemli537c05f2009-08-09 13:27:21 +0200431
Jason A. Donenfeld389cc172013-04-08 16:57:12 +0200432repo.branch-sort::
433 Flag which, when set to "age", enables date ordering in the branch ref
434 list, and when set to "name" enables ordering by branch name. Default
435 value: "name".
436
Lars Hjemlid3b29332009-02-12 09:58:28 +0100437repo.clone-url::
Lars Hjemlidf461232008-10-05 18:55:49 +0200438 A list of space-separated urls which can be used to clone this repo.
Lars Hjemlia1429db2011-06-06 20:49:13 +0000439 Default value: none. See also: "MACRO EXPANSION".
Lars Hjemlidf461232008-10-05 18:55:49 +0200440
Lars Hjemlie976df22009-08-09 13:22:00 +0200441repo.commit-filter::
Lars Hjemli2273c2c2009-08-24 08:53:21 +0200442 Override the default commit-filter. Default value: none. See also:
Ferry Hubertsb2cf6302011-03-23 11:57:44 +0100443 "enable-filter-overrides". See also: "FILTER API".
Lars Hjemlie976df22009-08-09 13:22:00 +0200444
Jason A. Donenfeld389cc172013-04-08 16:57:12 +0200445repo.commit-sort::
446 Flag which, when set to "date", enables strict date ordering in the
447 commit log, and when set to "topo" enables strict topological
448 ordering. If unset, the default ordering of "git log" is used. Default
449 value: unset.
450
Lars Hjemlid3b29332009-02-12 09:58:28 +0100451repo.defbranch::
Lars Hjemlidf461232008-10-05 18:55:49 +0200452 The name of the default branch for this repository. If no such branch
453 exists in the repository, the first branch name (when sorted) is used
Julius Plenzd711de52011-04-07 12:59:24 +0200454 as default instead. Default value: branch pointed to by HEAD, or
455 "master" if there is no suitable HEAD.
Lars Hjemlidf461232008-10-05 18:55:49 +0200456
Lars Hjemlid3b29332009-02-12 09:58:28 +0100457repo.desc::
Lars Hjemlidf461232008-10-05 18:55:49 +0200458 The value to show as repository description. Default value: none.
459
Johan Herland9a8d39c2010-11-15 18:39:50 +0100460repo.enable-commit-graph::
461 A flag which can be used to disable the global setting
462 `enable-commit-graph'. Default value: none.
463
Lars Hjemlid3b29332009-02-12 09:58:28 +0100464repo.enable-log-filecount::
Lars Hjemlidf461232008-10-05 18:55:49 +0200465 A flag which can be used to disable the global setting
466 `enable-log-filecount'. Default value: none.
467
Lars Hjemlid3b29332009-02-12 09:58:28 +0100468repo.enable-log-linecount::
Lars Hjemlidf461232008-10-05 18:55:49 +0200469 A flag which can be used to disable the global setting
470 `enable-log-linecount'. Default value: none.
471
Lars Hjemli41934a32009-11-07 19:10:58 +0100472repo.enable-remote-branches::
473 Flag which, when set to "1", will make cgit display remote branches
474 in the summary and refs views. Default value: <enable-remote-branches>.
475
Lars Hjemli581a0c22010-02-27 13:12:55 +0100476repo.enable-subject-links::
477 A flag which can be used to override the global setting
478 `enable-subject-links'. Default value: none.
479
Bernhard Reutner-Fischer808c6852010-12-23 12:47:54 +0100480repo.logo::
481 Url which specifies the source of an image which will be used as a logo
482 on this repo's pages. Default value: global logo.
483
484repo.logo-link::
485 Url loaded when clicking on the cgit logo image. If unspecified the
486 calculated url of the repository index page will be used. Default
487 value: global logo-link.
488
Lars Hjemli46ca32e2011-06-15 09:58:42 +0200489repo.module-link::
490 Text which will be used as the formatstring for a hyperlink when a
491 submodule is printed in a directory listing. The arguments for the
492 formatstring are the path and SHA1 of the submodule commit. Default
493 value: <module-link>
494
Lars Hjemli6857bec2011-06-15 10:04:13 +0200495repo.module-link.<path>::
496 Text which will be used as the formatstring for a hyperlink when a
497 submodule with the specified subdirectory path is printed in a
498 directory listing. The only argument for the formatstring is the SHA1
499 of the submodule commit. Default value: none.
500
Lars Hjemlid3b29332009-02-12 09:58:28 +0100501repo.max-stats::
Lars Hjemlifb2f3f62008-12-07 13:17:21 +0100502 Override the default maximum statistics period. Valid values are equal
503 to the values specified for the global "max-stats" setting. Default
504 value: none.
Lars Hjemlif86a23f2008-12-06 17:38:19 +0100505
Lars Hjemlid3b29332009-02-12 09:58:28 +0100506repo.name::
Lars Hjemlidf461232008-10-05 18:55:49 +0200507 The value to show as repository name. Default value: <repo.url>.
508
Lars Hjemlid3b29332009-02-12 09:58:28 +0100509repo.owner::
Lars Hjemlidf461232008-10-05 18:55:49 +0200510 A value used to identify the owner of the repository. Default value:
511 none.
512
Lars Hjemlid3b29332009-02-12 09:58:28 +0100513repo.path::
Lars Hjemlidf461232008-10-05 18:55:49 +0200514 An absolute path to the repository directory. For non-bare repositories
515 this is the .git-directory. Default value: none.
516
Lars Hjemlid3b29332009-02-12 09:58:28 +0100517repo.readme::
Lars Hjemlidf461232008-10-05 18:55:49 +0200518 A path (relative to <repo.path>) which specifies a file to include
Jason A. Donenfeld379e80e2010-08-04 00:45:42 +0200519 verbatim as the "About" page for this repo. You may also specify a
520 git refspec by head or by hash by prepending the refspec followed by
Jason A. Donenfeld3cb5d862013-05-25 14:19:10 +0200521 a colon. For example, "master:docs/readme.mkd". If the value begins
522 with a colon, i.e. ":docs/readme.rst", the default branch of the
Jason A. Donenfeld2a1ead32013-05-25 20:30:57 +0200523 repository will be used. Sharing any file will expose that entire
524 directory tree to the "/about/PATH" endpoints, so be sure that there
525 are no non-public files located in the same directory as the readme
526 file. Default value: <readme>.
Lars Hjemlidf461232008-10-05 18:55:49 +0200527
Lars Hjemlid3b29332009-02-12 09:58:28 +0100528repo.snapshots::
Lars Hjemlidf461232008-10-05 18:55:49 +0200529 A mask of allowed snapshot-formats for this repo, restricted by the
530 "snapshots" global setting. Default value: <snapshots>.
531
Lars Hjemli39398542009-08-23 23:00:28 +0200532repo.section::
Lars Hjemli007df982009-08-24 07:51:48 +0200533 Override the current section name for this repository. Default value:
534 none.
Lars Hjemli39398542009-08-23 23:00:28 +0200535
Lars Hjemlie976df22009-08-09 13:22:00 +0200536repo.source-filter::
Lars Hjemli2273c2c2009-08-24 08:53:21 +0200537 Override the default source-filter. Default value: none. See also:
Ferry Hubertsb2cf6302011-03-23 11:57:44 +0100538 "enable-filter-overrides". See also: "FILTER API".
Lars Hjemlie976df22009-08-09 13:22:00 +0200539
Lars Hjemlid3b29332009-02-12 09:58:28 +0100540repo.url::
Lars Hjemlidf461232008-10-05 18:55:49 +0200541 The relative url used to access the repository. This must be the first
542 setting specified for each repo. Default value: none.
543
544
Lars Hjemli74061ed2009-08-24 00:04:58 +0200545REPOSITORY-SPECIFIC CGITRC FILE
546-------------------------------
Lars Hjemli007df982009-08-24 07:51:48 +0200547When the option "scan-path" is used to auto-discover git repositories, cgit
548will try to parse the file "cgitrc" within any found repository. Such a
549repo-specific config file may contain any of the repo-specific options
Lars Hjemli2273c2c2009-08-24 08:53:21 +0200550described above, except "repo.url" and "repo.path". Additionally, the "filter"
551options are only acknowledged in repo-specific config files when
552"enable-filter-overrides" is set to "1".
553
554Note: the "repo." prefix is dropped from the option names in repo-specific
555config files, e.g. "repo.desc" becomes "desc".
Lars Hjemli74061ed2009-08-24 00:04:58 +0200556
557
Ferry Hubertsb2cf6302011-03-23 11:57:44 +0100558FILTER API
559----------
Lars Hjemlib88cda62011-06-13 22:34:13 +0000560about filter::
Jason A. Donenfeldc0dfaf12013-05-25 14:50:19 +0200561 This filter is given a single parameter: the filename of the source
562 file to filter. The filter can use the filename to determine (for
563 example) the type of syntax to follow when formatting the readme file.
564 The about text that is to be filtered is available on standard input
565 and the filtered text is expected on standard output.
Lars Hjemlib88cda62011-06-13 22:34:13 +0000566
567commit filter::
568 This filter is given no arguments. The commit message text that is to
569 be filtered is available on standard input and the filtered text is
570 expected on standard output.
571
572source filter::
573 This filter is given a single parameter: the filename of the source
574 file to filter. The filter can use the filename to determine (for
575 example) the syntax highlighting mode. The contents of the source
576 file that is to be filtered is available on standard input and the
577 filtered contents is expected on standard output.
Ferry Hubertsb2cf6302011-03-23 11:57:44 +0100578
579Also, all filters are handed the following environment variables:
Lars Hjemlib88cda62011-06-13 22:34:13 +0000580
581- CGIT_REPO_URL (from repo.url)
582- CGIT_REPO_NAME (from repo.name)
583- CGIT_REPO_PATH (from repo.path)
584- CGIT_REPO_OWNER (from repo.owner)
585- CGIT_REPO_DEFBRANCH (from repo.defbranch)
586- CGIT_REPO_SECTION (from repo.section)
587- CGIT_REPO_CLONE_URL (from repo.clone-url)
Ferry Hubertsb2cf6302011-03-23 11:57:44 +0100588
589If a setting is not defined for a repository and the corresponding global
590setting is also not defined (if applicable), then the corresponding
Lukas Fleischerd96d2c92011-09-14 11:52:43 +0200591environment variable will be unset.
Ferry Hubertsb2cf6302011-03-23 11:57:44 +0100592
Ferry Hubertsb2cf6302011-03-23 11:57:44 +0100593
Lars Hjemlief13e5e2011-06-13 21:58:39 +0000594MACRO EXPANSION
595---------------
Přemysl Janouch88028ad2013-09-11 20:10:10 +0200596The following cgitrc options support a simple macro expansion feature,
597where tokens prefixed with "$" are replaced with the value of a similarly
Lars Hjemlief13e5e2011-06-13 21:58:39 +0000598named environment variable:
599
600- cache-root
601- include
602- project-list
603- scan-path
604
605Macro expansion will also happen on the content of $CGIT_CONFIG, if
606defined.
607
608One usage of this feature is virtual hosting, which in its simplest form
609can be accomplished by adding the following line to /etc/cgitrc:
610
611 include=/etc/cgitrc.d/$HTTP_HOST
612
Lars Hjemlia1429db2011-06-06 20:49:13 +0000613The following options are expanded during request processing, and support
614the environment variables defined in "FILTER API":
615
616- clone-url
617- repo.clone-url
618
Lars Hjemlief13e5e2011-06-13 21:58:39 +0000619
Lars Hjemlidf461232008-10-05 18:55:49 +0200620EXAMPLE CGITRC FILE
621-------------------
622
Lars Hjemlib875a9e2009-02-12 10:02:09 +0100623....
Přemysl Janouch88028ad2013-09-11 20:10:10 +0200624# Enable caching of up to 1000 output entries
Lars Hjemlidf461232008-10-05 18:55:49 +0200625cache-size=1000
626
627
Lars Hjemlia1429db2011-06-06 20:49:13 +0000628# Specify some default clone urls using macro expansion
629clone-url=git://foo.org/$CGIT_REPO_URL git@foo.org:$CGIT_REPO_URL
Lars Hjemlidf461232008-10-05 18:55:49 +0200630
631# Specify the css url
632css=/css/cgit.css
633
634
Jason A. Donenfeldd6d3dbc2013-05-27 21:47:02 +0200635# Show owner on index page
636enable-index-owner=1
637
638
639# Allow http transport git clone
Přemysl Janouch17e6a2a2013-09-11 20:10:13 +0200640enable-http-clone=1
Jason A. Donenfeldd6d3dbc2013-05-27 21:47:02 +0200641
642
Lars Hjemlidf461232008-10-05 18:55:49 +0200643# Show extra links for each repository on the index page
644enable-index-links=1
645
646
Johan Herland9a8d39c2010-11-15 18:39:50 +0100647# Enable ASCII art commit history graph on the log pages
648enable-commit-graph=1
649
650
Lars Hjemlidf461232008-10-05 18:55:49 +0200651# Show number of affected files per commit on the log pages
652enable-log-filecount=1
653
654
655# Show number of added/removed lines per commit on the log pages
656enable-log-linecount=1
657
658
Jason A. Donenfeldd6d3dbc2013-05-27 21:47:02 +0200659# Sort branches by date
660branch-sort=age
661
662
Lars Hjemlidf461232008-10-05 18:55:49 +0200663# Add a cgit favicon
664favicon=/favicon.ico
665
666
667# Use a custom logo
668logo=/img/mylogo.png
669
670
Lars Hjemlifb2f3f62008-12-07 13:17:21 +0100671# Enable statistics per week, month and quarter
672max-stats=quarter
673
674
Lars Hjemlidf461232008-10-05 18:55:49 +0200675# Set the title and heading of the repository index page
Todd Zullinger66df1132010-09-06 09:31:26 -0400676root-title=example.com git repositories
Lars Hjemlidf461232008-10-05 18:55:49 +0200677
678
679# Set a subheading for the repository index page
680root-desc=tracking the foobar development
681
682
Todd Zullinger66df1132010-09-06 09:31:26 -0400683# Include some more info about example.com on the index page
Lars Hjemlidf461232008-10-05 18:55:49 +0200684root-readme=/var/www/htdocs/about.html
685
686
Todd Zullinger3796c2d2009-01-11 18:23:39 -0500687# Allow download of tar.gz, tar.bz2 and zip-files
688snapshots=tar.gz tar.bz2 zip
Lars Hjemlidf461232008-10-05 18:55:49 +0200689
690
691##
Lars Hjemlic4d46c72009-02-13 20:43:30 +0100692## List of common mimetypes
693##
694
Johan Herland9ce5d052010-06-10 01:09:22 +0200695mimetype.gif=image/gif
Lars Hjemlic4d46c72009-02-13 20:43:30 +0100696mimetype.html=text/html
697mimetype.jpg=image/jpeg
698mimetype.jpeg=image/jpeg
699mimetype.pdf=application/pdf
700mimetype.png=image/png
701mimetype.svg=image/svg+xml
702
703
Přemysl Janouch88028ad2013-09-11 20:10:10 +0200704# Highlight source code with python pygments-based highlighter
Jason A. Donenfeldd6d3dbc2013-05-27 21:47:02 +0200705source-filter=/var/www/cgit/filters/syntax-highlighting.py
706
707# Format markdown, restructuredtext, manpages, text files, and html files
708# through the right converters
709about-filter=/var/www/cgit/filters/about-formatting.sh
710
711##
712## Search for these files in the root of the default branch of repositories
713## for coming up with the about page:
714##
715readme=:README.md
716readme=:readme.md
717readme=:README.mkd
718readme=:readme.mkd
719readme=:README.rst
720readme=:readme.rst
721readme=:README.html
722readme=:readme.html
723readme=:README.htm
724readme=:readme.htm
725readme=:README.txt
726readme=:readme.txt
727readme=:README
728readme=:readme
729readme=:INSTALL.md
730readme=:install.md
731readme=:INSTALL.mkd
732readme=:install.mkd
733readme=:INSTALL.rst
734readme=:install.rst
735readme=:INSTALL.html
736readme=:install.html
737readme=:INSTALL.htm
738readme=:install.htm
739readme=:INSTALL.txt
740readme=:install.txt
741readme=:INSTALL
742readme=:install
743
744
Lars Hjemlic4d46c72009-02-13 20:43:30 +0100745##
Lars Hjemlidf461232008-10-05 18:55:49 +0200746## List of repositories.
Loui Chang8071e182009-09-14 01:21:11 -0400747## PS: Any repositories listed when section is unset will not be
748## displayed under a section heading
Lars Hjemlidf461232008-10-05 18:55:49 +0200749## PPS: This list could be kept in a different file (e.g. '/etc/cgitrepos')
750## and included like this:
751## include=/etc/cgitrepos
752##
753
754
755repo.url=foo
756repo.path=/pub/git/foo.git
757repo.desc=the master foo repository
Todd Zullinger66df1132010-09-06 09:31:26 -0400758repo.owner=fooman@example.com
Lars Hjemlidf461232008-10-05 18:55:49 +0200759repo.readme=info/web/about.html
760
761
762repo.url=bar
763repo.path=/pub/git/bar.git
764repo.desc=the bars for your foo
Todd Zullinger66df1132010-09-06 09:31:26 -0400765repo.owner=barman@example.com
Lars Hjemlidf461232008-10-05 18:55:49 +0200766repo.readme=info/web/about.html
767
768
769# The next repositories will be displayed under the 'extras' heading
Loui Chang8071e182009-09-14 01:21:11 -0400770section=extras
Lars Hjemlidf461232008-10-05 18:55:49 +0200771
772
773repo.url=baz
774repo.path=/pub/git/baz.git
775repo.desc=a set of extensions for bar users
776
777repo.url=wiz
778repo.path=/pub/git/wiz.git
779repo.desc=the wizard of foo
780
781
782# Add some mirrored repositories
Loui Chang8071e182009-09-14 01:21:11 -0400783section=mirrors
Lars Hjemlidf461232008-10-05 18:55:49 +0200784
785
786repo.url=git
787repo.path=/pub/git/git.git
788repo.desc=the dscm
789
790
791repo.url=linux
792repo.path=/pub/git/linux.git
793repo.desc=the kernel
794
795# Disable adhoc downloads of this repo
796repo.snapshots=0
797
798# Disable line-counts for this repo
799repo.enable-log-linecount=0
800
Lars Hjemlifb2f3f62008-12-07 13:17:21 +0100801# Restrict the max statistics period for this repo
802repo.max-stats=month
Lars Hjemlib875a9e2009-02-12 10:02:09 +0100803....
Lars Hjemlifb2f3f62008-12-07 13:17:21 +0100804
Lars Hjemlidf461232008-10-05 18:55:49 +0200805
806BUGS
807----
808Comments currently cannot appear on the same line as a setting; the comment
809will be included as part of the value. E.g. this line:
810
811 robots=index # allow indexing
812
813will generate the following html element:
814
815 <meta name='robots' content='index # allow indexing'/>
816
817
818
819AUTHOR
820------
821Lars Hjemli <hjemli@gmail.com>
Jason A. Donenfeld2e4a9412010-07-29 19:47:50 +0200822Jason A. Donenfeld <Jason@zx2c4.com>