From 26533034b1977dd1bc0c3e27bce24b8a12274964 Mon Sep 17 00:00:00 2001 From: sveisvei Date: Sun, 8 Jan 2017 20:40:50 +0100 Subject: [PATCH] validate configures strategy shape --- lib/routes/feature.js | 29 ++++++++++++++++++++++++----- 1 file changed, 24 insertions(+), 5 deletions(-) diff --git a/lib/routes/feature.js b/lib/routes/feature.js index 458ee98d1d..5188d1b7c4 100644 --- a/lib/routes/feature.js +++ b/lib/routes/feature.js @@ -1,5 +1,6 @@ 'use strict'; +const joi = require('joi'); const logger = require('../logger'); const { FEATURE_CREATED, FEATURE_UPDATED, FEATURE_ARCHIVED } = require('../event-type'); const NameExistsError = require('../error/name-exists-error'); @@ -131,11 +132,29 @@ module.exports = function (app, config) { return Promise.resolve(req); } - function validateStrategy (featureToggle) { - if (!featureToggle.strategies || featureToggle.strategies.length === 0) { - return Promise.reject(new ValidationError('You must define at least one strategy')); - } - return Promise.resolve(featureToggle); + const strategiesSchema = joi.object().keys({ + name: joi.string() + .regex(/^[a-zA-Z0-9\\.\\-]{3,100}$/) + .required(), + parameters: joi.object(), + }); + + function validateStrategy (featureToggle) { + return new Promise((resolve, reject) => { + if (!featureToggle.strategies || featureToggle.strategies.length === 0) { + return reject(new ValidationError('You must define at least one strategy')); + } + + featureToggle.strategies = featureToggle.strategies.map((strategyConfig) => { + const result = joi.validate(strategyConfig, strategiesSchema); + if (result.error) { + throw result.error; + } + return result.value; + }); + + return resolve(featureToggle); + }); } };