In this tutorial we show how to setup a Federation with a Trust Anchor, a Provider and a Relying Party. We can achieve this though the Admin backend or via internal API.
If you're using the Docker-compose demo, you can skip the creation of a Federation Authority.
setup
- add
spid_cie_oidc.entity
andspid_cie_oidc.authority
in settings.INSTALLED_APPS - do migrations
./manage.py migrate
- create superuser
./manage.py createsuperuser
, eg:- username: admin
- password: oidcadmin
- log in the
/admin
interface using admin oidcadmin
configure the federation entity
Click on Federation Entity Configuration and create your entity, with the following information:
- sub
- jwks (if omitted it will auto provisioned)
- metadata, containing the endpoints that matches to your urls webpaths
- is_active, must set to True
To onboard a new entity in the federation you have to do the following steps:
configure descendants entities
- Click on Federation Entity Descendant and configure a descendant
- Click on Federation Entity Profile and create the desidered profiles and trust marks template
- Click on Federation Entity Descendant Assigned Profile and assing at least one profile to the new descendant
In this doc we describe the detailed steps to register a Relying Party and a Provider.
A profile that may be assigned to a Relying Party.
An assigned profile to a Relying Party.
The JWKS if not submitted it will be created automatically.
from spid_cie_oidc.entity.models import *
TA_SUB = "http://testserver"
FA_METADATA = {
"federation_entity": {
"contacts": ["ops@localhost"],
"federation_fetch_endpoint": f"{TA_SUB}/fetch",
"homepage_uri": f"{TA_SUB}",
"name": "example TA",
}
}
TM_ISSUERS = {
"https://www.spid.gov.it/certification/rp/public": [
TA_SUB,
"https://public.intermediary.spid.it",
],
"https://www.spid.gov.it/certification/rp/private": [
TA_SUB,
"https://private.other.intermediary.it",
],
"https://sgd.aa.it/onboarding": ["https://sgd.aa.it"],
}
FA_CONSTRAINTS = {"max_path_length": 1}
ta_conf_data = dict(
sub=TA_SUB,
metadata=FA_METADATA,
constraints=FA_CONSTRAINTS,
is_active=True,
trust_mark_issuers=TM_ISSUERS,
)
FederationEntityConfiguration.objects.create(**ta_conf_data)
Using different kind of metadata we can create OpenID Relying Parties or Providers. Just rememeber, for these latter, to add also the authority_hints value as follow.
authority_hints = ["http://testserver"]
see unit tests.
In you project configure the settingslocal.py file and import it in your settings.py file, for all the provider configuration parameters see here.
For CIE or Spid provider configure OIDCFED_PROVIDER_PROFILE
parameter in settingslocal.py as "cie" or "spid"
In examples/provider configure a federation entity configuration as OP:
./manage.py runserver 0.0.0.0:8002
Open http://127.0.0.1:8002/admin in you web browser and in FederationEntityConfiguration create a new entry with the following data:
- sub (eg. 'http://127.0.0.1:8002/oidc/op')
- authority hints, list of trust anchor(eg. ["http://127.0.0.1:8000"])
- Jwks, private jwks, if you don't have one please create a pair of private using the OnBoarding tool
Create a JWK
. - metadata, url paths in metadata need to be mapped in
examples/relying_party/urls.py
, here.
An example of metadata here
Now that you configured your Provider Entity you have to register it in the federation. Access to the Federation Authority admin backend and configure your OP as a descendant and assign to it a profile, as shown in the previous section. In the admin page of your Trust Anchor (http://127.0.0.1:8000/admin) create a descendant entity with the following paramenters:
- OP name
- sub (eg. 'http://127.0.0.1:8002/oidc/op')
- Jwks, public jwks available in the OP's entity configuration
- is_active, must set to True
Then assign a profile, select 'Identity Provider'.
In you project configure the settingslocal.py file and import it in your settings.py file. For more information on configuration parameters see here.
Then apply migrations:
examples/relying_party/manage.py migrate
In examples/relying_party configure a federation entity configuration as RP:
./manage.py runserver 0.0.0.0:[port]
In the admin page (http://127.0.0.1:[port]/admin) create a FederationEntityConfiguration with at least these parameters:
- sub (eg. 'http://127.0.0.1:[port]/oidc/rp')
- authority hints, list of trust anchor(eg. ["http://127.0.0.1:8000"])
- Jwks, private jwks, If you don't have one please create a pair of private/public using the OnBoarding tool
Create a JWK
. - metadata, url paths in metadata need to be mapped in examples/relying_party/urls.py, here.
- is_active, must set to True
An example of metadatahere
Now that you configured your Provider Entity you have to register it in the federation. Access to the Federation Authority admin backend and configure your RP as descendant and assign to it a profile. In the admin page of your Trust Anchor (http://127.0.0.1:8000/admin) create a descendant entity with the following paramenters:
- RP name
- sub (eg. 'http://127.0.0.1:[port]/oidc/rp')
- Jwks, public jwks, the public jwk of the private configurd in the FederationEntityConfiguration of the RP.
- is_active, must set to True
Then assign the profile, 'SPID Private SP'.
In relying_party service build trust chain for all the configure OpenID Connect Provider. These are configured in the parameter OIDCFED_IDENTITY_PROVIDERS
in settingslocal.py.
examples/relying_party/manage.py fetch_openid_providers --start -f
Connect to the login page specified in settingslocal.py by 'LOGIN_URL' parameter (eg. 'http://127.0.0.1:[port]/oidc/rp/landing' where 'LOGIN_URL=/oidc/rp/landing') and start authentication.