Skip to content

Instantly share code, notes, and snippets.

@arno-di-loreto
Created June 13, 2016 17:25
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save arno-di-loreto/707f15ff819428bdbd7a3acab3bc8333 to your computer and use it in GitHub Desktop.
Save arno-di-loreto/707f15ff819428bdbd7a3acab3bc8333 to your computer and use it in GitHub Desktop.
OpenAPI 3.0 proposal - Structural improvements: inheritance on paths and its sublevels (cf. https://github.com/OAI/OpenAPI-Specification/issues/684)
version: '3.0'
info:
version: 1.1.0
title: Simple API
description: A simple API to learn how to write OpenAPI Specification
schemes:
- https
host: simple.api
basePath: /openapi101
paths:
shared:
security:
- $ref: '#/allDefinitions/securityDefinitionsOauthSecurity'
- user
- $ref: '#/allDefinitions/securityLegacySecurity'
consumes:
- application/json
- application/x-yaml
produces:
- application/json
- application/x-yaml
parameters:
- $ref: '#/allDefinitions/parameters/userAgent'
responseHeaders:
X-Rate-Limit-Remaining:
type: integer
X-Rate-Limit-Reset:
type: string
format: date-time
responses:
'500':
$ref: '#/allDefinitions/responses/Standard500ErrorResponse'
default:
$ref: '#/allDefinitions/responses/TotallyUnexpectedResponse'
/persons:
get:
summary: Gets some persons
description: Returns a list containing all persons. The list supports paging.
parameters:
- $ref: '#/allDefinitions/parameters/pageSize'
- $ref: '#/allDefinitions/parameters/pageNumber'
- $ref: '#/allDefinitions/parameters/includeNonVerifiedUsers'
- $ref: '#/allDefinitions/parameters/sortPersons'
responses:
'200':
description: A list of Person
schema:
$ref: '#/allDefinitions/definitions/Persons'
post:
summary: Creates a person
description: Adds a new person to the persons list.
security:
- OauthSecurity:
- admin
- LegacySecurity: []
parameters:
- name: person
in: body
required: true
description: The person to create.
schema:
$ref: '#/allDefinitions/definitions/Person'
responses:
'204':
description: Person succesfully created.
'400':
description: Person couldn't have been created.
/js-less-consumer-persons:
post:
summary: Creates a person
description: For JS-less partners
security:
- OauthSecurity:
- admin
- LegacySecurity: []
consumes:
- application/x-www-form-urlencoded
parameters:
- name: username
in: formData
required: true
pattern: '[a-z0-9]{8,64}'
minLength: 8
maxLength: 64
type: string
- name: firstname
in: formData
type: string
- name: lastname
in: formData
type: string
- name: dateOfBirth
in: formData
type: string
format: date
responses:
shared:
produces:
- text/html
responseHeaders:
X-PARTNER-HEADER:
description: a dummy header returned by all post /js-less-consumers-persons responses
type: string
'204':
description: Person succesfully created.
'400':
description: Person couldn't have been created.
'/persons/{username}':
shared:
parameters:
- $ref: '#/allDefinitions/parameters/username'
responses:
'404':
$ref: '#/allDefinitions/responses/PersonDoesNotExistResponse'
get:
summary: Gets a person
description: Returns a single person for its username.
responses:
'200':
description: A Person
schema:
$ref: '#/allDefinitions/definitions/Person'
delete:
summary: Deletes a person
description: Delete a single person identified via its username
responses:
'204':
description: Person successfully deleted.
'/persons/{username}/friends':
shared:
parameters:
- $ref: '#/allDefinitions/parameters/username'
responses:
'404':
$ref: '#/allDefinitions/responses/PersonDoesNotExistResponse'
get:
summary: Gets a person's friends
description: Returns a list containing all persons. The list supports paging.
parameters:
- $ref: '#/allDefinitions/parameters/pageSize'
- $ref: '#/allDefinitions/parameters/pageNumber'
- $ref: '#/allDefinitions/parameters/includeNonVerifiedUsers'
- $ref: '#/allDefinitions/parameters/sortPersons'
responses:
'200':
description: A person's friends list
schema:
$ref: '#/allDefinitions/definitions/PagedPersons'
'/persons/{username}/collecting-items':
shared:
parameters:
- $ref: '#/allDefinitions/parameters/username'
responses:
'404':
$ref: '#/allDefinitions/responses/PersonDoesNotExistResponse'
get:
summary: Gets a person's collecting items list
description: >-
Returns a list containing all items this person is looking for. The list
supports paging.
parameters:
- $ref: '#/allDefinitions/parameters/pageSize'
- $ref: '#/allDefinitions/parameters/pageNumber'
- $ref: '#/allDefinitions/parameters/filterItemTypes'
responses:
'200':
description: A collected items list
schema:
$ref: '#/allDefinitions/definitions/PagedCollectingItems'
/images:
post:
summary: Uploads an image
security:
- MediaSecurity: []
consumes:
- multipart/form-data
parameters:
- name: image
in: formData
type: file
responses:
'200':
description: Image's ID
schema:
properties:
imageId:
type: string
/images/{imageId}:
get:
summary: Gets an image
parameters:
- name: imageId
in: path
required: true
type: string
responses:
'200':
description: The image
produces:
- image/png
- image/gif
- image/jpeg
allDefinitions:
securityDefinitions:
OauthSecurity:
type: oauth2
flow: accessCode
authorizationUrl: 'https://oauth.simple.api/authorization'
tokenUrl: 'https://oauth.simple.api/token'
scopes:
admin: Admin scope
user: User scope
MediaSecurity:
type: apiKey
in: query
name: media-api-key
LegacySecurity:
type: basic
definitions:
Person:
required:
- username
properties:
firstName:
type: string
lastName:
type: string
username:
type: string
pattern: '[a-z0-9]{8,64}'
minLength: 8
maxLength: 64
dateOfBirth:
type: string
format: date
lastTimeOnline:
type: string
format: date-time
readOnly: true
avatarBase64PNG:
type: string
format: byte
default: 
spokenLanguages:
$ref: '#/allDefinitions/definitions/SpokenLanguages'
SpokenLanguages:
additionalProperties:
type: string
properties:
defaultLanguage:
type: string
default: english
Persons:
required:
- items
properties:
items:
type: array
minItems: 10
maxItems: 100
uniqueItems: true
items:
$ref: '#/allDefinitions/definitions/Person'
ErrorMessage:
required:
- longMessage
- shortMessage
properties:
longMessage:
type: string
shortMessage:
type: string
MultilingualErrorMessage:
additionalProperties:
$ref: '#/allDefinitions/definitions/ErrorMessage'
properties:
defaultLanguage:
$ref: '#/allDefinitions/definitions/ErrorMessage'
Error:
required:
- code
- message
properties:
code:
type: string
enum:
- DBERR
- NTERR
- UNERR
message:
$ref: '#/allDefinitions/definitions/MultilingualErrorMessage'
CollectingItem:
discriminator: itemType
required:
- itemType
properties:
itemType:
type: string
enum:
- AudioCassette
- Vinyl
- VHS
imageId:
type: string
maxPrice:
type: number
format: double
minimum: 0
maximum: 10000
exclusiveMinimum: true
exclusiveMaximum: false
Vinyl:
allOf:
- $ref: '#/allDefinitions/definitions/CollectingItem'
- required:
- albumName
- artist
properties:
albumName:
type: string
artist:
type: string
VHS:
allOf:
- $ref: '#/allDefinitions/definitions/CollectingItem'
- required:
- movieTitle
properties:
movieTitle:
type: string
director:
type: string
AudioCassette:
allOf:
- $ref: '#/allDefinitions/definitions/CollectingItem'
- required:
- albumName
- artist
properties:
albumName:
type: string
artist:
type: string
Paging:
required:
- totalItems
- totalPages
- pageSize
- currentPage
properties:
totalItems:
type: integer
totalPages:
type: integer
pageSize:
type: integer
currentPage:
type: integer
PagedPersons:
allOf:
- $ref: '#/allDefinitions/definitions/Persons'
- $ref: '#/allDefinitions/definitions/Paging'
PagedCollectingItems:
allOf:
- properties:
items:
type: array
minItems: 10
maxItems: 100
uniqueItems: true
items:
$ref: '#/allDefinitions/definitions/CollectingItem'
- $ref: '#/allDefinitions/definitions/Paging'
responses:
Standard500ErrorResponse:
description: An unexpected error occured.
schema:
$ref: '#/allDefinitions/definitions/Error'
PersonDoesNotExistResponse:
description: Person does not exist.
TotallyUnexpectedResponse:
description: A totally unexpected response
parameters:
username:
name: username
in: path
required: true
description: The person's username
type: string
pageSize:
name: pageSize
in: query
description: Number of persons returned
type: integer
format: int32
minimum: 0
exclusiveMinimum: true
maximum: 100
exclusiveMaximum: false
multipleOf: 10
default: 20
pageNumber:
name: pageNumber
in: query
description: Page number
type: integer
default: 1
includeNonVerifiedUsers:
name: includeNonVerifiedUsers
in: query
type: boolean
default: false
allowEmptyValue: true
sortPersons:
name: sort
in: query
type: array
uniqueItems: true
minItems: 1
maxItems: 3
collectionFormat: pipes
items:
type: string
pattern: '[-+](username|lastTimeOnline|firstname|lastname)'
default:
- -lastTimeOnline
- +username
filterItemTypes:
name: itemType
in: query
type: array
collectionFormat: multi
uniqueItems: true
items:
type: string
enum:
- AudioCassette
- Vinyl
- VHS
userAgent:
name: User-Agent
type: string
in: header
required: true
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment