|
swagger: '2.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 |
|
consumes: |
|
- application/json |
|
- application/x-yaml |
|
produces: |
|
- application/json |
|
- application/x-yaml |
|
paths: |
|
/persons: |
|
parameters: |
|
- $ref: '#/parameters/userAgent' |
|
get: |
|
summary: Gets some persons |
|
description: Returns a list containing all persons. The list supports paging. |
|
parameters: |
|
- $ref: '#/parameters/pageSize' |
|
- $ref: '#/parameters/pageNumber' |
|
- $ref: '#/parameters/includeNonVerifiedUsers' |
|
- $ref: '#/parameters/sortPersons' |
|
responses: |
|
'200': |
|
description: A list of Person |
|
schema: |
|
$ref: '#/definitions/Persons' |
|
headers: |
|
X-Rate-Limit-Remaining: |
|
type: integer |
|
X-Rate-Limit-Reset: |
|
type: string |
|
format: date-time |
|
'500': |
|
$ref: '#/responses/Standard500ErrorResponse' |
|
default: |
|
$ref: '#/responses/TotallyUnexpectedResponse' |
|
post: |
|
summary: Creates a person |
|
description: Adds a new person to the persons list. |
|
parameters: |
|
- name: person |
|
in: body |
|
required: true |
|
description: The person to create. |
|
schema: |
|
$ref: '#/definitions/Person' |
|
responses: |
|
'204': |
|
description: Person succesfully created. |
|
headers: |
|
X-Rate-Limit-Remaining: |
|
type: integer |
|
X-Rate-Limit-Reset: |
|
type: string |
|
format: date-time |
|
'400': |
|
description: Person couldn't have been created. |
|
headers: |
|
X-Rate-Limit-Remaining: |
|
type: integer |
|
X-Rate-Limit-Reset: |
|
type: string |
|
format: date-time |
|
'500': |
|
$ref: '#/responses/Standard500ErrorResponse' |
|
default: |
|
$ref: '#/responses/TotallyUnexpectedResponse' |
|
/js-less-consumer-persons: |
|
parameters: |
|
- $ref: '#/parameters/userAgent' |
|
post: |
|
summary: Creates a person |
|
description: For JS-less partners |
|
consumes: |
|
- application/x-www-form-urlencoded |
|
produces: |
|
- text/html |
|
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: |
|
'204': |
|
description: Person succesfully created. |
|
headers: |
|
X-Rate-Limit-Remaining: |
|
type: integer |
|
X-Rate-Limit-Reset: |
|
type: string |
|
format: date-time |
|
'400': |
|
description: Person couldn't have been created. |
|
headers: |
|
X-Rate-Limit-Remaining: |
|
type: integer |
|
X-Rate-Limit-Reset: |
|
type: string |
|
format: date-time |
|
'500': |
|
description: An error occured. |
|
headers: |
|
X-Rate-Limit-Remaining: |
|
type: integer |
|
X-Rate-Limit-Reset: |
|
type: string |
|
format: date-time |
|
default: |
|
$ref: '#/responses/TotallyUnexpectedResponse' |
|
'/persons/{username}': |
|
parameters: |
|
- $ref: '#/parameters/username' |
|
- $ref: '#/parameters/userAgent' |
|
get: |
|
summary: Gets a person |
|
description: Returns a single person for its username. |
|
responses: |
|
'200': |
|
description: A Person |
|
schema: |
|
$ref: '#/definitions/Person' |
|
headers: |
|
X-Rate-Limit-Remaining: |
|
type: integer |
|
X-Rate-Limit-Reset: |
|
type: string |
|
format: date-time |
|
'404': |
|
$ref: '#/responses/PersonDoesNotExistResponse' |
|
'500': |
|
$ref: '#/responses/Standard500ErrorResponse' |
|
default: |
|
$ref: '#/responses/TotallyUnexpectedResponse' |
|
delete: |
|
summary: Deletes a person |
|
description: Delete a single person identified via its username |
|
responses: |
|
'204': |
|
description: Person successfully deleted. |
|
headers: |
|
X-Rate-Limit-Remaining: |
|
type: integer |
|
X-Rate-Limit-Reset: |
|
type: string |
|
format: date-time |
|
'404': |
|
$ref: '#/responses/PersonDoesNotExistResponse' |
|
'500': |
|
$ref: '#/responses/Standard500ErrorResponse' |
|
default: |
|
$ref: '#/responses/TotallyUnexpectedResponse' |
|
'/persons/{username}/friends': |
|
parameters: |
|
- $ref: '#/parameters/username' |
|
- $ref: '#/parameters/userAgent' |
|
get: |
|
summary: Gets a person's friends |
|
description: Returns a list containing all persons. The list supports paging. |
|
parameters: |
|
- $ref: '#/parameters/pageSize' |
|
- $ref: '#/parameters/pageNumber' |
|
- $ref: '#/parameters/includeNonVerifiedUsers' |
|
- $ref: '#/parameters/sortPersons' |
|
responses: |
|
'200': |
|
description: A person's friends list |
|
schema: |
|
$ref: '#/definitions/PagedPersons' |
|
headers: |
|
X-Rate-Limit-Remaining: |
|
type: integer |
|
X-Rate-Limit-Reset: |
|
type: string |
|
format: date-time |
|
'404': |
|
$ref: '#/responses/PersonDoesNotExistResponse' |
|
'500': |
|
$ref: '#/responses/Standard500ErrorResponse' |
|
default: |
|
$ref: '#/responses/TotallyUnexpectedResponse' |
|
'/persons/{username}/collecting-items': |
|
parameters: |
|
- $ref: '#/parameters/username' |
|
- $ref: '#/parameters/userAgent' |
|
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: '#/parameters/pageSize' |
|
- $ref: '#/parameters/pageNumber' |
|
- $ref: '#/parameters/filterItemTypes' |
|
responses: |
|
'200': |
|
description: A collected items list |
|
schema: |
|
$ref: '#/definitions/PagedCollectingItems' |
|
headers: |
|
X-Rate-Limit-Remaining: |
|
type: integer |
|
X-Rate-Limit-Reset: |
|
type: string |
|
format: date-time |
|
'404': |
|
$ref: '#/responses/PersonDoesNotExistResponse' |
|
'500': |
|
$ref: '#/responses/Standard500ErrorResponse' |
|
default: |
|
$ref: '#/responses/TotallyUnexpectedResponse' |
|
/images: |
|
parameters: |
|
- $ref: '#/parameters/userAgent' |
|
post: |
|
summary: Uploads an image |
|
consumes: |
|
- multipart/form-data |
|
parameters: |
|
- name: image |
|
in: formData |
|
type: file |
|
responses: |
|
'200': |
|
description: Image's ID |
|
schema: |
|
properties: |
|
imageId: |
|
type: string |
|
headers: |
|
X-Rate-Limit-Remaining: |
|
type: integer |
|
X-Rate-Limit-Reset: |
|
type: string |
|
format: date-time |
|
'500': |
|
$ref: '#/responses/Standard500ErrorResponse' |
|
default: |
|
$ref: '#/responses/TotallyUnexpectedResponse' |
|
/images/{imageId}: |
|
parameters: |
|
- $ref: '#/parameters/userAgent' |
|
get: |
|
summary: Gets an image |
|
parameters: |
|
- name: imageId |
|
in: path |
|
required: true |
|
type: string |
|
produces: |
|
- image/png |
|
- image/gif |
|
- image/jpeg |
|
- application/json |
|
- application/x-yaml |
|
responses: |
|
'200': |
|
description: The image |
|
headers: |
|
X-Rate-Limit-Remaining: |
|
type: integer |
|
X-Rate-Limit-Reset: |
|
type: string |
|
format: date-time |
|
'404': |
|
description: Image do not exists |
|
headers: |
|
X-Rate-Limit-Remaining: |
|
type: integer |
|
X-Rate-Limit-Reset: |
|
type: string |
|
format: date-time |
|
'500': |
|
$ref: '#/responses/Standard500ErrorResponse' |
|
default: |
|
$ref: '#/responses/TotallyUnexpectedResponse' |
|
|
|
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: '#/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: '#/definitions/Person' |
|
ErrorMessage: |
|
required: |
|
- longMessage |
|
- shortMessage |
|
properties: |
|
longMessage: |
|
type: string |
|
shortMessage: |
|
type: string |
|
MultilingualErrorMessage: |
|
additionalProperties: |
|
$ref: '#/definitions/ErrorMessage' |
|
properties: |
|
defaultLanguage: |
|
$ref: '#/definitions/ErrorMessage' |
|
Error: |
|
required: |
|
- code |
|
- message |
|
properties: |
|
code: |
|
type: string |
|
enum: |
|
- DBERR |
|
- NTERR |
|
- UNERR |
|
message: |
|
$ref: '#/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: '#/definitions/CollectingItem' |
|
- required: |
|
- albumName |
|
- artist |
|
properties: |
|
albumName: |
|
type: string |
|
artist: |
|
type: string |
|
VHS: |
|
allOf: |
|
- $ref: '#/definitions/CollectingItem' |
|
- required: |
|
- movieTitle |
|
properties: |
|
movieTitle: |
|
type: string |
|
director: |
|
type: string |
|
AudioCassette: |
|
allOf: |
|
- $ref: '#/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: '#/definitions/Persons' |
|
- $ref: '#/definitions/Paging' |
|
PagedCollectingItems: |
|
allOf: |
|
- properties: |
|
items: |
|
type: array |
|
minItems: 10 |
|
maxItems: 100 |
|
uniqueItems: true |
|
items: |
|
$ref: '#/definitions/CollectingItem' |
|
- $ref: '#/definitions/Paging' |
|
responses: |
|
Standard500ErrorResponse: |
|
description: An unexpected error occured. |
|
headers: |
|
X-Rate-Limit-Remaining: |
|
type: integer |
|
X-Rate-Limit-Reset: |
|
type: string |
|
format: date-time |
|
schema: |
|
$ref: '#/definitions/Error' |
|
PersonDoesNotExistResponse: |
|
description: Person does not exist. |
|
headers: |
|
X-Rate-Limit-Remaining: |
|
type: integer |
|
X-Rate-Limit-Reset: |
|
type: string |
|
format: date-time |
|
TotallyUnexpectedResponse: |
|
description: A totally unexpected response |
|
headers: |
|
X-Rate-Limit-Remaining: |
|
type: integer |
|
X-Rate-Limit-Reset: |
|
type: string |
|
format: date-time |
|
|
|
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 |