🚀 DAY 5 OF LAUNCH WEEK: Introducing Socket Firewall Enterprise.Learn more →
Socket
Book a DemoInstallSign in
Socket

@fastify/formbody

Package Overview
Dependencies
Maintainers
19
Versions
14
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@fastify/formbody

A module for Fastify to parse x-www-form-urlencoded bodies

latest
Source
npmnpm
Version
8.0.2
Version published
Weekly downloads
591K
-10.08%
Maintainers
19
Weekly downloads
 
Created
Source

@fastify/formbody

CI NPM version NPM downloads neostandard javascript style

A simple plugin for Fastify that adds a content type parser for the content type application/x-www-form-urlencoded.

Install

npm i @fastify/formbody

Compatibility

Plugin versionFastify version
^8.x^5.x
^7.x^4.x
^6.x^3.x
^3.x^2.x
^2.x^1.x

Please note that if a Fastify version is out of support, then so are the corresponding versions of this plugin in the table above. See Fastify's LTS policy for more details.

Example

Given the following code:

const fastify = require('fastify')()

fastify.register(require('@fastify/formbody'))

fastify.post('/', (req, reply) => {
  reply.send(req.body)
})

fastify.listen({ port: 8000 }, (err) => {
  if (err) throw err
})

And a POST body of:

foo=foo&bar=bar&answer=42

The sent reply would be the object:

{
  foo: 'foo',
  bar: 'bar',
  answer: 42
}

Options

The plugin accepts an options object with the following properties:

  • bodyLimit: The maximum amount of bytes to process before returning an error. If the limit is exceeded, a 500 error will be returned immediately. When set to undefined the limit will be set to whatever is configured on the parent Fastify instance. The default value is whatever is configured in fastify (1048576 by default).
  • parser: The default parser used is the querystring.parse built-in. You can change this default by passing a parser function e.g. fastify.register(require('@fastify/formbody'), { parser: str => myParser(str) })

Upgrading from 4.x

Previously, the external qs lib was used that did things like parse nested objects. For example:

  • Input: foo[one]=foo&foo[two]=bar
  • Parsed: { foo: { one: 'foo', two: 'bar' } }

The way this is handled now using the built-in querystring.parse:

  • Input: foo[one]=foo&foo[two]=bar
  • Parsed: { 'foo[one]': 'foo', 'foo[two]': 'bar' }

If you need nested parsing, you must configure it manually by installing the qs lib (npm i qs), and then configure an optional parser:

const fastify = require('fastify')()
const qs = require('qs')
fastify.register(require('@fastify/formbody'), { parser: str => qs.parse(str) })

License

Licensed under MIT.

Keywords

fastify

FAQs

Package last updated on 10 Jan 2025

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts