Skip to main content

keyring backend for GitLab package indexes

Project description

PyPI CI Status MIT License

keyring-gitlab-pypi is a backend for keyring which recognises GitLab package registry URLs.

  • ⚡️ Works seamlessly with uv
  • 🚀 Zero config needed on GitLab CI
  • 🗝️ No more per-index credentials on your machine

Using it locally

  1. Install keyring with this backend

    uv tool install keyring --with keyring-gitlab-pypi
    
  2. Open the config file for editing:

    User

    macOS
    $HOME/Library/Application Support/gitlab-pypi/gitlab-pypi.toml if directory $HOME/Library/Application Support/gitlab-pypi exists, or $HOME/.config/gitlab-pypi.toml otherwise.
    Linux
    $XDG_CONFIG_HOME/gitlab-pypi.toml if XDG_CONFIG_HOME is set, or $HOME/.config/gitlab-pypi.toml otherwise.
    Windows
    %LOCALAPPDATA%\gitlab-pypi\gitlab-pypi.toml

    System

    macOS
    /Library/Application Support/gitlab-pypi/gitlab-pypi.toml
    Linux

    <config_dir>/gitlab-pypi/gitlab-pypi.toml where <config_dir> is any of the paths set in $XDG_CONFIG_DIRS paths, defaulting to /etc/xdg

    /etc/gitlab-pypi.toml is higher priority than the above.

    Windows
    C:\ProgramData\gitlab-pypi\gitlab-pypi.toml
  3. Configure a token

    Personal Access Token

    Create a personal access token with the read_api scope and add it to the config file:

    ["gitlab.com"]
    token = "<token>"
    

    or set environment variables where <name> is an arbitrary key to group the variables, e.g. MYORG

    export KEYRING_GITLAB_PYPI_<name>_INSTANCE=gitlab.com
    export KEYRING_GITLAB_PYPI_<name>_TOKEN=<token>
    

    Deploy Token

    Create a deploy token with the read_package_registry scope and add it to the config file:

    ["gitlab.com"]
    username = "<username>"
    token = "<token>"
    

    or set environment variables where <name> is an arbitrary key to group the variables, e.g. MYORG

    export KEYRING_GITLAB_PYPI_<name>_INSTANCE=gitlab.com
    export KEYRING_GITLAB_PYPI_<name>_USERNAME=<username>
    export KEYRING_GITLAB_PYPI_<name>_TOKEN=<token>
    
  4. Configure keyring-provider in uv:

    • using an environment variable:

      export UV_KEYRING_PROVIDER=subprocess
      
    • or in uv.toml:

      keyring-provider = "subprocess"
      
    • or using the option

      uv sync --keyring-provider=subprocess
      
  5. Configure one or more GitLab package indexes

    For example, in pyproject.toml:

    [[tool.uv.index]]
    name = "myindex"
    url = "https://gitlab.example.com/api/v4/projects/1/packages/pypi/simple"
    authenticate = "always"
    

    Note

    You need authenticate = "always" for uv to invoke keyring when no username is specified. This option is a good idea anyway!

    Alternatively, add the username (which is __token__ for personal access tokens) to the URL, but this is not recommended for pyproject.toml as you likely want to use a different username in CI, for example.

  6. Done! keyring-gitlab-pypi will return your token for URLs that look like package installs.

Using it in GitLab CI

$CI_JOB_TOKEN will be used automatically as long as the index URL matches the running GitLab instance.

In principle this is all you need:

variables:
  UV_KEYRING_PROVIDER: subprocess
  UV_TOOL_BIN_DIR: /usr/local/bin

test:
  image: ghcr.io/astral-sh/uv:python3.13-bookworm
  before_script:
    - uv tool install keyring --with keyring-gitlab-pypi
    - uv sync

This assumes that you haven't set UV_INDEX. (uv tool ignores pyproject.toml so you don't need to worry about indexes configured there).

It's recommended to constrain the versions:

printf '%s\n' keyring keyring-gitlab-pypi > keyring-constraints.in
uv pip compile --universal keyring-constraints.in -o keyring-constraints.txt
variables:
  UV_KEYRING_PROVIDER: subprocess
  UV_TOOL_BIN_DIR: /usr/local/bin

test:
  image: ghcr.io/astral-sh/uv:python3.13-bookworm
  before_script:
    - uv tool install keyring --with keyring-gitlab-pypi -c keyring-constraints.txt
    - uv sync

Motivation

  • When using multiple GitLab package indexes, it can be cumbersome to configure them with the same token via environment variables or otherwise.
  • keyring's keychain backend on macOS does not support --mode creds
  • uv will reuse credentials for URLs on the same host, but it feels fragile to just configure one of the indexes and let the credentials cache serve the rest. At the very least, keyring-gitlab-pypi is set-and-forget across multiple projects.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

keyring_gitlab_pypi-1.2.tar.gz (8.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

keyring_gitlab_pypi-1.2-py3-none-any.whl (7.0 kB view details)

Uploaded Python 3

File details

Details for the file keyring_gitlab_pypi-1.2.tar.gz.

File metadata

  • Download URL: keyring_gitlab_pypi-1.2.tar.gz
  • Upload date:
  • Size: 8.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for keyring_gitlab_pypi-1.2.tar.gz
Algorithm Hash digest
SHA256 048f00715c65b87931c8fc5581fbfd995a62d923abdf83f27df782efb513e979
MD5 0a6a569b9a55f2610f9a692633b5b456
BLAKE2b-256 ed3e00bd6760135fc9545c6967226ba2f13a07c5c65d21566293331c4c7b9edb

See more details on using hashes here.

Provenance

The following attestation bundles were made for keyring_gitlab_pypi-1.2.tar.gz:

Publisher: python-publish.yml on RazerM/keyring-gitlab-pypi

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file keyring_gitlab_pypi-1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for keyring_gitlab_pypi-1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 ec95fe4c000bfab06b5767e38c3c90a011697484e92f44cc03cfb19587a6ea82
MD5 c333e0edf9a802ccf34952d48eea2be3
BLAKE2b-256 a1b8484e7dc0af46a15934a2c94b2e69d10540f2a66042add161d626ebfbc759

See more details on using hashes here.

Provenance

The following attestation bundles were made for keyring_gitlab_pypi-1.2-py3-none-any.whl:

Publisher: python-publish.yml on RazerM/keyring-gitlab-pypi

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page