|
|
eval("\nvar CombinedStream = __webpack_require__(/*! combined-stream */ \"(ssr)/./node_modules/combined-stream/lib/combined_stream.js\");\nvar util = __webpack_require__(/*! util */ \"util\");\nvar path = __webpack_require__(/*! path */ \"path\");\nvar http = __webpack_require__(/*! http */ \"http\");\nvar https = __webpack_require__(/*! https */ \"https\");\nvar parseUrl = (__webpack_require__(/*! url */ \"url\").parse);\nvar fs = __webpack_require__(/*! fs */ \"fs\");\nvar Stream = (__webpack_require__(/*! stream */ \"stream\").Stream);\nvar mime = __webpack_require__(/*! mime-types */ \"(ssr)/./node_modules/mime-types/index.js\");\nvar asynckit = __webpack_require__(/*! asynckit */ \"(ssr)/./node_modules/asynckit/index.js\");\nvar populate = __webpack_require__(/*! ./populate.js */ \"(ssr)/./node_modules/form-data/lib/populate.js\");\n// Public API\nmodule.exports = FormData;\n// make it a Stream\nutil.inherits(FormData, CombinedStream);\n/**\n * Create readable \"multipart/form-data\" streams.\n * Can be used to submit forms\n * and file uploads to other web applications.\n *\n * @constructor\n * @param {Object} options - Properties to be added/overriden for FormData and CombinedStream\n */ function FormData(options) {\n if (!(this instanceof FormData)) {\n return new FormData(options);\n }\n this._overheadLength = 0;\n this._valueLength = 0;\n this._valuesToMeasure = [];\n CombinedStream.call(this);\n options = options || {};\n for(var option in options){\n this[option] = options[option];\n }\n}\nFormData.LINE_BREAK = \"\\r\\n\";\nFormData.DEFAULT_CONTENT_TYPE = \"application/octet-stream\";\nFormData.prototype.append = function(field, value, options) {\n options = options || {};\n // allow filename as single option\n if (typeof options == \"string\") {\n options = {\n filename: options\n };\n }\n var append = CombinedStream.prototype.append.bind(this);\n // all that streamy business can't handle numbers\n if (typeof value == \"number\") {\n value = \"\" + value;\n }\n // https://github.com/felixge/node-form-data/issues/38\n if (util.isArray(value)) {\n // Please convert your array into string\n // the way web server expects it\n this._error(new Error(\"Arrays are not supported.\"));\n return;\n }\n var header = this._multiPartHeader(field, value, options);\n var footer = this._multiPartFooter();\n append(header);\n append(value);\n append(footer);\n // pass along options.knownLength\n this._trackLength(header, value, options);\n};\nFormData.prototype._trackLength = function(header, value, options) {\n var valueLength = 0;\n // used w/ getLengthSync(), when length is known.\n // e.g. for streaming directly from a remote server,\n // w/ a known file a size, and not wanting to wait for\n // incoming file to finish to get its size.\n if (options.knownLength != null) {\n valueLength += +options.knownLength;\n } else if (Buffer.isBuffer(value)) {\n valueLength = value.length;\n } else if (typeof value === \"string\") {\n valueLength = Buffer.byteLength(value);\n }\n this._valueLength += valueLength;\n // @check why add CRLF? does this account for custom/multiple CRLFs?\n this._overheadLength += Buffer.byteLength(header) + FormData.LINE_BREAK.length;\n // empty or either doesn't have path or not an http response or not a stream\n if (!value || !value.path && !(value.readable && value.hasOwnProperty(\"httpVersion\")) && !(value instanceof Stream)) {\n return;\n }\n // no need to bother with the length\n if (!options.knownLength) {\n this._valuesToMeasure.push(value);\n }\n};\nFormData.prototype._lengthRetriever = function(value, callback) {\n if (value.hasOwnProperty(\"fd\")) {\n // take read range into a account\n // `end` = Infinity –> read file till the end\n //\n // TODO: Looks like there is bug in Node fs.createReadStream\n // it doesn't respect `end` options without `start` options\n // Fix it when node fixes it.\n // https://github.com/joyent/node/issues/7819\n if (value.end != undefined && value.end != Infinity && value.start != undefined) {\n // when end specified\n // no need to calculate range\n // inclusive, starts with 0\n callback(null, value.end + 1 - (value.start ? value.start : 0));\n // not that fast snoopy\n } else {\n // still need to fetch file size from fs\n fs.stat(value.path, function(err, stat) {\n var fileSize;\n if (err) {\n callback(err);\n return;\n }\n // update final size based on the range options\n fileSize = stat.size - (value.start ? value.start : 0);\n callback(null, fileSize);\n });\n }\n // or http response\n } else if (value.hasOwnProperty(\"httpVersion\")) {\n callback(null, +value.headers[\"content-length\"]);\n // or request stream http://github.com/mikeal/request\n } else if (value.hasOwnProperty(\"httpModule\")) {\n // wait till response come back\n value.on(\"response\", function(response) {\n value.pause();\n callback(null, +response.headers[\"content-length\"]);\n });\n value.resume();\n // something else\n } else {\n callback(\"Unknown stream\");\n }\n};\nFormData.prototype._multiPartHeader = function(field, value, options) {\n // custom header specified (as string)?\n // it becomes responsible for boundary\n // (e.g. to handle extra CRLFs on .NET servers)\n if (typeof options.header == \"string\") {\n return options.header;\n }\n var contentDisposition = this._getContentDisposition(value, options);\n var contentType = this._getContentType(value, options);\n var contents = \"\";\n var headers = {\n // add custom disposition as third element or keep it two elements if not\n \"Content-Disposition\": [\n \"form-data\",\n 'name=\"' + field + '\"'\n ].concat(contentDisposition || []),\n // if no content type. allow it to be empty array\n \"Content-Type\": [].concat(contentType || [])\n };\n // allow custom headers.\n if (typeof options.header == \"object\") {\n populate(headers, options.header);\n }\n var header;\n for(var prop in headers){\n if (!headers.hasOwnProperty(prop)) continue;\n header = headers[prop];\n // skip nullish headers.\n if (header == null) {\n continue;\n }\n // convert all headers to arrays.\n if (!Array.isArray(header)) {\n header = [\n header\n ];\n }\n // add non-empty headers.\n if (header.length) {\n contents += prop + \": \" + header.join(\"; \") + FormData.LINE_BREAK;\n }\n }\n return \"--\" + this.getBoundary() + FormData.LINE_BREAK + contents + FormData.LINE_BREAK;\n};\nFormData.prototype._getContentDisposition = function(value, options) {\n var filename, contentDisposition;\n if (typeof options.filepath === \"string\") {\n // custom filepath for relative paths\n filename = path.normalize(options.filepath).replace(/\\\\/g, \"/\");\n } else if (options.filename || value.name || value.path) {\n // custom filename take precedence\n // formidable and the browser add a name property\n // fs- and request- streams have path property\n filename = path.basename(options.filename || value.name || value.path);\n } else if (value.readable && value.hasOwnProperty(\"httpVersion\")) {\n // or try http response\n filename = path.basename(value.client._httpMessage.path || \"\");\n }\n if (filename) {\n contentDisposition = 'filename=\"' + filename + '\"';\n }\n return contentDisposition;\n};\nFormData.prototype._getContentType = function(value, options) {\n // use custom content-type above all\n var contentType = options.contentType;\n // or try `name` from formidable, browser\n if (!contentType && value.name) {\n contentType = mime.lookup(value.name);\n }\n // or try `path` from fs-, request- streams\n if (!contentType && value.path) {\n contentType = mime.lookup(value.path);\n }\n // or if it's http-reponse\n if (!contentType && value.readable && value.hasOwnProperty(\"httpVersion\")) {\n contentType = value.headers[\"content-type\"];\n }\n // or guess it from the filepath or filename\n if (!contentType && (options.filepath || options.filename)) {\n contentType = mime.lookup(options.filepath || options.filename);\n }\n // fallback to the default content type if `value` is not simple value\n if (!contentType && typeof value == \"object\") {\n contentType = FormData.DEFAULT_CONTENT_TYPE;\n }\n return contentType;\n};\nFormData.prototype._multiPartFooter = function() {\n return (function(next) {\n var footer = FormData.LINE_BREAK;\n var lastPart = this._streams.length === 0;\n if (lastPart) {\n footer += this._lastBoundary();\n }\n next(footer);\n }).bind(this);\n};\nFormData.prototype._lastBoundary = function() {\n return \"--\" + this.getBoundary() + \"--\" + FormData.LINE_BREAK;\n};\nFormData.prototype.getHeaders = function(userHeaders) {\n var header;\n var formHeaders = {\n \"content-type\": \"multipart/form-data; boundary=\" + this.getBoundary()\n };\n for(header in userHeaders){\n if (userHeaders.hasOwnProperty(header)) {\n formHeaders[header.toLowerCase()] = userHeaders[header];\n }\n }\n return formHeaders;\n};\nFormData.prototype.setBoundary = function(boundary) {\n this._boundary = boundary;\n};\nFormData.prototype.getBoundary = function() {\n if (!this._boundary) {\n this._generateBoundary();\n }\n return this._boundary;\n};\nFormData.prototype.getBuffer = function() {\n var dataBuffer = new Buffer.alloc(0);\n var boundary = this.getBoundary();\n // Create the form content. Add Line breaks to the end of data.\n for(var i = 0, len = this._streams.length; i < len; i++){\n if (typeof this._streams[i] !== \"function\") {\n // Add content to the buffer.\n if (Buffer.isBuffer(this._streams[i])) {\n dataBuffer = Buffer.concat([\n dataBuffer,\n this._streams[i]\n ]);\n } else {\n dataBuffer = Buffer.concat([\n dataBuffer,\n Buffer.from(this._streams[i])\n ]);\n }\n // Add break after content.\n if (typeof this._streams[i] !== \"string\" || this._streams[i].substring(2, boundary.length + 2) !== boundary) {\n dataBuffer = Buffer.concat([\n dataBuffer,\n Buffer.from(FormData.LINE_BREAK)\n ]);\n }\n }\n }\n // Add the footer and return the Buffer object.\n return Buffer.concat([\n dataBuffer,\n Buffer.from(this._lastBoundary())\n ]);\n};\nFormData.prototype._generateBoundary = function() {\n // This generates a 50 character boundary similar to those used by Firefox.\n // They are optimized for boyer-moore parsing.\n var boundary = \"--------------------------\";\n for(var i = 0; i < 24; i++){\n boundary += Math.floor(Math.random() * 10).toString(16);\n }\n this._boundary = boundary;\n};\n// Note: getLengthSync DOESN'T calculate streams length\n// As workaround one can calculate file size manually\n// and add it as knownLength option\nFormData.prototype.getLengthSync = function() {\n var knownLength = this._overheadLength + this._valueLength;\n // Don't get confused, there are 3 \"internal\" streams for each keyval pair\n // so it basically checks if there is any value added to the form\n if (this._streams.length) {\n knownLength += this._lastBoundary().length;\n }\n // https://github.com/form-data/form-data/issues/40\n if (!this.hasKnownLength()) {\n // Some async length retrievers are present\n // therefore synchronous length calculation is false.\n // Please use getLength(callback) to get proper length\n this._error(new Error(\"Cannot calculate proper length in synchronous way.\"));\n }\n return knownLength;\n};\n// Public API to check if length of added values is known\n// https://github.com/form-data/form-data/issues/196\n// https://github.com/form-data/form-data/issues/262\nFormData.prototype.hasKnownLength = function() {\n var hasKnownLength = true;\n if (this._valuesToMeasure.length) {\n hasKnownLength = false;\n }\n return hasKnownLength;\n};\nFormData.prototype.getLength = function(cb) {\n var knownLength = this._overheadLength + this._valueLength;\n if (this._streams.length) {\n knownLength += this._lastBoundary().length;\n }\n if (!this._valuesToMeasure.length) {\n process.nextTick(cb.bind(this, null, knownLength));\n return;\n }\n asynckit.parallel(this._valuesToMeasure, this._lengthRetriever, function(err, values) {\n if (err) {\n cb(err);\n return;\n }\n values.forEach(function(length) {\n knownLength += length;\n });\n cb(null, knownLength);\n });\n};\nFormData.prototype.submit = function(params, cb) {\n var request, options, defaults = {\n method: \"post\"\n };\n // parse provided url if it's string\n // or treat it as options object\n if (typeof params == \"string\") {\n params = parseUrl(params);\n options = populate({\n port: params.port,\n path: params.pathname,\n host: params.hostname,\n protocol: params.protocol\n }, defaults);\n // use custom params\n } else {\n options = populate(params, defaults);\n // if no port provided use default one\n if (!options.port) {\n options.port = options.protocol == \"https:\" ? 443 : 80;\n }\n }\n // put that good code in getHeaders to some use\n options.headers = this.getHeaders(params.headers);\n // https if specified, fallback to http in any other case\n if (options.protocol == \"https:\") {\n request = https.request(options);\n } else {\n request = http.request(options);\n }\n // get content length and fire away\n this.getLength((function(err, length) {\n if (err && err !== \"Unknown stream\") {\n this._error(err);\n return;\n }\n // add content length\n if (length) {\n request.setHeader(\"Content-Length\", length);\n }\n this.pipe(request);\n if (cb) {\n var onResponse;\n var callback = function(error, responce) {\n request.removeListener(\"error\", callback);\n request.removeListener(\"response\", onResponse);\n return cb.call(this, error, responce);\n };\n onResponse = callback.bind(this, null);\n request.on(\"error\", callback);\n request.on(\"response\", onResponse);\n }\n }).bind(this));\n return request;\n};\nFormData.prototype._error = function(err) {\n if (!this.error) {\n this.error = err;\n this.pause();\n this.emit(\"error\", err);\n }\n};\nFormData.prototype.toString = function() {\n return \"[object FormData]\";\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/form-data/lib/form_data.js","mappings":"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","sources":["webpack://nextchat/./node_modules/form-data/lib/form_data.js?2b0d"],"sourcesContent":["var CombinedStream = require('combined-stream');\nvar util = require('util');\nvar path = require('path');\nvar http = require('http');\nvar https = require('https');\nvar parseUrl = require('url').parse;\nvar fs = require('fs');\nvar Stream = require('stream').Stream;\nvar mime = require('mime-types');\nvar asynckit = require('asynckit');\nvar populate = require('./populate.js');\n\n// Public API\nmodule.exports = FormData;\n\n// make it a Stream\nutil.inherits(FormData, CombinedStream);\n\n/**\n * Create readable \"multipart/form-data\" streams.\n * Can be used to submit forms\n * and file uploads to other web applications.\n *\n * @constructor\n * @param {Object} options - Properties to be added/overriden for FormData and CombinedStream\n */\nfunction FormData(options) {\n  if (!(this instanceof FormData)) {\n    return new FormData(options);\n  }\n\n  this._overheadLength = 0;\n  this._valueLength = 0;\n  this._valuesToMeasure = [];\n\n  CombinedStream.call(this);\n\n  options = options || {};\n  for (var option in options) {\n    this[option] = options[option];\n  }\n}\n\nFormData.LINE_BREAK = '\\r\\n';\nFormData.DEFAULT_CONTENT_TYPE = 'application/octet-stream';\n\nFormData.prototype.append = function(field, value, options) {\n\n  options = options || {};\n\n  // allow filename as single option\n  if (typeof options == 'string') {\n    options = {filename: options};\n  }\n\n  var append = CombinedStream.prototype.append.bind(this);\n\n  // all that streamy business can't handle numbers\n  if (typeof value == 'number') {\n    value = '' + value;\n  }\n\n  // https://github.com/felixge/node-form-data/issues/38\n  if (util.isArray(value)) {\n    // Please convert your array into string\n    // the way web server expects it\n    this._error(new Error('Arrays are not supported.'));\n    return;\n  }\n\n  var header = this._multiPartHeader(field, value, options);\n  var footer = this._multiPartFooter();\n\n  append(header);\n  append(value);\n  append(footer);\n\n  // pass along options.knownLength\n  this._trackLength(header, value, options);\n};\n\nFormData.prototype._trackLength = function(header, value, options) {\n  var valueLength = 0;\n\n  // used w/ getLengthSync(), when length is known.\n  // e.g. for streaming directly from a remote server,\n  // w/ a known file a size, and not wanting to wait for\n  // incoming file to finish to get its size.\n  if (options.knownLength != null) {\n    valueLength += +options.knownLength;\n  } else if (Buffer.isBuffer(value)) {\n    valueLength = value.length;\n  } else if (typeof value === 'string') {\n    valueLength = Buffer.byteLength(value);\n  }\n\n  this._valueLength += valueLength;\n\n  // @check why add CRLF? does this account for custom/multiple CRLFs?\n  this._overheadLength +=\n    Buffer.byteLength(header) +\n    FormData.LINE_BREAK.length;\n\n  // empty or either doesn't have path or not an http response or not a stream\n  if (!value || ( !value.path && !(value.readable && value.hasOwnProperty('httpVersion')) && !(value instanceof Stream))) {\n    return;\n  }\n\n  // no need to bother with the length\n  if (!options.knownLength) {\n    this._valuesToMeasure.push(value);\n  }\n};\n\nFormData.prototype._lengthRetriever = function(value, callback) {\n\n  if (value.hasOwnProperty('fd')) {\n\n    // take read range into a account\n    // `end` = Infinity –> read file till the end\n    //\n    // TODO: Looks like there is bug in Node fs.createReadStream\n    // it doesn't respect `end` options without `start` options\n    // Fix it when node fixes it.\n    // https://github.com/joyent/node/issues/7819\n    if (value.end != undefined && value.end != Infinity && value.start != undefined) {\n\n      // when end specified\n      // no need to calculate range\n      // inclusive, starts with 0\n      callback(null, value.end + 1 - (value.start ? value.start : 0));\n\n    // not that fast snoopy\n    } else {\n      // still need to fetch file size from fs\n      fs.stat(value.path, function(err, stat) {\n\n        var fileSize;\n\n        if (err) {\n          callback(err);\n          return;\n        }\n\n        // update final size based on the range options\n        fileSize = stat.size - (value.start ? value.start : 0);\n        callback(null, fileSize);\n      });\n    }\n\n  // or http response\n  } else if (value.hasOwnProperty('httpVersion')) {\n    callback(null, +value.headers['content-length']);\n\n  // or request stream http://github.com/mikeal/request\n  } else if (value.hasOwnProperty('httpModule')) {\n    // wait till response come back\n    value.on('response', function(response) {\n      value.pause();\n      callback(null, +response.headers['content-length']);\n    });\n    value.resume();\n\n  // something else\n  } else {\n    callback('Unknown stream');\n  }\n};\n\nFormData.prototype._multiPartHeader = function(field, value, options) {\n  // custom header specified (as string)?\n  // it becomes responsible for boundary\n  // (e.g. to handle extra CRLFs on .NET servers)\n  if (typeof options.header == 'string') {\n    return options.header;\n  }\n\n  var contentDisposition = this._getContentDisposition(value, options);\n  var contentType = this._getContentType(value, options);\n\n  var contents = '';\n  var headers  = {\n    // add custom disposition as third element or keep it two elements if not\n    'Content-Disposition': ['form-data', 'name=\"' + field + '\"'].concat(contentDisposition || []),\n    // if no content type. allow it to be empty array\n    'Content-Type': [].concat(contentType || [])\n  };\n\n  // allow custom headers.\n  if (typeof options.header == 'object') {\n    populate(headers, options.header);\n  }\n\n  var header;\n  for (var prop in headers) {\n    if (!headers.hasOwnProperty(prop)) continue;\n    header = headers[prop];\n\n    // skip nullish headers.\n    if (header == null) {\n      continue;\n    }\n\n    // convert all headers to arrays.\n    if (!Array.isArray(header)) {\n      header = [header];\n    }\n\n    // add non-empty headers.\n    if (header.length) {\n      contents += prop + ': ' + header.join('; ') + FormData.LINE_BREAK;\n    }\n  }\n\n  return '--' + this.getBoundary() + FormData.LINE_BREAK + contents + FormData.LINE_BREAK;\n};\n\nFormData.prototype._getContentDisposition = function(value, options) {\n\n  var filename\n    , contentDisposition\n    ;\n\n  if (typeof options.filepath === 'string') {\n    // custom filepath for relative paths\n    filename = path.normalize(options.filepath).replace(/\\\\/g, '/');\n  } else if (options.filename || value.name || value.path) {\n    // custom filename take precedence\n    // formidable and the browser add a name property\n    // fs- and request- streams have path property\n    filename = path.basename(options.filename || value.name || value.path);\n  } else if (value.readable && value.hasOwnProperty('httpVersion')) {\n    // or try http response\n    filename = path.basename(value.client._httpMessage.path || '');\n  }\n\n  if (filename) {\n    contentDisposition = 'filename=\"' + filename + '\"';\n  }\n\n  return contentDisposition;\n};\n\nFormData.prototype._getContentType = function(value, options) {\n\n  // use custom content-type above all\n  var contentType = options.contentType;\n\n  // or try `name` from formidable, browser\n  if (!contentType && value.name) {\n    contentType = mime.lookup(value.name);\n  }\n\n  // or try `path` from fs-, request- streams\n  if (!contentType && value.path) {\n    contentType = mime.lookup(value.path);\n  }\n\n  // or if it's http-reponse\n  if (!contentType && value.readable && value.hasOwnProperty('httpVersion')) {\n    contentType = value.headers['content-type'];\n  }\n\n  // or guess it from the filepath or filename\n  if (!contentType && (options.filepath || options.filename)) {\n    contentType = mime.lookup(options.filepath || options.filename);\n  }\n\n  // fallback to the default content type if `value` is not simple value\n  if (!contentType && typeof value == 'object') {\n    contentType = FormData.DEFAULT_CONTENT_TYPE;\n  }\n\n  return contentType;\n};\n\nFormData.prototype._multiPartFooter = function() {\n  return function(next) {\n    var footer = FormData.LINE_BREAK;\n\n    var lastPart = (this._streams.length === 0);\n    if (lastPart) {\n      footer += this._lastBoundary();\n    }\n\n    next(footer);\n  }.bind(this);\n};\n\nFormData.prototype._lastBoundary = function() {\n  return '--' + this.getBoundary() + '--' + FormData.LINE_BREAK;\n};\n\nFormData.prototype.getHeaders = function(userHeaders) {\n  var header;\n  var formHeaders = {\n    'content-type': 'multipart/form-data; boundary=' + this.getBoundary()\n  };\n\n  for (header in userHeaders) {\n    if (userHeaders.hasOwnProperty(header)) {\n      formHeaders[header.toLowerCase()] = userHeaders[header];\n    }\n  }\n\n  return formHeaders;\n};\n\nFormData.prototype.setBoundary = function(boundary) {\n  this._boundary = boundary;\n};\n\nFormData.prototype.getBoundary = function() {\n  if (!this._boundary) {\n    this._generateBoundary();\n  }\n\n  return this._boundary;\n};\n\nFormData.prototype.getBuffer = function() {\n  var dataBuffer = new Buffer.alloc( 0 );\n  var boundary = this.getBoundary();\n\n  // Create the form content. Add Line breaks to the end of data.\n  for (var i = 0, len = this._streams.length; i < len; i++) {\n    if (typeof this._streams[i] !== 'function') {\n\n      // Add content to the buffer.\n      if(Buffer.isBuffer(this._streams[i])) {\n        dataBuffer = Buffer.concat( [dataBuffer, this._streams[i]]);\n      }else {\n        dataBuffer = Buffer.concat( [dataBuffer, Buffer.from(this._streams[i])]);\n      }\n\n      // Add break after content.\n      if (typeof this._streams[i] !== 'string' || this._streams[i].substring( 2, boundary.length + 2 ) !== boundary) {\n        dataBuffer = Buffer.concat( [dataBuffer, Buffer.from(FormData.LINE_BREAK)] );\n      }\n    }\n  }\n\n  // Add the footer and return the Buffer object.\n  return Buffer.concat( [dataBuffer, Buffer.from(this._lastBoundary())] );\n};\n\nFormData.prototype._generateBoundary = function() {\n  // This generates a 50 character boundary similar to those used by Firefox.\n  // They are optimized for boyer-moore parsing.\n  var boundary = '--------------------------';\n  for (var i = 0; i < 24; i++) {\n    boundary += Math.floor(Math.random() * 10).toString(16);\n  }\n\n  this._boundary = boundary;\n};\n\n// Note: getLengthSync DOESN'T calculate streams length\n// As workaround one can calculate file size manually\n// and add it as knownLength option\nFormData.prototype.getLengthSync = function() {\n  var knownLength = this._overheadLength + this._valueLength;\n\n  // Don't get confused, there are 3 \"internal\" streams for each keyval pair\n  // so it basically checks if there is any value added to the form\n  if (this._streams.length) {\n    knownLength += this._lastBoundary().length;\n  }\n\n  // https://github.com/form-data/form-data/issues/40\n  if (!this.hasKnownLength()) {\n    // Some async length retrievers are present\n    // therefore synchronous length calculation is false.\n    // Please use getLength(callback) to get proper length\n    this._error(new Error('Cannot calculate proper length in synchronous way.'));\n  }\n\n  return knownLength;\n};\n\n// Public API to check if length of added values is known\n// https://github.com/form-data/form-data/issues/196\n// https://github.com/form-data/form-data/issues/262\nFormData.prototype.hasKnownLength = function() {\n  var hasKnownLength = true;\n\n  if (this._valuesToMeasure.length) {\n    hasKnownLength = false;\n  }\n\n  return hasKnownLength;\n};\n\nFormData.prototype.getLength = function(cb) {\n  var knownLength = this._overheadLength + this._valueLength;\n\n  if (this._streams.length) {\n    knownLength += this._lastBoundary().length;\n  }\n\n  if (!this._valuesToMeasure.length) {\n    process.nextTick(cb.bind(this, null, knownLength));\n    return;\n  }\n\n  asynckit.parallel(this._valuesToMeasure, this._lengthRetriever, function(err, values) {\n    if (err) {\n      cb(err);\n      return;\n    }\n\n    values.forEach(function(length) {\n      knownLength += length;\n    });\n\n    cb(null, knownLength);\n  });\n};\n\nFormData.prototype.submit = function(params, cb) {\n  var request\n    , options\n    , defaults = {method: 'post'}\n    ;\n\n  // parse provided url if it's string\n  // or treat it as options object\n  if (typeof params == 'string') {\n\n    params = parseUrl(params);\n    options = populate({\n      port: params.port,\n      path: params.pathname,\n      host: params.hostname,\n      protocol: params.protocol\n    }, defaults);\n\n  // use custom params\n  } else {\n\n    options = populate(params, defaults);\n    // if no port provided use default one\n    if (!options.port) {\n      options.port = options.protocol == 'https:' ? 443 : 80;\n    }\n  }\n\n  // put that good code in getHeaders to some use\n  options.headers = this.getHeaders(params.headers);\n\n  // https if specified, fallback to http in any other case\n  if (options.protocol == 'https:') {\n    request = https.request(options);\n  } else {\n    request = http.request(options);\n  }\n\n  // get content length and fire away\n  this.getLength(function(err, length) {\n    if (err && err !== 'Unknown stream') {\n      this._error(err);\n      return;\n    }\n\n    // add content length\n    if (length) {\n      request.setHeader('Content-Length', length);\n    }\n\n    this.pipe(request);\n    if (cb) {\n      var onResponse;\n\n      var callback = function (error, responce) {\n        request.removeListener('error', callback);\n        request.removeListener('response', onResponse);\n\n        return cb.call(this, error, responce);\n      };\n\n      onResponse = callback.bind(this, null);\n\n      request.on('error', callback);\n      request.on('response', onResponse);\n    }\n  }.bind(this));\n\n  return request;\n};\n\nFormData.prototype._error = function(err) {\n  if (!this.error) {\n    this.error = err;\n    this.pause();\n    this.emit('error', err);\n  }\n};\n\nFormData.prototype.toString = function () {\n  return '[object FormData]';\n};\n"],"names":["CombinedStream","require","util","path","http","https","parseUrl","parse","fs","Stream","mime","asynckit","populate","module","exports","FormData","inherits","options","_overheadLength","_valueLength","_valuesToMeasure","call","option","LINE_BREAK","DEFAULT_CONTENT_TYPE","prototype","append","field","value","filename","bind","isArray","_error","Error","header","_multiPartHeader","footer","_multiPartFooter","_trackLength","valueLength","knownLength","Buffer","isBuffer","length","byteLength","readable","hasOwnProperty","push","_lengthRetriever","callback","end","undefined","Infinity","start","stat","err","fileSize","size","headers","on","response","pause","resume","contentDisposition","_getContentDisposition","contentType","_getContentType","contents","concat","prop","Array","join","getBoundary","filepath","normalize","replace","name","basename","client","_httpMessage","lookup","next","lastPart","_streams","_lastBoundary","getHeaders","userHeaders","formHeaders","toLowerCase","setBoundary","boundary","_boundary","_generateBoundary","getBuffer","dataBuffer","alloc","i","len","from","substring","Math","floor","random","toString","getLengthSync","hasKnownLength","getLength","cb","process","nextTick","parallel","values","forEach","submit","params","request","defaults","method","port","pathname","host","hostname","protocol","setHeader","pipe","onResponse","error","responce","removeListener","emit"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/form-data/lib/form_data.js\n");
|