Group and project access requests API

  • Tier: Free, Premium, Ultimate
  • Offering: GitLab.com, GitLab Self-Managed, GitLab Dedicated

Use this API to interact with access requests for group and projects.

Valid access levels

The access levels are defined in the Gitlab::Access module, and the following levels are recognized:

  • No access (0)
  • Minimal access (5)
  • Guest (10)
  • Planner (15)
  • Reporter (20)
  • Developer (30)
  • Maintainer (40)
  • Owner (50).

List access requests for a group or project

Gets a list of access requests viewable by the authenticated user.

GET /groups/:id/access_requests GET /projects/:id/access_requests
AttributeTypeRequiredDescription
idinteger/stringyesThe ID or URL-encoded path of the project

Example request:

curl --request GET \  --header "PRIVATE-TOKEN: <your_access_token>" \  --url "https://gitlab.example.com/api/v4/groups/:id/access_requests" curl --header "PRIVATE-TOKEN: <your_access_token>" \  --url "https://gitlab.example.com/api/v4/projects/:id/access_requests"

Example response:

[  {  "id": 1,  "username": "raymond_smith",  "name": "Raymond Smith",  "state": "active",  "locked": false,  "avatar_url": "https://gitlab.com/uploads/-/system/user/avatar/1/avatar.png",  "web_url": "https://gitlab.com/raymond_smith",  "requested_at": "2024-10-22T14:13:35Z"  },  {  "id": 2,  "username": "john_doe",  "name": "John Doe",  "state": "active",  "locked": false,  "avatar_url": "https://gitlab.com/uploads/-/system/user/avatar/2/avatar.png",  "web_url": "https://gitlab.com/john_doe",  "requested_at": "2024-10-22T14:13:35Z"  } ]

Request access to a group or project

Requests access for the authenticated user to a group or project.

POST /groups/:id/access_requests POST /projects/:id/access_requests
AttributeTypeRequiredDescription
idinteger/stringyesThe ID or URL-encoded path of the group or project

Example request:

curl --request POST \  --header "PRIVATE-TOKEN: <your_access_token>" \  --url "https://gitlab.example.com/api/v4/groups/:id/access_requests" curl --request POST \  --header "PRIVATE-TOKEN: <your_access_token>" \  --url "https://gitlab.example.com/api/v4/projects/:id/access_requests"

Example response:

{  "id": 1,  "username": "raymond_smith",  "name": "Raymond Smith",  "state": "active",  "created_at": "2012-10-22T14:13:35Z",  "requested_at": "2012-10-22T14:13:35Z" }

Approve an access request

Approves an access request for the given user.

PUT /groups/:id/access_requests/:user_id/approve PUT /projects/:id/access_requests/:user_id/approve
AttributeTypeRequiredDescription
idinteger/stringyesThe ID or URL-encoded path of the project
user_idintegeryesThe user ID of the access requester
access_levelintegernoA valid access level (defaults: 30, the Developer role)

Example request:

curl --request PUT \  --header "PRIVATE-TOKEN: <your_access_token>" \  --url "https://gitlab.example.com/api/v4/groups/:id/access_requests/:user_id/approve?access_level=20" curl --request PUT \  --header "PRIVATE-TOKEN: <your_access_token>" \  --url "https://gitlab.example.com/api/v4/projects/:id/access_requests/:user_id/approve?access_level=20"

Example response:

{  "id": 1,  "username": "raymond_smith",  "name": "Raymond Smith",  "state": "active",  "created_at": "2012-10-22T14:13:35Z",  "access_level": 20 }

Deny an access request

Denies an access request for the given user.

DELETE /groups/:id/access_requests/:user_id DELETE /projects/:id/access_requests/:user_id
AttributeTypeRequiredDescription
idinteger/stringyesThe ID or URL-encoded path of the project
user_idintegeryesThe user ID of the access requester

Example request:

curl --request DELETE \  --header "PRIVATE-TOKEN: <your_access_token>" \  --url "https://gitlab.example.com/api/v4/groups/:id/access_requests/:user_id" curl --request DELETE \  --header "PRIVATE-TOKEN: <your_access_token>" \  --url "https://gitlab.example.com/api/v4/projects/:id/access_requests/:user_id"