Verify OIDC JWT identity tokens using OIDC discovery
Project description
Python library to verify id tokens using OIDC discovery
OpenID connect identity tokens are a popular choice for federating identity between different systems without the need to share secrets. For example Trusted publishing on PyPI allows use of OIDC tokens created by GitHub or GitLab CI jobs to be used to authenticate when uploading new Python packages. Similarly, OIDC tokens can be used to authenticate to Google Cloud, AWS and Azure from any OIDC identity provider.
The jwt.io and jwt.ms tools allow validating OIDC id tokens without first configuring public keys by means of the OpenID connect discovery protocol.
This library implements the OpenID Connect discovery standard in Python to allow verification of OpenID Connect id tokens without previous configuration of public keys, etc.
Both synchronous and asynchronous (asyncio
) implementations are provided.
Example
Suppose you created a GitLab OIDC token as part of a CI job to make an authenticated HTTP GET request to some service:
# .gitlab-ci.yml within https://gitlab.com/my-group/my-project
job_with_id_token:
id_tokens:
ID_TOKEN:
aud: https://my-service.example.com
script:
- curl -X GET -H "Authorization: Bearer $ID_TOKEN" https://my-service.example.com
The following example shows how to verify the OIDC token came from a specific project within a backend implementation:
from typing import Any
from federatedidentity import Issuer, verifiers, verify_id_token
# Use OIDC discovery to fetch public keys for verifying GitLab tokens.
GITLAB_ISSUER = Issuer.from_discovery("https://gitlab.com")
# Expected project path for id token
EXPECTED_PROJECT_PATH = "my-group/my-project"
# Expected audience claim for id token.
EXPECTED_AUDIENCE_CLAIM = "https://my-service.example.com"
def verify_gitlab_token(token: str) -> dict[str, Any]:
"""
Verify an OIDC token from GitLab and return the dictionary of claims. Raises
federatedidentity.FederatedIdentityError if the token failed verification.
"""
return verify_id_token(
token,
valid_issuers=[GITLAB_ISSUER],
valid_audiences=[EXPECTED_AUDIENCE_CLAIM],
required_claims=[
# The "project_path" claim must match the expected project.
{"project_path": EXPECTED_PROJECT_PATH},
],
)
See the full documentation for more examples.
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
Built Distribution
File details
Details for the file verify_oidc_identity-0.3.7.tar.gz
.
File metadata
- Download URL: verify_oidc_identity-0.3.7.tar.gz
- Upload date:
- Size: 9.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 22f68934fa9a0c010d68955388d00d3dd460d06a38c9af5697b6ceeb66c23cc5 |
|
MD5 | 5f725e3b63c762858f5944201dbd2253 |
|
BLAKE2b-256 | 6c0d97046d7e5c59f22b00930d2a1deb8b70b5b26f4a955bfd403cede17d493d |
Provenance
The following attestation bundles were made for verify_oidc_identity-0.3.7.tar.gz
:
Publisher:
main.yml
on rjw57/verify-oidc-identity
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
verify_oidc_identity-0.3.7.tar.gz
- Subject digest:
22f68934fa9a0c010d68955388d00d3dd460d06a38c9af5697b6ceeb66c23cc5
- Sigstore transparency entry: 150535729
- Sigstore integration time:
- Predicate type:
File details
Details for the file verify_oidc_identity-0.3.7-py3-none-any.whl
.
File metadata
- Download URL: verify_oidc_identity-0.3.7-py3-none-any.whl
- Upload date:
- Size: 10.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 27b5bcc6fc3187132c056bdcf2e5234743eb16cb3c4cf68e2b0e46c6ac7d8fa0 |
|
MD5 | 36e2f3eef567b1e7fb044f9154ca7ccb |
|
BLAKE2b-256 | a6c8158d17e50faac3be202497c925ded395e416af4e73423ddedf289140a5a1 |
Provenance
The following attestation bundles were made for verify_oidc_identity-0.3.7-py3-none-any.whl
:
Publisher:
main.yml
on rjw57/verify-oidc-identity
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
verify_oidc_identity-0.3.7-py3-none-any.whl
- Subject digest:
27b5bcc6fc3187132c056bdcf2e5234743eb16cb3c4cf68e2b0e46c6ac7d8fa0
- Sigstore transparency entry: 150535731
- Sigstore integration time:
- Predicate type: