all files / lib/routers/ mountLiveInfo.js

39.13% Statements 27/69
25% Branches 4/16
100% Functions 2/2
37.88% Lines 25/66
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123                                                                                                                                                                                                16×    
'use strict';
 
Object.defineProperty(exports, "__esModule", {
        value: true
});
exports.default = mountLiveInfo;
 
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);
 
var _DataAPI = require('../DataAPI');
 
var _DataAPI2 = _interopRequireDefault(_DataAPI);
 
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 
//endregion
 
const context = {
        router: _express2.default.Router({ mergeParams: true }),
        cameras: null,
        streamers: null,
        logger: null
};
//endregion
 
//region 2. Project Libraries
//region 1. Platform Libraries
 
 
context.router.get('/', _checkObjectID2.default);
context.router.get('/', _checkStreamIndex2.default);
context.router.get('/', (req, res) => {
        const log = (lvl, msg) => context.logger.log(lvl, msg, { tags: `GET ${ req.originalUrl }` });
        log('debug', JSON.stringify(req.params, null, 2));
        const _id = new _mongodb2.default.ObjectID(req.params.id);
        context.cameras.findOne({ _id }, (findOneCameraErr, camera) => {
                if (findOneCameraErr) {
                        log('error', findOneCameraErr.message);
                        res.status(500).send(findOneCameraErr.message);
                        return;
                }
                if (!camera) {
                        const message = 'Camera Not Found';
                        log('error', message);
                        res.status(500).send(message);
                        return;
                }
                /** @type Stream */
                const stream = camera.streams[req.params.index];
                if (!stream) {
                        const message = 'Stream Not Found';
                        log('error', message);
                        res.status(500).send(message);
                        return;
                }
                const rtspUrl = stream.rtsp_url;
                if (!rtspUrl) {
                        const message = 'RTSP URL Not Found';
                        log('error', message);
                        res.status(500).send(message);
                        return;
                }
                const reply = {
                        rtspUrl,
                        audio: 'OFF'
                };
                const expired = new Date(Date.now() - (_DataAPI2.default.heartbeatInterval + 3) * 1000);
                context.streamers.findOne({
                        updated: { $gt: expired }
                }, {
                        sort: { cpu_load: 1 }
                }, (findOneStreamerErr, streamer) => {
                        if (findOneStreamerErr) {
                                log('error', findOneStreamerErr.message);
                                res.status(500).send(findOneStreamerErr.message);
                                return;
                        }
                        if (!streamer) {
                                const message = 'No Streamer Available';
                                log('error', message);
                                res.status(500).send(message);
                                return;
                        }
                        reply.streamerUrl = `http://${ streamer.private_ip }:${ streamer.port }`;
                        log('info', '200 OK');
                        log('debug', JSON.stringify(reply, null, 2));
                        res.status(200).send(reply);
                });
        });
});
 
//noinspection JSUnusedGlobalSymbols
/**
 * Mount router for /c/:/s/:/live-info
 * @param {object}         options          Options
 * @param {object}         options.app      Express App
 * @param {MongoClient.Db} options.database Associated Database
 * @param {winston.Logger} options.logger   Logger
 */
function mountLiveInfo(options) {
        context.logger = options.logger;
        const log = (lvl, msg) => context.logger.log(lvl, msg, { tags: 'mountLiveInfo' });
        log('debug', 'Mounting router for /c/:/s/:/live-info....');
        options.app.use('/cameras/:id/streams/:index/live-info', context.router);
        context.cameras = options.database.collection('cameras');
        context.streamers = options.database.collection('streamers');
        log('info', 'Router for /c/:/s/:/live-info Mounted');
}
//# sourceMappingURL=mountLiveInfo.js.map