Skip to content

Commit

Permalink
Change multipart to false by default. Closes hapijs#3920
Browse files Browse the repository at this point in the history
  • Loading branch information
hueniverse committed Sep 16, 2019
1 parent d8cb893 commit 0ee64bd
Show file tree
Hide file tree
Showing 3 changed files with 46 additions and 5 deletions.
6 changes: 4 additions & 2 deletions API.md
Original file line number Diff line number Diff line change
Expand Up @@ -3198,11 +3198,13 @@ cause the server to run out of memory.

#### <a name="route.options.payload.multipart" /> `route.options.payload.multipart`

Default value: none.
Default value: `false`.

Overrides payload processing for multipart requests. Value can be one of:

- `false` - disable multipart processing.
- `false` - disable multipart processing (this is the default value).

- `true` - enable multipart processing using the [`output`](#route.options.payload.output) value.

- an object with the following required options:

Expand Down
4 changes: 3 additions & 1 deletion lib/config.js
Original file line number Diff line number Diff line change
Expand Up @@ -143,7 +143,9 @@ internals.routeBase = Joi.object({
multipart: Joi.object({
output: Joi.valid('data', 'stream', 'file', 'annotated').required()
})
.allow(false),
.default(false)
.allow(true, false)
.when('.', { is: true, then: Joi.object().strip() }),
allow: Joi.array().items(Joi.string()).single(),
override: Joi.string(),
protoAction: Joi.valid('error', 'remove', 'ignore').default('error'),
Expand Down
41 changes: 39 additions & 2 deletions test/payload.js
Original file line number Diff line number Diff line change
Expand Up @@ -575,7 +575,7 @@ describe('Payload', () => {
};

const server = Hapi.server();
server.route({ method: 'POST', path: '/echo', handler });
server.route({ method: 'POST', path: '/echo', handler, options: { payload: { multipart: true } } });

const res = await server.inject({ method: 'POST', url: '/echo', payload: multipartPayload, headers: { 'content-type': 'multipart/form-data; boundary=AaB03x' } });
expect(Object.keys(res.result).length).to.equal(3);
Expand Down Expand Up @@ -698,10 +698,47 @@ describe('Payload', () => {
'--AaB03x--\r\n';

const server = Hapi.server();
server.route({ method: 'POST', path: '/echo', options: { handler: () => 'result', payload: { output: 'data', parse: true, maxBytes: 5 } } });
server.route({ method: 'POST', path: '/echo', options: { handler: () => 'result', payload: { output: 'data', parse: true, maxBytes: 5, multipart: true } } });

const res = await server.inject({ method: 'POST', url: '/echo', payload: multipartPayload, simulate: { split: true }, headers: { 'content-length': null, 'content-type': 'multipart/form-data; boundary=AaB03x' } });
expect(res.statusCode).to.equal(400);
expect(res.payload.toString()).to.equal('{"statusCode":400,"error":"Bad Request","message":"Invalid multipart payload format"}');
});

it('errors if multipart disabled (default)', async () => {

const multipartPayload =
'--AaB03x\r\n' +
'content-disposition: form-data; name="x"\r\n' +
'\r\n' +
'First\r\n' +
'--AaB03x\r\n' +
'content-disposition: form-data; name="x"\r\n' +
'\r\n' +
'Second\r\n' +
'--AaB03x\r\n' +
'content-disposition: form-data; name="x"\r\n' +
'\r\n' +
'Third\r\n' +
'--AaB03x\r\n' +
'content-disposition: form-data; name="field1"\r\n' +
'\r\n' +
'Joe Blow\r\nalmost tricked you!\r\n' +
'--AaB03x\r\n' +
'content-disposition: form-data; name="field1"\r\n' +
'\r\n' +
'Repeated name segment\r\n' +
'--AaB03x\r\n' +
'content-disposition: form-data; name="pics"; filename="file1.txt"\r\n' +
'Content-Type: text/plain\r\n' +
'\r\n' +
'... contents of file1.txt ...\r\r\n' +
'--AaB03x--\r\n';

const server = Hapi.server();
server.route({ method: 'POST', path: '/echo', options: { handler: () => 'result', payload: { output: 'data', parse: true, maxBytes: 5 } } });

const res = await server.inject({ method: 'POST', url: '/echo', payload: multipartPayload, simulate: { split: true }, headers: { 'content-length': null, 'content-type': 'multipart/form-data; boundary=AaB03x' } });
expect(res.statusCode).to.equal(415);
});
});

0 comments on commit 0ee64bd

Please sign in to comment.