2013-12-20 12:55:51 -08:00
|
|
|
= Gerrit Code Review - /access/ REST API
|
2013-06-24 16:46:34 +02:00
|
|
|
|
|
|
|
This page describes the access rights related REST endpoints.
|
|
|
|
Please also take note of the general information on the
|
|
|
|
link:rest-api.html[REST API].
|
|
|
|
|
|
|
|
[[access-endpoints]]
|
2013-12-20 12:55:51 -08:00
|
|
|
== Access Rights Endpoints
|
2013-06-24 16:46:34 +02:00
|
|
|
|
|
|
|
[[list-access]]
|
2013-12-20 12:55:51 -08:00
|
|
|
=== List Access Rights
|
2013-11-15 11:47:46 -08:00
|
|
|
--
|
2013-06-24 16:46:34 +02:00
|
|
|
'GET /access/?project=link:rest-api-projects.html#project-name[\{project-name\}]'
|
2013-11-15 11:47:46 -08:00
|
|
|
--
|
2013-06-24 16:46:34 +02:00
|
|
|
|
|
|
|
Lists the access rights for projects. The projects for which the access
|
|
|
|
rights should be returned must be specified as `project` options. The
|
|
|
|
`project` can be specified multiple times.
|
|
|
|
|
|
|
|
As result a map is returned that maps the project name to
|
|
|
|
link:#project-access-info[ProjectAccessInfo] entities.
|
|
|
|
|
|
|
|
The entries in the map are sorted by project name.
|
|
|
|
|
|
|
|
.Request
|
|
|
|
----
|
|
|
|
GET /access/?project=MyProject&project=All-Projects HTTP/1.0
|
|
|
|
----
|
|
|
|
|
|
|
|
.Response
|
|
|
|
----
|
|
|
|
HTTP/1.1 200 OK
|
2015-01-06 15:44:00 +09:00
|
|
|
Content-Type: application/json; charset=UTF-8
|
2013-06-24 16:46:34 +02:00
|
|
|
|
|
|
|
)]}'
|
|
|
|
{
|
|
|
|
"All-Projects": {
|
|
|
|
"revision": "edd453d18e08640e67a8c9a150cec998ed0ac9aa",
|
|
|
|
"local": {
|
|
|
|
"GLOBAL_CAPABILITIES": {
|
|
|
|
"permissions": {
|
|
|
|
"priority": {
|
|
|
|
"rules": {
|
|
|
|
"15bfcd8a6de1a69c50b30cedcdcc951c15703152": {
|
|
|
|
"action": "BATCH"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"streamEvents": {
|
|
|
|
"rules": {
|
|
|
|
"15bfcd8a6de1a69c50b30cedcdcc951c15703152": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"administrateServer": {
|
|
|
|
"rules": {
|
|
|
|
"53a4f647a89ea57992571187d8025f830625192a": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"refs/meta/config": {
|
|
|
|
"permissions": {
|
|
|
|
"submit": {
|
|
|
|
"rules": {
|
|
|
|
"53a4f647a89ea57992571187d8025f830625192a": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
},
|
|
|
|
"global:Project-Owners": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"label-Code-Review": {
|
|
|
|
"label": "Code-Review",
|
|
|
|
"rules": {
|
|
|
|
"53a4f647a89ea57992571187d8025f830625192a": {
|
|
|
|
"action": "ALLOW",
|
|
|
|
"min": -2,
|
|
|
|
"max": 2
|
|
|
|
},
|
|
|
|
"global:Project-Owners": {
|
|
|
|
"action": "ALLOW",
|
|
|
|
"min": -2,
|
|
|
|
"max": 2
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"read": {
|
|
|
|
"exclusive": true,
|
|
|
|
"rules": {
|
|
|
|
"53a4f647a89ea57992571187d8025f830625192a": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
},
|
|
|
|
"global:Project-Owners": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"push": {
|
|
|
|
"rules": {
|
|
|
|
"53a4f647a89ea57992571187d8025f830625192a": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
},
|
|
|
|
"global:Project-Owners": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"refs/for/refs/*": {
|
|
|
|
"permissions": {
|
|
|
|
"pushMerge": {
|
|
|
|
"rules": {
|
|
|
|
"global:Registered-Users": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"push": {
|
|
|
|
"rules": {
|
|
|
|
"global:Registered-Users": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"refs/tags/*": {
|
|
|
|
"permissions": {
|
2016-09-05 14:32:38 +02:00
|
|
|
"createSignedTag": {
|
2013-06-24 16:46:34 +02:00
|
|
|
"rules": {
|
|
|
|
"53a4f647a89ea57992571187d8025f830625192a": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
},
|
|
|
|
"global:Project-Owners": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
2016-09-05 14:32:38 +02:00
|
|
|
"createTag": {
|
2013-06-24 16:46:34 +02:00
|
|
|
"rules": {
|
|
|
|
"53a4f647a89ea57992571187d8025f830625192a": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
},
|
|
|
|
"global:Project-Owners": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"refs/heads/*": {
|
|
|
|
"permissions": {
|
|
|
|
"forgeCommitter": {
|
|
|
|
"rules": {
|
|
|
|
"53a4f647a89ea57992571187d8025f830625192a": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
},
|
|
|
|
"global:Project-Owners": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"forgeAuthor": {
|
|
|
|
"rules": {
|
|
|
|
"global:Registered-Users": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"submit": {
|
|
|
|
"rules": {
|
|
|
|
"53a4f647a89ea57992571187d8025f830625192a": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
},
|
|
|
|
"global:Project-Owners": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"editTopicName": {
|
|
|
|
"rules": {
|
|
|
|
"53a4f647a89ea57992571187d8025f830625192a": {
|
|
|
|
"action": "ALLOW",
|
|
|
|
"force": true
|
|
|
|
},
|
|
|
|
"global:Project-Owners": {
|
|
|
|
"action": "ALLOW",
|
|
|
|
"force": true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"label-Code-Review": {
|
|
|
|
"label": "Code-Review",
|
|
|
|
"rules": {
|
|
|
|
"global:Registered-Users": {
|
|
|
|
"action": "ALLOW",
|
|
|
|
"min": -1,
|
|
|
|
"max": 1
|
|
|
|
},
|
|
|
|
"53a4f647a89ea57992571187d8025f830625192a": {
|
|
|
|
"action": "ALLOW",
|
|
|
|
"min": -2,
|
|
|
|
"max": 2
|
|
|
|
},
|
|
|
|
"global:Project-Owners": {
|
|
|
|
"action": "ALLOW",
|
|
|
|
"min": -2,
|
|
|
|
"max": 2
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"create": {
|
|
|
|
"rules": {
|
|
|
|
"53a4f647a89ea57992571187d8025f830625192a": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
},
|
|
|
|
"global:Project-Owners": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"push": {
|
|
|
|
"rules": {
|
|
|
|
"53a4f647a89ea57992571187d8025f830625192a": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
},
|
|
|
|
"global:Project-Owners": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"refs/*": {
|
|
|
|
"permissions": {
|
|
|
|
"read": {
|
|
|
|
"rules": {
|
|
|
|
"global:Anonymous-Users": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
},
|
|
|
|
"53a4f647a89ea57992571187d8025f830625192a": {
|
|
|
|
"action": "ALLOW"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
2013-07-12 13:21:15 +02:00
|
|
|
"is_owner": true,
|
2013-06-24 16:46:34 +02:00
|
|
|
"owner_of": [
|
|
|
|
"GLOBAL_CAPABILITIES",
|
|
|
|
"refs/meta/config",
|
|
|
|
"refs/for/refs/*",
|
|
|
|
"refs/tags/*",
|
|
|
|
"refs/heads/*",
|
|
|
|
"refs/*"
|
|
|
|
],
|
|
|
|
"can_upload": true,
|
|
|
|
"can_add": true,
|
2018-09-10 16:52:54 -04:00
|
|
|
"can_add_tags": true,
|
2017-08-08 15:38:18 -03:00
|
|
|
"config_visible": true,
|
|
|
|
"groups": {
|
|
|
|
"53a4f647a89ea57992571187d8025f830625192a": {
|
|
|
|
"url": "#/admin/groups/uuid-53a4f647a89ea57992571187d8025f830625192a",
|
|
|
|
"options": {},
|
|
|
|
"description": "Gerrit Site Administrators",
|
|
|
|
"group_id": 1,
|
|
|
|
"owner": "Administrators",
|
|
|
|
"owner_id": "53a4f647a89ea57992571187d8025f830625192a",
|
|
|
|
"created_on": "2009-06-08 23:31:00.000000000",
|
|
|
|
"name": "Administrators"
|
|
|
|
},
|
|
|
|
"global:Registered-Users": {
|
|
|
|
"options": {},
|
|
|
|
"name": "Registered Users"
|
|
|
|
},
|
|
|
|
"global:Project-Owners": {
|
|
|
|
"options": {},
|
|
|
|
"name": "Project Owners"
|
|
|
|
},
|
|
|
|
"15bfcd8a6de1a69c50b30cedcdcc951c15703152": {
|
|
|
|
"url": "#/admin/groups/uuid-15bfcd8a6de1a69c50b30cedcdcc951c15703152",
|
|
|
|
"options": {},
|
|
|
|
"description": "Users who perform batch actions on Gerrit",
|
|
|
|
"group_id": 2,
|
|
|
|
"owner": "Administrators",
|
|
|
|
"owner_id": "53a4f647a89ea57992571187d8025f830625192a",
|
|
|
|
"created_on": "2009-06-08 23:31:00.000000000",
|
|
|
|
"name": "Non-Interactive Users"
|
|
|
|
},
|
|
|
|
"global:Anonymous-Users": {
|
|
|
|
"options": {},
|
|
|
|
"name": "Anonymous Users"
|
|
|
|
}
|
|
|
|
}
|
2013-06-24 16:46:34 +02:00
|
|
|
},
|
|
|
|
"MyProject": {
|
|
|
|
"revision": "61157ed63e14d261b6dca40650472a9b0bd88474",
|
|
|
|
"inherits_from": {
|
|
|
|
"id": "All-Projects",
|
|
|
|
"name": "All-Projects",
|
|
|
|
"description": "Access inherited by all other projects."
|
|
|
|
},
|
|
|
|
"local": {},
|
2013-07-12 13:21:15 +02:00
|
|
|
"is_owner": true,
|
2013-06-24 16:46:34 +02:00
|
|
|
"owner_of": [
|
|
|
|
"refs/*"
|
|
|
|
],
|
|
|
|
"can_upload": true,
|
|
|
|
"can_add": true,
|
2018-09-10 16:52:54 -04:00
|
|
|
"can_add_tags": true,
|
2013-06-24 16:46:34 +02:00
|
|
|
"config_visible": true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
----
|
|
|
|
|
2014-11-25 17:13:11 +09:00
|
|
|
[[json-entities]]
|
|
|
|
== JSON Entities
|
|
|
|
|
2013-06-24 16:46:34 +02:00
|
|
|
[[access-section-info]]
|
2013-12-20 12:55:51 -08:00
|
|
|
=== AccessSectionInfo
|
2013-06-24 16:46:34 +02:00
|
|
|
The `AccessSectionInfo` describes the access rights that are assigned
|
|
|
|
on a ref.
|
|
|
|
|
2014-11-25 17:24:47 +09:00
|
|
|
[options="header",cols="1,^1,5"]
|
2013-06-24 16:46:34 +02:00
|
|
|
|==================================
|
|
|
|
|Field Name ||Description
|
|
|
|
|`permissions` ||
|
|
|
|
The permissions assigned on the ref of this access section as a map
|
|
|
|
that maps the permission names to link:#permission-info[PermissionInfo]
|
|
|
|
entities.
|
|
|
|
|==================================
|
|
|
|
|
|
|
|
[[permission-info]]
|
2013-12-20 12:55:51 -08:00
|
|
|
=== PermissionInfo
|
2013-06-24 16:46:34 +02:00
|
|
|
The `PermissionInfo` entity contains information about an assigned
|
|
|
|
permission.
|
|
|
|
|
2014-11-25 17:24:47 +09:00
|
|
|
[options="header",cols="1,^1,5"]
|
2013-06-24 16:46:34 +02:00
|
|
|
|==================================
|
|
|
|
|Field Name ||Description
|
|
|
|
|`label` |optional|
|
|
|
|
The name of the label. Not set if it's not a label permission.
|
|
|
|
|`exclusive` |not set if `false`|
|
|
|
|
Whether this permission is assigned exclusively.
|
|
|
|
|`rules` ||
|
|
|
|
The rules assigned for this permission as a map that maps the UUIDs of
|
|
|
|
the groups for which the permission are assigned to
|
|
|
|
link:#permission-info[PermissionRuleInfo] entities.
|
|
|
|
|==================================
|
|
|
|
|
|
|
|
[[permission-rule-info]]
|
2013-12-20 12:55:51 -08:00
|
|
|
=== PermissionRuleInfo
|
2013-06-24 16:46:34 +02:00
|
|
|
The `PermissionRuleInfo` entity contains information about a permission
|
|
|
|
rule that is assigned to group.
|
|
|
|
|
2014-11-25 17:24:47 +09:00
|
|
|
[options="header",cols="1,^1,5"]
|
2013-06-24 16:46:34 +02:00
|
|
|
|==================================
|
|
|
|
|Field Name ||Description
|
|
|
|
|`action` ||
|
|
|
|
The action of this rule. For normal permissions this can be `ALLOW`,
|
|
|
|
`DENY` or `BLOCK`. Special values for global capabilities are
|
|
|
|
`INTERACTIVE` and `BATCH`.
|
|
|
|
|`force` |not set if `false`|
|
|
|
|
Whether the force flag is set.
|
|
|
|
|`min` |
|
2016-10-02 23:50:17 +00:00
|
|
|
not set if range is empty (from `0` to `0`) or not set|
|
2013-06-24 16:46:34 +02:00
|
|
|
The min value of the permission range.
|
|
|
|
|`max` |
|
2016-10-02 23:50:17 +00:00
|
|
|
not set if range is empty (from `0` to `0`) or not set|
|
2013-06-24 16:46:34 +02:00
|
|
|
The max value of the permission range.
|
|
|
|
|==================================
|
|
|
|
|
|
|
|
[[project-access-info]]
|
2013-12-20 12:55:51 -08:00
|
|
|
=== ProjectAccessInfo
|
2013-06-24 16:46:34 +02:00
|
|
|
The `ProjectAccessInfo` entity contains information about the access
|
|
|
|
rights for a project.
|
|
|
|
|
2014-11-25 17:24:47 +09:00
|
|
|
[options="header",cols="1,^1,5"]
|
2013-06-24 16:46:34 +02:00
|
|
|
|==================================
|
|
|
|
|Field Name ||Description
|
|
|
|
|`revision` ||
|
|
|
|
The revision of the `refs/meta/config` branch from which the access
|
|
|
|
rights were loaded.
|
|
|
|
|`inherits_from` |not set for the `All-Project` project|
|
|
|
|
The parent project from which permissions are inherited as a
|
|
|
|
link:rest-api-projects.html#project-info[ProjectInfo] entity.
|
|
|
|
|`local` ||
|
|
|
|
The local access rights of the project as a map that maps the refs to
|
|
|
|
link:#access-section-info[AccessSectionInfo] entities.
|
2013-07-12 13:21:15 +02:00
|
|
|
|`is_owner` |not set if `false`|
|
|
|
|
Whether the calling user owns this project.
|
2013-06-24 16:46:34 +02:00
|
|
|
|`owner_of` ||The list of refs owned by the calling user.
|
|
|
|
|`can_upload` |not set if `false`|
|
|
|
|
Whether the calling user can upload to any ref.
|
|
|
|
|`can_add` |not set if `false`|
|
|
|
|
Whether the calling user can add any ref.
|
2018-09-10 16:52:54 -04:00
|
|
|
|`can_add_tags` |not set if `false`|
|
|
|
|
Whether the calling user can add any tag ref.
|
2013-06-24 16:46:34 +02:00
|
|
|
|`config_visible` |not set if `false`|
|
|
|
|
Whether the calling user can see the `refs/meta/config` branch of the
|
|
|
|
project.
|
2018-02-07 13:01:05 +01:00
|
|
|
|`groups` ||A map of group UUID to
|
|
|
|
link:rest-api-groups.html#group-info[GroupInfo] objects, with names and
|
|
|
|
URLs for the group UUIDs used in the `local` map.
|
|
|
|
This will include names for groups that might
|
|
|
|
be invisible to the caller.
|
2018-01-30 17:21:21 +01:00
|
|
|
|`configWebLinks` ||
|
|
|
|
A list of URLs that display the history of the configuration file
|
|
|
|
governing this project's access rights.
|
2013-06-24 16:46:34 +02:00
|
|
|
|==================================
|
|
|
|
|
|
|
|
|
|
|
|
GERRIT
|
|
|
|
------
|
|
|
|
Part of link:index.html[Gerrit Code Review]
|
2013-10-31 17:26:00 -07:00
|
|
|
|
|
|
|
SEARCHBOX
|
|
|
|
---------
|