UNPKG

@arisan/data-api

Version:

The Universal Database API Gateway for CLIO's Modules

99 lines (80 loc) 3.27 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = mountStreamStatus; var _bodyParser = require('body-parser'); var _bodyParser2 = _interopRequireDefault(_bodyParser); var _express = require('express'); var _express2 = _interopRequireDefault(_express); var _mongodb = require('mongodb'); var _mongodb2 = _interopRequireDefault(_mongodb); var _checkObjectID = require('../middleware/checkObjectID'); var _checkObjectID2 = _interopRequireDefault(_checkObjectID); var _checkStreamIndex = require('../middleware/checkStreamIndex'); var _checkStreamIndex2 = _interopRequireDefault(_checkStreamIndex); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } //endregion //endregion //region 2. Project Libraries const context = { router: _express2.default.Router({ mergeParams: true }), serviceEvents: null, logger: null }; //region 1. Platform Libraries context.router.use('/', _checkObjectID2.default); context.router.use('/', _checkStreamIndex2.default); context.router.put('/', _bodyParser2.default.json()); context.router.put('/', (req, res) => { const log = (lvl, msg) => context.logger.log(lvl, msg, { tags: `PUT ${req.originalUrl}` }); log('debug', JSON.stringify(req.body, null, 2)); if (req.body.length === 0) { const message = 'No Request or Request Body'; log('error', message); res.status(400).send(message); return; } ['recorderId', 'module', 'status'].forEach(property => { if ({}.hasOwnProperty.call(req.body, property)) { return; } const message = `Video Info Contains No ${property}`; log('error', message); res.status(400).send(message); throw new Error(message); }); const serviceEvent = { camera_id: new _mongodb2.default.ObjectId(req.params.id), stream_index: parseInt(req.params.index, 10), service_name: req.body.module, service_id: new _mongodb2.default.ObjectId(req.body.recorderId), message: req.body.status, created: new Date() }; context.serviceEvents.insert(serviceEvent, serviceEventsInsertErr => { if (serviceEventsInsertErr) { log('error', serviceEventsInsertErr.message); res.status(500).send(serviceEventsInsertErr.message); return; } log('info', '200 OK'); res.sendStatus(200); }); }); //noinspection JSUnusedGlobalSymbols /** * Mount router for /c/:/s/:/status * @param {object} options Options * @param {object} options.app Express App * @param {MongoClient.Db} options.database Associated Database * @param {winston.Logger} options.logger Logger */ function mountStreamStatus(options) { context.logger = options.logger; const log = (lvl, msg) => context.logger.log(lvl, msg, { tags: 'mountStreamStatus' }); log('debug', 'Mounting router for /c/:/s/:/status....'); options.app.use('/cameras/:id/streams/:index/status', context.router); context.serviceEvents = options.database.collection('service_events'); log('info', 'Router for /c/:/s/:/status Mounted'); } //# sourceMappingURL=mountStreamStatus.js.map