You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					114 lines
				
				2.6 KiB
			
		
		
			
		
	
	
					114 lines
				
				2.6 KiB
			| 
											3 years ago
										 | 'use strict' | ||
|  | 
 | ||
|  | const util = require('util') | ||
|  | const test = require('tap').test | ||
|  | const FormData = require('form-data') | ||
|  | const Fastify = require('fastify') | ||
|  | const multipart = require('..') | ||
|  | const http = require('http') | ||
|  | const path = require('path') | ||
|  | const fs = require('fs') | ||
|  | const stream = require('stream') | ||
|  | const pump = util.promisify(stream.pipeline) | ||
|  | 
 | ||
|  | const filePath = path.join(__dirname, '../README.md') | ||
|  | 
 | ||
|  | test('should not allow __proto__ as file name', function (t) { | ||
|  |   t.plan(4) | ||
|  | 
 | ||
|  |   const fastify = Fastify() | ||
|  |   t.teardown(fastify.close.bind(fastify)) | ||
|  | 
 | ||
|  |   fastify.register(multipart) | ||
|  | 
 | ||
|  |   fastify.post('/', async function (req, reply) { | ||
|  |     t.ok(req.isMultipart()) | ||
|  | 
 | ||
|  |     try { | ||
|  |       await req.file() | ||
|  |       reply.code(200).send() | ||
|  |     } catch (error) { | ||
|  |       t.ok(error instanceof fastify.multipartErrors.PrototypeViolationError) | ||
|  |       reply.code(500).send() | ||
|  |     } | ||
|  |   }) | ||
|  | 
 | ||
|  |   fastify.listen(0, async function () { | ||
|  |     // request
 | ||
|  |     const form = new FormData() | ||
|  |     const opts = { | ||
|  |       protocol: 'http:', | ||
|  |       hostname: 'localhost', | ||
|  |       port: fastify.server.address().port, | ||
|  |       path: '/', | ||
|  |       headers: form.getHeaders(), | ||
|  |       method: 'POST' | ||
|  |     } | ||
|  | 
 | ||
|  |     const req = http.request(opts, (res) => { | ||
|  |       t.equal(res.statusCode, 500) | ||
|  |       res.resume() | ||
|  |       res.on('end', () => { | ||
|  |         t.pass('res ended successfully') | ||
|  |       }) | ||
|  |     }) | ||
|  |     const rs = fs.createReadStream(filePath) | ||
|  |     form.append('__proto__', rs) | ||
|  | 
 | ||
|  |     try { | ||
|  |       await pump(form, req) | ||
|  |     } catch (error) { | ||
|  |       t.error(error, 'formData request pump: no err') | ||
|  |     } | ||
|  |   }) | ||
|  | }) | ||
|  | 
 | ||
|  | test('should not allow __proto__ as field name', function (t) { | ||
|  |   t.plan(4) | ||
|  | 
 | ||
|  |   const fastify = Fastify() | ||
|  |   t.teardown(fastify.close.bind(fastify)) | ||
|  | 
 | ||
|  |   fastify.register(multipart) | ||
|  | 
 | ||
|  |   fastify.post('/', async function (req, reply) { | ||
|  |     t.ok(req.isMultipart()) | ||
|  | 
 | ||
|  |     try { | ||
|  |       await req.file() | ||
|  |       reply.code(200).send() | ||
|  |     } catch (error) { | ||
|  |       t.ok(error instanceof fastify.multipartErrors.PrototypeViolationError) | ||
|  |       reply.code(500).send() | ||
|  |     } | ||
|  |   }) | ||
|  | 
 | ||
|  |   fastify.listen(0, async function () { | ||
|  |     // request
 | ||
|  |     const form = new FormData() | ||
|  |     const opts = { | ||
|  |       protocol: 'http:', | ||
|  |       hostname: 'localhost', | ||
|  |       port: fastify.server.address().port, | ||
|  |       path: '/', | ||
|  |       headers: form.getHeaders(), | ||
|  |       method: 'POST' | ||
|  |     } | ||
|  | 
 | ||
|  |     const req = http.request(opts, (res) => { | ||
|  |       t.equal(res.statusCode, 500) | ||
|  |       res.resume() | ||
|  |       res.on('end', () => { | ||
|  |         t.pass('res ended successfully') | ||
|  |       }) | ||
|  |     }) | ||
|  |     form.append('__proto__', 'world') | ||
|  | 
 | ||
|  |     try { | ||
|  |       await pump(form, req) | ||
|  |     } catch (error) { | ||
|  |       t.error(error, 'formData request pump: no err') | ||
|  |     } | ||
|  |   }) | ||
|  | }) |