Skip to content

Latest commit

 

History

History
391 lines (249 loc) · 20.3 KB

authentication-for-opds-1.0.md

File metadata and controls

391 lines (249 loc) · 20.3 KB

Authentication for OPDS 1.0

This specification, Authentication for OPDS Catalogs (1.0), defines a standard way for OPDS Catalog providers and clients to:

  • provide relevant information for clients to display an authentication page
  • expose how a client can authenticate using various Authentication Flows

The primary objective is to allow access to specific feeds (such as bookshelf and subscriptions) along with support for interactions that require authentication (specific acquisition links such as buy, borrow and subscribe).

This version:

Editors:

  • Hadrien Gardeur

Participate:

Status of this Document

This document is a draft of the 1.0 version of the Authentication for OPDS specification.

1. Overview

1.1. Terminology

This specification uses the following terms from [OPDS]:

OPDS Catalog
All of the Atom Feeds (Acquisition and Navigation) and Entries (Partial and Complete) following this specification published together to describe a consolidated group of available Publications.
Acquisition Link
An atom:link element with a relation that begins with http://opds-spec.org/acquisition and refers to the Resource which holds the content of the described Publication or the Resource through which it may be acquired for any OPDS Catalog Entry. See the Sections Acquisition Relations and Acquiring Publications. They are serialized as OPDS Catalog Feed Documents.

In addition, it defines the following terms:

Authentication Document
A discovery document that indicates which Authentication Flows are supported, how to interact with them, and what should be displayed to the user.
Authentication Flow
A series of steps necessary to authenticate the user.
Authentication Page
A page that contains various information provided by the Authentication Document along with input fields based on the Authentication Flow.
Authentication Provider
A server that supports one or more Authentication Flows to authenticate a client.

1.2. Notational Conventions

The keywords must, must not, required, shall, shall not, should, should not, recommended, may, and optional in this document are to be interpreted as described in [RFC2119].

All sections of this specification are normative except where identified by the informative status label "This section is informative". The application of informative status to sections and appendices applies to all child content and subsections they may contain.

All examples in this specification are informative.

2. Authentication Document

2.1. Introduction

This section is informative.

The Authentication Document is essentially a service discovery document.

Part of its content is meant to identify how a client will authenticate a user with a Catalog provider:

  • a list of supported Authentication Flows
  • locations where specific interactions can be made
  • a unique identifier for the Catalog

The rest of its content is meant to be displayed to the user:

  • title of the service
  • a logo
  • a text prompt
  • alternate labels for fields that will be displayed
  • a registration link
  • resources where the user can get support

2.2. Content Conformance

An Authentication Document must meet all of the following criteria:

  • It must meet the conformance constraints for JSON documents as defined in [RFC4627].
  • It must parse as a single JSON object.
  • It must be encoded using UTF-8.

Access to an Authentication Document must not require any form of authentication.

The MIME media type for an Authentication Document is application/opds-authentication+json, and HTTP servers must set the Content-Type header appropriately.

2.3. Syntax

2.3.1. Core Properties

The Authentication Document must contain the following keys:

Key Definition Format
authentication A list of supported Authentication Flows as defined in section 3. Authentication Flows. Authentication Object
title Title of the Catalog being accessed. String
id Unique identifier for the Catalog provider and canonical location for the Authentication Document. URL

In addition, the Authentication Document may contain the key:

Key Definition Format
description A description of the service being displayed to the user. String

2.3.2. Links

An Authentication Document may also contain a links object.

This is used to associate the Authentication Document with resources that are not locally available.

The links object contains one or more link with the following keys:

Key Definition Format Required?
href URI or URI template of the linked resource URI or URI template Yes
templated Indicates that href is a URI template Boolean, defaults to false Only when href is a URI template
type Media type of the linked resource MIME Media Type No
title Title of the linked resource String No
rel Relation between the resource and its containing collection One or more Link Relations No
height Height of the linked resource in pixels Integer No
width Width of the linked resource in pixels Integer No
duration Duration of the linked resource in seconds Float No
bitrate Bit rate of the linked resource in kilobits per second Float No

This specification introduces the following link relations:

Relation Definition Required?
logo Logo associated to the Catalog provider. No
register Location where a user can register. No
help Support resources for the user (either a website, an email or a telephone number). No

Link relations may also be extended for vendor-specific applications. Such links must use a URL instead of a string to identify their link relations.

2.3.3. Example

This section is informative.

In the following example, the Authentication Document indicates that the Catalog can support two Authentication Flows: Basic Auth and OAuth 2.0 through an implicit grant.

{
  "id": "http://example.com/auth.json",
  "title": "Public Library",
  "description": "Enter a valid library card number and PIN code to authenticate on our service.",
  "links": [
    {"rel": "logo", "href": "http://example.com/logo.jpg", "type": "image/jpeg", "width": 90, "height": 90},
    {"rel": "help", "href": "mailto:[email protected]"},
    {"rel": "help", "href": "tel:1800836482"},
    {"rel": "help", "href": "http://example.com/support", "type": "text/html"},
    {"rel": "register", "href": "http://example.com/registration", "type": "text/html"}
  ],
  "authentication": [
    {
      "type": "http://opds-spec.org/auth/basic",
      "labels": {
        "login": "Library card",
        "password": "PIN"
      }
    },
    {
      "type": "http://opds-spec.org/auth/oauth/implicit",
      "links": [
        {"rel": "authenticate", "href": "http://example.com/oauth", "type": "text/html"}
      ]
    }
  ]
}

2.4. Authentication Provider

In order to require the client to authenticate, an Authentication Provider must send a 401 Unauthorized HTTP status code.

In this context, the Authentication Provider must also serve the Authentication Document as the content of the response along with the proper MIME media type (application/opds-authentication+json) in its Content-Type header.

The Authentication Provider may also use the Link header from [RFC5988] to indicate the location of the Authentication Document. The link-value must be identified by:

  • the http://opds-spec.org/auth/document relationship
  • the application/opds-authentication+json media type

Example: Discovery using the Link header in HTTP

GET /resource HTTP/1.1
Link: <http://example.com/auth_document>;                              
         rel="http://opds-spec.org/auth/document";
         type="application/opds-authentication+json"

2.5. Client

An OPDS client must detect the presence of an Authentication Document, no matter whether it is served as the Content of an HTTP response, or in the Link header.

Once the client detects the Authentication Document, it must select and trigger a specific Authentication Flow listed in the Authentication Document.

For some Authentication Flows, the client must display an Authentication Page.

An Authentication Page must display all the information provided in the Authentication Document.

3. Authentication Flows

In addition to the Authentication Document, this specification also defines multiple scenarios to handle how the client is authenticated.

3.1. Authentication Object

Each Authentication Document contains at least one Authentication Object that describes how a client can leverage an Authentication Flow.

The Authentication Object must contain at least a type.

Key Definition Format
type A URI that identifies the nature of an Authentication Flow. URI

3.1.1. Labels

An Authentication Object may also include a labels object.

The labels object is meant to provide alternate labels for fields that the client will display to the user. All alternate labels must be provided as a string.

It may contain the following keys:

Key Definition Authentication Flows
login Alternate label for a login. Basic Authentication & OAuth with Resource Owner Password Credentials Grant
password Alternate label for a password. Basic Authentication & OAuth with Resource Owner Password Credentials Grant

3.1.2. Links

An Authentication Object may also include a links object using the same syntax as defined in 2.3.2. Links.

The following link relations are defined in this context:

Relation Definition Required?
authenticate Location where a client can authenticate the user with OAuth. Yes if the Authentication Flow list contains OAuth
refresh Location where a client can refresh the Access Token by sending a Refresh Token. No

3.2. Use of TLS

All resources must use Transport Layout Security (TLS) during each step of an Authentication Flow.

Implementations may also support additional transport-layer security mechanisms that meet their security requirements.

3.3. Basic Authentication

In order to identify the use of Basic Authentication as defined in [RFC2617], this specification defines a new type value:

Value Scope
http://opds-spec.org/auth/basic The type object as defined in 3.1. Authentication Object

A client that detects and decides to use Basic Authentication as an Authentication Flow for a catalog must display an Authentication Page containing all the information available in the Authentication Document. The Authentication Page must contain two input fields for the username and password. If the Authentication Document includes alternate labels, the Authentication Page must display these labels next to the input fields.

An OPDS client may store these credentials for future use, but should make its best efforts to protect them.

Basic Authentication is weaker than the other Authentication Flows exposed in this specification, and exposes the client and resource owner to a higher risk. For this reason, both Authentication Provider and client should minimize use of this Authentication Flow and utilize other Authentication Flows whenever possible.

3.4. OAuth 2.0

3.4.1. Introduction

This section is informative.

The OAuth 2.0 Authorization Framework is widely used to grant access to protected resources.

It defines several Authentication Flows (called authorization grant types in the OAuth specification) that all follow the same principle: in exchange for an authorization grant, the client receives a token to access protected resources.

This specification defines how a sub-set of OAuth 2.0 (a limited set of authorization grant types) can be used as Authentication Flows. In addition to limiting the scope of OAuth 2.0, this specification also adds support for endpoint discovery through the use of the Authentication Document.

3.4.2. A Shared Client Identifier

While OAuth favors client registration, the OPDS ecosystem favors discovery and maximum interoperability instead.

For this reason, any Authentication Provider that supports OPDS Authentication 1.0 and exposes an Authentication Flow based on OAuth must identify all OPDS clients using the following information :

Name Identifier Callback URI
OPDS client http://opds-spec.org/auth/client opds://authorize/

The unique identifier used in the callback URI must have the same value as the identifier provided in the Authentication Document.

Specific OPDS clients may also be registered by each Catalog, in order to be further identified.

3.4.3. Bearer Token

All of the OAuth-based Authentication Flows described in this document rely on the Authorization header field in HTTP to transmit an Access Token as described in section 2.1. Authorization Request Header Field of [RFC6750].

Using a Bearer token to transmit an Access Token.

GET /resource HTTP/1.1
Host: server.example.com
Authorization: Bearer mF_9.B5f-4.1JqM

3.4.4. Security Considerations

All clients and Authentication Providers should follow the security considerations as detailed in:

3.4.5. Implicit Grant

In order to identify the use of an Implicit Grant Authentication Flow (as defined in [RFC6749] in section 4.2. Implicit Grant), this specification defines a new type value:

Value Scope
http://opds-spec.org/auth/oauth/implicit The type object as defined in 3.1. Authentication Object

A valid Authentication Object that lists the Implicit Grant as an available Authentication Flow must also include a link identified by the authenticate relationship.

If a client detects and decides to use this Authentication Flow, it must not display an Authentication Page. Instead, it must redirect the user to a webview or browser to the location indicated in the link identified by the authenticate relationship.

If the authentication is successful, the Authentication Provider must provide an Access Token Response with the following restrictions:

  • it must use the OPDS callback URI as described in 3.5.2. A Shared Client Identifier
  • it must follow the requirements from the [RFC6749] specification as described in 4.2.2. Access Token Response
  • it must use the id query parameter to indicate the Authentication Document identifier
  • it must use bearer as the value for the token_type query parameter

Example of an OPDS callback containing an Access Token

opds://authorize/?id=http%3A%2F%2Fexample.org%2Fauth.json&access_token=9b3dc428-df5f-4bd2-9f0d-72497cbf8464&token_type=bearer

An OPDS client can then associate this Access Token to an OPDS Catalog and its Authentication Provider using the unique identifier.

Upon receiving this Access Token, the client should attempt to authenticate on the same resource that initially prompted the Authentication Document.

3.4.6. Resource Owner Password Credentials Grant

In order to identify the use of a Resource Owner Password Credentials Grant Authentication Flow (as defined in [RFC6749] in section 4.3. Resource Owner Password Credentials Grant), this specification defines defines a new type value:

Value Scope
http://opds-spec.org/auth/oauth/password The type object as defined in 3.1. Authentication Object

A valid Authentication Object that lists the Resource Owner Password Credentials Grant as an available Authentication Flow must also include an authenticate link. It may also include a refresh link if the Authentication Provider includes a Refresh Token in its Response Document.

A client that detects and decides to use Resource Owner Password Credentials as an Authentication Flow for a catalog must display an Authentication Page containing all the information available in the Authentication Document.

The Authentication Page must contain two input fields for the username and password. If the Authentication Document includes alternate labels, the Authentication Page must display these labels next to the input fields.

An OPDS client must not store these credentials for future use.

In case of a successful request, the OAuth Response Document must return an Access Token as a bearer token.

3.4.7. OAuth Response Document

We'll define additional information that can show up in the document (such as LCP Keys or Vendor ID account).

4. Extensibility

All extensions identified by URIs (for types, labels and for link relationships)

5. References

5.1. Normative References

Appendix A. JSON Schema

A JSON Schema is available under version control at https://github.com/opds-community/drafts/blob/master/schema/authentication.schema.json

For the purpose of validating an OPDS Authentication Document, use the following URL: https://drafts.opds.io/schema/authentication.schema.json