Protected packages

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

By default, any user with at least the Developer role can create, edit, and delete packages. Add a package protection rule to restrict which users can make changes to your packages.

GitLab supports only push protection for npm packages, but epic 5574 proposes to add additional features and package formats.

When a package is protected, the default behavior enforces these restrictions on the package:

Action Who can do it
Protect a package At least the Maintainer role.
Push a new package At least the role set in Minimum access level for push.
Push a new package with a deploy token Any valid deploy token, only if the pushed package is not matched by a protection rule. Protected packages cannot be pushed with a deploy token.

Protect a package

History

Prerequisites:

  • You must have at least the Maintainer role.

To protect a package:

  1. On the left sidebar, select Search or go to and find your project.
  2. Select Settings > Packages and registries.
  3. Expand Package registry.
  4. Under Protected packages, select Add protection rule.
  5. Complete the fields:
    • Name pattern is a package name pattern you want to protect. The pattern can include a wildcard (*).
    • Package type is the type of package to protect.
    • Minimum access level for push is the minimum role required to push a package matching the name pattern.
  6. Select Protect.

The package protection rule is created, and appears in the settings.

Protecting multiple packages

You can use a wildcard to protect multiple packages with the same package protection rule. For example, you can protect all the temporary packages built during a CI/CD pipeline.

The following table contains examples of package protection rules that match multiple packages:

Package name pattern with wildcard Matching packages
@group/package-* @group/package-prod, @group/package-prod-sha123456789
@group/*package @group/package, @group/prod-package, @group/prod-sha123456789-package
@group/*package* @group/package, @group/prod-sha123456789-package-v1

It’s possible to apply several protection rules to the same package. If at least one protection rule applies to the package, the package is protected.

Delete a package protection rule and unprotect a package

History

Prerequisites:

  • You must have at least the Maintainer role.

To unprotect a package:

  1. On the left sidebar, select Search or go to and find your project.
  2. Select Settings > Packages and registries.
  3. Expand Package registry.
  4. Under Protected packages, next to the protection rule you want to delete, select Delete ().
  5. On the confirmation dialog, select Delete.

The package protection rule is deleted, and does not appear in the settings.