add updates to results and sample services

This commit is contained in:
Torma Kristóf 2021-08-17 16:28:27 +02:00
parent 06df9ec4eb
commit dba9c3b11b
Signed by: tormakris
GPG Key ID: DC83C4F2C41B1047
2 changed files with 238 additions and 0 deletions

View File

@ -33,6 +33,40 @@ paths:
'application/JSON': 'application/JSON':
schema: schema:
$ref: '#/components/schemas/ApiResponse' $ref: '#/components/schemas/ApiResponse'
/output/count:
get:
tags:
- output
summary: Get number of decision objects
operationId: getcount
responses:
200:
description: Number of decision objects
content:
'application/JSON':
schema:
$ref: '#/components/schemas/Count'
/output/page/{pageNum}:
get:
tags:
- output
summary: Get decision objects (paginated, filter is always 10)
operationId: getpage
parameters:
- name: pageNum
in: path
description: Number of page
required: true
schema:
type: integer
minimum: 0
responses:
200:
description: Array of decision objects
content:
'application/JSON':
schema:
$ref: '#/components/schemas/ResultObjects'
/output/filter/negative: /output/filter/negative:
get: get:
tags: tags:
@ -172,3 +206,7 @@ components:
type: string type: string
message: message:
type: string type: string
Count:
type: integer
properties:
minimum: 0

200
sample-service.yml Normal file
View File

@ -0,0 +1,200 @@
openapi: 3.0.3
info:
title: Sample Service
description: This is the feature extraction interface of the Birbnetes system.
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://birb.k8s.kmlabz.com
tags:
- name: sample
description: Sample Service interaction
paths:
/sample:
get:
tags:
- sample
summary: Get all sample objects
operationId: getall
responses:
200:
description: Array of sample objects
content:
'application/JSON':
schema:
$ref: '#/components/schemas/ResultObjects'
404:
description: No object matching filter
content:
'application/JSON':
schema:
$ref: '#/components/schemas/ApiResponse'
/sample/count:
get:
tags:
- sample
summary: Get number of sample objects
operationId: getcount
responses:
200:
description: Number of sample objects
content:
'application/JSON':
schema:
$ref: '#/components/schemas/Count'
/sample/page/{pageNum}:
get:
tags:
- sample
summary: Get sample objects (paginated, filter is always 10)
operationId: getpage
parameters:
- name: pageNum
in: path
description: Number of page
required: true
schema:
type: integer
minimum: 0
responses:
200:
description: Array of sample objects
content:
'application/JSON':
schema:
$ref: '#/components/schemas/ResultObjects'
/sample/after/{dateAfter}:
get:
tags:
- sample
summary: Get sample before a date
operationId: getallafter
parameters:
- name: dateAfter
in: path
description: Date of filter
required: true
schema:
type: string
format: date
responses:
200:
description: Array of sample objects
content:
'application/JSON':
schema:
$ref: '#/components/schemas/ResultObjects'
404:
description: No object matching filter
content:
'application/JSON':
schema:
$ref: '#/components/schemas/ApiResponse'
/sample/before/{dateBefore}:
get:
tags:
- sample
summary: Get sample before a date
operationId: getallbefore
parameters:
- name: dateBefore
in: path
description: Date of filter
required: true
schema:
type: string
format: date
responses:
200:
description: Array of sample objects
content:
'application/JSON':
schema:
$ref: '#/components/schemas/ResultObjects'
404:
description: NO objects matching filter
content:
'application/JSON':
schema:
$ref: '#/components/schemas/ApiResponse'
/sample/device_id/{deviceId}:
get:
tags:
- sample
summary: Get sample of device
operationId: getsampledevice
parameters:
- name: deviceId
in: path
description: Device id
required: true
schema:
type: integer
responses:
200:
description: Array of sample objects
content:
'application/JSON':
schema:
$ref: '#/components/schemas/ResultObjects'
404:
description: NO objects matching filter
content:
'application/JSON':
schema:
$ref: '#/components/schemas/ApiResponse'
/sample/{tagID}:
get:
tags:
- sample
summary: Get sample by ID
operationId: getsampleid
parameters:
- name: tagID
in: path
description: ID of wave file
required: true
schema:
type: integer
format: int32
responses:
200:
description: sample object
content:
'application/JSON':
schema:
$ref: '#/components/schemas/ResultObject'
404:
description: Tag not found
content:
'application/JSON':
schema:
$ref: '#/components/schemas/ApiResponse'
components:
schemas:
ResultObjects:
type: array
items:
$ref: '#/components/schemas/ResultObject'
ResultObject:
type: object
properties:
tag:
type: string
probability:
type: number
ApiResponse:
type: object
properties:
status:
type: string
message:
type: string
Count:
type: integer
properties:
minimum: 0