GHCR Pruning
ActionsTags
(2)GitHub Action to prune/delete container versions from GitHub Container Registry (ghcr.io).
By default, both prune-untagged
and prune-tags-regexes
inputs are disabled and as result no versions will be matched for pruning. Either or both inputs must be explicitly configured for versions to be pruned. This behaviour helps to avoid pruning versions by mistake when first configuring this action.
As this action is destructive, it's recommended to test any changes to the configuration of the action with a dry-run to ensure the expected versions are matched for pruning. For more details about dry-runs, see the dry-run input.
This is especially true when the prune-tags-regexes
input is used as regular expressions can easily match all versions of a container and result in complete deletion of all available versions.
Pruning all untagged versions older than 7 days, except the 2 most recent:
steps:
- name: Prune
uses: vlaurin/[email protected]
with:
token: ${{ secrets.YOUR_TOKEN }}
organization: your-org
container: your-container
dry-run: true # Dry-run first, then change to `false`
keep-younger-than: 7 # days
keep-last: 2
prune-untagged: true
For more pruning strategies, see filters.
This action uses the Github Rest API deletePackageVersionForOrg() resource which states:
To use this endpoint, you must have admin permissions in the organization and authenticate using an access token with the
packages:read
andpackages:delete
scopes. In addition: [...] Ifpackage_type
is container, you must also have admin permissions to the container you want to delete.
As a result, for this action to work, the token must be associated to a user who has admin permissions for both the organization and the package. If this is not the case, then dry-runs will work as expected but actual runs will fail with a Package not found
error when attempting to delete versions.
Required Secret access token with scopes packages:read
and packages:delete
and write permissions on the targeted container. See Creating a personal access token
for more details about GitHub access tokens.
Name of the organization owning the container package.
user
.
Only one of the 2 can be used at any time.
If neither are provided, then the packages of the authenticated user (cf. token
) are considered.
Name of the user owning the container package.
organization
.
Only one of the 2 can be used at any time.
If neither are provided, then the packages of the authenticated user (cf. token
) are considered.
Required Name of the container package for which versions should be pruned.
Optional Boolean controlling whether to execute the action as a dry-run. When true
the action will print out details of the version that will be pruned without actually deleting them. Defaults to false
.
As this action is destructive, it's recommended to test any changes to the configuration of the action with a dry-run to ensure the expected versions are matched for pruning.
This action supports 2 types of filters:
- Exclusion filters, prefixed with
keep-
, exclude versions from pruning, preventing them from being deleted. - Inclusion filters, prefixed with
prune-
, select the versions to prune.
Exclusion filters always take precedence over inclusion filters. This means that if a version of a container is matched by both an exclusion and an inclusion filter, the exclusion will take priority and the version will not be pruned.
Versions that are not matched by any filter are preserved.
Optional Count of most recent, matching containers to exclude from pruning. Defaults to 0
which means that all matching containers are pruned.
Optional List of tags to exclude from pruning, one per line. Any version with at least one matching tag will be excluded. Matching is exact and case-sensitive.
Optional List of regular expressions for tags to exclude from pruning, one per line. Each expression will be evaluated against all tags of a version. Any version with at least one tag matching the expression will be excluded from pruning.
For example, pruning all versions with tags starting with either pr-
or test-
, except the ones ending with numbers 42 or 1337:
steps:
- name: Prune
uses: vlaurin/[email protected]
with:
token: ${{ secrets.YOUR_TOKEN }}
organization: your-org
container: your-container
dry-run: true # Dry-run first, then change to `false`
keep-tags-regexes: |
42$
1337$
prune-tags-regexes: |
^pr-
^test-
Optional Minimum age in days a version must have to qualify for pruning. All versions below that age at time of execution are excluded from pruning. Defaults to 0
which means no versions will be excluded from pruning.
Optional List of regular expressions for tags to prune, one per line. Each expression will be evaluated against all tags of a version. Any version with at least one tag matching the expression will be pruned. Disabled by default (ie. no versions pruned based on tags).
prune-tags-regexes
, please make sure you've read the Word of caution
For example, pruning all versions with tags starting with either pr-
or test-
:
steps:
- name: Prune
uses: vlaurin/[email protected]
with:
token: ${{ secrets.YOUR_TOKEN }}
organization: your-org
container: your-container
dry-run: true # Dry-run first, then change to `false`
prune-tags-regexes: |
^pr-
^test-
Optional Boolean controlling whether untagged versions should be pruned (true
) or not (false
). Defaults to false
.
The count of container versions which were successfully pruned by the action.
An array containing all the version IDs successfully pruned as part of the run.
Boolean flag indicating whether the execution was a dry-run, as per input dry-run
. This output can be used to determine if other outputs relates to a dry-run or actual pruning of versions.
This action is compiled into a single JS file using @vercel/ncc. This produces a dist/
folder which must be checked in with the code.
Compilation can be done using:
npm run build
The scripts and documentation in this project are released under the MIT License.
GHCR Pruning is not certified by GitHub. It is provided by a third-party and is governed by separate terms of service, privacy policy, and support documentation.