Skip to content

Instantly share code, notes, and snippets.

Created October 29, 2012 20:58
Show Gist options
  • Save anonymous/3976504 to your computer and use it in GitHub Desktop.
Save anonymous/3976504 to your computer and use it in GitHub Desktop.
/*!
* Connect - Multipart
* Copyright(c) 2010 TJ Holowaychuk <tj@vision-media.ca>
* MIT Licensed
*/
/**
* Module dependencies.
*/
var formidable = require('formidable');
/**
* Setup form with the given `options`.
*
* Options:
*
* - `encoding` Encoding used for incoming forms. Defaults to utf8
* - `uploadDir` Directory to save uploads. Defaults to "/tmp"
* - `keepExtensions` Include original extensions. Defaults to `false`
*
* Examples:
*
* var form = require('connect-form');
* var server = connect.createServer(
* form({ keepExtensions: true }),
* function(req, res, next){
* // Form was submitted
* if (req.form) {
* // Do something when parsing is finished
* // and respond, or respond immediately
* // and work with the files.
* req.form.complete(function(err, fields, files){
* res.writeHead(200, {});
* if (err) res.write(JSON.stringify(err.message));
* res.write(JSON.stringify(fields));
* res.write(JSON.stringify(files));
* res.end();
* });
* // Regular request, pass to next middleware
* } else {
* next();
* }
* }
* );
*
* @param {Object} options
* @return {Function}
* @api public
*/
module.exports = function(options){
options = options || {};
return function(req, res, next){
if (formRequest(req)) {
var form = req.form = new formidable.IncomingForm;
merge(form, options);
form.complete = function(fn){
form.parse(req, fn);
};
}
next();
};
};
/**
* Check if `req` is a valid form request.
*
* @param {IncomingMessage} req
* @return {Boolean}
* @api private
*/
function formRequest(req) {
var contentType = req.headers['content-type'];
if (!contentType) return;
return req.body === undefined
&& (req.method === 'POST'
|| req.method === 'PUT')
&& (~contentType.indexOf('multipart/form-data')
|| ~contentType.indexOf('urlencoded'));
}
/**
* Merge object `b` with object `a`.
*
* @param {Object} a
* @param {Object} b
* @return {Object} a
* @api private
*/
function merge(a, b) {
var keys = Object.keys(b);
for (var i = 0, len = keys.length; i < len; ++i) {
a[keys[i]] = b[keys[i]];
}
return a;
}
module.exports = require('./lib/connect-form');
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment