Created
June 13, 2016 17:25
-
-
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)
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| 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