blob: 276117bc378a40c2b001e1cac01b2c0f9cf77b9e [file] [log] [blame]
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -08001= Gerrit Code Review - Project Configuration File Format
Fredrik Luthandera3cf3542012-07-04 16:55:35 -07002
3This page explains the storage format of Gerrit's project configuration
4and access control models.
5
6The web UI access control panel is a front end for human-readable
7configuration files under the +refs/meta/config+ namespace in the
8affected project. Direct manipulation of these files is mainly
9relevant in an automation scenario of the access controls.
10
11
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -080012== The +refs/meta/config+ namespace
Fredrik Luthandera3cf3542012-07-04 16:55:35 -070013
14The namespace contains three different files that play different
15roles in the permission model. With read permission to that reference,
16it is possible to fetch the +refs/meta/config+ reference to a local
17repository. A nice side effect is that you can also upload changes
18to project permissions and review them just like with regular code
19changes. The preview changes option is also provided on the UI. Please note
20that you will have to configure push rights for the +refs/meta/config+ name
21space if you'd like to use the possibility to automate permission updates.
22
23
24[[file-project_config]]
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -080025== The file +project.config+
Fredrik Luthandera3cf3542012-07-04 16:55:35 -070026
27The +project.config+ file contains the link between groups and their
28permitted actions on reference patterns in this project and any projects
29that inherit its permissions.
30
31The format in this file corresponds to the Git config file format, so
32if you want to automate your permissions it is a good idea to use the
33+git config+ command when writing to the file. This way you know you
34don't accidentally break the format of the file.
35
36Here follows a +git config+ command example:
37
38----
39$ git config -f project.config project.description "Rights inherited by all other projects"
40----
41
42Below you will find an example of the +project.config+ file format:
43
44----
45[project]
46 description = Rights inherited by all other projects
47[access "refs/*"]
48 read = group Administrators
David Myllykangasb3ccec62015-01-21 15:41:13 +010049[access "refs/heads/*"]
50 label-Your-Label-Here = -1..+1 group Administrators
Fredrik Luthandera3cf3542012-07-04 16:55:35 -070051[capability]
52 administrateServer = group Administrators
53[receive]
54 requireContributorAgreement = false
David Myllykangasb3ccec62015-01-21 15:41:13 +010055[label "Your-Label-Here"]
56 function = MaxWithBlock
57 value = -1 Your -1 Description
58 value = 0 Your No score Description
59 value = +1 Your +1 Description
Fredrik Luthandera3cf3542012-07-04 16:55:35 -070060----
61
62As you can see, there are several sections.
63
64The link:#project-section[+project+ section] appears once per project.
65
66The link:#access-section[+access+ section] appears once per reference pattern,
Jonathan Nieder5758f182015-03-30 11:28:55 -070067such as `+refs/*+` or `+refs/heads/*+`. Only one access section per pattern is
Fredrik Luthandera3cf3542012-07-04 16:55:35 -070068allowed. You will find examples of keys and values in each category section
69<<access_category,below>>.
70
71The link:#receive-section[+receive+ section] appears once per project.
72
73The link:#submit-section[+submit+ section] appears once per project.
74
75The link:#capability-section[+capability+] section only appears once, and only
76in the +All-Projects+ repository. It controls core features that are configured
77on a global level. You can find examples of these
78<<capability_category,below>>.
79
David Myllykangasb3ccec62015-01-21 15:41:13 +010080The link:#label-section[+label+] section can appear multiple times. You can
81also redefine the text and behavior of the built in label types `Code-Review`
82and `Verified`.
Fredrik Luthandera3cf3542012-07-04 16:55:35 -070083
84[[project-section]]
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -080085=== Project section
Fredrik Luthandera3cf3542012-07-04 16:55:35 -070086
87The project section includes configuration of project settings.
88
89These are the keys:
90
91- Description
92
93
94[[receive-section]]
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -080095=== Receive section
Fredrik Luthandera3cf3542012-07-04 16:55:35 -070096
97The receive section includes configuration of project-specific
98receive settings:
99
100[[receive.requireContributorAgreement]]receive.requireContributorAgreement::
101+
102Controls whether or not a user must complete a contributor agreement before
103they can upload changes. Default is `INHERIT`. If `All-Project` enables this
104option then the dependent project must set it to false if users are not
105required to sign a contributor agreement prior to submitting changes for that
106specific project. To use that feature the global option in `gerrit.config`
107must be enabled:
108link:config-gerrit.html#auth.contributorAgreements[auth.contributorAgreements].
109
110[[receive.requireSignedOffBy]]receive.requireSignedOffBy::
111+
112Sign-off can be a requirement for some projects (for example Linux kernel uses
113it). Sign-off is a line at the end of the commit message which certifies who
114is the author of the commit. Its main purpose is to improve tracking of who
115did what, especially with patches. Default is `INHERIT`, which means that this
116property is inherited from the parent project.
117
118[[receive.requireChangeId]]receive.requireChangeId::
119+
120Controls whether or not the Change-Id must be included in the commit message
121in the last paragraph. Default is `INHERIT`, which means that this property
122is inherited from the parent project.
123
124[[receive.maxObjectSizeLimit]]receive.maxObjectSizeLimit::
125+
126Maximum allowed Git object size that receive-pack will accept. If an object
127is larger than the given size the pack-parsing will abort and the push
128operation will fail. If set to zero then there is no limit.
129+
130Project owners can use this setting to prevent developers from pushing
131objects which are too large to Gerrit. This setting can also be set it
132`gerrit.config` globally link:config-gerrit.html#receive.maxObjectSizeLimit[
133receive.maxObjectSizeLimit].
134+
135The project specific setting in `project.config` is only honored when it
136further reduces the global limit.
137+
138Default is zero.
139+
140Common unit suffixes of k, m, or g are supported.
141
Rob Ward2cf12952014-01-26 20:38:12 +0000142[[receive.checkReceivedObjects]]receive.checkReceivedObjects::
143+
144Controls whether or not the JGit functionality for checking received objects
145is enabled.
146+
147By default Gerrit checks the validity of git objects. Setting this variable to
148false should not be used unless a project with history containing invalid
149objects needs to be pushed into a Gerrit repository.
150+
151This functionality is provided as some other git implementations have allowed
152bad history to be written into git repositories. If these repositories need pushing
153up to Gerrit then the JGit checks need to be disabled.
154+
155The default value for this is true, false disables the checks.
156
Fredrik Luthandera3cf3542012-07-04 16:55:35 -0700157[[submit-section]]
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -0800158=== Submit section
Fredrik Luthandera3cf3542012-07-04 16:55:35 -0700159
160The submit section includes configuration of project-specific
161submit settings:
162
163- 'mergeContent': Defines whether to automatically merge changes. Valid values
164are 'true', 'false', or 'INHERIT'. Default is 'INHERIT'.
165
Stefan Lay08ba4732014-05-05 16:36:12 +0200166- 'action': defines the link:project-configuration.html#submit_type[submit type]. Valid
Fredrik Luthandera3cf3542012-07-04 16:55:35 -0700167values are 'fast forward only', 'merge if necessary', 'rebase if necessary',
168'merge always' and 'cherry pick'. The default is 'merge if necessary'.
169
170Merge strategy
171
172
173[[access-section]]
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -0800174=== Access section
Fredrik Luthandera3cf3542012-07-04 16:55:35 -0700175
176Each +access+ section includes a reference and access rights connected
177to groups. Each group listed must exist in the link:#file-groups[+groups+ file].
178
179Please refer to the
180link:access-control.html#access_categories[Access Categories]
181documentation for a full list of available access rights.
182
183
Shawn Pearce9cfcebd2014-04-25 16:41:12 -0700184[[mimetype-section]]
185=== MIME Types section
186
187The +mimetype+ section may be configured to force the web code
188reviewer to return certain MIME types by file path. MIME types
189may be used to activate syntax highlighting.
190
191----
192[mimetype "text/x-c"]
193 path = *.pkt
194[mimetype "text/x-java"]
195 path = api/current.txt
196----
197
198
Fredrik Luthandera3cf3542012-07-04 16:55:35 -0700199[[capability-section]]
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -0800200=== Capability section
Fredrik Luthandera3cf3542012-07-04 16:55:35 -0700201
202The +capability+ section only appears once, and only in the +All-Projects+
203repository. It controls Gerrit administration capabilities that are configured
204on a global level.
205
206Please refer to the
207link:access-control.html#global_capabilities[Global Capabilities]
208documentation for a full list of available capabilities.
209
David Myllykangasb3ccec62015-01-21 15:41:13 +0100210[[label-section]]
211=== Label section
212
213Please refer to link:config-labels.html#label_custom[Custom Labels] documentation.
Fredrik Luthandera3cf3542012-07-04 16:55:35 -0700214
Saša Živkov944b8382014-05-08 14:02:15 +0200215[[branchOrder-section]]
216=== branchOrder section
217
218Defines a branch ordering which is used for backporting of changes.
219Backporting will be offered for a change (in the Gerrit UI) for all
220more stable branches where the change can merge cleanly.
221
222[[branchOrder.branch]]branchOrder.branch::
223+
224A branch name, typically multiple values will be defined. The order of branch
225names in this section defines the branch order. The topmost is considered to be
226the least stable branch (typically the master branch) and the last one the
227most stable (typically the last maintained release branch).
228
229Example:
230
231----
232[branchOrder]
233 branch = master
234 branch = stable-2.9
235 branch = stable-2.8
236 branch = stable-2.7
237----
238
239The `branchOrder` section is inheritable. This is useful when multiple or all
240projects follow the same branch rules. A `branchOrder` section in a child
241project completely overrides any `branchOrder` section from a parent i.e. there
242is no merging of `branchOrder` sections. A present but empty `branchOrder`
243section removes all inherited branch order.
244
245Branches not listed in this section will not be included in the mergeability
246check. If the `branchOrder` section is not defined then the mergeability of a
247change into other branches will not be done.
248
249
Fredrik Luthandera3cf3542012-07-04 16:55:35 -0700250[[file-groups]]
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -0800251== The file +groups+
Fredrik Luthandera3cf3542012-07-04 16:55:35 -0700252
253Each group in this list is linked with its UUID so that renaming of
254groups is possible without having to rewrite every +groups+ file
255in every repository where it's used.
256
257This is what the default groups file for +All-Projects.git+ looks like:
258
259----
260# UUID Group Name
261#
2623d6da7dc4e99e6f6e5b5196e21b6f504fc530bba Administrators
263global:Anonymous-Users Anonymous Users
Khai Do5aaeee32014-09-05 10:14:32 -0700264global:Change-Owner Change Owner
Fredrik Luthandera3cf3542012-07-04 16:55:35 -0700265global:Project-Owners Project Owners
266global:Registered-Users Registered Users
267----
268
269This file can't be written to by the +git config+ command.
270
271In order to reference a group in +project.config+, it must be listed in
272the +groups+ file. When editing permissions through the web UI this
273file is maintained automatically, but when pushing updates to
274+refs/meta/config+ this must be dealt with by hand. Gerrit will refuse
275+project.config+ files that refer to groups not listed in +groups+.
276
277The UUID of a group can be found on the General tab of the group's page
278in the web UI or via the +-v+ option to
279link:cmd-ls-groups.html[the +ls-groups+ SSH command].
280
281
282[[file-rules_pl]]
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -0800283== The file +rules.pl+
Fredrik Luthandera3cf3542012-07-04 16:55:35 -0700284
285The +rules.pl+ files allows you to replace or amend the default Prolog
286rules that control e.g. what conditions need to be fulfilled for a
287change to be submittable. This file content should be
288interpretable by the 'Prolog Cafe' interpreter.
289
290You can read more about the +rules.pl+ file and the prolog rules on
291link:prolog-cookbook.html[the Prolog cookbook page].
292
293GERRIT
294------
295Part of link:index.html[Gerrit Code Review]
Yuxuan 'fishy' Wang99cb68d2013-10-31 17:26:00 -0700296
297SEARCHBOX
298---------