Skip to content

Latest commit

 

History

History
186 lines (128 loc) · 7.21 KB

CREATE_A_FEDERATION.md

File metadata and controls

186 lines (128 loc) · 7.21 KB

Create a OpenID Connect Federation

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.

Create a Federation Authority via web

setup

  1. add spid_cie_oidc.entity and spid_cie_oidc.authority in settings.INSTALLED_APPS
  2. do migrations ./manage.py migrate
  3. create superuser ./manage.py createsuperuser, eg:
    • username: admin
    • password: oidcadmin
  4. 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

Create a Federation Descendant via web

To onboard a new entity in the federation you have to do the following steps:

configure descendants entities

  1. Click on Federation Entity Descendant and configure a descendant
  2. Click on Federation Entity Profile and create the desidered profiles and trust marks template
  3. 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.

profile A profile that may be assigned to a Relying Party.

profile An assigned profile to a Relying Party.

Create an Entity via API

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_marks_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"]

Create a Federation Descendant via API

see unit tests.

Register a Provider in the Federation

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

OP federation entity

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 as descendant

Then assign a profile, select 'Identity Provider'.

OP assigned profile

Create a Relying Party

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

RP federation entity

Register an entity as descendant

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

RP as descendant

Then assign the profile, 'SPID Private SP'.

RP assigned profile

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.