KNOWN_BUGS 32 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852
  1. _ _ ____ _
  2. ___| | | | _ \| |
  3. / __| | | | |_) | |
  4. | (__| |_| | _ <| |___
  5. \___|\___/|_| \_\_____|
  6. Known Bugs
  7. These are problems and bugs known to exist at the time of this release. Feel
  8. free to join in and help us correct one or more of these! Also be sure to
  9. check the changelog of the current development status, as one or more of these
  10. problems may have been fixed or changed somewhat since this was written!
  11. 1. HTTP
  12. 1.2 Multiple methods in a single WWW-Authenticate: header
  13. 1.3 STARTTRANSFER time is wrong for HTTP POSTs
  14. 1.4 multipart formposts file name encoding
  15. 1.5 Expect-100 meets 417
  16. 1.6 Unnecessary close when 401 received waiting for 100
  17. 1.7 Deflate error after all content was received
  18. 1.8 DoH isn't used for all name resolves when enabled
  19. 1.9 HTTP/2 frames while in the connection pool kill reuse
  20. 1.11 CURLOPT_SEEKFUNCTION not called with CURLFORM_STREAM
  21. 2. TLS
  22. 2.1 CURLINFO_SSL_VERIFYRESULT has limited support
  23. 2.2 DER in keychain
  24. 2.3 Unable to use PKCS12 certificate with Secure Transport
  25. 2.4 Secure Transport won't import PKCS#12 client certificates without a password
  26. 2.5 Client cert handling with Issuer DN differs between backends
  27. 2.6 CURL_GLOBAL_SSL
  28. 2.7 Client cert (MTLS) issues with Schannel
  29. 2.8 Schannel disable CURLOPT_SSL_VERIFYPEER and verify hostname
  30. 2.9 TLS session cache doesn't work with TFO
  31. 2.10 Store TLS context per transfer instead of per connection
  32. 2.11 Schannel TLS 1.2 handshake bug in old Windows versions
  33. 2.12 FTPS with Schannel times out file list operation
  34. 3. Email protocols
  35. 3.1 IMAP SEARCH ALL truncated response
  36. 3.2 No disconnect command
  37. 3.3 POP3 expects "CRLF.CRLF" eob for some single-line responses
  38. 3.4 AUTH PLAIN for SMTP is not working on all servers
  39. 4. Command line
  40. 4.1 -J and -O with %-encoded file names
  41. 4.2 -J with -C - fails
  42. 4.3 --retry and transfer timeouts
  43. 4.4 Improve --data-urlencode space encoding
  44. 5. Build and portability issues
  45. 5.1 OS400 port requires deprecated IBM library
  46. 5.2 curl-config --libs contains private details
  47. 5.3 curl compiled on OSX 10.13 failed to run on OSX 10.10
  48. 5.4 Build with statically built dependency
  49. 5.5 can't handle Unicode arguments in non-Unicode builds on Windows
  50. 5.6 cmake: use correct SONAME for shared library
  51. 5.7 Visual Studio project gaps
  52. 5.8 configure finding libs in wrong directory
  53. 5.9 Utilize Requires.private directives in libcurl.pc
  54. 5.10 SMB tests fail with Python 2
  55. 5.11 configure --with-gssapi with Heimdal is ignored on macOS
  56. 5.12 cmake: support build with GnuTLS
  57. 5.13 cmake: unusable tool_hugehelp.c with MinGW
  58. 5.14 cmake: build docs/curl.1
  59. 6. Authentication
  60. 6.1 NTLM authentication and unicode
  61. 6.2 MIT Kerberos for Windows build
  62. 6.3 NTLM in system context uses wrong name
  63. 6.4 Negotiate and Kerberos V5 need a fake user name
  64. 6.5 NTLM doesn't support password with § character
  65. 6.6 libcurl can fail to try alternatives with --proxy-any
  66. 6.7 Don't clear digest for single realm
  67. 6.8 RTSP authentication breaks without redirect support
  68. 7. FTP
  69. 7.1 FTP without or slow 220 response
  70. 7.2 FTP with CONNECT and slow server
  71. 7.3 FTP with NOBODY and FAILONERROR
  72. 7.4 FTP with ACCT
  73. 7.5 ASCII FTP
  74. 7.6 FTP with NULs in URL parts
  75. 7.7 FTP and empty path parts in the URL
  76. 7.8 Premature transfer end but healthy control channel
  77. 7.9 Passive transfer tries only one IP address
  78. 7.10 FTPS needs session reuse
  79. 8. TELNET
  80. 8.1 TELNET and time limitations don't work
  81. 8.2 Microsoft telnet server
  82. 9. SFTP and SCP
  83. 9.1 SFTP doesn't do CURLOPT_POSTQUOTE correct
  84. 9.2 wolfssh: publickey auth doesn't work
  85. 10. SOCKS
  86. 10.3 FTPS over SOCKS
  87. 10.4 active FTP over a SOCKS
  88. 11. Internals
  89. 11.1 Curl leaks .onion hostnames in DNS
  90. 11.2 error buffer not set if connection to multiple addresses fails
  91. 11.3 c-ares deviates from stock resolver on http://1346569778
  92. 11.4 HTTP test server 'connection-monitor' problems
  93. 11.5 Connection information when using TCP Fast Open
  94. 11.6 slow connect to localhost on Windows
  95. 11.7 signal-based resolver timeouts
  96. 11.8 DoH leaks memory after followlocation
  97. 11.9 DoH doesn't inherit all transfer options
  98. 11.10 Blocking socket operations in non-blocking API
  99. 11.11 A shared connection cache is not thread-safe
  100. 11.12 'no_proxy' string-matches IPv6 numerical addreses
  101. 12. LDAP and OpenLDAP
  102. 12.1 OpenLDAP hangs after returning results
  103. 12.2 LDAP on Windows does authentication wrong?
  104. 12.3 LDAP on Windows doesn't work
  105. 12.4 LDAPS with NSS is slow
  106. 13. TCP/IP
  107. 13.1 --interface for ipv6 binds to unusable IP address
  108. 14 DICT
  109. 14.1 DICT responses show the underlying protocol
  110. ==============================================================================
  111. 1. HTTP
  112. 1.2 Multiple methods in a single WWW-Authenticate: header
  113. The HTTP responses headers WWW-Authenticate: can provide information about
  114. multiple authentication methods as multiple headers or as several methods
  115. within a single header. The latter way, several methods in the same physical
  116. line, is not supported by libcurl's parser. (For no good reason.)
  117. 1.3 STARTTRANSFER time is wrong for HTTP POSTs
  118. Wrong STARTTRANSFER timer accounting for POST requests Timer works fine with
  119. GET requests, but while using POST the time for CURLINFO_STARTTRANSFER_TIME
  120. is wrong. While using POST CURLINFO_STARTTRANSFER_TIME minus
  121. CURLINFO_PRETRANSFER_TIME is near to zero every time.
  122. https://github.com/curl/curl/issues/218
  123. https://curl.se/bug/view.cgi?id=1213
  124. 1.4 multipart formposts file name encoding
  125. When creating multipart formposts. The file name part can be encoded with
  126. something beyond ascii but currently libcurl will only pass in the verbatim
  127. string the app provides. There are several browsers that already do this
  128. encoding. The key seems to be the updated draft to RFC2231:
  129. https://tools.ietf.org/html/draft-reschke-rfc2231-in-http-02
  130. 1.5 Expect-100 meets 417
  131. If an upload using Expect: 100-continue receives an HTTP 417 response, it
  132. ought to be automatically resent without the Expect:. A workaround is for
  133. the client application to redo the transfer after disabling Expect:.
  134. https://curl.se/mail/archive-2008-02/0043.html
  135. 1.6 Unnecessary close when 401 received waiting for 100
  136. libcurl closes the connection if an HTTP 401 reply is received while it is
  137. waiting for the 100-continue response.
  138. https://curl.se/mail/lib-2008-08/0462.html
  139. 1.7 Deflate error after all content was received
  140. There's a situation where we can get an error in a HTTP response that is
  141. compressed, when that error is detected after all the actual body contents
  142. have been received and delivered to the application. This is tricky, but is
  143. ultimately a broken server.
  144. See https://github.com/curl/curl/issues/2719
  145. 1.8 DoH isn't used for all name resolves when enabled
  146. Even if DoH is specified to be used, there are some name resolves that are
  147. done without it. This should be fixed. When the internal function
  148. `Curl_resolver_wait_resolv()` is called, it doesn't use DoH to complete the
  149. resolve as it otherwise should.
  150. See https://github.com/curl/curl/pull/3857 and
  151. https://github.com/curl/curl/pull/3850
  152. 1.9 HTTP/2 frames while in the connection pool kill reuse
  153. If the server sends HTTP/2 frames (like for example an HTTP/2 PING frame) to
  154. curl while the connection is held in curl's connection pool, the socket will
  155. be found readable when considered for reuse and that makes curl think it is
  156. dead and then it will be closed and a new connection gets created instead.
  157. This is *best* fixed by adding monitoring to connections while they are kept
  158. in the pool so that pings can be responded to appropriately.
  159. 1.11 CURLOPT_SEEKFUNCTION not called with CURLFORM_STREAM
  160. I'm using libcurl to POST form data using a FILE* with the CURLFORM_STREAM
  161. option of curl_formadd(). I've noticed that if the connection drops at just
  162. the right time, the POST is reattempted without the data from the file. It
  163. seems like the file stream position isn't getting reset to the beginning of
  164. the file. I found the CURLOPT_SEEKFUNCTION option and set that with a
  165. function that performs an fseek() on the FILE*. However, setting that didn't
  166. seem to fix the issue or even get called. See
  167. https://github.com/curl/curl/issues/768
  168. 2. TLS
  169. 2.1 CURLINFO_SSL_VERIFYRESULT has limited support
  170. CURLINFO_SSL_VERIFYRESULT is only implemented for the OpenSSL, NSS and
  171. GnuTLS backends, so relying on this information in a generic app is flaky.
  172. 2.2 DER in keychain
  173. Curl doesn't recognize certificates in DER format in keychain, but it works
  174. with PEM. https://curl.se/bug/view.cgi?id=1065
  175. 2.3 Unable to use PKCS12 certificate with Secure Transport
  176. See https://github.com/curl/curl/issues/5403
  177. 2.4 Secure Transport won't import PKCS#12 client certificates without a password
  178. libcurl calls SecPKCS12Import with the PKCS#12 client certificate, but that
  179. function rejects certificates that do not have a password.
  180. https://github.com/curl/curl/issues/1308
  181. 2.5 Client cert handling with Issuer DN differs between backends
  182. When the specified client certificate doesn't match any of the
  183. server-specified DNs, the OpenSSL and GnuTLS backends behave differently.
  184. The github discussion may contain a solution.
  185. See https://github.com/curl/curl/issues/1411
  186. 2.6 CURL_GLOBAL_SSL
  187. Since libcurl 7.57.0, the flag CURL_GLOBAL_SSL is a no-op. The change was
  188. merged in https://github.com/curl/curl/commit/d661b0afb571a
  189. It was removed since it was
  190. A) never clear for applications on how to deal with init in the light of
  191. different SSL backends (the option was added back in the days when life
  192. was simpler)
  193. B) multissl introduced dynamic switching between SSL backends which
  194. emphasized (A) even more
  195. C) libcurl uses some TLS backend functionality even for non-TLS functions (to
  196. get "good" random) so applications trying to avoid the init for
  197. performance reasons would do wrong anyway
  198. D) never very carefully documented so all this mostly just happened to work
  199. for some users
  200. However, in spite of the problems with the feature, there were some users who
  201. apparently depended on this feature and who now claim libcurl is broken for
  202. them. The fix for this situation is not obvious as a downright revert of the
  203. patch is totally ruled out due to those reasons above.
  204. https://github.com/curl/curl/issues/2276
  205. 2.7 Client cert (MTLS) issues with Schannel
  206. See https://github.com/curl/curl/issues/3145
  207. 2.8 Schannel disable CURLOPT_SSL_VERIFYPEER and verify hostname
  208. This seems to be a limitation in the underlying Schannel API.
  209. https://github.com/curl/curl/issues/3284
  210. 2.9 TLS session cache doesn't work with TFO
  211. See https://github.com/curl/curl/issues/4301
  212. 2.10 Store TLS context per transfer instead of per connection
  213. The GnuTLS `backend->cred` and the OpenSSL `backend->ctx` data and their
  214. proxy versions (and possibly other TLS backends), could be better moved to be
  215. stored in the Curl_easy handle instead of in per connection so that a single
  216. transfer that makes multiple connections can reuse the context and reduce
  217. memory consumption.
  218. https://github.com/curl/curl/issues/5102
  219. 2.11 Schannel TLS 1.2 handshake bug in old Windows versions
  220. In old versions of Windows such as 7 and 8.1 the Schannel TLS 1.2 handshake
  221. implementation likely has a bug that can rarely cause the key exchange to
  222. fail, resulting in error SEC_E_BUFFER_TOO_SMALL or SEC_E_MESSAGE_ALTERED.
  223. https://github.com/curl/curl/issues/5488
  224. 2.12 FTPS with Schannel times out file list operation
  225. "Instead of the command completing, it just sits there until the timeout
  226. expires." - the same command line seems to work with other TLS backends and
  227. other operating systems. See https://github.com/curl/curl/issues/5284.
  228. 3. Email protocols
  229. 3.1 IMAP SEARCH ALL truncated response
  230. IMAP "SEARCH ALL" truncates output on large boxes. "A quick search of the
  231. code reveals that pingpong.c contains some truncation code, at line 408, when
  232. it deems the server response to be too large truncating it to 40 characters"
  233. https://curl.se/bug/view.cgi?id=1366
  234. 3.2 No disconnect command
  235. The disconnect commands (LOGOUT and QUIT) may not be sent by IMAP, POP3 and
  236. SMTP if a failure occurs during the authentication phase of a connection.
  237. 3.3 POP3 expects "CRLF.CRLF" eob for some single-line responses
  238. You have to tell libcurl not to expect a body, when dealing with one line
  239. response commands. Please see the POP3 examples and test cases which show
  240. this for the NOOP and DELE commands. https://curl.se/bug/?i=740
  241. 3.4 AUTH PLAIN for SMTP is not working on all servers
  242. Specifying "--login-options AUTH=PLAIN" on the command line doesn't seem to
  243. work correctly.
  244. See https://github.com/curl/curl/issues/4080
  245. 4. Command line
  246. 4.1 -J and -O with %-encoded file names
  247. -J/--remote-header-name doesn't decode %-encoded file names. RFC6266 details
  248. how it should be done. The can of worm is basically that we have no charset
  249. handling in curl and ascii >=128 is a challenge for us. Not to mention that
  250. decoding also means that we need to check for nastiness that is attempted,
  251. like "../" sequences and the like. Probably everything to the left of any
  252. embedded slashes should be cut off.
  253. https://curl.se/bug/view.cgi?id=1294
  254. -O also doesn't decode %-encoded names, and while it has even less
  255. information about the charset involved the process is similar to the -J case.
  256. Note that we won't add decoding to -O without the user asking for it with
  257. some other means as well, since -O has always been documented to use the name
  258. exactly as specified in the URL.
  259. 4.2 -J with -C - fails
  260. When using -J (with -O), automatically resumed downloading together with "-C
  261. -" fails. Without -J the same command line works! This happens because the
  262. resume logic is worked out before the target file name (and thus its
  263. pre-transfer size) has been figured out!
  264. https://curl.se/bug/view.cgi?id=1169
  265. 4.3 --retry and transfer timeouts
  266. If using --retry and the transfer timeouts (possibly due to using -m or
  267. -y/-Y) the next attempt doesn't resume the transfer properly from what was
  268. downloaded in the previous attempt but will truncate and restart at the
  269. original position where it was at before the previous failed attempt. See
  270. https://curl.se/mail/lib-2008-01/0080.html and Mandriva bug report
  271. https://qa.mandriva.com/show_bug.cgi?id=22565
  272. 4.4 Improve --data-urlencode space encoding
  273. ASCII space characters in --data-urlencode are currently encoded as %20
  274. rather than +, which RFC 1866 says should be used.
  275. See https://github.com/curl/curl/issues/3229
  276. 5. Build and portability issues
  277. 5.1 OS400 port requires deprecated IBM library
  278. curl for OS400 requires QADRT to build, which provides ASCII wrappers for
  279. libc/POSIX functions in the ILE, but IBM no longer supports or even offers
  280. this library to download.
  281. See https://github.com/curl/curl/issues/5176
  282. 5.2 curl-config --libs contains private details
  283. "curl-config --libs" will include details set in LDFLAGS when configure is
  284. run that might be needed only for building libcurl. Further, curl-config
  285. --cflags suffers from the same effects with CFLAGS/CPPFLAGS.
  286. 5.3 curl compiled on OSX 10.13 failed to run on OSX 10.10
  287. See https://github.com/curl/curl/issues/2905
  288. 5.4 Build with statically built dependency
  289. The build scripts in curl (autotools, cmake and others) are primarily done to
  290. work with shared/dynamic third party dependencies. When linking with shared
  291. libraries, the dependency "chain" is handled automatically by the library
  292. loader - on all modern systems.
  293. If you instead link with a static library, we need to provide all the
  294. dependency libraries already at the link command line.
  295. Figuring out all the dependency libraries for a given library is hard, as it
  296. might also involve figuring out the dependencies of the dependencies and they
  297. may vary between platforms and even change between versions.
  298. When using static dependencies, the build scripts will mostly assume that
  299. you, the user, will provide all the necessary additional dependency libraries
  300. as additional arguments in the build. With configure, by setting LIBS/LDFLAGS
  301. on the command line.
  302. We welcome help to improve curl's ability to link with static libraries, but
  303. it is likely a task that we can never fully support.
  304. 5.5 can't handle Unicode arguments in non-Unicode builds on Windows
  305. If a URL or filename can't be encoded using the user's current codepage then
  306. it can only be encoded properly in the Unicode character set. Windows uses
  307. UTF-16 encoding for Unicode and stores it in wide characters, however curl
  308. and libcurl are not equipped for that at the moment except when built with
  309. _UNICODE and UNICODE defined. And, except for Cygwin, Windows can't use UTF-8
  310. as a locale.
  311. https://curl.se/bug/?i=345
  312. https://curl.se/bug/?i=731
  313. https://curl.se/bug/?i=3747
  314. 5.6 cmake: use correct SONAME for shared library
  315. The autotools build sets the SONAME properly according to VERSIONINFO in
  316. lib/Makefile.am and so should cmake to make comparable build.
  317. See https://github.com/curl/curl/pull/5935
  318. 5.7 Visual Studio project gaps
  319. The Visual Studio projects lack some features that the autoconf and nmake
  320. builds offer, such as the following:
  321. - support for zlib and nghttp2
  322. - use of static runtime libraries
  323. - add the test suite components
  324. In addition to this the following could be implemented:
  325. - support for other development IDEs
  326. - add PATH environment variables for third-party DLLs
  327. 5.8 configure finding libs in wrong directory
  328. When the configure script checks for third-party libraries, it adds those
  329. directories to the LDFLAGS variable and then tries linking to see if it
  330. works. When successful, the found directory is kept in the LDFLAGS variable
  331. when the script continues to execute and do more tests and possibly check for
  332. more libraries.
  333. This can make subsequent checks for libraries wrongly detect another
  334. installation in a directory that was previously added to LDFLAGS by another
  335. library check!
  336. A possibly better way to do these checks would be to keep the pristine LDFLAGS
  337. even after successful checks and instead add those verified paths to a
  338. separate variable that only after all library checks have been performed gets
  339. appended to LDFLAGS.
  340. 5.9 Utilize Requires.private directives in libcurl.pc
  341. https://github.com/curl/curl/issues/864
  342. 5.10 SMB tests fail with Python 2
  343. The error message says "TreeConnectAndX not found".
  344. See https://github.com/curl/curl/issues/5983
  345. 5.11 configure --with-gssapi with Heimdal is ignored on macOS
  346. ... unless you also pass --with-gssapi-libs
  347. https://github.com/curl/curl/issues/3841
  348. 5.12 cmake: support build with GnuTLS
  349. 5.13 cmake: unusable tool_hugehelp.c with MinGW
  350. see https://github.com/curl/curl/issues/3125
  351. 5.14 cmake: build docs/curl.1
  352. The cmake build doesn't create the docs/curl.1 file and therefor must rely on
  353. it being there already. This makes the --manual option not work and test
  354. cases like 1139 can't function.
  355. 6. Authentication
  356. 6.1 NTLM authentication and unicode
  357. NTLM authentication involving unicode user name or password only works
  358. properly if built with UNICODE defined together with the Schannel
  359. backend. The original problem was mentioned in:
  360. https://curl.se/mail/lib-2009-10/0024.html
  361. https://curl.se/bug/view.cgi?id=896
  362. The Schannel version verified to work as mentioned in
  363. https://curl.se/mail/lib-2012-07/0073.html
  364. 6.2 MIT Kerberos for Windows build
  365. libcurl fails to build with MIT Kerberos for Windows (KfW) due to KfW's
  366. library header files exporting symbols/macros that should be kept private to
  367. the KfW library. See ticket #5601 at https://krbdev.mit.edu/rt/
  368. 6.3 NTLM in system context uses wrong name
  369. NTLM authentication using SSPI (on Windows) when (lib)curl is running in
  370. "system context" will make it use wrong(?) user name - at least when compared
  371. to what winhttp does. See https://curl.se/bug/view.cgi?id=535
  372. 6.4 Negotiate and Kerberos V5 need a fake user name
  373. In order to get Negotiate (SPNEGO) authentication to work in HTTP or Kerberos
  374. V5 in the e-mail protocols, you need to provide a (fake) user name (this
  375. concerns both curl and the lib) because the code wrongly only considers
  376. authentication if there's a user name provided by setting
  377. conn->bits.user_passwd in url.c https://curl.se/bug/view.cgi?id=440 How?
  378. https://curl.se/mail/lib-2004-08/0182.html A possible solution is to
  379. either modify this variable to be set or introduce a variable such as
  380. new conn->bits.want_authentication which is set when any of the authentication
  381. options are set.
  382. 6.5 NTLM doesn't support password with § character
  383. https://github.com/curl/curl/issues/2120
  384. 6.6 libcurl can fail to try alternatives with --proxy-any
  385. When connecting via a proxy using --proxy-any, a failure to establish an
  386. authentication will cause libcurl to abort trying other options if the
  387. failed method has a higher preference than the alternatives. As an example,
  388. --proxy-any against a proxy which advertise Negotiate and NTLM, but which
  389. fails to set up Kerberos authentication won't proceed to try authentication
  390. using NTLM.
  391. https://github.com/curl/curl/issues/876
  392. 6.7 Don't clear digest for single realm
  393. https://github.com/curl/curl/issues/3267
  394. 6.8 RTSP authentication breaks without redirect support
  395. RTSP authentication broke in 7.66.0. A work-around is to enable RTSP in
  396. CURLOPT_REDIR_PROTOCOLS. Authentication should however not be considered an
  397. actual redirect so a "proper" fix needs to be different and not require users
  398. to allow redirects to RTSP to work.
  399. See https://github.com/curl/curl/pull/4750
  400. 7. FTP
  401. 7.1 FTP without or slow 220 response
  402. If a connection is made to a FTP server but the server then just never sends
  403. the 220 response or otherwise is dead slow, libcurl will not acknowledge the
  404. connection timeout during that phase but only the "real" timeout - which may
  405. surprise users as it is probably considered to be the connect phase to most
  406. people. Brought up (and is being misunderstood) in:
  407. https://curl.se/bug/view.cgi?id=856
  408. 7.2 FTP with CONNECT and slow server
  409. When doing FTP over a socks proxy or CONNECT through HTTP proxy and the multi
  410. interface is used, libcurl will fail if the (passive) TCP connection for the
  411. data transfer isn't more or less instant as the code does not properly wait
  412. for the connect to be confirmed. See test case 564 for a first shot at a test
  413. case.
  414. 7.3 FTP with NOBODY and FAILONERROR
  415. It seems sensible to be able to use CURLOPT_NOBODY and CURLOPT_FAILONERROR
  416. with FTP to detect if a file exists or not, but it is not working:
  417. https://curl.se/mail/lib-2008-07/0295.html
  418. 7.4 FTP with ACCT
  419. When doing an operation over FTP that requires the ACCT command (but not when
  420. logging in), the operation will fail since libcurl doesn't detect this and
  421. thus fails to issue the correct command:
  422. https://curl.se/bug/view.cgi?id=635
  423. 7.5 ASCII FTP
  424. FTP ASCII transfers do not follow RFC959. They don't convert the data
  425. accordingly (not for sending nor for receiving). RFC 959 section 3.1.1.1
  426. clearly describes how this should be done:
  427. The sender converts the data from an internal character representation to
  428. the standard 8-bit NVT-ASCII representation (see the Telnet
  429. specification). The receiver will convert the data from the standard
  430. form to his own internal form.
  431. Since 7.15.4 at least line endings are converted.
  432. 7.6 FTP with NULs in URL parts
  433. FTP URLs passed to curl may contain NUL (0x00) in the RFC 1738 <user>,
  434. <password>, and <fpath> components, encoded as "%00". The problem is that
  435. curl_unescape does not detect this, but instead returns a shortened C string.
  436. From a strict FTP protocol standpoint, NUL is a valid character within RFC
  437. 959 <string>, so the way to handle this correctly in curl would be to use a
  438. data structure other than a plain C string, one that can handle embedded NUL
  439. characters. From a practical standpoint, most FTP servers would not
  440. meaningfully support NUL characters within RFC 959 <string>, anyway (e.g.,
  441. Unix pathnames may not contain NUL).
  442. 7.7 FTP and empty path parts in the URL
  443. libcurl ignores empty path parts in FTP URLs, whereas RFC1738 states that
  444. such parts should be sent to the server as 'CWD ' (without an argument). The
  445. only exception to this rule, is that we knowingly break this if the empty
  446. part is first in the path, as then we use the double slashes to indicate that
  447. the user wants to reach the root dir (this exception SHALL remain even when
  448. this bug is fixed).
  449. 7.8 Premature transfer end but healthy control channel
  450. When 'multi_done' is called before the transfer has been completed the normal
  451. way, it is considered a "premature" transfer end. In this situation, libcurl
  452. closes the connection assuming it doesn't know the state of the connection so
  453. it can't be reused for subsequent requests.
  454. With FTP however, this isn't necessarily true but there are a bunch of
  455. situations (listed in the ftp_done code) where it *could* keep the connection
  456. alive even in this situation - but the current code doesn't. Fixing this would
  457. allow libcurl to reuse FTP connections better.
  458. 7.9 Passive transfer tries only one IP address
  459. When doing FTP operations through a proxy at localhost, the reported spotted
  460. that curl only tried to connect once to the proxy, while it had multiple
  461. addresses and a failed connect on one address should make it try the next.
  462. After switching to passive mode (EPSV), curl should try all IP addresses for
  463. "localhost". Currently it tries ::1, but it should also try 127.0.0.1.
  464. See https://github.com/curl/curl/issues/1508
  465. 7.10 FTPS needs session reuse
  466. When the control connection is reused for a subsequent transfer, some FTPS
  467. servers complain about "missing session reuse" for the data channel for the
  468. second transfer.
  469. https://github.com/curl/curl/issues/4654
  470. 8. TELNET
  471. 8.1 TELNET and time limitations don't work
  472. When using telnet, the time limitation options don't work.
  473. https://curl.se/bug/view.cgi?id=846
  474. 8.2 Microsoft telnet server
  475. There seems to be a problem when connecting to the Microsoft telnet server.
  476. https://curl.se/bug/view.cgi?id=649
  477. 9. SFTP and SCP
  478. 9.1 SFTP doesn't do CURLOPT_POSTQUOTE correct
  479. When libcurl sends CURLOPT_POSTQUOTE commands when connected to a SFTP server
  480. using the multi interface, the commands are not being sent correctly and
  481. instead the connection is "cancelled" (the operation is considered done)
  482. prematurely. There is a half-baked (busy-looping) patch provided in the bug
  483. report but it cannot be accepted as-is. See
  484. https://curl.se/bug/view.cgi?id=748
  485. 9.2 wolfssh: publickey auth doesn't work
  486. When building curl to use the wolfSSH backend for SFTP, the publickey
  487. authentication doesn't work. This is simply functionality not written for curl
  488. yet, the necessary API for make this work is provided by wolfSSH.
  489. See https://github.com/curl/curl/issues/4820
  490. 10. SOCKS
  491. 10.3 FTPS over SOCKS
  492. libcurl doesn't support FTPS over a SOCKS proxy.
  493. 10.4 active FTP over a SOCKS
  494. libcurl doesn't support active FTP over a SOCKS proxy
  495. 11. Internals
  496. 11.1 Curl leaks .onion hostnames in DNS
  497. Curl sends DNS requests for hostnames with a .onion TLD. This leaks
  498. information about what the user is attempting to access, and violates this
  499. requirement of RFC7686: https://tools.ietf.org/html/rfc7686
  500. Issue: https://github.com/curl/curl/issues/543
  501. 11.2 error buffer not set if connection to multiple addresses fails
  502. If you ask libcurl to resolve a hostname like example.com to IPv6 addresses
  503. only. But you only have IPv4 connectivity. libcurl will correctly fail with
  504. CURLE_COULDNT_CONNECT. But the error buffer set by CURLOPT_ERRORBUFFER
  505. remains empty. Issue: https://github.com/curl/curl/issues/544
  506. 11.3 c-ares deviates from stock resolver on http://1346569778
  507. When using the socket resolvers, that URL becomes:
  508. * Rebuilt URL to: http://1346569778/
  509. * Trying 80.67.6.50...
  510. but with c-ares it instead says "Could not resolve: 1346569778 (Domain name
  511. not found)"
  512. See https://github.com/curl/curl/issues/893
  513. 11.4 HTTP test server 'connection-monitor' problems
  514. The 'connection-monitor' feature of the sws HTTP test server doesn't work
  515. properly if some tests are run in unexpected order. Like 1509 and then 1525.
  516. See https://github.com/curl/curl/issues/868
  517. 11.5 Connection information when using TCP Fast Open
  518. CURLINFO_LOCAL_PORT (and possibly a few other) fails when TCP Fast Open is
  519. enabled.
  520. See https://github.com/curl/curl/issues/1332 and
  521. https://github.com/curl/curl/issues/4296
  522. 11.6 slow connect to localhost on Windows
  523. When connecting to "localhost" on Windows, curl will resolve the name for
  524. both ipv4 and ipv6 and try to connect to both happy eyeballs-style. Something
  525. in there does however make it take 200 milliseconds to succeed - which is the
  526. HAPPY_EYEBALLS_TIMEOUT define exactly. Lowering that define speeds up the
  527. connection, suggesting a problem in the HE handling.
  528. If we can *know* that we're talking to a local host, we should lower the
  529. happy eyeballs delay timeout for IPv6 (related: hardcode the "localhost"
  530. addresses, mentioned in TODO). Possibly we should reduce that delay for all.
  531. https://github.com/curl/curl/issues/2281
  532. 11.7 signal-based resolver timeouts
  533. libcurl built without an asynchronous resolver library uses alarm() to time
  534. out DNS lookups. When a timeout occurs, this causes libcurl to jump from the
  535. signal handler back into the library with a sigsetjmp, which effectively
  536. causes libcurl to continue running within the signal handler. This is
  537. non-portable and could cause problems on some platforms. A discussion on the
  538. problem is available at https://curl.se/mail/lib-2008-09/0197.html
  539. Also, alarm() provides timeout resolution only to the nearest second. alarm
  540. ought to be replaced by setitimer on systems that support it.
  541. 11.8 DoH leaks memory after followlocation
  542. https://github.com/curl/curl/issues/4592
  543. 11.9 DoH doesn't inherit all transfer options
  544. https://github.com/curl/curl/issues/4578
  545. 11.10 Blocking socket operations in non-blocking API
  546. The list of blocking socket operations is in TODO section "More non-blocking".
  547. 11.11 A shared connection cache is not thread-safe
  548. The share interface offers CURL_LOCK_DATA_CONNECT to have multiple easy
  549. handle share a connection cache, but due to how connections are used they are
  550. still not thread-safe when used shared.
  551. See https://github.com/curl/curl/issues/4915 and lib1541.c
  552. 11.12 'no_proxy' string-matches IPv6 numerical addreses
  553. This has the downside that "::1" for example doesn't match "::0:1" even
  554. though they are in fact the same address.
  555. See https://github.com/curl/curl/issues/5745
  556. 12. LDAP and OpenLDAP
  557. 12.1 OpenLDAP hangs after returning results
  558. By configuration defaults, openldap automatically chase referrals on
  559. secondary socket descriptors. The OpenLDAP backend is asynchronous and thus
  560. should monitor all socket descriptors involved. Currently, these secondary
  561. descriptors are not monitored, causing openldap library to never receive
  562. data from them.
  563. As a temporary workaround, disable referrals chasing by configuration.
  564. The fix is not easy: proper automatic referrals chasing requires a
  565. synchronous bind callback and monitoring an arbitrary number of socket
  566. descriptors for a single easy handle (currently limited to 5).
  567. Generic LDAP is synchronous: OK.
  568. See https://github.com/curl/curl/issues/622 and
  569. https://curl.se/mail/lib-2016-01/0101.html
  570. 12.2 LDAP on Windows does authentication wrong?
  571. https://github.com/curl/curl/issues/3116
  572. 12.3 LDAP on Windows doesn't work
  573. A simple curl command line getting "ldap://ldap.forumsys.com" returns an
  574. error that says "no memory" !
  575. https://github.com/curl/curl/issues/4261
  576. 12.4 LDAPS with NSS is slow
  577. See https://github.com/curl/curl/issues/5874
  578. 13. TCP/IP
  579. 13.1 --interface for ipv6 binds to unusable IP address
  580. Since IPv6 provides a lot of addresses with different scope, binding to an
  581. IPv6 address needs to take the proper care so that it doesn't bind to a
  582. locally scoped address as that is bound to fail.
  583. https://github.com/curl/curl/issues/686
  584. 14. DICT
  585. 14.1 DICT responses show the underlying protocol
  586. When getting a DICT response, the protocol parts of DICT aren't stripped off
  587. from the output.
  588. https://github.com/curl/curl/issues/1809