1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-01 00:08:27 +01:00

add joy validation to client input data

This commit is contained in:
sveisvei 2016-11-09 11:16:44 +01:00
parent a84289fb95
commit c3dfd81eea
2 changed files with 48 additions and 12 deletions

View File

@ -3,6 +3,7 @@
const logger = require('../logger'); const logger = require('../logger');
const ClientMetrics = require('../client-metrics'); const ClientMetrics = require('../client-metrics');
const ClientMetricsService = require('../client-metrics/service'); const ClientMetricsService = require('../client-metrics/service');
const joi = require('joi');
module.exports = function (app, config) { module.exports = function (app, config) {
const { const {
@ -27,27 +28,60 @@ module.exports = function (app, config) {
res.json(metrics.getTogglesMetrics()); res.json(metrics.getTogglesMetrics());
}); });
const clientMetricsSchema = joi.object().keys({
appName: joi.string().required(),
instanceId: joi.string().required(),
bucket: joi.object().required()
.keys({
start: joi.date().required(),
stop: joi.date().required(),
toggles: joi.object()
.required()
.unknown()
.min(1)
.max(1000),
}),
});
app.post('/client/metrics', (req, res) => { app.post('/client/metrics', (req, res) => {
try { try {
const data = typeof req.body === 'string' ? JSON.parse(req.body) : req.body; const data = typeof req.body === 'string' ? JSON.parse(req.body) : req.body;
const result = joi.validate(data, clientMetricsSchema);
if (result.error) {
throw result.error;
}
service service
.insert(data) .insert(result.value)
.catch(e => logger.error('Error inserting metrics data', e)); .catch(e => logger.error('Error inserting metrics data', e));
} catch (e) { } catch (e) {
logger.error('Error receiving metrics', e); logger.error('Error receiving metrics', e);
} }
res.end(); res.end();
}); });
const clientRegisterSchema = joi.object().keys({
appName: joi.string().required(),
instanceId: joi.string().required(),
strategies: joi.array()
.required()
.items(joi.string(), joi.any().strip()),
started: joi.date().required(),
interval: joi.number().required(),
});
app.post('/client/register', (req, res) => { app.post('/client/register', (req, res) => {
const data = req.body; const data = req.body;
const clientIp = req.ip; const clientIp = req.ip;
console.log(data);
clientStrategyStore.insert(data.appName, data.strategies) joi.validate(data, clientRegisterSchema, (err, cleaned) => {
if (err) {
return res.json(400, err);
}
clientStrategyStore.insert(cleaned.appName, cleaned.strategies)
.then(() => clientInstanceStore.insert({ .then(() => clientInstanceStore.insert({
appName: data.appName, appName: cleaned.appName,
instanceId: data.instanceId, instanceId: cleaned.instanceId,
clientIp, clientIp,
})) }))
.then(() => console.log('new client registerd')) .then(() => console.log('new client registerd'))
@ -55,6 +89,7 @@ module.exports = function (app, config) {
res.end(); res.end();
}); });
});
app.get('/client/strategies', (req, res) => { app.get('/client/strategies', (req, res) => {
clientStrategyStore.getAll().then(data => res.json(data)); clientStrategyStore.getAll().then(data => res.json(data));

View File

@ -57,6 +57,7 @@
"express": "4.14.0", "express": "4.14.0",
"express-validator": "2.20.8", "express-validator": "2.20.8",
"install": "^0.8.1", "install": "^0.8.1",
"joi": "^9.2.0",
"knex": "^0.12.6", "knex": "^0.12.6",
"log4js": "^0.6.38", "log4js": "^0.6.38",
"moment": "^2.15.2", "moment": "^2.15.2",