multi-part-lite
A multi-part-lite
allows you to create multipart/form-data Stream
and Buffer
, which can be used to submit forms and file uploads to other web applications.
There are no external dependencies, so it as fast and simple as possible.
Supports: Strings
, Numbers
, Arrays
, Streams
, Buffers
and Vinyl
.
Install
$ npm install multi-part-lite --save
Usage
Usage with got
as Stream
:
const got = ;const Multipart = ;const form = ; form;form; got;
Usage with got
as Buffer
:
const got = ;const Multipart = ;const form = ; form;form; async { const body = await form; got;}
Usage with http
/https
as Stream
:
const http = ;const https = ;const Multipart = ;const form = ; form; form;
Usage with http
/https
as Buffer
:
const http = ;const https = ;const Multipart = ;const form = ; form; async { const body = await form; const req = http; req;}
API
new Multipart([options])
Constructor.
Params:
- [options] (Object) -
Object
with options:- [boundary] (String|Number) - Custom boundary for
multipart
data. Ex: if equalCustomBoundary
, boundary will be equal exactlyCustomBoundary
. - [boundaryPrefix] (String|Number) - Custom boundary prefix for
multipart
data. Ex: if equalCustomBoundary
, boundary will be equal something like--CustomBoundary567689371204
. - [defaults] (Object) -
Object
with defaults values:- [name] (String) - File name which will be used, if
filename
is not specified in the options of.append
method. By defaultfile
. - [ext] (String) - File extension which will be used, if
filename
is not specified in the options of.append
method. By defaultbin
. - [type] (String) - File content-type which will be used, if
contentType
is not specified in the options of.append
method. By defaultapplication/octet-stream
.
- [name] (String) - File name which will be used, if
- [boundary] (String|Number) - Custom boundary for
.append(name, value, [options])
Adds a new data to the multipart/form-data
stream.
Params:
- name (String|Number) - Field name. Ex:
photo
. - value (Mixed) - Value can be
String
,Number
,Array
,Buffer
,ReadableStream
or even Vynil. - [options] (Object) - Additional options:
- filename (String) - File name. You should always specify file name with extension, otherwise
file.bin
will be set. Ex:anonim.jpg
. - contentType (String) - File content type. You should always specify content-type, otherwise
application/octet-stream
will be set. Ex:image/jpeg
.
- filename (String) - File name. You should always specify file name with extension, otherwise
If value
is an array, append
will be called for each value:
form; // similar to form;form;form;form;
Null
, false
and true
will be converted to '0'
, '0'
and '1'
. Numbers will be converted to strings also.
Warning: You must specify the correct contentType
and filename
. This library doesn't validate them. You can use multi-part
library which can handle it for you.
.stream()
Returns a multipart/form-data
stream.
.buffer()
Returns a Promise
with a buffer of the multipart/form-data
stream data.
.getBoundary()
Returns the form boundary used in the multipart/form-data
stream.
form; // -> '--MultipartBoundary352840693617'
.getLength()
Returns the length of a buffer of the multipart/form-data
stream data.
Should be called after .buffer()
;
For .stream()
it's always 0
.
await form;form; // -> 12345
.getHeaders(chunked = true)
Returns the headers.
If you want to get correct content-length
, you should call it after .buffer()
. There is no way to know content-length
of the .stream()
, so it will be always 0
.
Params:
- chunked (Boolean) - If
false
- headers will includecontent-length
header, otherwise there will betransfer-encoding: 'chunked'
.
form; // ->//{// 'transfer-encoding': 'chunked',// 'content-type': 'multipart/form-data; boundary="--MultipartBoundary352840693617"'//}
With .buffer()
:
form; // ->//{// 'content-length': '0',// 'content-type': 'multipart/form-data; boundary="--MultipartBoundary352840693617"'//} await form;form; // ->//{// 'content-length': '12345',// 'content-type': 'multipart/form-data; boundary="--MultipartBoundary352840693617"'//}
License
The MIT License (MIT)
Copyright (c) 2019 Alexey Bystrov