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

fix: Add validation of required parameters

This commit is contained in:
Christopher Kolstad 2021-02-05 14:07:46 +01:00 committed by Ivar Conradi Østhus
parent 65996e72e0
commit dcf1224a17
2 changed files with 68 additions and 1 deletions

View File

@ -1,6 +1,7 @@
'use strict';
const memoize = require('memoizee');
const { ValidationError } = require('joi');
const addonProvidersClasses = require('../addons');
const events = require('../event-type');
const { addonSchema } = require('./addon-schema');
@ -147,6 +148,7 @@ class AddonService {
async createAddon(data, userName) {
const addonConfig = await addonSchema.validateAsync(data);
await this.validateKnownProvider(addonConfig);
await this.validateRequiredParameters(addonConfig);
const createdAddon = await this.addonStore.insert(addonConfig);
await this.addTagTypes(createdAddon.provider);
@ -166,6 +168,7 @@ class AddonService {
async updateAddon(id, data, userName) {
const addonConfig = await addonSchema.validateAsync(data);
await this.validateRequiredParameters(addonConfig);
if (this.sensitiveParams[addonConfig.provider].length > 0) {
const existingConfig = await this.addonStore.get(id);
addonConfig.parameters = Object.keys(addonConfig.parameters).reduce(
@ -208,6 +211,27 @@ class AddonService {
return true;
}
}
async validateRequiredParameters({ provider, parameters }) {
const providerDefinition = this.addonProviders[provider].definition;
const requiredParamsMissing = providerDefinition.parameters
.filter(p => p.required)
.map(p => p.name)
.filter(
requiredParam =>
!Object.keys(parameters).includes(requiredParam),
);
if (requiredParamsMissing.length > 0) {
throw new ValidationError(
`Missing required parameters: ${requiredParamsMissing.join(
',',
)} `,
'',
);
}
return true;
}
}
module.exports = AddonService;

View File

@ -2,7 +2,7 @@
const test = require('ava');
const proxyquire = require('proxyquire').noCallThru();
const { ValidationError } = require('joi');
const Addon = require('../addons/addon');
const store = require('../../test/fixtures/store');
@ -319,3 +319,46 @@ test('should not overwrite masked values when updating', async t => {
t.is(updatedConfig.parameters.url, 'http://localhost/wh');
t.is(updatedConfig.parameters.var, 'some-new-value');
});
test('should reject addon config with missing required parameter when creating', async t => {
const { addonService } = getSetup();
const config = {
provider: 'simple',
enabled: true,
parameters: {
var: 'some-value',
},
events: [FEATURE_CREATED],
};
await t.throwsAsync(
async () => addonService.createAddon(config, 'me@mail.com'),
{ instanceOf: ValidationError },
);
});
test('should reject updating addon config with missing required parameter', async t => {
const { addonService } = getSetup();
const addonConfig = {
provider: 'simple',
enabled: true,
parameters: {
url: 'https://some.site/api',
var: 'some-value',
},
events: [FEATURE_CREATED],
};
const config = await addonService.createAddon(addonConfig, 'me@mail.com');
const updated = {
...config,
parameters: { var: 'some-new-value' },
description: 'test',
};
await t.throwsAsync(
async () => addonService.updateAddon(config.id, updated, 'me@mail.com'),
{ instanceOf: ValidationError },
);
});