Python toolchain for building an OpenID4VP RP with a SATOSA backend compliant to the Italian Wallet Solution.
Project description
eudi-wallet-it-python
The EUDI Wallet Python toolchain is a suite of Python libraries designed to make it easy the implementation of an EUDI Wallet Relying Party according to the Italian Wallet implementation profile.
The toolchain contains the following components:
Name | Description |
---|---|
jwk | JSON Web Key (JWK) according to RFC7517. |
jwt | Signed and encrypted JSON Web Token (JWT) according to RFC7519, RFC7515 and RFC7516 |
tools.qrcode | QRCodes creation |
oauth2.dpop | Tools for issuing and parsing DPoP artifacts, according to OAuth 2.0 Demonstrating Proof-of-Possession at the Application Layer (DPoP) |
federation | Trust evaluation mechanisms, according to OpenID Federation 1.0 |
trust | Helper classes to handle both X.509 and OpenID Federation trust evaluation mechanisms |
satosa.backend | SATOSA Relying Party backend, according to OpenID for Verifiable Presentations |
openid4vp | Classes and schemas related to OpenID for Verifiable Presentations |
presentation_exchange | Resources related to DiF Presentation Exchange |
sd_jwt | Issuance and verification of SD-JWT according to Selective Disclosure for JWTs (SD-JWT) |
Setup
Install enviroment and dependencies
sudo apt install python3-dev python3-pip git
sudo python3 -m pip install --upgrade pip
sudo python3 -m pip install virtualenv
Activate the environment. It's optional and up to you if you want to install in a separate env or system wide
virtualenv -p python3 env
source env/bin/activate
Install using pip:
pip install pyeudiw
or pip install pyeudiw[satosa]
for the satosa backend.
Install using github:
pip install git+https://github.com/italia/eudi-wallet-it-python
Optionally for generate the documentation you need to install the following packages:
pip install sphinx sphinx_rtd_theme
Documentation
The API documentation is available in the githubpages, here.
In the docs/ folder there are some common example for some specific tasks.
Build the Documentation
For generate the documentaation enter in the terminal the following commands. The last argument is the exclude path, unit tests are then excluded from the API documentation.
cd docs
sphinx-apidoc -o ./source ../pyeudiw ../pyeudiw/tests
make html
Example project
The example project is a docker-compose that runs a demo composed by the following component:
- Wordpress with SAML2 support and Bootstrap Italia template preregistered to the IAM Proxy.
- Satosa-Saml2Spid IAM Proxy with a preconfigured OpenID4VP backend.
Please read this README to get a fully working Wordpress setup with SAML2 support.
SatoSa configuration
SaToSa is a general purpose IAM proxy solution that allows interoperability between different entities that implements different authentication protocols such as SAML2, OpenID Connect and OAuth2. This project offers a SaToSa backend to enable the OpenID4VP protocol.
Please read this README any details about how to configure SaToSa with the OpenID4VP Relying Party backend.
Contribute
Your contribution is welcome, no question is useless and no answer is obvious, we need you.
Contribute as end user
Please open an issue if you've found a bug or if you want to ask some features.
Contribute as developer
Please open your Pull Requests on the dev branch. Please consider the following branches:
- main: where we merge the code before tag a new stable release.
- dev: where we push our code during development.
- other-custom-name: where a new feature/contribution/bugfix will be handled, revisioned and then merged to dev branch.
Authors
- Giuseppe De Marco
- Pasquale De Rose
- Alessio Murru
- Salvatore Laiso
- Nicola Saitto
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 pyeudiw-0.8.0.tar.gz
.
File metadata
- Download URL: pyeudiw-0.8.0.tar.gz
- Upload date:
- Size: 96.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 608d33124271318e7862abba1eef7f64d0a1cea86ee1db985febde99d332b617 |
|
MD5 | 87ca59eed85525a2c1e6864c75cd04cd |
|
BLAKE2b-256 | c07e91e277077e69023eb246774f3e39be655ae4c435139d98da698c447abd1f |
File details
Details for the file pyeudiw-0.8.0-py3-none-any.whl
.
File metadata
- Download URL: pyeudiw-0.8.0-py3-none-any.whl
- Upload date:
- Size: 127.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 347dd300739fbad0dcdff691f6c849130d8f11da829d905067444b2266d0621a |
|
MD5 | 4d6efbae15c9c881df9c3c67f88a6178 |
|
BLAKE2b-256 | d485c66b95fd341cb9b0b14bb2acf126901ce8fa6417f2950cfa5fc6cbb0161e |