Protected packages API
- Tier: Free, Premium, Ultimate
- Offering: GitLab Self-Managed
This API manages the protection rules for packages.
List package protection rules
Gets a list of package protection rules from a project.
GET /api/v4/projects/:id/packages/protection/rulesSupported attributes:
| Attribute | Type | Required | Description | 
|---|---|---|---|
| id | integer or string | Yes | ID or URL-encoded path of the project. | 
If successful, returns 200 and a list of package protection rules.
Can return the following status codes:
- 200 OK: A list of package protection rules.
- 401 Unauthorized: The access token is invalid.
- 403 Forbidden: The user does not have permission to list package protection rules for this project.
- 404 Not Found: The project was not found.
Example request:
curl --header "PRIVATE-TOKEN: <your_access_token>" \
  --url "https://gitlab.example.com/api/v4/projects/7/packages/protection/rules"Example response:
[
 {
  "id": 1,
  "project_id": 7,
  "package_name_pattern": "@flightjs/flight-package-0",
  "package_type": "npm",
  "minimum_access_level_for_delete": "owner",
  "minimum_access_level_for_push": "maintainer"
 },
 {
  "id": 2,
  "project_id": 7,
  "package_name_pattern": "@flightjs/flight-package-1",
  "package_type": "npm",
  "minimum_access_level_for_delete": "owner",
  "minimum_access_level_for_push": "maintainer"
 }
]Create a package protection rule
Create a package protection rule for a project.
POST /api/v4/projects/:id/packages/protection/rulesSupported attributes:
| Attribute | Type | Required | Description | 
|---|---|---|---|
| id | integer or string | Yes | ID or URL-encoded path of the project. | 
| package_name_pattern | string | Yes | Package name protected by the protection rule. For example @my-scope/my-package-*. Wildcard character*allowed. | 
| package_type | string | Yes | Package type protected by the protection rule. For example npm. | 
| minimum_access_level_for_delete | string | Yes | Minimum GitLab access level required to delete a package. Valid values include null,owneroradmin. If the value isnull, the default minimum access level ismaintainer. Must be provided whenminimum_access_level_for_pushis not set. Behind a feature flag namedpackages_protected_packages_delete. Disabled by default. | 
| minimum_access_level_for_push | string | Yes | Minimum GitLab access level required to push a package. Valid values include null,maintainer,owneroradmin. If the value isnull, the default minimum access level isdeveloper. Must be provided whenminimum_access_level_for_deleteis not set. | 
If successful, returns 201 and the created package protection rule.
Can return the following status codes:
- 201 Created: The package protection rule was created successfully.
- 400 Bad Request: The package protection rule is invalid.
- 401 Unauthorized: The access token is invalid.
- 403 Forbidden: The user does not have permission to create a package protection rule.
- 404 Not Found: The project was not found.
- 422 Unprocessable Entity: The package protection rule could not be created, for example, because the- package_name_patternis already taken.
Example request:
curl --request POST \
  --header "PRIVATE-TOKEN: <your_access_token>" \
  --header "Content-Type: application/json" \
  --url "https://gitlab.example.com/api/v4/projects/7/packages/protection/rules" \
  --data '{
       "package_name_pattern": "package-name-pattern-*",
       "package_type": "npm",
       "minimum_access_level_for_delete": "owner",
       "minimum_access_level_for_push": "maintainer"
    }'Update a package protection rule
Update a package protection rule for a project.
PATCH /api/v4/projects/:id/packages/protection/rules/:package_protection_rule_idSupported attributes:
| Attribute | Type | Required | Description | 
|---|---|---|---|
| id | integer or string | Yes | ID or URL-encoded path of the project. | 
| package_protection_rule_id | integer | Yes | ID of the package protection rule to be updated. | 
| package_name_pattern | string | No | Package name protected by the protection rule. For example @my-scope/my-package-*. Wildcard character*allowed. | 
| package_type | string | No | Package type protected by the protection rule. For example npm. | 
| minimum_access_level_for_delete | string | No | Minimum GitLab access level required to delete a package. Valid values include null,owneroradmin. If the value isnull, the default minimum access level ismaintainer. Must be provided whenminimum_access_level_for_pushis not set. Behind a feature flag namedpackages_protected_packages_delete. Disabled by default. | 
| minimum_access_level_for_push | string | No | Minimum GitLab access level required to push a package. Valid values include null,maintainer,owneroradmin. If the value isnull, the default minimum access level isdeveloper. Must be provided whenminimum_access_level_for_deleteis not set. | 
If successful, returns 200 and the updated package protection rule.
Can return the following status codes:
- 200 OK: The package protection rule was patched successfully.
- 400 Bad Request: The patch is invalid.
- 401 Unauthorized: The access token is invalid.
- 403 Forbidden: The user does not have permission to patch a package protection rule.
- 404 Not Found: The project was not found.
- 422 Unprocessable Entity: The package protection rule could not be patched, for example, because the- package_name_patternis already taken.
Example request:
curl --request PATCH \
  --header "PRIVATE-TOKEN: <your_access_token>" \
  --header "Content-Type: application/json" \
  --url "https://gitlab.example.com/api/v4/projects/7/packages/protection/rules/32" \
  --data '{
       "package_name_pattern": "new-package-name-pattern-*"
    }'Delete a package protection rule
Deletes a package protection rule from a project.
DELETE /api/v4/projects/:id/packages/protection/rules/:package_protection_rule_idSupported attributes:
| Attribute | Type | Required | Description | 
|---|---|---|---|
| id | integer or string | Yes | ID or URL-encoded path of the project. | 
| package_protection_rule_id | integer | Yes | ID of the package protection rule to be deleted. | 
If successful, returns 204 No Content.
Can return the following status codes:
- 204 No Content: The package protection rule was deleted successfully.
- 400 Bad Request: The- idor the- package_protection_rule_idare missing or are invalid.
- 401 Unauthorized: The access token is invalid.
- 403 Forbidden: The user does not have permission to delete the package protection rule.
- 404 Not Found: The project or the package protection rule was not found.
Example request:
curl --request DELETE --header "PRIVATE-TOKEN: <your_access_token>" \
  --url "https://gitlab.example.com/api/v4/projects/7/packages/protection/rules/32"