Member roles API

Version history
On self-managed GitLab, by default this feature is not available. To make it available, an administrator can enable the feature flag named admin_merge_request. On GitLab.com, this feature is not available.

List all member roles of a group

Gets a list of group member roles viewable by the authenticated user.

GET /groups/:id/member_roles
AttributeTypeRequiredDescription
idinteger/stringyesThe ID or URL-encoded path of the group owned by the authenticated user

If successful, returns 200 and the following response attributes:

AttributeTypeDescription
[].idintegerThe ID of the member role.
[].namestringThe name of the member role.
[].descriptionstringThe description of the member role.
[].group_idintegerThe ID of the group that the member role belongs to.
[].base_access_levelintegerBase access level for member role. Valid values are 10 (Guest), 20 (Reporter), 30 (Developer), 40 (Maintainer), or 50 (Owner).
[].admin_merge_requestbooleanPermission to admin project merge requests and enables the ability to download_code.
[].admin_vulnerabilitybooleanPermission to admin project vulnerabilities.
[].read_codebooleanPermission to read project code.
[].read_dependencybooleanPermission to read project dependencies.
[].read_vulnerabilitybooleanPermission to read project vulnerabilities.

Example request:

curl --header "Authorization: Bearer <your_access_token>" "https://gitlab.example.com/api/v4/groups/84/member_roles"

Example response:

[
  {
    "id": 2,
    "name": "Custom + code",
    "description: "Custom guest that can read code",
    "group_id": 84,
    "base_access_level": 10,
    "admin_merge_request": false,
    "admin_vulnerability": false,
    "read_code": true,
    "read_dependency": false,
    "read_vulnerability": false
  },
  {
    "id": 3,
    "name": "Guest + security",
    "description: "Custom guest that read and admin security entities",
    "group_id": 84,
    "base_access_level": 10,
    "admin_merge_request": false,
    "admin_vulnerability": true,
    "read_code": false,
    "read_dependency": true,
    "read_vulnerability": true
  }
]

Add a member role to a group

Ability to add a name and description when creating a custom role introduced in GitLab 16.3.

Adds a member role to a group.

POST /groups/:id/member_roles

To add a member role to a group, the group must be at root-level (have no parent group).

AttributeTypeRequiredDescription
idinteger/stringyesThe ID or URL-encoded path of the group owned by the authenticated user.
namestringyesThe name of the member role.
descriptionstringnoThe description of the member role.
base_access_levelintegeryesBase access level for configured role. Valid values are 10 (Guest), 20 (Reporter), 30 (Developer), 40 (Maintainer), or 50 (Owner).
admin_merge_requestbooleannoPermission to admin project merge requests.
admin_vulnerabilitybooleannoPermission to admin project vulnerabilities.
read_codebooleannoPermission to read project code.
read_dependencybooleannoPermission to read project dependencies.
read_vulnerabilitybooleannoPermission to read project vulnerabilities.

If successful, returns 201 and the following attributes:

AttributeTypeDescription
idintegerThe ID of the member role.
namestringThe name of the member role.
descriptionstringThe description of the member role.
group_idintegerThe ID of the group that the member role belongs to.
base_access_levelintegerBase access level for member role.
admin_merge_requestbooleanPermission to admin project merge requests.
admin_vulnerabilitybooleanPermission to admin project vulnerabilities.
read_codebooleanPermission to read project code.
read_dependencybooleanPermission to read project dependencies.
read_vulnerabilitybooleanPermission to read project vulnerabilities.

Example request:

 curl --request POST --header "Content-Type: application/json" --header "Authorization: Bearer <your_access_token>" --data '{"name" : "Custom guest", "base_access_level" : 10, "read_code" : true}' "https://gitlab.example.com/api/v4/groups/84/member_roles"

Example response:

{
  "id": 3,
  "name": "Custom guest",
  "description": null,
  "group_id": 84,
  "base_access_level": 10,
  "admin_merge_requests": false,
  "admin_vulnerability": false,
  "read_code": true,
  "read_dependency": false,
  "read_vulnerability": false
}

In GitLab 16.3 and later, you can use the API to:

  • Add a name (required) and description (optional) when you create a new custom role.
  • Update an existing custom role’s name and description.

Remove member role of a group

Deletes a member role of a group.

DELETE /groups/:id/member_roles/:member_role_id
AttributeTypeRequiredDescription
idinteger/stringyesThe ID or URL-encoded path of the group owned by the authenticated user.
member_role_idintegeryesThe ID of the member role.

If successful, returns 204 and an empty response.

Example request:

curl --request DELETE --header "Content-Type: application/json" --header "Authorization: Bearer <your_access_token>" "https://gitlab.example.com/api/v4/groups/84/member_roles/1"