GitXplorerGitXplorer
d

id

public
10 stars
3 forks
3 issues

Commits

List of commits on branch main.
Verified
ef8ec83c54e0c9f9562f1687ac8a40267e086bf6

build(deps): update ruff requirement from <0.9.2 to <0.9.3 (#338)

ddependabot[bot] committed a day ago
Verified
9f5b94895de730c510df28924af9bd290191f357

build(deps): bump github/codeql-action from 3.28.0 to 3.28.1 in the actions group (#336)

ddependabot[bot] committed 5 days ago
Verified
f48e216859fffc68b76e95368461118c5884438e

build(deps): update ruff requirement from <0.9.1 to <0.9.2 (#337)

ddependabot[bot] committed 5 days ago
Verified
263f4565c00136cd4ad9469e1cbd374ae5c79975

build(deps): bump actions/upload-artifact from 4.5.0 to 4.6.0 in the actions group (#335)

ddependabot[bot] committed 8 days ago
Verified
30c4027272c2555fc2dc1b571eeae55c0deae5b0

build(deps): update ruff requirement from <0.8.7 to <0.9.1 (#334)

ddependabot[bot] committed 8 days ago
Verified
d6b012ce3d3512568f060566d6c4729741ab1ae7

build(deps): bump softprops/action-gh-release from 2.2.0 to 2.2.1 in the actions group (#332)

ddependabot[bot] committed 10 days ago

README

The README file for this repository.

id

CI PyPI version OpenSSF Scorecard SLSA

id is a Python tool for generating OIDC identities. It can automatically detect and produce OIDC credentials on a number of environments, including GitHub Actions, GitLab pipelines and Google Cloud.

Installation

id requires Python 3.8 or newer, and can be installed directly via pip:

python -m pip install id

Usage

You can run id as a Python module via python -m:

python -m id --help

Top-level:

usage: id [-h] [-V] [-v] [-d] audience

a tool for generating OIDC identities

positional arguments:
  audience       the OIDC audience to use

optional arguments:
  -h, --help     show this help message and exit
  -V, --version  show program's version number and exit
  -v, --verbose  run with additional debug logging; supply multiple times to
                 increase verbosity (default: 0)
  -d, --decode   decode the OIDC token into JSON (default: False)

For Python API usage, there is a single importable function, detect_credential:

>>> from id import detect_credential
>>> detect_credential(audience='something')
'<OIDC token>'

This function requires an audience parameter, which is used when generating the OIDC token. This should be set to the intended audience for the token.

If no supported environment is found, detect_credential returns None. If a supported environment is found but detect_credential fails to retrieve a token, it raises AmbientCredentialError.

Supported environments

id currently supports ambient credential detection in the following environments:

Tokens in environment variables

GitLab provides OIDC tokens through environment variables. The variable name must be <AUD>_ID_TOKEN where <AUD> is the uppercased audience argument where all characters outside of ASCII letters and digits are replaced with "_". A leading digit must also be replaced with a "_".

Licensing

id is licensed under the Apache 2.0 License.

Contributing

See the contributing docs for details.

SLSA Provenance

This project emits a SLSA provenance on its release! This enables you to verify the integrity of the downloaded artifacts and ensured that the binary's code really comes from this source code.

To do so, please follow the instructions here.