create api definition
This commit is contained in:
parent
b1154563cf
commit
da8d05f656
175
backend.yml
Normal file
175
backend.yml
Normal file
@ -0,0 +1,175 @@
|
|||||||
|
openapi: 3.0.3
|
||||||
|
info:
|
||||||
|
title: onSpot Backend
|
||||||
|
description: Backend of onSpot
|
||||||
|
contact:
|
||||||
|
email: tormakristof@tormakristof.eu
|
||||||
|
license:
|
||||||
|
name: Apache 2.0
|
||||||
|
url: http://www.apache.org/licenses/LICENSE-2.0.html
|
||||||
|
version: 1.0.0
|
||||||
|
servers:
|
||||||
|
- url: https://onspot.k8s.kmlabz.com
|
||||||
|
tags:
|
||||||
|
- name: backend
|
||||||
|
description: onSpot Backend interaction
|
||||||
|
paths:
|
||||||
|
/api/auth/login:
|
||||||
|
post:
|
||||||
|
tags:
|
||||||
|
- backend
|
||||||
|
summary: Logs on a user
|
||||||
|
operationId: logon
|
||||||
|
requestBody:
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/User'
|
||||||
|
required: true
|
||||||
|
responses:
|
||||||
|
200:
|
||||||
|
description: successful operation
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/LoginToken'
|
||||||
|
401:
|
||||||
|
description: Incorrect credentials
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/ApiResponse'
|
||||||
|
417:
|
||||||
|
description: JSON invalid schema
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/ApiResponse'
|
||||||
|
|
||||||
|
/api/lists:
|
||||||
|
get:
|
||||||
|
tags:
|
||||||
|
- backend
|
||||||
|
summary: Gets all lists
|
||||||
|
operationId: getAllLists
|
||||||
|
responses:
|
||||||
|
200:
|
||||||
|
description: Lists
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/ListArray'
|
||||||
|
|
||||||
|
|
||||||
|
/api/lists/{listid}:
|
||||||
|
get:
|
||||||
|
tags:
|
||||||
|
- backend
|
||||||
|
summary: Gets a single lists
|
||||||
|
operationId: getList
|
||||||
|
parameters:
|
||||||
|
- name: listid
|
||||||
|
in: path
|
||||||
|
description: ID of a list
|
||||||
|
required: true
|
||||||
|
schema:
|
||||||
|
type: integer
|
||||||
|
responses:
|
||||||
|
200:
|
||||||
|
description: List data
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/List'
|
||||||
|
|
||||||
|
/api/lists/{listid}/{trackid}:
|
||||||
|
get:
|
||||||
|
tags:
|
||||||
|
- backend
|
||||||
|
summary: Gets a track from a List
|
||||||
|
operationId: getTrack
|
||||||
|
parameters:
|
||||||
|
- name: listid
|
||||||
|
in: path
|
||||||
|
description: ID of a list
|
||||||
|
required: true
|
||||||
|
schema:
|
||||||
|
type: integer
|
||||||
|
- name: trackid
|
||||||
|
in: path
|
||||||
|
description: ID of a track
|
||||||
|
required: true
|
||||||
|
schema:
|
||||||
|
type: integer
|
||||||
|
responses:
|
||||||
|
200:
|
||||||
|
description: Track data
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/Track'
|
||||||
|
|
||||||
|
components:
|
||||||
|
schemas:
|
||||||
|
ListArray:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
$ref: '#/components/schemas/List'
|
||||||
|
List:
|
||||||
|
required:
|
||||||
|
- id
|
||||||
|
- tracklist
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
id:
|
||||||
|
type: integer
|
||||||
|
tracklist:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
$ref: '#/components/schemas/Track'
|
||||||
|
Track:
|
||||||
|
required:
|
||||||
|
- id
|
||||||
|
- title
|
||||||
|
- artist
|
||||||
|
- album
|
||||||
|
- spotify_id
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
id:
|
||||||
|
type: integer
|
||||||
|
title:
|
||||||
|
type: string
|
||||||
|
artist:
|
||||||
|
type: string
|
||||||
|
album:
|
||||||
|
type: string
|
||||||
|
spotify_id:
|
||||||
|
type: string
|
||||||
|
LoginToken:
|
||||||
|
required:
|
||||||
|
- token
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
token:
|
||||||
|
type: string
|
||||||
|
User:
|
||||||
|
required:
|
||||||
|
- name
|
||||||
|
- password
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
name:
|
||||||
|
type: string
|
||||||
|
password:
|
||||||
|
type: string
|
||||||
|
ApiResponse:
|
||||||
|
required:
|
||||||
|
- message
|
||||||
|
- status
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
status:
|
||||||
|
type: string
|
||||||
|
message:
|
||||||
|
type: string
|
Loading…
Reference in New Issue
Block a user