1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-20 00:08:02 +01:00
unleash.unleash/packages/unleash-api/lib/routes/metrics.js

68 lines
2.0 KiB
JavaScript
Raw Normal View History

'use strict';
const logger = require('../logger');
const ClientMetrics = require('../client-metrics');
2016-11-04 16:19:31 +01:00
const ClientMetricsService = require('../client-metrics/service');
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,
clientStrategyStore,
clientInstanceStore,
} = config.stores;
const metrics = new ClientMetrics();
2016-11-05 13:36:44 +01:00
const service = new ClientMetricsService(clientMetricsStore);
2016-11-02 12:49:25 +01:00
service.on('metrics', (entries) => {
2016-11-04 16:16:55 +01:00
entries.forEach((m) => {
metrics.addPayload(m.metrics);
});
2016-11-02 12:49:25 +01:00
});
2016-11-04 16:16:55 +01:00
app.get('/metrics', (req, res) => {
res.json(metrics.getMetricsOverview());
2016-11-02 12:49:25 +01:00
});
2016-10-27 16:55:38 +02:00
2016-11-05 11:50:34 +01:00
app.get('/metrics/features', (req, res) => {
2016-11-04 16:16:55 +01:00
res.json(metrics.getTogglesMetrics());
});
2016-11-02 12:49:25 +01:00
app.post('/client/metrics', (req, res) => {
try {
2016-11-02 12:49:25 +01:00
const data = typeof req.body === 'string' ? JSON.parse(req.body) : req.body;
2016-11-04 16:16:55 +01:00
service
.insert(data)
.catch(e => logger.error('Error inserting metrics data', e));
} catch (e) {
2016-11-02 12:49:25 +01:00
logger.error('Error receiving metrics', e);
}
res.end();
});
2016-10-27 16:55:38 +02: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;
clientStrategyStore.insert(data.appName, data.strategies)
.then(() => clientStrategyStore.insert({
2016-11-04 23:02:55 +01:00
appName: data.appName,
instanceId: data.instanceId,
2016-11-05 12:42:58 +01:00
clientIp,
2016-11-04 23:02:55 +01:00
}))
.then(() => console.log('new client registerd'))
.catch((error) => logger.error('Error registering client', error));
2016-11-02 12:49:25 +01:00
res.end();
2016-10-27 16:55:38 +02:00
});
2016-11-02 23:17:28 +01:00
app.get('/client/strategies', (req, res) => {
clientStrategyStore.getAll().then(data => res.json(data));
2016-11-02 23:17:28 +01:00
});
2016-11-04 23:02:55 +01:00
app.get('/client/instances', (req, res) => {
clientInstanceStore.getAll()
2016-11-04 23:02:55 +01:00
.then(data => res.json(data))
.catch(err => console.error(err));
});
};