1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-25 00:07:47 +01:00

Fix feature name validation regex

This commit is contained in:
Martin Lehmann 2017-10-23 17:13:26 +02:00 committed by Ivar Conradi Østhus
parent a48deea0bb
commit c957aeba94
2 changed files with 32 additions and 2 deletions

View File

@ -15,6 +15,8 @@ const ValidationError = require('../../error/validation-error.js');
const validateRequest = require('../../error/validate-request');
const extractUser = require('../../extract-user');
const nameRegex = /^[0-9a-zA-Z\-._]+$/;
const handleErrors = (req, res, error) => {
logger.warn('Error creating or updating feature', error);
switch (error.constructor) {
@ -115,8 +117,8 @@ module.exports.router = function(config) {
router.post('/', (req, res) => {
req.checkBody('name', 'Name is required').notEmpty();
req
.checkBody('name', 'Name must match format ^[0-9a-zA-Z\\.\\-\\_]+$')
.matches(/^[0-9a-zA-Z\\.\\-\\_]+$/i);
.checkBody('name', `Name must match format ${nameRegex.source}`)
.matches(nameRegex);
const userName = extractUser(req);
validateRequest(req)

View File

@ -95,3 +95,31 @@ test('should require at least one strategy when updating a feature toggle', t =>
.set('Content-Type', 'application/json')
.expect(400);
});
test('valid feature names pass validation', async t => {
t.plan(0);
const { request, base } = getSetup();
const validNames = [
'com.example',
'com.exampleFeature',
'com.example-company.feature',
'com.example-company.exampleFeature',
'123',
'com.example-company.someFeature.123',
];
return Promise.all(
validNames.map(name =>
request
.post(`${base}/api/admin/features`)
.send({
name,
enabled: false,
strategies: [{ name: 'default' }],
})
.set('Content-Type', 'application/json')
.expect(201)
)
);
});