Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/KantaraInitiative/wg-otto


https://github.com/KantaraInitiative/wg-otto

Last synced: 3 months ago
JSON representation

Awesome Lists containing this project

README

        

# Open Trust Taxonomy for Federation Operators

Table of Contents
=================

* [Abstract](#abstract)
* [Definitions](#definitions)
* [Schema](#schema)
* [Discovery Endpoint](#discovery-endpoint)
* [federations endpoint](#federations-endpoint)
* [Search Federations (GET)](#search-federations-get)
* [Create (POST)](#create-post)
* [Update (PUT)](#update-put)
* [Delete (DELETE)](#delete-delete)
* [Join federation (POST)](#join-federation-post)
* [Leave federation (DELETE)](#leave-federation-delete)
* [entity endpoint](#entity-endpoint)
* [Fetch (GET)](#fetch-get)
* [Create (POST)](#create-post-1)
* [Update (PUT)](#update-put-1)
* [Delete (DELETE)](#delete-delete-1)
* [partcipant endpoint](#participant-endpoint)
* [Create (POST)](#create-post-3)
* [Update (PUT)](#update-put-3)
* [Delete (DELETE)](#delete-delete-3)
* [Appendix A](#appendix-a)
* [Search federations endpoint : /federations/<federation id>?depth=1](#search-federations-endpoint--federationsfederation-iddepthfederations)
* [Search federations endpoint : /federations/<federation id>?depth=1&filter=<filter>](#search-federations-endpoint--federationsfederation-iddepth1filterfilter)
* [Questions](#questions)
* [More Info](#more-info)

## 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](https://raw.githubusercontent.com/KantaraInitiative/wg-otto/master/docs/proposal/otto_overview.png "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.

## [Configuration Endpoint](#endpoint-discovery)

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](https://tools.ietf.org/html/rfc5785)
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](https://github.com/dfilatov/jspath).
* 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:**
```json
{
"@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:**
```json
{
"@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",

}
}
```

### Create (POST)

**Request:**
```json
POST /federation
{
"name":"MyFederation",

}
```

**Response:**
```json
HTTP/1.1 201 Created
Content-Type: application/json

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

### Update (PUT)

**Request:**
```json
PUT /federations/904cb092-c5a6-11e5-9912-ba0be0483c18 HTTP/1.1
{
"name":"MyFederation",

}
```

**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**
```json
POST /federation/ HTTP/1.1
{
"name":"MyEntity",

}
```

**Response**
```
HTTP/1.1 200 OK
```

### Join federation (POST)

Join the federation.

**Request**
```json
POST /federation// HTTP/1.1
```

**Response**
```
HTTP/1.1 200 OK
```

### Leave federation (DELETE)

Leave federation.

**Request**
```
DELETE /federation// HTTP/1.1
```

**Response**
```
HTTP/1.1 200 OK
```

### Add Participant

Join participant to a federation

**Request**
```
POST /federation//participant/ 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:**
```json
{
"@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:**
```json
POST /entity
{
"name":"MyFederationEntity",

}
```

**Response:**
```json
HTTP/1.1 201 Created
Content-Type: application/json

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

### Update (PUT)

**Request:**
```json
PUT /entity/ HTTP/1.1
{
"name":"MyEntity",

}
```

**Response:**
```
HTTP/1.1 200 OK
```

### Delete (DELETE)

**Request:**
```
DELETE /entity/ 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:**
```json
{
"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:**
```json
{
"@id":"https://ra.org/participant/904cb092-c5a6-11e5-9912-ba0be0483c18",
"@context": "https://schema.org", <- context of participant
"@type":"Participant",
"name":"MyParticipant",

}
```

### Create (POST)

**Request:**
```json
POST /participant
{
"name":"MyParticipant",

}
```

**Response:**
```json
HTTP/1.1 201 Created
Content-Type: application/json

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

### Update (PUT)

**Request:**
```json
PUT /participant/904cb092-c5a6-11e5-9912-ba0be0483c18 HTTP/1.1
{
"name":"MyParticipant",

}
```

**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:**
```json
{
"@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",

},
"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:**
```json
{
"@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",

}
}
```

(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

* [External extensions](http://schema.org/docs/extension.html)
* [JSON-LD basic concept](https://www.w3.org/TR/json-ld/#basic-concepts)