A Python client to handle communication with FranceConnect
Project description
France Connect Py
france-connect-py is a package allowing to interact with FranceConnect V2
through a single and easy-to-use class.
Requirements
france-connect-py only support the supported version of each dependency (mainstream & lts).
Python(supported versions)
Installation
The easiest way to install france-connect-py is through pip:
pip install france-connect-py
How to use
You only need to import the FranceConnect class and create an instance to
start using the France Connect API.
from france_connect.clients import FranceConnect
from france_connect.scopes import ACRValues, Scopes
fc = FranceConnect(
client_id="<client_id>",
client_secret="<client_secret>",
scopes=[Scopes.PROFILE, Scopes.IDENTITE_PIVOT],
# Must be THE SAME url as defined in FranceConnect
# No additional query params
# Do not forget the potential trailing slash
login_callback_url="<login_callback_url>",
logout_callback_url="<logout_callback_url>",
fc_base_url="https://fcp-low.integ01.dev-franceconnect.fr",
)
# You can retrieve the FranceConnect's OpenID configuration as follow.
fc.get_configuration()
# Get the authorization URL.
#
# You can provide a specific `nonce` and `state` if needed, or let the class
# generate them as a random 64 bytes hex string. You can also inherit
# `FranceConnect` and override `generate_nonce()` and `generate_state()` to change
# the way they are generated.
#
# `eidas1` is used as the default level of end user assurance, you can provide
# a different value using the `acr_values` parameter.
# For more information, see:
# https://docs.partenaires.franceconnect.gouv.fr/fs/fs-technique/fs-technique-eidas-acr/
#
# The `login_callback_url` provided at instantiation will be used as the
# callback URL, you can override it using the `callback_url` parameter.
url, nonce, state = fc.get_authentication_url(acr_values=[ACRValues.EIDAS2])
# The following code must be called when the user is redirected back to the
# service provider after a successful authentication of FranceConnect.
#
# Retrieve the code from the FranceConnect request
code = ...
# Retrieve the ID Token (the signature is verified automatically)
raw_token, decoded_token = fc.get_id_token(code)
# Retrieve the user's information using the ID Token (the signature is also
# verified automatically) `user_info` is a dictionary containing the user's
# information asked in the scopes.
user_info = fc.get_user_info(raw_token["access_token"])
# To retrieve the logout url, uses `get_logout_url()`.
#
# The `logout_callback_url` provided at instantiation will be used as the
# callback URL, you can override it using the `callback_url` parameter.
logout_url = fc.get_logout_url(raw_token["id_token"], state)
Other
france-connect-py uses the requests library to interact with the France
Connect API. You can override how the library is used using the following
FranceConnect class parameters:
timeout: int = 10verify_ssl: bool = Trueallow_redirects: bool = True
Changelog
2.1.1 (2025-09-22)
- Add conditional SSL handling in
verify_jwtwhen SSL verification is disabled. (#9),
2.1.0 (2025-05-20)
- Allow customization of JWT algorithms using
jwt_algorithmswhen instantiating client (#7), Contributed by Vayel.
2.0.0 (2024-10-07)
- Initial release
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
File details
Details for the file france_connect_py-2.1.1.tar.gz.
File metadata
- Download URL: france_connect_py-2.1.1.tar.gz
- Upload date:
- Size: 10.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
032b32c02bd8682e18ae52cdcccde56d192fcb2d44000559e90170c2ea2dc2ee
|
|
| MD5 |
747bfa0d7b034dfa55080ebc3bd31837
|
|
| BLAKE2b-256 |
9ba9ec802bf5c4abc767cb97f6c6b0f9a3aad8be539660b90316289673009e32
|
Provenance
The following attestation bundles were made for france_connect_py-2.1.1.tar.gz:
Publisher:
tests_and_publish.yml on Codoc-os/france-connect-py
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
france_connect_py-2.1.1.tar.gz -
Subject digest:
032b32c02bd8682e18ae52cdcccde56d192fcb2d44000559e90170c2ea2dc2ee - Sigstore transparency entry: 545465487
- Sigstore integration time:
-
Permalink:
Codoc-os/france-connect-py@62077ab10326c65d4bf113a5a17720152e646522 -
Branch / Tag:
refs/tags/v2.1.1 - Owner: https://github.com/Codoc-os
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
tests_and_publish.yml@62077ab10326c65d4bf113a5a17720152e646522 -
Trigger Event:
release
-
Statement type: