Skip to content

Commit

Permalink
allowEmptyValue flag is ignored #190
Browse files Browse the repository at this point in the history
  • Loading branch information
Carmine DiMascio committed Dec 30, 2019
1 parent 72428c2 commit 7ce125a
Show file tree
Hide file tree
Showing 5 changed files with 63 additions and 7 deletions.
20 changes: 13 additions & 7 deletions src/middlewares/openapi.request.validator.ts
Original file line number Diff line number Diff line change
Expand Up @@ -115,7 +115,7 @@ export class RequestValidator {
mutator.modifyRequest(req);

if (!this.requestOpts.allowUnknownQueryParameters) {
this.rejectUnknownQueryParams(
this.processQueryParam(
req.query,
schema.properties.query,
securityQueryParam,
Expand All @@ -141,22 +141,28 @@ export class RequestValidator {
};
}

private rejectUnknownQueryParams(
query,
schema,
whiteList: string[] = [],
): void {
private processQueryParam(query, schema, whiteList: string[] = []) {
if (!schema.properties) return;
const knownQueryParams = new Set(Object.keys(schema.properties));
whiteList.forEach(item => knownQueryParams.add(item));
const queryParams = Object.keys(query);
const allowedEmpty = schema.allowEmptyValue;
for (const q of queryParams) {
if (!knownQueryParams.has(q)) {
if (
!this.requestOpts.allowUnknownQueryParameters &&
!knownQueryParams.has(q)
) {
throw validationError(
400,
`.query.${q}`,
`Unknown query parameter ${q}`,
);
} else if (!allowedEmpty?.has(q) && (query[q] === '' || null)) {
throw validationError(
400,
`.query.${q}`,
`query parameter ${q} has empty value`,
);
}
}
}
Expand Down
6 changes: 6 additions & 0 deletions src/middlewares/parsers/schema.parse.ts
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,12 @@ export class ParametersSchemaParser {
}

schemas[reqField].properties[name] = schema;
if (reqField === 'query' && parameter.allowEmptyValue) {
if (!schemas[reqField].allowEmptyValue) {
schemas[reqField].allowEmptyValue = new Set<string>();
}
schemas[reqField].allowEmptyValue.add(name);
}
if (parameter.required) {
if (!schemas[reqField].required) {
schemas[reqField].required = [];
Expand Down
2 changes: 2 additions & 0 deletions test/query.params.allow.unknown.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ describe(packageJson.name, () => {
request(app)
.get(`${app.basePath}/pets`)
.query({
name: 'max',
tags: 'one,two,three',
limit: 10,
breed: 'german_shepherd',
Expand All @@ -43,6 +44,7 @@ describe(packageJson.name, () => {
request(app)
.get(`${app.basePath}/pets`)
.query({
name: 'max',
tags: 'one,two,three',
limit: 10,
breed: 'german_shepherd',
Expand Down
35 changes: 35 additions & 0 deletions test/query.params.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ describe(packageJson.name, () => {
request(app)
.get(`${app.basePath}/pets`)
.query({
name: 'max',
tags: 'one,two,three',
limit: 10,
breed: 'german_shepherd',
Expand All @@ -40,6 +41,7 @@ describe(packageJson.name, () => {
request(app)
.get(`${app.basePath}/pets`)
.query({
name: 'max',
tags: 'one,two,three',
limit: 10,
breed: 'german_shepherd',
Expand All @@ -50,4 +52,37 @@ describe(packageJson.name, () => {
.then(r => {
expect(r.body.errors).to.be.an('array');
}));

it('should not allow empty query param value', async () =>
request(app)
.get(`${app.basePath}/pets`)
.query({
name: 'max',
tags: 'one,two,three',
limit: 10,
breed: '',
owner_name: 'carmine',
})
.expect(400)
.then(r => {
expect(r.body)
.to.have.property('message')
.that.equals('query parameter breed has empty value');
expect(r.body.errors)
.to.be.an('array')
.with.length(1);
expect(r.body.errors[0].path).to.equal('.query.breed');
}));

it('should allow empty query param value with allowEmptyValue: true', async () =>
request(app)
.get(`${app.basePath}/pets`)
.query({
name: '',
tags: 'one,two,three',
limit: 10,
breed: 'german_shepherd',
owner_name: 'carmine',
})
.expect(200));
});
7 changes: 7 additions & 0 deletions test/resources/query.params.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,13 @@ paths:
description: |
Returns all pets from the system that the user has access tp
parameters:
- name: name
in: query
description: name
required: true
schema:
type: string
allowEmptyValue: true
- name: tags
in: query
description: tags to filter by
Expand Down

0 comments on commit 7ce125a

Please sign in to comment.