2016-10-27 13:13:51 +02:00
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
|
|
const logger = require('../logger');
|
|
|
|
|
const ClientMetrics = require('../client-metrics');
|
2016-11-09 11:16:44 +01:00
|
|
|
|
const joi = require('joi');
|
2016-11-11 15:46:59 +01:00
|
|
|
|
const { clientMetricsSchema, clientRegisterSchema } = require('./metrics-schema');
|
2016-12-01 17:15:55 +01:00
|
|
|
|
const { catchLogAndSendErrorResponse } = require('./route-utils');
|
|
|
|
|
|
2016-10-27 16:55:38 +02:00
|
|
|
|
module.exports = function (app, config) {
|
2016-11-04 23:02:55 +01:00
|
|
|
|
const {
|
2016-11-05 13:36:44 +01:00
|
|
|
|
clientMetricsStore,
|
2016-11-05 14:08:47 +01:00
|
|
|
|
clientStrategyStore,
|
|
|
|
|
clientInstanceStore,
|
|
|
|
|
} = config.stores;
|
2016-11-30 23:41:57 +01:00
|
|
|
|
|
2016-11-28 17:11:11 +01:00
|
|
|
|
const metrics = new ClientMetrics(clientMetricsStore);
|
|
|
|
|
|
|
|
|
|
app.get('/client/seen-toggles', (req, res) => {
|
|
|
|
|
const seenAppToggles = metrics.getAppsWitToggles();
|
|
|
|
|
res.json(seenAppToggles);
|
2016-11-02 12:49:25 +01:00
|
|
|
|
});
|
2016-10-27 16:55:38 +02:00
|
|
|
|
|
2016-12-01 17:15:55 +01:00
|
|
|
|
app.get('/client/metrics/feature-toggles', (req, res) => {
|
2016-11-04 16:16:55 +01:00
|
|
|
|
res.json(metrics.getTogglesMetrics());
|
2016-10-27 13:13:51 +02:00
|
|
|
|
});
|
|
|
|
|
|
2016-11-02 12:49:25 +01:00
|
|
|
|
app.post('/client/metrics', (req, res) => {
|
2016-11-11 15:46:59 +01:00
|
|
|
|
const data = req.body;
|
2016-11-28 17:11:11 +01:00
|
|
|
|
const clientIp = req.ip;
|
|
|
|
|
|
2016-11-11 15:46:59 +01:00
|
|
|
|
joi.validate(data, clientMetricsSchema, (err, cleaned) => {
|
|
|
|
|
if (err) {
|
|
|
|
|
return res.status(400).json(err);
|
2016-11-09 11:16:44 +01:00
|
|
|
|
}
|
2016-11-28 17:11:11 +01:00
|
|
|
|
|
|
|
|
|
clientMetricsStore
|
|
|
|
|
.insert(cleaned)
|
|
|
|
|
.then(() => clientInstanceStore.insert({
|
|
|
|
|
appName: cleaned.appName,
|
|
|
|
|
instanceId: cleaned.instanceId,
|
|
|
|
|
clientIp,
|
|
|
|
|
}))
|
2016-12-02 17:19:59 +01:00
|
|
|
|
.catch(err => logger.error('failed to store metrics', err));
|
2016-11-11 15:46:59 +01:00
|
|
|
|
|
|
|
|
|
res.status(202).end();
|
|
|
|
|
});
|
2016-11-09 11:16:44 +01:00
|
|
|
|
});
|
|
|
|
|
|
2016-11-02 12:49:25 +01:00
|
|
|
|
app.post('/client/register', (req, res) => {
|
2016-11-04 23:02:55 +01:00
|
|
|
|
const data = req.body;
|
2016-11-05 12:42:58 +01:00
|
|
|
|
const clientIp = req.ip;
|
2016-11-02 12:49:25 +01:00
|
|
|
|
|
2016-11-09 11:16:44 +01:00
|
|
|
|
joi.validate(data, clientRegisterSchema, (err, cleaned) => {
|
|
|
|
|
if (err) {
|
2016-11-10 22:05:50 +01:00
|
|
|
|
return res.status(400).json(err);
|
2016-11-09 11:16:44 +01:00
|
|
|
|
}
|
|
|
|
|
|
2016-11-28 17:11:11 +01:00
|
|
|
|
clientStrategyStore
|
|
|
|
|
.insert(cleaned.appName, cleaned.strategies)
|
2016-11-09 11:16:44 +01:00
|
|
|
|
.then(() => clientInstanceStore.insert({
|
|
|
|
|
appName: cleaned.appName,
|
|
|
|
|
instanceId: cleaned.instanceId,
|
|
|
|
|
clientIp,
|
|
|
|
|
}))
|
2016-12-01 17:15:55 +01:00
|
|
|
|
.then(() => logger.info(`New client registered with
|
|
|
|
|
appName=${cleaned.appName} and instanceId=${cleaned.instanceId}`))
|
2016-12-02 17:19:59 +01:00
|
|
|
|
.catch(err => logger.error('failed to register client', err));
|
2016-11-09 11:16:44 +01:00
|
|
|
|
|
2016-11-11 15:46:59 +01:00
|
|
|
|
res.status(202).end();
|
2016-11-09 11:16:44 +01:00
|
|
|
|
});
|
2016-10-27 16:55:38 +02:00
|
|
|
|
});
|
2016-11-02 23:17:28 +01:00
|
|
|
|
|
|
|
|
|
app.get('/client/strategies', (req, res) => {
|
2016-11-28 17:11:11 +01:00
|
|
|
|
const appName = req.query.appName;
|
|
|
|
|
if(appName) {
|
|
|
|
|
clientStrategyStore.getByAppName(appName)
|
|
|
|
|
.then(data => res.json(data))
|
2016-12-01 17:15:55 +01:00
|
|
|
|
.catch(err => catchLogAndSendErrorResponse(err, res));
|
2016-11-28 17:11:11 +01:00
|
|
|
|
} else {
|
|
|
|
|
clientStrategyStore.getAll()
|
|
|
|
|
.then(data => res.json(data))
|
2016-12-01 17:15:55 +01:00
|
|
|
|
.catch(err => catchLogAndSendErrorResponse(err, res));
|
2016-11-28 17:11:11 +01:00
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
app.get('/client/applications/', (req, res) => {
|
|
|
|
|
clientInstanceStore.getApplications()
|
|
|
|
|
.then(apps => {
|
|
|
|
|
const applications = apps.map(({appName}) => ({
|
|
|
|
|
appName: appName,
|
|
|
|
|
links: {
|
|
|
|
|
appDetails: `/api/client/applications/${appName}`
|
|
|
|
|
}
|
|
|
|
|
}))
|
|
|
|
|
res.json({applications})
|
|
|
|
|
})
|
2016-12-01 17:15:55 +01:00
|
|
|
|
.catch(err => catchLogAndSendErrorResponse(err, res));
|
2016-11-02 23:17:28 +01:00
|
|
|
|
});
|
2016-11-04 23:02:55 +01:00
|
|
|
|
|
2016-11-28 17:11:11 +01:00
|
|
|
|
app.get('/client/applications/:appName', (req, res) => {
|
|
|
|
|
const appName = req.params.appName;
|
|
|
|
|
const seenToggles = metrics.getSeenTogglesByAppName(appName);
|
|
|
|
|
Promise.all([
|
|
|
|
|
clientInstanceStore.getByAppName(appName),
|
|
|
|
|
clientStrategyStore.getByAppName(appName)
|
|
|
|
|
])
|
|
|
|
|
.then(([instances, strategies]) => res.json({appName, instances, strategies, seenToggles}))
|
2016-12-01 17:15:55 +01:00
|
|
|
|
.catch(err => catchLogAndSendErrorResponse(err, res));
|
2016-11-04 23:02:55 +01:00
|
|
|
|
});
|
2016-10-27 13:13:51 +02:00
|
|
|
|
};
|