Navigation Menu

Skip to content

KantaraInitiative/wg-otto

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Open Trust Taxonomy for Federation Operators

Table of Contents

Abstract

The Open Trust Taxonomy for Federation Operators (OTTO) is a set of API's and a linked data schema to enable the formation of multi-party federations--where a central authority creates the rules for membership, enabling the participants to more efficiently collaborate. The goal of OTTO is to support a range of trust models from very low to very high. By providing a framework for extension, in addition to a core set of functionality and schema, the OTTO standard provides a scalable technical infrastructure to solve organizational challenges in a number of different ecosystems.

Big picture

OTTO Vocabulary

JSON-LD definitions to model the ecosystem components.

The schema file is located at The classes defined by OTTO:https://github.com/KantaraInitiative/wg-otto/blob/master/schema/otto-schema.jsonld

  • Federation
  • Participant
  • RegistrationAuthority
  • Entity
  • OpenIDProvider
  • OpenIDRelyingParty

Properties Defined by OTTO:

  • operates

Endpoints

OTTO defines certain standard API's. These are described below.

Registration Authority have metadata describing their configuration. These Registration Authority Metadata values are used by OTTO:

  • issuer - REQUIRED. URL using the https scheme with no query or fragment component that the RA asserts as its Issuer Identifier.
  • federations_endpoint - REQUIRED.
  • entity_endpoint - REQUIRED.
  • participant_endpoint - REQUIRED.

Registration Authority MUST make a JSON document available at the path formed by concatenating the string /.well-known/otto-configuration to the Issuer. The syntax and semantics of .well-known are defined in RFC 5785 and apply to the Issuer value when it contains no path component. otto-configuration MUST point to a JSON document compliant with this specification and MUST be returned using the application/json content type.

Non-normative example request

GET /.well-known/otto-configuration HTTP/1.1
Host: ra.org

The response is a set of Claims about the RA's configuration, including all necessary endpoints and public key location information. A successful response MUST use the 200 OK HTTP status code and return a JSON object using the application/json content type that contains a set of Claims as its members that are a subset of the RA's Metadata values. Other Claims MAY also be returned. Claims that return multiple values are represented as JSON arrays. Claims with zero elements MUST be omitted from the response. An error response uses the applicable HTTP status code value.

Non-normative example response

HTTP/1.1 200 OK
Content-Type: application/json

{
   "issuer":"https://ra.com",
   "federations_endpoint":"https://ra.com/otto/federations",
   "entity_endpoint":"https://ra.com/otto/entity",
   "participant_endpoint":"https://ra.com/otto/participant"
}

federation endpoint

Search Federations (GET)

Endpoint to return federation metadata or federation IDs that are hosted by given server.

Request:

  • federation_id - OPTIONAL - id of federation.
  • entity_type - OPTIONAL - filter to return federation entities only of specific type. For example, an OpenID Connect OP implementation may only need to know about RP entities. Such an implementation is not interested in other OP's or SAML entities. Possible values:
    • connect_rp
    • connect_op
    • saml_idp
    • saml_rp
  • filter - OPTIONAL - expression to narrow the result set based on specific criteria. Expression is represented in jspath format.
  • depth - OPTIONAL - represents depth of graph resolving.

Requests:

  • /federation - returns federation IDs available from this Registration Authority
  • /federation/federation id - returns metadata of federation
  • /federation/federation id&entity_type=type - returns metadata of federation filtered by type.
  • /federation/federation id&filter=filter - returns filtered metadata
  • /federation/federation id&depth=1 - how many inter-federations deep to search

Federation list Request:

GET https://ra.org/federations HTTP/1.1

Federation list Response:

{
  "@context": "https://ra.org/schema/otto/federation_list",
  "federations": [
    "https://ra.org/federation/904ca9da-c5a6-11e5-9912-ba0be0483c18",
    "https://ra.org/federation/904cae1c-c5a6-11e5-9912-ba0be0483c18",
    "https://ra.org/federation/904cb092-c5a6-11e5-9912-ba0be0483c18"
  ]
}

Federation Request:

GET https://ra.org/federation/904cb092-c5a6-11e5-9912-ba0be0483c18&depth=entities HTTP/1.1

Federation Response:

{
  "@id":"https://ra.org/federation/904cb092-c5a6-11e5-9912-ba0be0483c18",
  "@context": "https://ra.org/schema/otto/federation.jsonld",                      <- context of federation
  "name": "Our Federation",                                                        <- name of federation
  "entities":[
            {                                                                      <- reference to entity
                        "@context": "https://ra.org/schema/otto/entity/connect_rp.jsonld",
                        "@id": "https://ra.org/entity/664cb092-c5a6-11e5-9912-ba0be0483c18",
                        "name": "Gluu Server Ce-dev Client",
                        "id":"https://ce-dev.gluu.org/rp",          <- in RP context it is redirect_uri
                        "participant":"https://gluu.org/otto/participant"
            },
            {
                         "@context": "https://ra.org/schema/otto/entity/connect_op.jsonld",
                         "@id": "https://ra.org/entity/554cb092-c5a6-11e5-9912-ba0be0483c18",
                         "name": "Gluu Server Ce-dev",
                         "id":"https://ce-dev.gluu.org"           <- in OP context it is URI
                         "participant":"https://gluu.org/otto/participant"
            },
            {
                         "@context": "https://ra.org/schema/otto/entity/uma_rs.jsonld",
                         "@id": "https://ra.org/entity/904cb092-c5a6-11e5-9912-ba0be0483c18",
                         "name": "Gluu Resource Server",
                         "id":"https://ce-dev.gluu.org/rs",          <- in RS context it is URI
                         "participant":"https://gluu.org/otto/participant"
            }
  ]
  "federations":[                                                                  <- reference to federation
                         "https://ra.org/federations/904cb092-c5a6-11e5-9912-ba0be0483c18"
           ],
  "participant": { 
                    "@id":"https://ra.org/participant/554cb092-c5a6-11e5-9912-ba0be0483c18"
                    "@context": "https://ra.org/schema/otto/participant.jsonld",   <- participant
                     "name":"MyParticipant",
                     <other properties here>
                  }
}

Create (POST)

Request:

POST /federation
{
   "name":"MyFederation",
   <other properties here>
}

Response:

HTTP/1.1 201 Created
Content-Type: application/json

{
   "@id":"https://ra.org/federation/904cb092-c5a6-11e5-9912-ba0be0483c18"
}

Update (PUT)

Request:

PUT /federations/904cb092-c5a6-11e5-9912-ba0be0483c18 HTTP/1.1
{
   "name":"MyFederation",
   <other properties here>
}

Response:

HTTP/1.1 200 OK

Delete (DELETE)

Request:

DELETE /federation/904cb092-c5a6-11e5-9912-ba0be0483c18 HTTP/1.1

Response:

HTTP/1.1 200 OK

Create and Join federation (POST)

Create entity and join to the federation.

Request

POST /federation/<federation_id> HTTP/1.1
{
   "name":"MyEntity",
   <other properties here>
}

Response

HTTP/1.1 200 OK

Join federation (POST)

Join the federation.

Request

POST /federation/<federation_id>/<entity_id> HTTP/1.1

Response

HTTP/1.1 200 OK

Leave federation (DELETE)

Leave federation.

Request

DELETE /federation/<federation_id>/<entity id> HTTP/1.1

Response

HTTP/1.1 200 OK

Add Participant

Join participant to a federation

Request

POST /federation/<federation_id>/participant/<participant_id> HTTP/1.1

Response

HTTP/1.1 200 OK

entity endpoint

Fetch (GET)

Entity Request:

GET https://ra.org/entity/194d8ab2-c5a7-11e5-9912-ba0be0483c18 HTTP/1.1

OpenID Connect OP Entity Response:

{
  "@context": "https://raw.githubusercontent.com/KantaraInitiative/wg-otto/master/schema/openid/op.jsonld",
  "@id": "http://otto-test.gluu.org/otto/entity/589b11017d85a90393b189c8",
  "name": "Local org",
  "metadata_statements": null,
  "metadata_statement_uris": null,
  "signed_jwks_uri": "eyJhbGciOiJSUzI1NiJ9.aHR0cHM6Ly9jZS1kZXYyLmdsdXUub3JnL294YXV0aC9zZWFtL3Jlc291cmNlL3Jlc3R2MS9veGF1dGgvandrcw.WUk3hUD2_rl-ivnawikRdiMZ47SVWWgqq9OzuDeBtWt1rkzLDr4aJ1845Y5J_NRCf70GAE36qO5h5JUiOc6oT2ZlTymn1LdYC0Iiwb9GgIVk6fE6gpUv3KXa2V2nwAqcSPsx5y-9f2-in02Qo7Q7Chyi7Z3jGl7-Cjjk-7nqlyoZfM89LF9Xrt2u-gcZKzWS_XJN3HZaWgGi_R0DJdEUA_uQVCyYPl32uz4mP4lwQU5uVpBuIWB3MEjrgeEIvuT4ZQDYmLkaMG-xOGP7F097A28Ws67L1pOxmaDdJwNmiFKIr4XXJUPqkWlEMUMpqQsF3Gx2coDj2vQXiLQ73ccOxQ",
  "signing_keys": "-----BEGIN RSA PUBLIC KEY-----\nMIIBCgKCAQEAgqWRHafvK4aEHm5I3yS2ie8s7NPtbt2m+q4h8J4uPdoINu0uzT6aYwjTNuL6\nL2TSzdJA1CIgo5Vc7IOSdMkoci1bVFa06sDisdoNbT7OgnkOq9oRZ7QrILJjsJNwVjkonXbF\ngQtEKvcuFBATTPBCSDjYawAovCC7CYUXqd0DTZZkgjh7Ps50oVMTbWcUxo8McoYeLTh2TRy3\n9+v32tnzgoHCdAnvadQ6EYAYqRj3UP0J74u0wJKO6DjvsDg3i1zMEx4zFqRODoa+G9qCX4D8\nYlyaM0jq9hzgGPVu75m5LLGEXgU4Xtsc3h4JBHhrFAALT2eqAFnRzuON7H7XH/XVaQIDAQAB\n-----END RSA PUBLIC KEY-----\n",
  "type": "openid_provider",
  "participant": "http://otto-test.gluu.org/otto/participant/589b0ff37d85a90393b189c7"
}

Create (POST)

Request:

POST /entity
{
   "name":"MyFederationEntity",
   <other properties here>
}

Response:

HTTP/1.1 201 Created
Content-Type: application/json

{
   "@id":"https://ra.org/entity/904cb092-c5a6-11e5-9912-ba0be0483c19"
}

Update (PUT)

Request:

PUT /entity/<entity id> HTTP/1.1
{
   "name":"MyEntity",
   <other properties here>
}

Response:

HTTP/1.1 200 OK

Delete (DELETE)

Request:

DELETE /entity/<entity id> HTTP/1.1

Response:

HTTP/1.1 200 OK

participant endpoint

Participants list Request:

GET https://ra.org/participant HTTP/1.1

Participants list Response:

{
  "participants": [
    "https://ra.org/participant/904ca9da-c5a6-11e5-9912-ba0be0483c18",
    "https://ra.org/participant/904cae1c-c5a6-11e5-9912-ba0be0483c18",
    "https://ra.org/participant/904cb092-c5a6-11e5-9912-ba0be0483c18"
  ]
}

Participant Request:

GET https://ra.org/participant/904cb092-c5a6-11e5-9912-ba0be0483c18 HTTP/1.1

Participant Response:

{
  "@id":"https://ra.org/participant/904cb092-c5a6-11e5-9912-ba0be0483c18",
  "@context": "https://schema.org",                      <- context of participant
  "@type":"Participant",
   "name":"MyParticipant",
   <other properties here>
}

Create (POST)

Request:

POST /participant
{
   "name":"MyParticipant",
   <other properties here>
}

Response:

HTTP/1.1 201 Created
Content-Type: application/json

{
   "@id":"https://ra.org/participant/904cb092-c5a6-11e5-9912-ba0be0483c18"
}

Update (PUT)

Request:

PUT /participant/904cb092-c5a6-11e5-9912-ba0be0483c18 HTTP/1.1
{
   "name":"MyParticipant",
   <other properties here>
}

Response:

HTTP/1.1 200 OK

Delete (DELETE)

Request:

DELETE /participant/904cb092-c5a6-11e5-9912-ba0be0483c18 HTTP/1.1

Response:

HTTP/1.1 200 OK

Appendix A

Search federations endpoint : /federations/<federation id>?depth=federations

All entities are resolved and federations link too with depth=federations

Federation Request:

GET https://ra.org/federations/904cb092-c5a6-11e5-9912-ba0be0483c18&depth=federations HTTP/1.1

Federation Response:

{
  "@id":"https://ra.org/federations/904cb092-c5a6-11e5-9912-ba0be0483c18",
  "@context": "https://ra.org/schema/otto/federation.jsonld",                      <- context of federation
  "name": "OAuth 2 Federation",                                                    <- name of federation
  "entities": [                                                                    <- reference to entity
           {
             "@context": "https://ra.org/schema/otto/entity/connect_rp.jsonld",
             "uri": "https://ra.org/entity/664cb092-c5a6-11e5-9912-ba0be0483c18",
             "name": "Gluu Server Ce-dev Client",
             "id":"https://ce-dev.gluu.org/rp",          <- in RP context it is redirect_uri
             "participant":"https://gluu.org/otto/participant"
           },
           {
             "@context": "https://ra.org/schema/otto/entity/uma_rs.jsonld",
             "uri": "https://ra.org/entity/114cb092-c5a6-11e5-9912-ba0be0483c18",
             "name": "Gluu Resource Server",
             "id":"https://ce-dev.gluu.org/rs",          <- in RS context it is URI
             "participant":"https://gluu.org/otto/participant"
           }
  ],
  "federations":[
         {
                 "@context": "https://ra.org/schema/otto/federation.jsonld",                      <- context of sub federation
                 "name": "OAuth 2 Federation of Gluu",                                          <- name of sub federation
                 "entities":[
                          {                                                                    <- reference to entity
                            "@context": "https://ra.org/schema/otto/entity/connect_rp.jsonld",
                            "@id": "https://ra.org/entity/134cb092-c5a6-11e5-9912-ba0be0483c18",
                            "name": "Gluu Server Ce-dev2 Client",
                            "id":"https://ce-dev2.gluu.org/rp",          <- in RP context it is redirect_uri
                            "participant":"https://gluu.org/otto/participant"
                          },
                          {
                            "@context": "https://ra.org/schema/otto/entity/uma_rs.jsonld",
                            "@id": "https://ra.org/entity/344cb092-c5a6-11e5-9912-ba0be0483c18",
                            "name": "Gluu Resource Server 2",
                            "id":"https://ce-dev2.gluu.org/rs",          <- in RS context it is URI
                            "participant":"https://gluu.org/otto/participant"
                          }
                 ]
                 "federation": [                                                                 <- reference to federation
                          "https://ra.org/federations/222cb092-c5a6-11e5-9912-ba0be0483c18"
                 ]
                 "participant": "https://gluu.org/otto/participant"
        }
  ],
  "participant": {
                    "@id":"https://ra.org/participant/222cb092-c5a6-11e5-9912-ba0be0483c18".
                    "@context": "https://ra.org/schema/otto/participant.jsonld",   <- participant
                     "name":"MyParticipant",
                     <other properties here>
                  },
  "participants": [
    "https://ra.org/participant/589b0ff37d85a90393b189c7"
  ]
}

Search federations endpoint : /federations/<federation id>?depth=federations&filter=<filter>

Returns only .entity.name attributes.

Federation Request:

GET https://ra.org/federations/904cb092-c5a6-11e5-9912-ba0be0483c18&filter=.entity.name HTTP/1.1

Federation Response:

{
  "@id":"https://ra.org/federations/904cb092-c5a6-11e5-9912-ba0be0483c18",
  "@context": "https://ra.org/schema/otto/federation.jsonld",                      <- context of federation
  "name": "OAuth 2 Federation",                                                    <- name of federation
  "entities": [
           {                                                                       <- reference to entity
             "name": "Gluu Server Ce-dev Client"
           },
           {
             "name": "Gluu Resource Server"
           },
           {
             "name": "Gluu Resource Server 2",
           }
   ],
  "federations":[                                                                  <- reference to federation
           "https://ra.org/federations/222cb092-c5a6-11e5-9912-ba0be0483c18"
  ],
  "participant": {
                    "@context": "https://ra.org/schema/otto/participant.jsonld",   <- participant
                     "name":"MyParticipant",
                     <other properties here>
                  }
}

(in case of multiple attributes specify multiple filter parameters as mentioned on wiki https://en.wikipedia.org/wiki/Query_string) &filter=.entity.name&filter=.entity.id

Open Questions

  • How are we going version federation metadata?
  • How are we going version entities?
  • Do we want to support custom entities?

More info

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published