openapi-generator/samples/server/petstore/nodejs/api/swagger.yaml

723 lines
18 KiB
YAML
Raw Normal View History

2015-11-18 02:46:33 +00:00
---
swagger: "2.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."
2015-11-18 02:46:33 +00:00
version: "1.0.0"
title: "Swagger Petstore"
2016-04-09 10:15:22 +00:00
termsOfService: "http://swagger.io/terms/"
2015-11-18 02:46:33 +00:00
contact:
email: "apiteam@swagger.io"
2015-11-18 02:46:33 +00:00
license:
name: "Apache 2.0"
url: "http://www.apache.org/licenses/LICENSE-2.0.html"
host: "petstore.swagger.io"
basePath: "/v2"
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"
2015-11-18 02:46:33 +00:00
schemes:
- "http"
paths:
/pet:
2015-11-18 02:46:33 +00:00
post:
tags:
- "pet"
summary: "Add a new pet to the store"
2016-04-09 10:12:46 +00:00
description: ""
2015-11-18 02:46:33 +00:00
operationId: "addPet"
consumes:
- "application/json"
- "application/xml"
produces:
2016-04-09 10:12:46 +00:00
- "application/xml"
- "application/json"
2015-11-18 02:46:33 +00:00
parameters:
- in: "body"
name: "body"
description: "Pet object that needs to be added to the store"
required: true
2015-11-18 02:46:33 +00:00
schema:
$ref: "#/definitions/Pet"
responses:
405:
description: "Invalid input"
security:
- petstore_auth:
- "write:pets"
- "read:pets"
2016-04-05 14:08:46 +00:00
x-swagger-router-controller: "Pet"
2015-11-18 02:46:33 +00:00
put:
tags:
- "pet"
summary: "Update an existing pet"
2016-04-09 10:12:46 +00:00
description: ""
2015-11-18 02:46:33 +00:00
operationId: "updatePet"
consumes:
- "application/json"
- "application/xml"
produces:
2016-04-09 10:12:46 +00:00
- "application/xml"
- "application/json"
2015-11-18 02:46:33 +00:00
parameters:
- in: "body"
name: "body"
description: "Pet object that needs to be added to the store"
required: true
2015-11-18 02:46:33 +00:00
schema:
$ref: "#/definitions/Pet"
responses:
400:
description: "Invalid ID supplied"
404:
description: "Pet not found"
405:
description: "Validation exception"
security:
- petstore_auth:
- "write:pets"
- "read:pets"
2016-04-05 14:08:46 +00:00
x-swagger-router-controller: "Pet"
/pet/findByStatus:
2015-11-18 02:46:33 +00:00
get:
tags:
- "pet"
summary: "Finds Pets by status"
description: "Multiple status values can be provided with comma separated strings"
2015-11-18 02:46:33 +00:00
operationId: "findPetsByStatus"
produces:
2016-04-09 10:12:46 +00:00
- "application/xml"
- "application/json"
2015-11-18 02:46:33 +00:00
parameters:
- name: "status"
in: "query"
description: "Status values that need to be considered for filter"
required: true
2015-11-18 02:46:33 +00:00
type: "array"
items:
type: "string"
default: "available"
enum:
- "available"
- "pending"
- "sold"
collectionFormat: "csv"
2015-11-18 02:46:33 +00:00
responses:
200:
description: "successful operation"
schema:
type: "array"
items:
$ref: "#/definitions/Pet"
400:
description: "Invalid status value"
security:
- petstore_auth:
- "write:pets"
- "read:pets"
2016-04-05 14:08:46 +00:00
x-swagger-router-controller: "Pet"
/pet/findByTags:
2015-11-18 02:46:33 +00:00
get:
tags:
- "pet"
summary: "Finds Pets by tags"
description: "Multiple tags can be provided with comma separated strings. Use\
2016-04-09 10:12:46 +00:00
\ tag1, tag2, tag3 for testing."
2015-11-18 02:46:33 +00:00
operationId: "findPetsByTags"
produces:
2016-04-09 10:12:46 +00:00
- "application/xml"
- "application/json"
2015-11-18 02:46:33 +00:00
parameters:
- name: "tags"
in: "query"
description: "Tags to filter by"
required: true
2015-11-18 02:46:33 +00:00
type: "array"
items:
type: "string"
collectionFormat: "csv"
2015-11-18 02:46:33 +00:00
responses:
200:
description: "successful operation"
schema:
type: "array"
items:
$ref: "#/definitions/Pet"
400:
description: "Invalid tag value"
security:
- petstore_auth:
- "write:pets"
- "read:pets"
2016-04-05 14:08:46 +00:00
x-swagger-router-controller: "Pet"
/pet/{petId}:
2015-11-18 02:46:33 +00:00
get:
tags:
- "pet"
summary: "Find pet by ID"
description: "Returns a single pet"
2015-11-18 02:46:33 +00:00
operationId: "getPetById"
produces:
2016-04-09 10:12:46 +00:00
- "application/xml"
- "application/json"
2015-11-18 02:46:33 +00:00
parameters:
- name: "petId"
in: "path"
description: "ID of pet to return"
2015-11-18 02:46:33 +00:00
required: true
type: "integer"
format: "int64"
responses:
200:
description: "successful operation"
schema:
$ref: "#/definitions/Pet"
400:
description: "Invalid ID supplied"
404:
description: "Pet not found"
security:
- api_key: []
2016-04-05 14:08:46 +00:00
x-swagger-router-controller: "Pet"
2015-11-18 02:46:33 +00:00
post:
tags:
- "pet"
summary: "Updates a pet in the store with form data"
2016-04-09 10:12:46 +00:00
description: ""
2015-11-18 02:46:33 +00:00
operationId: "updatePetWithForm"
consumes:
- "application/x-www-form-urlencoded"
produces:
2016-04-09 10:12:46 +00:00
- "application/xml"
- "application/json"
2015-11-18 02:46:33 +00:00
parameters:
- name: "petId"
in: "path"
description: "ID of pet that needs to be updated"
required: true
type: "integer"
format: "int64"
2015-11-18 02:46:33 +00:00
- name: "name"
in: "formData"
description: "Updated name of the pet"
required: false
2015-11-18 02:46:33 +00:00
type: "string"
- name: "status"
in: "formData"
description: "Updated status of the pet"
required: false
2015-11-18 02:46:33 +00:00
type: "string"
responses:
405:
description: "Invalid input"
security:
- petstore_auth:
- "write:pets"
- "read:pets"
2016-04-05 14:08:46 +00:00
x-swagger-router-controller: "Pet"
2015-11-18 02:46:33 +00:00
delete:
tags:
- "pet"
summary: "Deletes a pet"
2016-04-09 10:12:46 +00:00
description: ""
2015-11-18 02:46:33 +00:00
operationId: "deletePet"
produces:
2016-04-09 10:12:46 +00:00
- "application/xml"
- "application/json"
2015-11-18 02:46:33 +00:00
parameters:
- name: "api_key"
in: "header"
required: false
2015-11-18 02:46:33 +00:00
type: "string"
- name: "petId"
in: "path"
description: "Pet id to delete"
required: true
type: "integer"
format: "int64"
responses:
400:
2016-04-09 10:12:46 +00:00
description: "Invalid pet value"
2015-11-18 02:46:33 +00:00
security:
- petstore_auth:
- "write:pets"
- "read:pets"
2016-04-05 14:08:46 +00:00
x-swagger-router-controller: "Pet"
/pet/{petId}/uploadImage:
post:
tags:
- "pet"
summary: "uploads an image"
description: ""
operationId: "uploadFile"
consumes:
- "multipart/form-data"
produces:
- "application/json"
parameters:
- name: "petId"
in: "path"
description: "ID of pet to update"
required: true
type: "integer"
format: "int64"
- name: "additionalMetadata"
in: "formData"
description: "Additional data to pass to server"
required: false
type: "string"
- name: "file"
in: "formData"
description: "file to upload"
required: false
type: "file"
responses:
200:
description: "successful operation"
schema:
$ref: "#/definitions/ApiResponse"
security:
- petstore_auth:
- "write:pets"
- "read:pets"
x-swagger-router-controller: "Pet"
/store/inventory:
get:
tags:
- "store"
summary: "Returns pet inventories by status"
description: "Returns a map of status codes to quantities"
operationId: "getInventory"
produces:
- "application/json"
parameters: []
responses:
200:
description: "successful operation"
schema:
type: "object"
additionalProperties:
type: "integer"
format: "int32"
security:
- api_key: []
x-swagger-router-controller: "Store"
/store/order:
2015-11-18 02:46:33 +00:00
post:
tags:
- "store"
summary: "Place an order for a pet"
2016-04-09 10:12:46 +00:00
description: ""
2015-11-18 02:46:33 +00:00
operationId: "placeOrder"
produces:
2016-04-09 10:12:46 +00:00
- "application/xml"
- "application/json"
2015-11-18 02:46:33 +00:00
parameters:
- in: "body"
name: "body"
description: "order placed for purchasing the pet"
required: true
2015-11-18 02:46:33 +00:00
schema:
$ref: "#/definitions/Order"
responses:
200:
description: "successful operation"
schema:
$ref: "#/definitions/Order"
400:
description: "Invalid Order"
2016-04-05 14:08:46 +00:00
x-swagger-router-controller: "Store"
/store/order/{orderId}:
2015-11-18 02:46:33 +00:00
get:
tags:
- "store"
summary: "Find purchase order by ID"
2016-04-09 10:12:46 +00:00
description: "For valid response try integer IDs with value <= 5 or > 10. Other\
\ values will generated exceptions"
2015-11-18 02:46:33 +00:00
operationId: "getOrderById"
produces:
2016-04-09 10:12:46 +00:00
- "application/xml"
- "application/json"
2015-11-18 02:46:33 +00:00
parameters:
- name: "orderId"
in: "path"
description: "ID of pet that needs to be fetched"
required: true
type: "integer"
maximum: 5
minimum: 1
format: "int64"
2015-11-18 02:46:33 +00:00
responses:
200:
description: "successful operation"
schema:
$ref: "#/definitions/Order"
400:
description: "Invalid ID supplied"
404:
description: "Order not found"
2016-04-05 14:08:46 +00:00
x-swagger-router-controller: "Store"
2015-11-18 02:46:33 +00:00
delete:
tags:
- "store"
summary: "Delete purchase order by ID"
2016-04-09 10:12:46 +00:00
description: "For valid response try integer IDs with value < 1000. Anything\
\ above 1000 or nonintegers will generate API errors"
2015-11-18 02:46:33 +00:00
operationId: "deleteOrder"
produces:
2016-04-09 10:12:46 +00:00
- "application/xml"
- "application/json"
2015-11-18 02:46:33 +00:00
parameters:
- name: "orderId"
in: "path"
description: "ID of the order that needs to be deleted"
required: true
2016-04-09 10:12:46 +00:00
type: "string"
minimum: 1
2015-11-18 02:46:33 +00:00
responses:
400:
description: "Invalid ID supplied"
404:
description: "Order not found"
2016-04-05 14:08:46 +00:00
x-swagger-router-controller: "Store"
/user:
2015-11-18 02:46:33 +00:00
post:
tags:
- "user"
summary: "Create user"
description: "This can only be done by the logged in user."
operationId: "createUser"
produces:
2016-04-09 10:12:46 +00:00
- "application/xml"
- "application/json"
2015-11-18 02:46:33 +00:00
parameters:
- in: "body"
name: "body"
description: "Created user object"
required: true
2015-11-18 02:46:33 +00:00
schema:
$ref: "#/definitions/User"
responses:
default:
description: "successful operation"
2016-04-05 14:08:46 +00:00
x-swagger-router-controller: "User"
/user/createWithArray:
2015-11-18 02:46:33 +00:00
post:
tags:
- "user"
summary: "Creates list of users with given input array"
2016-04-09 10:12:46 +00:00
description: ""
2015-11-18 02:46:33 +00:00
operationId: "createUsersWithArrayInput"
produces:
2016-04-09 10:12:46 +00:00
- "application/xml"
- "application/json"
2015-11-18 02:46:33 +00:00
parameters:
- in: "body"
name: "body"
description: "List of user object"
required: true
2015-11-18 02:46:33 +00:00
schema:
type: "array"
items:
$ref: "#/definitions/User"
responses:
default:
description: "successful operation"
2016-04-05 14:08:46 +00:00
x-swagger-router-controller: "User"
/user/createWithList:
2015-11-18 02:46:33 +00:00
post:
tags:
- "user"
summary: "Creates list of users with given input array"
2016-04-09 10:12:46 +00:00
description: ""
2015-11-18 02:46:33 +00:00
operationId: "createUsersWithListInput"
produces:
2016-04-09 10:12:46 +00:00
- "application/xml"
- "application/json"
2015-11-18 02:46:33 +00:00
parameters:
- in: "body"
name: "body"
description: "List of user object"
required: true
2015-11-18 02:46:33 +00:00
schema:
type: "array"
items:
$ref: "#/definitions/User"
responses:
default:
description: "successful operation"
2016-04-05 14:08:46 +00:00
x-swagger-router-controller: "User"
/user/login:
2015-11-18 02:46:33 +00:00
get:
tags:
- "user"
summary: "Logs user into the system"
2016-04-09 10:12:46 +00:00
description: ""
2015-11-18 02:46:33 +00:00
operationId: "loginUser"
produces:
2016-04-09 10:12:46 +00:00
- "application/xml"
- "application/json"
2015-11-18 02:46:33 +00:00
parameters:
- name: "username"
in: "query"
description: "The user name for login"
required: true
2015-11-18 02:46:33 +00:00
type: "string"
- name: "password"
in: "query"
description: "The password for login in clear text"
required: true
2015-11-18 02:46:33 +00:00
type: "string"
responses:
200:
description: "successful operation"
schema:
type: "string"
headers:
X-Rate-Limit:
type: "integer"
format: "int32"
description: "calls per hour allowed by the user"
X-Expires-After:
type: "string"
format: "date-time"
description: "date in UTC when toekn expires"
2015-11-18 02:46:33 +00:00
400:
description: "Invalid username/password supplied"
2016-04-05 14:08:46 +00:00
x-swagger-router-controller: "User"
/user/logout:
2015-11-18 02:46:33 +00:00
get:
tags:
- "user"
summary: "Logs out current logged in user session"
2016-04-09 10:12:46 +00:00
description: ""
2015-11-18 02:46:33 +00:00
operationId: "logoutUser"
produces:
2016-04-09 10:12:46 +00:00
- "application/xml"
- "application/json"
2015-11-18 02:46:33 +00:00
parameters: []
responses:
default:
description: "successful operation"
2016-04-05 14:08:46 +00:00
x-swagger-router-controller: "User"
/user/{username}:
2015-11-18 02:46:33 +00:00
get:
tags:
- "user"
summary: "Get user by user name"
2016-04-09 10:12:46 +00:00
description: ""
2015-11-18 02:46:33 +00:00
operationId: "getUserByName"
produces:
2016-04-09 10:12:46 +00:00
- "application/xml"
- "application/json"
2015-11-18 02:46:33 +00:00
parameters:
- name: "username"
in: "path"
description: "The name that needs to be fetched. Use user1 for testing. "
2015-11-18 02:46:33 +00:00
required: true
type: "string"
responses:
200:
description: "successful operation"
schema:
$ref: "#/definitions/User"
400:
description: "Invalid username supplied"
404:
description: "User not found"
2016-04-05 14:08:46 +00:00
x-swagger-router-controller: "User"
2015-11-18 02:46:33 +00:00
put:
tags:
- "user"
summary: "Updated user"
description: "This can only be done by the logged in user."
operationId: "updateUser"
produces:
2016-04-09 10:12:46 +00:00
- "application/xml"
- "application/json"
2015-11-18 02:46:33 +00:00
parameters:
- name: "username"
in: "path"
2016-04-09 10:12:46 +00:00
description: "name that need to be deleted"
2015-11-18 02:46:33 +00:00
required: true
type: "string"
- in: "body"
name: "body"
description: "Updated user object"
required: true
2015-11-18 02:46:33 +00:00
schema:
$ref: "#/definitions/User"
responses:
400:
description: "Invalid user supplied"
404:
description: "User not found"
2016-04-05 14:08:46 +00:00
x-swagger-router-controller: "User"
2015-11-18 02:46:33 +00:00
delete:
tags:
- "user"
summary: "Delete user"
description: "This can only be done by the logged in user."
operationId: "deleteUser"
produces:
2016-04-09 10:12:46 +00:00
- "application/xml"
- "application/json"
2015-11-18 02:46:33 +00:00
parameters:
- name: "username"
in: "path"
description: "The name that needs to be deleted"
required: true
type: "string"
responses:
400:
description: "Invalid username supplied"
404:
description: "User not found"
2016-04-05 14:08:46 +00:00
x-swagger-router-controller: "User"
2015-11-18 02:46:33 +00:00
securityDefinitions:
api_key:
type: "apiKey"
name: "api_key"
in: "header"
petstore_auth:
type: "oauth2"
2016-04-09 10:12:46 +00:00
authorizationUrl: "http://petstore.swagger.io/api/oauth/dialog"
2015-11-18 02:46:33 +00:00
flow: "implicit"
scopes:
write:pets: "modify pets in your account"
read:pets: "read your pets"
2015-11-18 02:46:33 +00:00
definitions:
Order:
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"
Category:
type: "object"
properties:
id:
type: "integer"
format: "int64"
name:
type: "string"
xml:
name: "Category"
2015-11-18 02:46:33 +00:00
User:
2016-04-05 14:08:46 +00:00
type: "object"
2015-11-18 02:46:33 +00:00
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"
Tag:
2016-04-05 14:08:46 +00:00
type: "object"
2015-11-18 02:46:33 +00:00
properties:
id:
type: "integer"
format: "int64"
name:
type: "string"
xml:
name: "Tag"
2015-11-18 02:46:33 +00:00
Pet:
2016-04-05 14:08:46 +00:00
type: "object"
2015-11-18 02:46:33 +00:00
required:
- "name"
- "photoUrls"
properties:
id:
type: "integer"
format: "int64"
category:
$ref: "#/definitions/Category"
name:
type: "string"
example: "doggie"
photoUrls:
type: "array"
xml:
name: "photoUrl"
wrapped: true
2015-11-18 02:46:33 +00:00
items:
type: "string"
tags:
type: "array"
xml:
name: "tag"
wrapped: true
2015-11-18 02:46:33 +00:00
items:
$ref: "#/definitions/Tag"
status:
type: "string"
description: "pet status in the store"
enum:
- "available"
- "pending"
- "sold"
xml:
name: "Pet"
ApiResponse:
2016-04-09 10:12:46 +00:00
type: "object"
properties:
code:
2015-11-18 02:46:33 +00:00
type: "integer"
format: "int32"
type:
2015-11-18 02:46:33 +00:00
type: "string"
message:
2015-11-18 02:46:33 +00:00
type: "string"
externalDocs:
description: "Find out more about Swagger"
url: "http://swagger.io"