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.
		
		
		
		
		
			
		
			
				
					
					
						
							160 lines
						
					
					
						
							3.8 KiB
						
					
					
				
			
		
		
	
	
							160 lines
						
					
					
						
							3.8 KiB
						
					
					
				'use strict'
 | 
						|
 | 
						|
const Fastify = require('..')
 | 
						|
const sget = require('simple-get').concat
 | 
						|
const t = require('tap')
 | 
						|
const test = t.test
 | 
						|
 | 
						|
test('proto-poisoning error', t => {
 | 
						|
  t.plan(3)
 | 
						|
 | 
						|
  const fastify = Fastify()
 | 
						|
  t.teardown(fastify.close.bind(fastify))
 | 
						|
 | 
						|
  fastify.post('/', (request, reply) => {
 | 
						|
    t.fail('handler should not be called')
 | 
						|
  })
 | 
						|
 | 
						|
  fastify.listen(0, function (err) {
 | 
						|
    t.error(err)
 | 
						|
 | 
						|
    sget({
 | 
						|
      method: 'POST',
 | 
						|
      url: 'http://localhost:' + fastify.server.address().port,
 | 
						|
      headers: { 'Content-Type': 'application/json' },
 | 
						|
      body: '{ "__proto__": { "a": 42 } }'
 | 
						|
    }, (err, response, body) => {
 | 
						|
      t.error(err)
 | 
						|
      t.equal(response.statusCode, 400)
 | 
						|
    })
 | 
						|
  })
 | 
						|
})
 | 
						|
 | 
						|
test('proto-poisoning remove', t => {
 | 
						|
  t.plan(4)
 | 
						|
 | 
						|
  const fastify = Fastify({ onProtoPoisoning: 'remove' })
 | 
						|
  t.teardown(fastify.close.bind(fastify))
 | 
						|
 | 
						|
  fastify.post('/', (request, reply) => {
 | 
						|
    t.equal(undefined, Object.assign({}, request.body).a)
 | 
						|
    reply.send({ ok: true })
 | 
						|
  })
 | 
						|
 | 
						|
  fastify.listen(0, function (err) {
 | 
						|
    t.error(err)
 | 
						|
 | 
						|
    sget({
 | 
						|
      method: 'POST',
 | 
						|
      url: 'http://localhost:' + fastify.server.address().port,
 | 
						|
      headers: { 'Content-Type': 'application/json' },
 | 
						|
      body: '{ "__proto__": { "a": 42 }, "b": 42 }'
 | 
						|
    }, (err, response, body) => {
 | 
						|
      t.error(err)
 | 
						|
      t.equal(response.statusCode, 200)
 | 
						|
    })
 | 
						|
  })
 | 
						|
})
 | 
						|
 | 
						|
test('proto-poisoning ignore', t => {
 | 
						|
  t.plan(4)
 | 
						|
 | 
						|
  const fastify = Fastify({ onProtoPoisoning: 'ignore' })
 | 
						|
  t.teardown(fastify.close.bind(fastify))
 | 
						|
 | 
						|
  fastify.post('/', (request, reply) => {
 | 
						|
    t.equal(42, Object.assign({}, request.body).a)
 | 
						|
    reply.send({ ok: true })
 | 
						|
  })
 | 
						|
 | 
						|
  fastify.listen(0, function (err) {
 | 
						|
    t.error(err)
 | 
						|
 | 
						|
    sget({
 | 
						|
      method: 'POST',
 | 
						|
      url: 'http://localhost:' + fastify.server.address().port,
 | 
						|
      headers: { 'Content-Type': 'application/json' },
 | 
						|
      body: '{ "__proto__": { "a": 42 }, "b": 42 }'
 | 
						|
    }, (err, response, body) => {
 | 
						|
      t.error(err)
 | 
						|
      t.equal(response.statusCode, 200)
 | 
						|
    })
 | 
						|
  })
 | 
						|
})
 | 
						|
 | 
						|
test('constructor-poisoning error (default in v3)', t => {
 | 
						|
  t.plan(3)
 | 
						|
 | 
						|
  const fastify = Fastify()
 | 
						|
  t.teardown(fastify.close.bind(fastify))
 | 
						|
 | 
						|
  fastify.post('/', (request, reply) => {
 | 
						|
    reply.send('ok')
 | 
						|
  })
 | 
						|
 | 
						|
  fastify.listen(0, function (err) {
 | 
						|
    t.error(err)
 | 
						|
 | 
						|
    sget({
 | 
						|
      method: 'POST',
 | 
						|
      url: 'http://localhost:' + fastify.server.address().port,
 | 
						|
      headers: { 'Content-Type': 'application/json' },
 | 
						|
      body: '{ "constructor": { "prototype": { "foo": "bar" } } }'
 | 
						|
    }, (err, response, body) => {
 | 
						|
      t.error(err)
 | 
						|
      t.equal(response.statusCode, 400)
 | 
						|
    })
 | 
						|
  })
 | 
						|
})
 | 
						|
 | 
						|
test('constructor-poisoning error', t => {
 | 
						|
  t.plan(3)
 | 
						|
 | 
						|
  const fastify = Fastify({ onConstructorPoisoning: 'error' })
 | 
						|
  t.teardown(fastify.close.bind(fastify))
 | 
						|
 | 
						|
  fastify.post('/', (request, reply) => {
 | 
						|
    t.fail('handler should not be called')
 | 
						|
  })
 | 
						|
 | 
						|
  fastify.listen(0, function (err) {
 | 
						|
    t.error(err)
 | 
						|
 | 
						|
    sget({
 | 
						|
      method: 'POST',
 | 
						|
      url: 'http://localhost:' + fastify.server.address().port,
 | 
						|
      headers: { 'Content-Type': 'application/json' },
 | 
						|
      body: '{ "constructor": { "prototype": { "foo": "bar" } } }'
 | 
						|
    }, (err, response, body) => {
 | 
						|
      t.error(err)
 | 
						|
      t.equal(response.statusCode, 400)
 | 
						|
    })
 | 
						|
  })
 | 
						|
})
 | 
						|
 | 
						|
test('constructor-poisoning remove', t => {
 | 
						|
  t.plan(4)
 | 
						|
 | 
						|
  const fastify = Fastify({ onConstructorPoisoning: 'remove' })
 | 
						|
  t.teardown(fastify.close.bind(fastify))
 | 
						|
 | 
						|
  fastify.post('/', (request, reply) => {
 | 
						|
    t.equal(undefined, Object.assign({}, request.body).foo)
 | 
						|
    reply.send({ ok: true })
 | 
						|
  })
 | 
						|
 | 
						|
  fastify.listen(0, function (err) {
 | 
						|
    t.error(err)
 | 
						|
 | 
						|
    sget({
 | 
						|
      method: 'POST',
 | 
						|
      url: 'http://localhost:' + fastify.server.address().port,
 | 
						|
      headers: { 'Content-Type': 'application/json' },
 | 
						|
      body: '{ "constructor": { "prototype": { "foo": "bar" } } }'
 | 
						|
    }, (err, response, body) => {
 | 
						|
      t.error(err)
 | 
						|
      t.equal(response.statusCode, 200)
 | 
						|
    })
 | 
						|
  })
 | 
						|
})
 |