Tool to make GitLab generic package registry operations easy.
Project description
glpkg - GitLab Generic Package registry tools
glpkg is a tool that makes it easy to work with GitLab generic package registry.
Installation
Install the tool from with pip:
pip install glpkg
To check the installation and version, run:
glpkg --version
If you see a version in the terminal, you're good to go!
Usage
By default, the used GitLab host is gitlab.com. If you use a self-hosted GitLab, use argument --host my-gitlab.net with the commands.
Only https scheme is supported.
To authenticate with the package registry in any of the commands below, use --token readapitoken123 argument where the readapitoken123 is a personal or project access token, with read API scope. In case the package registry is public, you can omit this argument.
The above arguments are omitted in the examples below to focus on the functions. Add the arguments to change the host or to authenticate with the registry.
In general, run glpkg --help when needed.
Listing package versions
To list the versions of a generic package, run
glpkg list --project 12345 --name mypackagename
Where:
12345is your projects ID (Find the Project ID) or the path of the project (likenamespace/project)mypackagenameis the name of the generic package
The output will be, if package is found, something like:
Name Version
mypackagename 1.0
mypackagename 1.5
mypackagename 2.0
Download generic package
To download everything from a specific generic package, run
glpkg download --project 12345 --name mypackagename --version 1.0
Where:
12345is your projects ID (Find the Project ID) or the path of the project (likenamespace/project)mypackagenameis the name of the generic package1.0is the version of the generic package from which the files are downloaded
The files will be downloaded in the current working directory. Any pre-existing files will be overridden without warning.
If a package has multiple files with the same filename, the tool can only download the newest file. This is a restriction of GitLab API.
Upload a file to a generic package
To upload a file to a version of a generic package, run
glpkg upload --project 12345 --name mypackagename --version 1.0 --file my-file.txt
Where:
12345is your projects ID (Find the Project ID) or the path of the project (likenamespace/project)mypackagenameis the name of the generic package1.0is the version of the generic package to which the file is uploadedmy-file.txtis the file that is uploaded to the generic package. Currently, only relative paths are supported, and the relative path (e.g.folder/file.txt) is preserved when uploading the file to the registry.
A GitLab generic package may have multiple files with the same file name. However, it likely is not a great idea, as they cannot be downloaded separately from the GitLab API.
Use in GitLab pipelines
If you use the tool in a GitLab pipeline, using --ci argument uses GitLab predefined variables to configure the tool. In this case CI_SERVER_HOST, CI_PROJECT_ID, and CI_JOB_TOKEN environment variables are used. The --project, and --token arguments can still be used to override the project ID and to use a personal or project access token instead of CI_JOB_TOKEN.
In other words, you don't need to give the --host, --project, or --token arguments if you are interacting with the package registry of the project where the pipeline is running. Example: uploading my-file.txt to generic package mypackagename version 1.0 in the project package registry in CI:
glpkg upload --ci --name mypackagename --version 1.0 --file my-file.txt
To use the CI_JOB_TOKEN with package registry of another projects, add --project <otherproject ID> argument. Remember that you may need to add permissions for the CI_JOB_TOKEN in the other project.
Limitations
The tool is not perfect (yet) and has limitations. The following limitations are known, but more can exist:
- Uploading files must be done one-by-one.
- Only project registries are supported for now.
- Pagination is not supported for now - in case you have more than 100 versions of a package, not all will be shown.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file glpkg-0.0.1.tar.gz.
File metadata
- Download URL: glpkg-0.0.1.tar.gz
- Upload date:
- Size: 8.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
67169b4bd06e4d0f8998359d7cbfa26349ace901f9c40fb97058b5fa1811b054
|
|
| MD5 |
d397c30ff147b4f62e6c0ce925ea8b47
|
|
| BLAKE2b-256 |
9802dc27ef28882f7027ec389ca221d8fd9f4e457fa5763cbc6a0f69345e4944
|
File details
Details for the file glpkg-0.0.1-py3-none-any.whl.
File metadata
- Download URL: glpkg-0.0.1-py3-none-any.whl
- Upload date:
- Size: 7.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
42fe5bdf10fe2a352827f2b34e099cd90cc59148d0911433053240550772018a
|
|
| MD5 |
652b16e5314c14cc435b84db9a8481bf
|
|
| BLAKE2b-256 |
de6d6eaa3b78ae6be1c4cbfa3102686bbbb7d7d4727262c4769f4eeb37ec1fbc
|