Skip to main content

Python toolchain for building an OpenID4VP RP with a SATOSA backend compliant to the Italian Wallet Solution.

Project description

eudi-wallet-it-python

CI build Python version py-versions GitHub issues Get invited Join the #spid openid

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 specification.

All the components listed below are tailored to this scope.

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)
openid4vp.federation Trust evaluation mechanisms, according to OpenID Connect Federation 1.0
satosa.openid4vp.backend SATOSA Relying Party backend, according to OpenID for Verifiable Presentations

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

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 demo setup.

Satosa configuration

To install the OpenID4VP SATOSA backend you just need to:

  1. install this package
  2. copy and customize example/pyeudiw_backend.yml
  3. include the backend configuration in your satosa configuration
  4. start Satosa.

Please read README-SATOSA.md for details.

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

pyeudiw-0.5.0.tar.gz (70.5 kB view details)

Uploaded Source

Built Distribution

pyeudiw-0.5.0-py3-none-any.whl (95.0 kB view details)

Uploaded Python 3

File details

Details for the file pyeudiw-0.5.0.tar.gz.

File metadata

  • Download URL: pyeudiw-0.5.0.tar.gz
  • Upload date:
  • Size: 70.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.17

File hashes

Hashes for pyeudiw-0.5.0.tar.gz
Algorithm Hash digest
SHA256 69d127c1736c27fadc8cf56a5c987b610b952158a6844678194afca061ea7f78
MD5 b2d780e80f36bdc4a5310ba5d6665dc8
BLAKE2b-256 ff4daacb1cc4c3200da4e36fca8db192a6e3f629eb92b102be3e748f95d85391

See more details on using hashes here.

File details

Details for the file pyeudiw-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: pyeudiw-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 95.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.17

File hashes

Hashes for pyeudiw-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d4464b1c96cec39b8a1236dc2f3cc38c5576d1c8c74d7e24e9202e487719503c
MD5 a7a6fb0026b1c0cd44bb798170a9f66f
BLAKE2b-256 d549d84d5af7cb4b3b74118c20dc15ed98572ebca732813a7141959592cfc70f

See more details on using hashes here.

Supported by

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