Skip to content

Latest commit

 

History

History
149 lines (112 loc) · 4.46 KB

COMPLIANCE.md

File metadata and controls

149 lines (112 loc) · 4.46 KB

DRAFT: How to conform API specs?

To conform your API to the specs, just start creating an openapi-v3 specification file.

Expose OpenAPI v3 specs

If you don't use swagger

Check the API samples and write your own specs.

If you use swagger

Add as much informations as possible to swagger v2 specs, and we'll convert to v3 after with swaggerhub or mermade.

https://mermade.org.uk/api/v1/convert?url=$YOUR_SWAGGER_URL

Required informations

We expect every API specifies

info:
  version: "0.0.1"
  title: |
    Just an API
  x-summary: An one-liner headline to be used in catalogs.
  description: |
    A short description of the application.
    [CommonMark](http://spec.commonmark.org/) syntax
    *MAY* be used for rich text representation.

    The `x-api-id` *MUST* be an [UUID](https://en.wikipedia.org/wiki/Universally_unique_identifier).
  termsOfService: 'https://en.wikipedia.org/wiki/Terms_of_service'
  contact:
    email: [email protected]
    name: Roberto Polli
    url: 'https://twitter.com/ioggstream'
  x-audience: |
    Definire qui l'audience delle API
  x-api-id: b9ec7026-5da5-4db6-a959-fce72db5de64
  license:
    name: Apache 2.0
    url: 'http://www.apache.org/licenses/LICENSE-2.0.html'

Use Problem.Json for errors

Every error should be packed in a RFC7807 object

The schema is defined here https://teamdigitale.github.io/openapi/0.0.5/definitions.yaml and can be referenced directly by your API. Eg.

components:
  schemas:
    Problem:
      $ref: 'https://teamdigitale.github.io/openapi/0.0.5/definitions.yaml#/schemas/Problem'

Throttle clients

Your API should throttle clients always returning the following headers.

  headers:
    # Headers conform to http://lg-modellointeroperabilita.readthedocs.io/it/latest/doc/doc_02_cap_04.html#throttling-ed-indisponibilita-del-servizio
    X-RateLimit-Limit:
      $ref: 'https://teamdigitale.github.io/openapi/0.0.5/definitions.yaml#/headers/X-RateLimit-Limit'
    X-RateLimit-Remaining:
      $ref: 'https://teamdigitale.github.io/openapi/0.0.5/definitions.yaml#/headers/X-RateLimit-Remaining'
    X-RateLimit-Reset:
      $ref: 'https://teamdigitale.github.io/openapi/0.0.5/definitions.yaml#/headers/X-RateLimit-Reset'

You can use the pre-built responses in errors.

# https://teamdigitale.github.io/openapi/responses/v3.yaml#/429TooManyRequests
429TooManyRequests:
  description: Too many requests
  headers:
    X-RateLimit-Limit:
      $ref: 'https://teamdigitale.github.io/openapi/0.0.5/definitions.yaml#/headers/X-RateLimit-Limit'
    X-RateLimit-Remaining:  
      $ref: 'https://teamdigitale.github.io/openapi/0.0.5/definitions.yaml#/headers/X-RateLimit-Remaining'
    X-RateLimit-Reset:
      $ref: 'https://teamdigitale.github.io/openapi/0.0.5/definitions.yaml#/headers/X-RateLimit-Reset'
    Retry-After:
      $ref: 'https://teamdigitale.github.io/openapi/0.0.5/definitions.yaml#/headers/Retry-After'
  content:
    application/problem+json:
      schema:
        $ref: 'https://teamdigitale.github.io/openapi/0.0.5/definitions.yaml#/schemas/Problem'

Use common parameters in requests

To ease API consumption, we standardize some request parameters.

Pagination

Pagination must be implemented with the following parameters:

  • limit: max number of entries returned
  • offset: offset from the first entries
  • cursor: replaces offset for cursor pagination, the key representing the first entry to return
  • sort: a list of sorting fields, use minus "-" for descending order

Use HTTP headers (etags) for Conditional requests

HTTP Headers for conditional requests are defined here:

# https://teamdigitale.github.io/openapi/0.0.5/definitions.yaml#/parameters
Etag:
  name: Etag
  description: |
    The RFC7232 ETag header field in a response provides the current entity-
    tag for the selected resource. An entity-tag is an opaque identifier for
    different versions of a resource over time, regardless whether multiple
    versions are valid at the same time. An entity-tag consists of an opaque
    quoted string, possibly prefixed by a weakness indicator.
  in: header
  example: W/"xy", "5", "7da7a728-f910-11e6-942a-68f728c1ba70"
  required: false
  schema:
    type: string
...

Use them when needed, eg

...
    parameters:
    - "$ref": "https://teamdigitale.github.io/openapi/0.0.5/definitions.yaml#/parameters/Etag"