resources-manager-api/docs/resources-manager.yml
2019-12-03 22:50:06 +01:00

270 lines
6.2 KiB
YAML

swagger: "2.0"
info:
description: "Resources Manager API"
version: "1.0.0"
title: "Resources Manager API"
host: "localhost"
basePath: "/api"
tags:
- name: "user"
description: "Operations about user"
- name: "session"
description: "logon and log out methods to get a token"
schemes:
- "https"
paths:
/user:
post:
tags:
- "user"
summary: "Create user"
description: "Need pass an api key to authentificate."
produces:
- "application/json"
parameters:
- in: "body"
name: "body"
description: "Created user object"
required: true
schema:
$ref: "#/definitions/User"
- in: header
name: X-API-Key
type: string
required: true
responses:
default:
description: "successful operation"
401:
description: Authentification failed
403:
description: You are not allowed to do that
/user/createWithList:
post:
tags:
- "user"
summary: "Creates list of users with given input array"
description: ""
produces:
- "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"
401:
description: Authentification failed
403:
description: You are not allowed to do that
/user/{username}:
get:
tags:
- "user"
summary: "Get user by user name"
description: ""
produces:
- "application/json"
parameters:
- name: "username"
in: "path"
description: "The name that needs to be fetched."
required: true
type: "string"
- in: header
name: X-API-Key
type: string
required: false
responses:
200:
description: "successful operation"
schema:
$ref: "#/definitions/UserInfo"
400:
description: "Invalid username supplied"
404:
description: "User not found"
401:
description: Authentification failed
403:
description: You are not allowed to do that
put:
tags:
- "user"
summary: "Updated user"
description: "This can only be done by the logged in user."
produces:
- "application/json"
parameters:
- name: "username"
in: "path"
description: "name that need to be updated"
required: true
type: "string"
- in: "body"
name: "body"
description: "Updated user object"
required: true
schema:
$ref: "#/definitions/User"
- in: header
name: X-API-Key
type: string
required: true
responses:
400:
description: "Invalid user supplied"
404:
description: "User not found"
401:
description: Authentification failed
403:
description: You are not allowed to do that
delete:
tags:
- "user"
summary: "Delete user"
description: "This can only be done by the logged in user."
operationId: "deleteUser"
produces:
- "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"
401:
description: Authentification failed
403:
description: You are not allowed to do that
/session:
get:
tags:
- session
summary: "Get current session info"
parameters:
- in: header
name: X-API-Key
type: string
required: true
responses:
401:
description: Authentification failed
200:
description: "successful operation"
schema:
$ref: "#/definitions/Session"
post:
tags:
- session
summary: "Try to auth and retrive an api key"
parameters:
- in: "body"
name: "body"
description: "auth"
required: true
schema:
$ref: "#/definitions/InternalAuth"
responses:
401:
description: Authentification failed
200:
description: "successful operation"
schema:
$ref: "#/definitions/Session"
definitions:
User:
type: "object"
properties:
id:
type: "integer"
format: "int64"
username:
type: "string"
firstName:
type: "string"
lastName:
type: "string"
email:
type: "string"
password:
type: "string"
format: "password"
phone:
type: "string"
userStatus:
type: "integer"
format: "int32"
description: "User Status"
authMethod:
type: "string"
pattern: '^(internal|ldap|cas)$'
UserInfo:
type: "object"
properties:
id:
type: "integer"
format: "int64"
username:
type: "string"
firstName:
type: "string"
lastName:
type: "string"
email:
type: "string"
phone:
type: "string"
userStatus:
type: "integer"
format: "int32"
description: "User Status"
authMethod:
type: "string"
pattern: '^(internal|ldap|cas)$'
lastConnect:
type: "string"
format: date-time
Session:
type: "object"
properties:
user:
type: object
createDate:
type: string
format: date-time
endDate:
type: string
format: date-time
X-API-Key:
type: string
InternalAuth:
type: "object"
properties:
username:
type: "string"
password:
type: "string"
format: password