Changelog All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog and this project adheres to Semantic Versioning.
- Fix retrieve-win-deps Windows build script not working correctly
- Added missing
CURLOPT_SASL_AUTHZID
option - libcurl 7.66.0 - Added missing
CURLE_AUTH_ERROR
error code added with libcurl 7.66.0 - Added missing
CURLINFO_RETRY_AFTER
info field - libcurl 7.66.0 - Added missing
CURL_HTTP_VERSION_3
constant related http version to theCurlHttpVersion
enum - libcurl 7.66.0 - Added missing
CURLMOPT_MAX_CONCURRENT_STREAMS
option - libcurl 7.67.0 - Added missing
CurlProgressFunc
enum to reflect the newCURL_PROGRESSFUNC_CONTINUE
constant - libcurl 7.68.0 - Added missing
CurlSslOpt
enum memberNoPartialChain
- libcurl 7.68.0 - Added missing
CURLE_HTTP3
error code - An HTTP/3 layer problem - libcurl 7.68.0 - Added missing
CURLM_WAKEUP_FAILURE
error code - wakeup is unavailable or failed - libcurl 7.68.0 - Added missing
CURLM_BAD_FUNCTION_ARGUMENT
error code - function called with a bad parameter - libcurl 7.69.0 - Added missing
CURLE_QUIC_CONNECT_ERROR
error code - QUIC connection error - libcurl 7.69.0 - Added missing
CURLOPT_MAIL_RCPT_ALLLOWFAILS
option - libcurl 7.69.0
- Prebuilt binaries are now compiled with libcurl 7.69.1 and, when possible, latest version of other related dependencies:
- OpenSSL 1.1.1d
- nghttp2 1.4.0
- libssh2 1.9.0
- Added prebuilt binaries for:
- Electron v8
- NW.js v0.44, v0.43 and v0.42
- Dropped prebuilt binaries for:
- Node.js 8
- Electron v3, v4 and v5
- NW.js v0.38 and v0.39
- Updated return type of DEBUGFUNCTION (#202)
- Fixed issues when building with newer versions of v8 (Node.js >= 13 and Electron >= 7) (#203)
- Type for
this
added to event listeners callbacks - Build on Node.js 13 and Electron 7
- Build on Electron v6
- Improved build scripts
- bump libssh2 to 1.9.0
- Fixed problem when building with libcurl <= 7.38
- Dropped support for Node.js 4 and 6
- Prebuilt binary is now statically built with brotli, libssh2, nghttp2, OpenSSL and zlib. brotli, OpenSSL, nghttp2 and zlib versions match their respective versions used by Node.js.
- The minimum libcurl version being tested is now
7.50.0
, which itself is almost 3 years old.
The addon will still try to be compatible with old versions up to7.32.0
, but there are no guarantees. Curl.reset
now correctly resets their instance (#141)- Previously
Curl.code
had all Curl codes into a single enum like object, that is, it included properties for eachCURLMCode
,CURLcode
andCURLSHcode
libcurl enums.
Now they are separated, each on their own object:
CURLMCode
->CurlMultiCode
CURLcode
->CurlCode
CURLSHCode
->CurlShareCode
DEBUGFUNCTION
now receives aBuffer
as thedata
argument, instead of astring
.Easy.send
andEasy.recv
now return an object,{ code: CurlCode, bytesSent: number }
and{ code: CurlCode, bytesReceived: number }
respectively.Curl
class: removed_
prefix from their private members.
Only a breaking change in case you were using internal methods.Curl
class: methodsonData
andonHeader
renamed todefaultWriteFunction
anddefaultHeaderFunction
.
Only a breaking change in case you were using internal methods.Curl
class: deprecated instance fieldsonData
andonHeader
were removed.
Use optionsWRITEFUNCTION
andHEADERFUNCTION
respectively.Curl.dupHandle
, argumentshouldCopyCallbacks
was removed, it was the first one.
This is not needed anymore because the previously set callbacks (onData
andonHeader
) can now only be set using their respective libcurl options, which is always copied when duplicating a handle.Curl.multi
moved toMulti.option
Curl.share
moved toShare.option
- Following members were moved to their own export:
Curl.auth
->CurlAuth
Curl.pause
->CurlPause
Curl.http
->CurlHttpversion
Curl.feature
->CurlFeature
Curl.lock
->CurlShareLock
Curl.header
->CurlHeader
Curl.info.debug
->CurlInfoDebug
Curl.netrc
->CurlNetrc
Curl.chunk
->CurlChunk
Curl.filetype
->CurlFileType
Curl.fnmatchfunc
->CurlFnMatchFunc
Curl.ftpauth
->CurlFtpAuth
Curl.ftpssl
->CurlFtpSsl
Curl.ftpmethod
->CurlFtpMethod
Curl.rtspreq
->CurlRtspRequest
Curl.ipresolve
->CurlIpResolve
Curl.proxy
->CurlProxy
Curl.pipe
->CurlPipe
Curl.usessl
->CurlUseSsl
Curl.sslversion
->CurlSslVersion
Curl.sslversion.max
->CurlSslVersionMax
Curl.ssh_auth
->CurlSshAuth
Curl.timecond
->CurlTimeCond
Easy.socket
->SocketState
And their fields were changed fromSNAKE_CASE
toPascalCase
.
The change in casing was to follow Typescript's Enum naming convention. Curl.protocol
also moved to their own exportCurlProtocol
, no changes were made to fields casing in this case.- Passing non-integer option value to
Multi.setOpt
will now throw an error.
Previously the value was converted to1
if it was a truthy value, or0
if otherwise.
- Fix SigAbort caused by calling v8
AsFunction
on null value atEasy::SetOpt
- Fix SegFault during gargage collection after
process.exit
(#165) - Using
curl_socket_t
without libcurl version guard onEasy::GetInfo
- Support Node.js 12
- Added missing options:
CURLOPT_DISALLOW_USERNAME_IN_URL
CURLOPT_DNS_SHUFFLE_ADDRESSES
CURLOPT_DOH_URL
CURLOPT_HAPPY_EYEBALLS_TIMEOUT_MS
CURLOPT_HAPROXYPROTOCOL
CURLOPT_HTTP09_ALLOWED
CURLOPT_REQUEST_TARGET
CURLOPT_FTP_FILEMETHOD
(#148)CURLOPT_MAXAGE_CONN
CURLOPT_PROXY_*
CURLOPT_RTSPHEADER
CURLOPT_RTSP_REQUEST
CURLOPT_SOCKS5_AUTH
CURLOPT_SSH_COMPRESSION
CURLOPT_TLS13_CIPHERS
CURLOPT_TIMEVALUE_LARGE
CURLOPT_TRAILERFUNCTION
CURLOPT_UPKEEP_INTERVAL_MS
- Add missing info fields:
CURLINFO_*_{DOWNLOAD,UPLOAD}_T
CURLINFO_*_TIME_T
CURLINFO_FILETIME_T
- Add
Curl.getVersionInfo()
which returns an object that represents the struct returned fromcurl_version_info()
.
See their type definition for details: [./lib/types/CurlVersionInfoNativeBinding.ts
](./lib/types/ - Add
Curl.getVersionInfoString()
which returns a string representation of the above function.
It should be almost identical to the one returned fromcurl -V
. - Add
Curl.isVersionGreaterOrEqualThan(x, y, z)
to help test if the libcurl version the addon was built against is greater or equal than x.y.z. - Add
upkeep
function to Easy and Curl classes. This is a binding for thecurl_easy_upkeep()
function. - Errors thrown inside callbacks are correctly caught / passed forward (if using multi interface)
- All
Curl
instances now set theirUSERAGENT
tonode-libcurl/${packageVersion}
during creation.
You change the default user agent string by changingCurl.defaultUserAgent
, and disable it by setting their value to null. CurlWriteFunc
andCurlReadFunc
enums with special return codes for their respective options,WRITEFUNCTION
andREADFUNCTION
.- Added experimental
curly(url: string, options: {})
/curly.<http-verb>(url: string, options: {})
async api.
This API can change between minor releases.
- Migrated project to Typescript and added type definitions
- Bumped libcurl version used on Windows to
7.64.1
, which hasnghttp2
support - Added the
Curl
instance that emitted the event as the last param passed to events, can be useful if using anonymous functions as callback for the events. Example:// ... curl.on('end', (statusCode, data, headers, curlInstance) => { // ... })
- Fix erratic condition when setting option
HEADERFUNCTION
(#142) - macOS libs should be linked against @rpath (#145)
Special Thanks to @koskokos2 for their contributions to this release.
- Node.js 10 on CI and respective prebuilt binaries
- Removed deprecated NAN method calls
1.3.2 - 2018-05-24
- Curl multi integer options being wrongly tested (#126)
1.3.1 - 2018-05-04
- Changelog file (finally)
- Improved code style, started using prettier