--- openapi: 3.0.0 info: description: 'This is a sample server Petstore server. You can find out more about Swagger at [http://swagger.io](http://swagger.io) or on [irc.freenode.net, #swagger](http://swagger.io/irc/). For this sample, you can use the api key `special-key` to test the authorization filters.' version: 1.0.0 title: Swagger Petstore termsOfService: http://swagger.io/terms/ contact: email: apiteam@swagger.io license: name: Apache 2.0 url: http://www.apache.org/licenses/LICENSE-2.0.html tags: - name: pet description: Everything about your Pets externalDocs: description: Find out more url: http://swagger.io - name: store description: Access to Petstore orders - name: user description: Operations about user externalDocs: description: Find out more about our store url: http://swagger.io paths: "/pet": post: tags: - pet summary: Add a new pet to the store description: '' operationId: addPet servers: - url: http://petstore.swagger.io/v2 requestBody: description: Pet object that needs to be added to the store required: true content: application/json: schema: type: object required: - name - photoUrls properties: id: type: integer format: int64 category: type: object properties: id: type: integer format: int64 name: type: string name: type: string example: doggie photoUrls: type: array items: type: string tags: type: array items: type: object properties: id: type: integer format: int64 name: type: string status: type: string description: pet status in the store enum: - available - pending - sold application/xml: schema: type: object required: - name - photoUrls properties: id: type: integer format: int64 category: type: object properties: id: type: integer format: int64 name: type: string xml: name: Category name: type: string example: doggie photoUrls: type: array xml: name: photoUrl wrapped: true items: type: string tags: type: array xml: name: tag wrapped: true items: type: object properties: id: type: integer format: int64 name: type: string xml: name: Tag status: type: string description: pet status in the store enum: - available - pending - sold xml: name: Pet responses: '405': description: Invalid input security: - petstore_auth: - write:pets - read:pets put: tags: - pet summary: Update an existing pet description: '' operationId: updatePet servers: - url: http://petstore.swagger.io/v2 requestBody: description: Pet object that needs to be added to the store required: true content: application/json: schema: type: object required: - name - photoUrls properties: id: type: integer format: int64 category: type: object properties: id: type: integer format: int64 name: type: string name: type: string example: doggie photoUrls: type: array items: type: string tags: type: array items: type: object properties: id: type: integer format: int64 name: type: string status: type: string description: pet status in the store enum: - available - pending - sold application/xml: schema: type: object required: - name - photoUrls properties: id: type: integer format: int64 category: type: object properties: id: type: integer format: int64 name: type: string xml: name: Category name: type: string example: doggie photoUrls: type: array xml: name: photoUrl wrapped: true items: type: string tags: type: array xml: name: tag wrapped: true items: type: object properties: id: type: integer format: int64 name: type: string xml: name: Tag status: type: string description: pet status in the store enum: - available - pending - sold xml: name: Pet responses: '400': description: Invalid ID supplied '404': description: Pet not found '405': description: Validators exception security: - petstore_auth: - write:pets - read:pets "/pet/findByStatus": get: tags: - pet summary: Finds Pets by status description: Multiple status values can be provided with comma separated strings operationId: findPetsByStatus servers: - url: http://petstore.swagger.io/v2 parameters: - name: status in: query description: Status values that need to be considered for filter required: true schema: type: array items: type: string enum: - available - pending - sold default: available style: form explode: true responses: '200': description: successful operation content: application/json: schema: type: array items: type: object required: - name - photoUrls properties: id: type: integer format: int64 category: type: object properties: id: type: integer format: int64 name: type: string name: type: string example: doggie photoUrls: type: array items: type: string tags: type: array items: type: object properties: id: type: integer format: int64 name: type: string status: type: string description: pet status in the store enum: - available - pending - sold application/xml: schema: type: array items: type: object required: - name - photoUrls properties: id: type: integer format: int64 category: type: object properties: id: type: integer format: int64 name: type: string xml: name: Category name: type: string example: doggie photoUrls: type: array xml: name: photoUrl wrapped: true items: type: string tags: type: array xml: name: tag wrapped: true items: type: object properties: id: type: integer format: int64 name: type: string xml: name: Tag status: type: string description: pet status in the store enum: - available - pending - sold xml: name: Pet '400': description: Invalid status value security: - petstore_auth: - write:pets - read:pets "/pet/findByTags": get: tags: - pet summary: Finds Pets by tags description: Muliple tags can be provided with comma separated strings. Use tag1, tag2, tag3 for testing. operationId: findPetsByTags servers: - url: http://petstore.swagger.io/v2 parameters: - name: tags in: query description: Tags to filter by required: true schema: type: array items: type: string style: form explode: true responses: '200': description: successful operation content: application/json: schema: type: array items: type: object required: - name - photoUrls properties: id: type: integer format: int64 category: type: object properties: id: type: integer format: int64 name: type: string name: type: string example: doggie photoUrls: type: array items: type: string tags: type: array items: type: object properties: id: type: integer format: int64 name: type: string status: type: string description: pet status in the store enum: - available - pending - sold application/xml: schema: type: array items: type: object required: - name - photoUrls properties: id: type: integer format: int64 category: type: object properties: id: type: integer format: int64 name: type: string xml: name: Category name: type: string example: doggie photoUrls: type: array xml: name: photoUrl wrapped: true items: type: string tags: type: array xml: name: tag wrapped: true items: type: object properties: id: type: integer format: int64 name: type: string xml: name: Tag status: type: string description: pet status in the store enum: - available - pending - sold xml: name: Pet '400': description: Invalid tag value security: - petstore_auth: - write:pets - read:pets deprecated: true "/pet/{petId}": get: tags: - pet summary: Find pet by ID description: Returns a single pet operationId: getPetById servers: - url: http://petstore.swagger.io/v2 parameters: - name: petId in: path description: ID of pet required: true schema: type: integer format: int64 responses: '200': description: successful operation content: application/xml: schema: type: object required: - name - photoUrls properties: id: type: integer format: int64 category: type: object properties: id: type: integer format: int64 name: type: string xml: name: Category name: type: string example: doggie photoUrls: type: array xml: name: photoUrl wrapped: true items: type: string tags: type: array xml: name: tag wrapped: true items: type: object properties: id: type: integer format: int64 name: type: string xml: name: Tag status: type: string description: pet status in the store enum: - available - pending - sold xml: name: Pet application/json: schema: type: object required: - name - photoUrls properties: id: type: integer format: int64 category: type: object properties: id: type: integer format: int64 name: type: string name: type: string example: doggie photoUrls: type: array items: type: string tags: type: array items: type: object properties: id: type: integer format: int64 name: type: string status: type: string description: pet status in the store enum: - available - pending - sold '400': description: Invalid ID supplied '404': description: Pet not found security: - api_key: [] post: tags: - pet summary: Updates a pet in the store with form data description: '' operationId: updatePetWithForm servers: - url: http://petstore.swagger.io/v2 parameters: - name: petId in: path description: ID of pet required: true schema: type: integer format: int64 requestBody: content: application/x-www-form-urlencoded: schema: type: object properties: name: description: Updated name of the pet required: false type: string status: description: Updated status of the pet required: false type: string responses: '405': description: Invalid input security: - petstore_auth: - write:pets - read:pets delete: tags: - pet summary: Deletes a pet description: '' operationId: deletePet servers: - url: http://petstore.swagger.io/v2 parameters: - name: petId in: path description: ID of pet required: true schema: type: integer format: int64 - name: api_key in: header required: false schema: type: string responses: '400': description: Invalid ID supplied '404': description: Pet not found security: - petstore_auth: - write:pets - read:pets "/pet/{petId}/uploadImage": post: tags: - pet summary: uploads an image description: '' operationId: uploadFile servers: - url: http://petstore.swagger.io/v2 parameters: - name: petId in: path description: ID of pet required: true schema: type: integer format: int64 requestBody: content: multipart/form-data: schema: type: object properties: additionalMetadata: description: Additional data to pass to server required: false type: string file: description: file to upload required: false type: string responses: '200': description: successful operation content: application/json: schema: type: object properties: code: type: integer format: int32 type: type: string message: type: string security: - petstore_auth: - write:pets - read:pets "/store/inventory": get: tags: - store summary: Returns pet inventories by status description: Returns a map of status codes to quantities operationId: getInventory servers: - url: http://petstore.swagger.io/v2 responses: '200': description: successful operation content: application/json: schema: type: object additionalProperties: type: integer format: int32 security: - api_key: [] "/store/order": post: tags: - store summary: Place an order for a pet description: '' operationId: placeOrder servers: - url: http://petstore.swagger.io/v2 requestBody: required: true description: order placed for purchasing the pet content: application/json: schema: type: object properties: id: type: integer format: int64 petId: type: integer format: int64 quantity: type: integer format: int32 shipDate: type: string format: date-time status: type: string description: Order Status enum: - placed - approved - delivered complete: type: boolean default: false application/xml: schema: type: object properties: id: type: integer format: int64 petId: type: integer format: int64 quantity: type: integer format: int32 shipDate: type: string format: date-time status: type: string description: Order Status enum: - placed - approved - delivered complete: type: boolean default: false xml: name: Order responses: '200': description: successful operation content: application/json: schema: type: object properties: id: type: integer format: int64 petId: type: integer format: int64 quantity: type: integer format: int32 shipDate: type: string format: date-time status: type: string description: Order Status enum: - placed - approved - delivered complete: type: boolean default: false application/xml: schema: type: object properties: id: type: integer format: int64 petId: type: integer format: int64 quantity: type: integer format: int32 shipDate: type: string format: date-time status: type: string description: Order Status enum: - placed - approved - delivered complete: type: boolean default: false xml: name: Order '400': description: Invalid Order "/store/order/{orderId}": get: tags: - store summary: Find purchase order by ID description: For valid response try integer IDs with value >= 1 and <= 10. Other values will generated exceptions operationId: getOrderById servers: - url: http://petstore.swagger.io/v2 parameters: - name: "orderId" in: "path" description: ID of purchase order required: true schema: type: "integer" maximum: 10.0 minimum: 1.0 format: "int64" responses: '200': description: successful operation content: application/json: schema: type: object properties: id: type: integer format: int64 petId: type: integer format: int64 quantity: type: integer format: int32 shipDate: type: string format: date-time status: type: string description: Order Status enum: - placed - approved - delivered complete: type: boolean default: false application/xml: schema: type: object properties: id: type: integer format: int64 petId: type: integer format: int64 quantity: type: integer format: int32 shipDate: type: string format: date-time status: type: string description: Order Status enum: - placed - approved - delivered complete: type: boolean default: false xml: name: Order '400': description: Invalid ID supplied '404': description: Order not found delete: tags: - store summary: Delete purchase order by ID description: For valid response try integer IDs with positive integer value. Negative or non-integer values will generate API errors operationId: deleteOrder servers: - url: http://petstore.swagger.io/v2 parameters: - name: "orderId" in: "path" description: ID of purchase order required: true schema: type: "integer" maximum: 10.0 minimum: 1.0 format: "int64" responses: '400': description: Invalid ID supplied '404': description: Order not found "/user": post: tags: - user summary: Create user description: This can only be done by the logged in user. operationId: createUser servers: - url: http://petstore.swagger.io/v2 requestBody: description: Created user object required: true content: application/json: schema: type: object properties: id: type: integer format: int64 username: type: string firstName: type: string lastName: type: string email: type: string password: type: string phone: type: string userStatus: type: integer format: int32 description: User Status application/xml: schema: type: object properties: id: type: integer format: int64 username: type: string firstName: type: string lastName: type: string email: type: string password: type: string phone: type: string userStatus: type: integer format: int32 description: User Status xml: name: User responses: default: description: successful operation "/user/createWithArray": post: tags: - user summary: Creates list of users with given input array description: '' operationId: createUsersWithArrayInput servers: - url: http://petstore.swagger.io/v2 requestBody: description: List of user object required: true content: application/json: schema: type: array items: type: object properties: id: type: integer format: int64 username: type: string firstName: type: string lastName: type: string email: type: string password: type: string phone: type: string userStatus: type: integer format: int32 description: User Status application/xml: schema: type: array items: type: object properties: id: type: integer format: int64 username: type: string firstName: type: string lastName: type: string email: type: string password: type: string phone: type: string userStatus: type: integer format: int32 description: User Status xml: name: User responses: default: description: successful operation "/user/createWithList": post: tags: - user summary: Creates list of users with given input array description: '' operationId: createUsersWithListInput servers: - url: http://petstore.swagger.io/v2 requestBody: description: List of user object required: true content: application/json: schema: type: array items: type: object properties: id: type: integer format: int64 username: type: string firstName: type: string lastName: type: string email: type: string password: type: string phone: type: string userStatus: type: integer format: int32 description: User Status application/xml: schema: type: array items: type: object properties: id: type: integer format: int64 username: type: string firstName: type: string lastName: type: string email: type: string password: type: string phone: type: string userStatus: type: integer format: int32 description: User Status xml: name: User responses: default: description: successful operation "/user/login": get: tags: - user summary: Logs user into the system description: '' operationId: loginUser servers: - url: http://petstore.swagger.io/v2 parameters: - name: username in: query description: The user name for login required: true schema: type: string - name: password in: query description: The password for login in clear text required: true schema: type: string responses: '200': description: successful operation headers: X-Rate-Limit: description: calls per hour allowed by the user schema: type: integer format: int32 X-Expires-After: description: date in UTC when token expires schema: type: string format: date-time content: application/xml: schema: type: string application/json: schema: type: string '400': description: Invalid username/password supplied "/user/logout": get: tags: - user summary: Logs out current logged in user session description: '' operationId: logoutUser servers: - url: http://petstore.swagger.io/v2 responses: default: description: successful operation "/user/{username}": get: tags: - user summary: Get user by user name description: '' operationId: getUserByName servers: - url: http://petstore.swagger.io/v2 parameters: - name: username in: path description: 'The name of the user. Use user1 for testing. ' required: true schema: type: string responses: '200': description: successful operation content: application/json: schema: type: object properties: id: type: integer format: int64 username: type: string firstName: type: string lastName: type: string email: type: string password: type: string phone: type: string userStatus: type: integer format: int32 description: User Status application/xml: schema: type: object properties: id: type: integer format: int64 username: type: string firstName: type: string lastName: type: string email: type: string password: type: string phone: type: string userStatus: type: integer format: int32 description: User Status xml: name: User '400': description: Invalid username supplied '404': description: User not found put: tags: - user summary: Updated user description: This can only be done by the logged in user. operationId: updateUser servers: - url: http://petstore.swagger.io/v2 parameters: - name: username in: path description: 'The name of the user. Use user1 for testing. ' required: true schema: type: string requestBody: description: Updated user object required: true content: application/json: schema: type: object properties: id: type: integer format: int64 username: type: string firstName: type: string lastName: type: string email: type: string password: type: string phone: type: string userStatus: type: integer format: int32 description: User Status application/xml: schema: type: object properties: id: type: integer format: int64 username: type: string firstName: type: string lastName: type: string email: type: string password: type: string phone: type: string userStatus: type: integer format: int32 description: User Status xml: name: User responses: '400': description: Invalid user supplied '404': description: User not found delete: tags: - user summary: Delete user description: This can only be done by the logged in user. operationId: deleteUser servers: - url: http://petstore.swagger.io/v2 parameters: - name: username in: path description: 'The name of the user to be deleted. ' required: true schema: type: string responses: '400': description: Invalid username supplied '404': description: User not found components: securitySchemes: petstore_auth: type: oauth2 flows: implicit: authorizationUrl: http://petstore.swagger.io/oauth/dialog scopes: write:pets: modify pets in your account read:pets: read your pets api_key: type: apiKey name: api_key in: header externalDocs: description: Find out more about Swagger url: http://swagger.io