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 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 security: - OauthSecurity: - user - LegacySecurity: [] 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. security: - OauthSecurity: - admin - LegacySecurity: [] 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 security: - OauthSecurity: - admin - LegacySecurity: [] 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 security: - MediaSecurity: [] 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