add rest API for update Device note (#222)

* add rest API for update Device note

Signed-off-by: Jussi Vatjus-Anttila <jussiva@gmail.com>

* improve failure message

Signed-off-by: Jussi Vatjus-Anttila <jussiva@gmail.com>

Co-authored-by: Karol Wrótniak <karol.wrotniak@droidsonroids.pl>
This commit is contained in:
Jussi Vatjus-Anttila
2021-04-06 12:21:38 +03:00
committed by GitHub
parent 38cb66b1bd
commit 3370f679bc
2 changed files with 76 additions and 0 deletions

View File

@@ -459,6 +459,32 @@ function removeOriginGroupDevice(req, res) {
apiutil.redirectApiWrapper('serial', removeOriginGroupDevices, req, res)
}
function putDeviceInfoBySerial(req, res) {
const serial = req.swagger.params.serial.value
const body = req.swagger.params.device.value.device
dbapi.loadDeviceBySerial(serial)
.then((data) => {
if (!data) {
return apiutil.respond(res, 404, `Not Found (${serial})`)
}
var updates = []
// Update fields based on given body
if (_.has(body, 'note')) {
updates.push(dbapi.setDeviceNote(serial, body.note))
}
if (updates.length === 0) {
return apiutil.respond(res, 400, 'No content to update')
}
return Promise.all(updates)
.then(function() {
apiutil.respond(res, 200)
})
})
.catch(function(err) {
apiutil.internalError(res, 'Failed to update device: ', err.stack)
})
}
function deleteDevices(req, res) {
const serials = apiutil.getBodyParameter(req.body, 'serials')
const target = apiutil.getQueryParameter(req.swagger.params.redirected) ? 'device' : 'devices'
@@ -509,12 +535,17 @@ function deleteDevices(req, res) {
})
}
function putDeviceBySerial(req, res) {
apiutil.redirectApiWrapper('serial', putDeviceInfoBySerial, req, res)
}
function deleteDevice(req, res) {
apiutil.redirectApiWrapper('serial', deleteDevices, req, res)
}
module.exports = {
getDevices: getDevices
, putDeviceBySerial: putDeviceBySerial
, getDeviceBySerial: getDeviceBySerial
, getDeviceGroups: getDeviceGroups
, getDeviceBookings: getDeviceBookings

View File

@@ -1877,6 +1877,45 @@ paths:
$ref: "#/definitions/UnexpectedErrorResponse"
security:
- accessTokenAuth: []
put:
summary: Adds device informatin
description: Adds device information
operationId: putDeviceBySerial
consumes:
- application/json
tags:
- admin
parameters:
- name: serial
in: path
description: Device identifier (serial)
required: true
type: string
- name: device
in: body
description: >
Information to add for device. Supports only notes -field.
required: true
schema:
$ref: "#/definitions/DevicePayload"
responses:
"200":
description: Storing success
schema:
$ref: "#/definitions/Response"
default:
description: >
Unexpected Error:
* 400: Bad Request => invalid request
* 401: Unauthorized => bad credentials
* 404: Not Found => unknown device
* 500: Internal Server Error
* 503: Service Unavailable => server too busy or a lock on a resource is pending
* 504: Gateway Time-out => server is not responding
schema:
$ref: "#/definitions/UnexpectedErrorResponse"
security:
- accessTokenAuth: [ ]
/devices/groups/{id}:
x-swagger-router-controller: devices
put:
@@ -2380,6 +2419,12 @@ definitions:
emails:
description: Comma-separated list of emails
type: string
DevicePayload:
description: payload object for adding device information
properties:
note:
description: Device Note
type: string
DevicesPayload:
description: Payload object for adding/removing devices
properties: