2025-04-02 06:50:39 -04:00

83 lines
1.6 KiB
JavaScript

'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 {
return undefined;
}
}
/**
* Get the simple type checker.
*
* @param {string | 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 options to normalize
* @param {string | string[] | function} defaultType default content type(s) or a function to determine it
* @returns {object}
*/
function normalizeOptions(options, defaultType) {
if (!defaultType) {
// Parsers must define a default content type
throw new TypeError('defaultType must be provided');
}
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,
};
}