users swagger def

This commit is contained in:
Gnieark 2019-12-03 21:30:47 +01:00
parent 1b47bbfc63
commit 6924473f78

View File

@ -1,110 +1,195 @@
swagger: "2.0"
info:
description: "SimplePAD API"
description: "Resources Manager API"
version: "1.0.0"
title: "SimplePad API"
host: "simplepad.localhost"
host: "localhost"
basePath: "/api"
tags:
- name: "pad"
description: "CRUD Pads"
- name: "user"
description: "Operations about user"
schemes:
- "https"
- "http"
paths:
/pad:
/user:
post:
tags:
- "pad"
summary: "Create a new pad"
description: "Create a new PAD (with a random id)"
consumes:
- "application/json"
- "user"
summary: "Create user"
description: "Need pass an api key to authentificate."
operationId: "createUser"
produces:
- "application/json"
parameters:
- in: "body"
name: "body"
description: "Created user object"
required: true
schema:
$ref: "#/definitions/Pad"
$ref: "#/definitions/User"
- in: header
name: X-API-Key
type: string
required: true
responses:
405:
description: "Invalid input"
200:
description: "SuccessFull"
default:
description: "successful operation"
/user/createWithArray:
post:
tags:
- "user"
summary: "Creates list of users with given input array"
description: ""
operationId: "createUsersWithArrayInput"
produces:
- "application/xml"
- "application/json"
parameters:
- in: "body"
name: "body"
description: "List of user object"
required: true
schema:
$ref: "#/definitions/Pad"
/pad/{pad_id}:
type: "array"
items:
$ref: "#/definitions/User"
- in: header
name: X-API-Key
type: string
required: true
responses:
default:
description: "successful operation"
/user/createWithList:
post:
tags:
- "user"
summary: "Creates list of users with given input array"
description: ""
operationId: "createUsersWithListInput"
produces:
- "application/xml"
- "application/json"
parameters:
- in: "body"
name: "body"
description: "List of user object"
required: true
schema:
type: "array"
items:
$ref: "#/definitions/User"
- in: header
name: X-API-Key
type: string
required: true
responses:
default:
description: "successful operation"
/user/{username}:
get:
tags:
- "pad"
- "user"
summary: "Get user by user name"
description: ""
operationId: "getUserByName"
produces:
- "application/xml"
- "application/json"
parameters:
- in: "path"
name: "pad_id"
- name: "username"
in: "path"
description: "The name that needs to be fetched."
required: true
type: "string"
- in: header
name: X-API-Key
type: string
maxLength: 6
minLength: 6
required: false
responses:
404:
description: "Does not exists"
200:
description: "SuccessFull"
description: "successful operation"
schema:
$ref: "#/definitions/Pad"
post:
$ref: "#/definitions/User"
400:
description: "Invalid username supplied"
404:
description: "User not found"
put:
tags:
- "pad"
description: "Create a new PAD with the given ID"
- "user"
summary: "Updated user"
description: "This can only be done by the logged in user."
operationId: "updateUser"
produces:
- "application/xml"
- "application/json"
parameters:
- in: "path"
name: "pad_id"
- name: "username"
in: "path"
description: "name that need to be updated"
required: true
type: string
maxLength: 6
minLength: 6
type: "string"
- in: "body"
name: "body"
description: "content"
description: "Updated user object"
required: true
schema:
$ref: "#/definitions/PadPost"
$ref: "#/definitions/User"
- in: header
name: X-API-Key
type: string
required: true
responses:
405:
description: "Invalid input"
409:
description: "Given Id already exists"
200:
description: "SuccessFull"
schema:
$ref: "#/definitions/Pad"
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"
produces:
- "application/xml"
- "application/json"
parameters:
- name: "username"
in: "path"
description: "The name that needs to be deleted"
required: true
type: "string"
- in: header
name: X-API-Key
type: string
required: true
responses:
400:
description: "Invalid username supplied"
404:
description: "User not found"
definitions:
Pad:
User:
type: "object"
properties:
id:
type: string
maxLength: 6
minLength: 6
content:
type: string
create_date:
type: string
format: date
PadPost:
type: "object"
required:
- content
properties:
content:
type: string
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"