Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

refactor: normalize common options for all parsers #551

Open
wants to merge 2 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions HISTORY.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
unreleased
=========================

* extract shared utility functions
* remove `unpipe` package and use native `unpipe()` method

2.0.1 / 2024-09-10
Expand Down
47 changes: 2 additions & 45 deletions lib/types/json.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,13 +12,12 @@
* @private
*/

var bytes = require('bytes')
var contentType = require('content-type')
var createError = require('http-errors')
var debug = require('debug')('body-parser:json')
var isFinished = require('on-finished').isFinished
var read = require('../read')
var typeis = require('type-is')
var { getCharset, normalizeOptions } = require('../utils')

/**
* Module exports.
Expand Down Expand Up @@ -53,24 +52,10 @@ var JSON_SYNTAX_REGEXP = /#+/g

function json (options) {
var opts = options || {}
var { inflate, limit, verify, shouldParse } = normalizeOptions(opts, 'application/json')

var limit = typeof opts.limit !== 'number'
? bytes.parse(opts.limit || '100kb')
: opts.limit
var inflate = opts.inflate !== false
var reviver = opts.reviver
var strict = opts.strict !== false
var type = opts.type || 'application/json'
var verify = opts.verify || false

if (verify !== false && typeof verify !== 'function') {
throw new TypeError('option verify must be function')
}

// create the appropriate type checking function
var shouldParse = typeof type !== 'function'
? typeChecker(type)
: type

function parse (body) {
if (body.length === 0) {
Expand Down Expand Up @@ -196,21 +181,6 @@ function firstchar (str) {
: undefined
}

/**
* Get the charset of a request.
*
* @param {object} req
* @api private
*/

function getCharset (req) {
try {
return (contentType.parse(req).parameters.charset || '').toLowerCase()
} catch (e) {
return undefined
}
}

/**
* Normalize a SyntaxError for JSON.parse.
*
Expand All @@ -235,16 +205,3 @@ function normalizeJsonSyntaxError (error, obj) {

return error
}

/**
* Get the simple type checker.
*
* @param {string} type
* @return {function}
*/

function typeChecker (type) {
return function checkType (req) {
return Boolean(typeis(req, type))
}
}
32 changes: 2 additions & 30 deletions lib/types/raw.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,11 +10,11 @@
* Module dependencies.
*/

var bytes = require('bytes')
var debug = require('debug')('body-parser:raw')
var isFinished = require('on-finished').isFinished
var read = require('../read')
var typeis = require('type-is')
var { normalizeOptions } = require('../utils')

/**
* Module exports.
Expand All @@ -32,22 +32,7 @@ module.exports = raw

function raw (options) {
var opts = options || {}

var inflate = opts.inflate !== false
var limit = typeof opts.limit !== 'number'
? bytes.parse(opts.limit || '100kb')
: opts.limit
var type = opts.type || 'application/octet-stream'
var verify = opts.verify || false

if (verify !== false && typeof verify !== 'function') {
throw new TypeError('option verify must be function')
}

// create the appropriate type checking function
var shouldParse = typeof type !== 'function'
? typeChecker(type)
: type
var { inflate, limit, verify, shouldParse } = normalizeOptions(opts, 'application/octet-stream')

function parse (buf) {
return buf
Expand Down Expand Up @@ -89,16 +74,3 @@ function raw (options) {
})
}
}

/**
* Get the simple type checker.
*
* @param {string} type
* @return {function}
*/

function typeChecker (type) {
return function checkType (req) {
return Boolean(typeis(req, type))
}
}
47 changes: 2 additions & 45 deletions lib/types/text.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,12 +10,11 @@
* Module dependencies.
*/

var bytes = require('bytes')
var contentType = require('content-type')
var debug = require('debug')('body-parser:text')
var isFinished = require('on-finished').isFinished
var read = require('../read')
var typeis = require('type-is')
var { getCharset, normalizeOptions } = require('../utils')

/**
* Module exports.
Expand All @@ -33,23 +32,9 @@ module.exports = text

function text (options) {
var opts = options || {}
var { inflate, limit, verify, shouldParse } = normalizeOptions(opts, 'text/plain')

var defaultCharset = opts.defaultCharset || 'utf-8'
var inflate = opts.inflate !== false
var limit = typeof opts.limit !== 'number'
? bytes.parse(opts.limit || '100kb')
: opts.limit
var type = opts.type || 'text/plain'
var verify = opts.verify || false

if (verify !== false && typeof verify !== 'function') {
throw new TypeError('option verify must be function')
}

// create the appropriate type checking function
var shouldParse = typeof type !== 'function'
? typeChecker(type)
: type

function parse (buf) {
return buf
Expand Down Expand Up @@ -94,31 +79,3 @@ function text (options) {
})
}
}

/**
* Get the charset of a request.
*
* @param {object} req
* @api private
*/

function getCharset (req) {
try {
return (contentType.parse(req).parameters.charset || '').toLowerCase()
} catch (e) {
return undefined
}
}

/**
* Get the simple type checker.
*
* @param {string} type
* @return {function}
*/

function typeChecker (type) {
return function checkType (req) {
return Boolean(typeis(req, type))
}
}
47 changes: 2 additions & 45 deletions lib/types/urlencoded.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,14 +12,13 @@
* @private
*/

var bytes = require('bytes')
var contentType = require('content-type')
var createError = require('http-errors')
var debug = require('debug')('body-parser:urlencoded')
var isFinished = require('on-finished').isFinished
var read = require('../read')
var typeis = require('type-is')
var qs = require('qs')
var { getCharset, normalizeOptions } = require('../utils')

/**
* Module exports.
Expand All @@ -37,21 +36,12 @@ module.exports = urlencoded

function urlencoded (options) {
var opts = options || {}
var { inflate, limit, verify, shouldParse } = normalizeOptions(opts, 'application/x-www-form-urlencoded')

var extended = Boolean(opts.extended)
var inflate = opts.inflate !== false
var limit = typeof opts.limit !== 'number'
? bytes.parse(opts.limit || '100kb')
: opts.limit
var type = opts.type || 'application/x-www-form-urlencoded'
var verify = opts.verify || false
var charsetSentinel = opts.charsetSentinel
var interpretNumericEntities = opts.interpretNumericEntities

if (verify !== false && typeof verify !== 'function') {
throw new TypeError('option verify must be function')
}

var defaultCharset = opts.defaultCharset || 'utf-8'
if (defaultCharset !== 'utf-8' && defaultCharset !== 'iso-8859-1') {
throw new TypeError('option defaultCharset must be either utf-8 or iso-8859-1')
Expand All @@ -60,11 +50,6 @@ function urlencoded (options) {
// create the appropriate query parser
var queryparse = createQueryParser(opts, extended)

// create the appropriate type checking function
var shouldParse = typeof type !== 'function'
? typeChecker(type)
: type

function parse (body, encoding) {
return body.length
? queryparse(body, encoding)
Expand Down Expand Up @@ -184,21 +169,6 @@ function createQueryParser (options, extended) {
}
}

/**
* Get the charset of a request.
*
* @param {object} req
* @api private
*/

function getCharset (req) {
try {
return (contentType.parse(req).parameters.charset || '').toLowerCase()
} catch (e) {
return undefined
}
}

/**
* Count the number of parameters, stopping once limit reached
*
Expand All @@ -222,16 +192,3 @@ function parameterCount (body, limit) {

return count
}

/**
* Get the simple type checker.
*
* @param {string} type
* @return {function}
*/

function typeChecker (type) {
return function checkType (req) {
return Boolean(typeis(req, type))
}
}
84 changes: 84 additions & 0 deletions lib/utils.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,84 @@
/*!
* body-parser
* Copyright(c) 2014-2015 Douglas Christopher Wilson
* MIT Licensed
*/

'use strict'

/**
* Module dependencies.
*/

var bytes = require('bytes')
var contentType = require('content-type')
var typeis = require('type-is')

/**
* Module exports.
*/

module.exports = {
getCharset,
normalizeOptions
}

/**
* Get the charset of a request.
*
* @param {object} req
* @api private
*/

function getCharset (req) {
try {
return (contentType.parse(req).parameters.charset || '').toLowerCase()
} catch (e) {
return undefined
}
}

/**
* Get the simple type checker.
*
* @param {string} type
* @return {function}
*/

function typeChecker (type) {
return function checkType (req) {
return Boolean(typeis(req, type))
}
}

/**
* Normalizes the common options for all parsers.
*
* @param {object} options
* @param {string} defaultType
* @returns {object}
*/
function normalizeOptions (options, defaultType) {
var inflate = options.inflate !== false
var limit = typeof options.limit !== 'number'
? bytes.parse(options.limit || '100kb')
: options.limit
var type = options.type || defaultType
var verify = options.verify || false

if (verify !== false && typeof verify !== 'function') {
throw new TypeError('option verify must be function')
}

// create the appropriate type checking function
var shouldParse = typeof type !== 'function'
? typeChecker(type)
: type

return {
inflate,
limit,
verify,
shouldParse
}
}