Merge branch 'master' into http2-push
This commit is contained in:
2
README
2
README
@@ -38,7 +38,7 @@ GIT
|
|||||||
|
|
||||||
To download the very latest source off the GIT server do this:
|
To download the very latest source off the GIT server do this:
|
||||||
|
|
||||||
git clone git://github.com/bagder/curl.git
|
git clone https://github.com/bagder/curl.git
|
||||||
|
|
||||||
(you'll get a directory named curl created, filled with the source code)
|
(you'll get a directory named curl created, filled with the source code)
|
||||||
|
|
||||||
|
117
RELEASE-NOTES
117
RELEASE-NOTES
@@ -1,83 +1,19 @@
|
|||||||
Curl and libcurl 7.43.0
|
Curl and libcurl 7.44.0
|
||||||
|
|
||||||
Public curl releases: 147
|
Public curl releases: 148
|
||||||
Command line options: 176
|
Command line options: 176
|
||||||
curl_easy_setopt() options: 218
|
curl_easy_setopt() options: 219
|
||||||
Public functions in libcurl: 58
|
Public functions in libcurl: 58
|
||||||
Contributors: 1265
|
Contributors: 1291
|
||||||
|
|
||||||
This release includes the following changes:
|
This release includes the following changes:
|
||||||
|
|
||||||
o Added CURLOPT_PROXY_SERVICE_NAME[11]
|
o
|
||||||
o Added CURLOPT_SERVICE_NAME[12]
|
|
||||||
o New curl option: --proxy-service-name[13]
|
|
||||||
o Mew curl option: --service-name [14]
|
|
||||||
o New curl option: --data-raw [5]
|
|
||||||
o Added CURLOPT_PIPEWAIT [15]
|
|
||||||
o Added support for multiplexing transfers using HTTP/2, enable this
|
|
||||||
with the new CURLPIPE_MULTIPLEX bit for CURLMOPT_PIPELINING [16]
|
|
||||||
o HTTP/2: requires nghttp2 1.0.0 or later
|
|
||||||
o scripts: add zsh.pl for generating zsh completion
|
|
||||||
o curl.h: add CURL_HTTP_VERSION_2
|
|
||||||
|
|
||||||
This release includes the following bugfixes:
|
This release includes the following bugfixes:
|
||||||
|
|
||||||
o nss: fix compilation failure with old versions of NSS [1]
|
o
|
||||||
o curl_easy_getinfo.3: document 'internals' in CURLINFO_TLS_SESSION
|
|
||||||
o schannel.c: Fix possible SEC_E_BUFFER_TOO_SMALL error
|
|
||||||
o Curl_ossl_init: load builtin modules [2]
|
|
||||||
o configure: follow-up fix for krb5-config [3]
|
|
||||||
o sasl_sspi: Populate domain from the realm in the challenge [4]
|
|
||||||
o netrc: support 'default' token
|
|
||||||
o README: convert to UTF-8
|
|
||||||
o cyassl: Implement public key pinning
|
|
||||||
o nss: implement public key pinning for NSS backend
|
|
||||||
o mingw build: add arch -m32/-m64 to LDFLAGS
|
|
||||||
o schannel: Fix out of bounds array [6]
|
|
||||||
o configure: remove autogenerated files by autoconf
|
|
||||||
o configure: remove --automake from libtoolize call
|
|
||||||
o acinclude.m4: fix shell test for default CA cert bundle/path
|
|
||||||
o schannel: fix regression in schannel_recv [7]
|
|
||||||
o openssl: skip trace outputs for ssl_ver == 0 [8]
|
|
||||||
o gnutls: properly retrieve certificate status
|
|
||||||
o netrc: Read in text mode when cygwin [9]
|
|
||||||
o winbuild: Document the option used to statically link the CRT [10]
|
|
||||||
o FTP: Make EPSV use the control IP address rather than the original host
|
|
||||||
o FTP: fix dangling conn->ip_addr dereference on verbose EPSV
|
|
||||||
o conncache: keep bundles on host+port bases, not only host names
|
|
||||||
o runtests.pl: use 'h2c' now, no -14 anymore
|
|
||||||
o curlver: introducing new version number (checking) macros
|
|
||||||
o openssl: boringssl build brekage, use SSL_CTX_set_msg_callback [17]
|
|
||||||
o CURLOPT_POSTFIELDS.3: correct variable names [18]
|
|
||||||
o curl_easy_unescape.3: update RFC reference [19]
|
|
||||||
o gnutls: don't fail on non-fatal alerts during handshake
|
|
||||||
o testcurl.pl: allow source to be in an arbitrary directory
|
|
||||||
o CURLOPT_HTTPPROXYTUNNEL.3: only works with a HTTP proxy
|
|
||||||
o SSPI-error: Change SEC_E_ILLEGAL_MESSAGE description [20]
|
|
||||||
o parse_proxy: switch off tunneling if non-HTTP proxy [21]
|
|
||||||
o share_init: fix OOM crash
|
|
||||||
o perl: remove subdir, not touched in 9 years
|
|
||||||
o CURLOPT_COOKIELIST.3: Add example
|
|
||||||
o CURLOPT_COOKIE.3: Explain that the cookies won't be modified [22]
|
|
||||||
o CURLOPT_COOKIELIST.3: Explain Set-Cookie without a domain [23]
|
|
||||||
o FAQ: How do I port libcurl to my OS?
|
|
||||||
o openssl: Use TLS_client_method for OpenSSL 1.1.0+
|
|
||||||
o HTTP-NTLM: fail auth on connection close instead of looping [24]
|
|
||||||
o curl_setup: Add macros for FOPEN_READTEXT, FOPEN_WRITETEXT [25]
|
|
||||||
o curl_getdate.3: update RFC reference
|
|
||||||
o curl_multi_info_read.3: added example
|
|
||||||
o curl_multi_perform.3: added example
|
|
||||||
o curl_multi_timeout.3: added example
|
|
||||||
o cookie: Stop exporting any-domain cookies [26]
|
|
||||||
o openssl: remove dummy callback use from SSL_CTX_set_verify()
|
|
||||||
o openssl: remove SSL_get_session()-using code
|
|
||||||
o openssl: removed USERDATA_IN_PWD_CALLBACK kludge
|
|
||||||
o openssl: removed error string #ifdef
|
|
||||||
o openssl: Fix verification of server-sent legacy intermediates [27]
|
|
||||||
o docs: man page indentation and syntax fixes
|
|
||||||
o docs: Spelling fixes
|
|
||||||
o fopen.c: fix a few compiler warnings
|
|
||||||
o CURLOPT_OPENSOCKETFUNCTION: return error at once [28]
|
|
||||||
|
|
||||||
This release includes the following known bugs:
|
This release includes the following known bugs:
|
||||||
|
|
||||||
@@ -86,45 +22,10 @@ This release includes the following known bugs:
|
|||||||
This release would not have looked like this without help, code, reports and
|
This release would not have looked like this without help, code, reports and
|
||||||
advice from friends like these:
|
advice from friends like these:
|
||||||
|
|
||||||
Alessandro Ghedini, Alexander Dyagilev, Anders Bakken, Anthony Avina,
|
|
||||||
Ashish Shukla, Bert Huijben, Brian Chrisman, Brian Prodoehl, Chris Araman,
|
|
||||||
Dagobert Michelsen, Dan Fandrich, Daniel Melani, Daniel Stenberg,
|
|
||||||
Dmitry Eremin-Solenikov, Egon Eckert, Fred Stluka, Gisle Vanem, Grant Pannell,
|
|
||||||
Isaac Boukris, Jens Rantil, Kamil Dudka, Linus Nielsen, Liviu Chircu,
|
|
||||||
Marc Hoersken, Michael Osipov, Oren Souroujon, Orgad Shaneh, Patrick Monnerat,
|
|
||||||
Patrick Rapin, Paul Howarth, Rafayel Mkrtchyan, Ray Satiro, Sean Boudreau,
|
|
||||||
Tatsuhiro Tsujikawa, Viktor Szakáts, Ville Skyttä, Yehezkel Horowitz,
|
|
||||||
(37 contributors)
|
|
||||||
|
|
||||||
Thanks! (and sorry if I forgot to mention someone)
|
Thanks! (and sorry if I forgot to mention someone)
|
||||||
|
|
||||||
References to bug reports and discussions on issues:
|
References to bug reports and discussions on issues:
|
||||||
|
|
||||||
[1] = http://curl.haxx.se/mail/lib-2015-04/0095.html
|
[1] =
|
||||||
[2] = https://github.com/bagder/curl/pull/206
|
|
||||||
[3] = https://github.com/bagder/curl/commit/5b668606527613179d0349f21b4ab0df2971e3d2#commitcomment-10473445
|
|
||||||
[4] = https://github.com/bagder/curl/pull/141
|
|
||||||
[5] = https://github.com/bagder/curl/issues/198
|
|
||||||
[6] = http://curl.haxx.se/mail/lib-2015-04/0199.html
|
|
||||||
[7] = https://github.com/bagder/curl/issues/244
|
|
||||||
[8] = https://github.com/bagder/curl/issues/219
|
|
||||||
[9] = https://github.com/bagder/curl/pull/258
|
|
||||||
[10] = https://github.com/bagder/curl/issues/254
|
|
||||||
[11] = http://curl.haxx.se/libcurl/c/CURLOPT_PROXY_SERVICE_NAME.html
|
|
||||||
[12] = http://curl.haxx.se/libcurl/c/CURLOPT_SERVICE_NAME.html
|
|
||||||
[13] = http://curl.haxx.se/docs/manpage.html#--proxy-service-name
|
|
||||||
[14] = http://curl.haxx.se/docs/manpage.html#--service-name
|
|
||||||
[15] = http://curl.haxx.se/libcurl/c/CURLOPT_PIPEWAIT.html
|
|
||||||
[16] = http://curl.haxx.se/libcurl/c/CURLMOPT_PIPELINING.html
|
|
||||||
[17] = https://github.com/bagder/curl/issues/275
|
|
||||||
[18] = https://github.com/bagder/curl/issues/281
|
|
||||||
[19] = https://github.com/bagder/curl/issues/282
|
|
||||||
[20] = https://github.com/bagder/curl/issues/267
|
|
||||||
[21] = http://curl.haxx.se/mail/lib-2015-05/0056.html
|
|
||||||
[22] = http://curl.haxx.se/mail/lib-2015-05/0115.html
|
|
||||||
[23] = http://curl.haxx.se/mail/lib-2015-05/0137.html
|
|
||||||
[24] = https://github.com/bagder/curl/issues/256
|
|
||||||
[25] = https://github.com/bagder/curl/pull/258#issuecomment-107093055
|
|
||||||
[26] = https://github.com/bagder/curl/issues/292
|
|
||||||
[27] = https://rt.openssl.org/Ticket/Display.html?id=3621&user=guest&pass=guest
|
|
||||||
[28] = http://curl.haxx.se/mail/lib-2015-06/0047.html
|
|
||||||
|
@@ -78,7 +78,7 @@ Ferite
|
|||||||
|
|
||||||
Gambas
|
Gambas
|
||||||
|
|
||||||
http://gambas.sourceforge.net
|
http://gambas.sourceforge.net/
|
||||||
|
|
||||||
glib/GTK+
|
glib/GTK+
|
||||||
|
|
||||||
@@ -130,7 +130,7 @@ Mono
|
|||||||
.NET
|
.NET
|
||||||
|
|
||||||
libcurl-net by Jeffrey Phillips
|
libcurl-net by Jeffrey Phillips
|
||||||
http://sourceforge.net/projects/libcurl-net/
|
https://sourceforge.net/projects/libcurl-net/
|
||||||
|
|
||||||
node.js
|
node.js
|
||||||
|
|
||||||
@@ -145,7 +145,7 @@ Object-Pascal
|
|||||||
O'Caml
|
O'Caml
|
||||||
|
|
||||||
Written by Lars Nilsson
|
Written by Lars Nilsson
|
||||||
http://sourceforge.net/projects/ocurl/
|
https://sourceforge.net/projects/ocurl/
|
||||||
|
|
||||||
Pascal
|
Pascal
|
||||||
|
|
||||||
@@ -160,7 +160,7 @@ Perl
|
|||||||
PHP
|
PHP
|
||||||
|
|
||||||
Written by Sterling Hughes
|
Written by Sterling Hughes
|
||||||
http://php.net/curl
|
https://php.net/curl
|
||||||
|
|
||||||
PostgreSQL
|
PostgreSQL
|
||||||
|
|
||||||
@@ -174,8 +174,7 @@ Python
|
|||||||
|
|
||||||
R
|
R
|
||||||
|
|
||||||
RCurl by Duncan Temple Lang
|
http://cran.r-project.org/package=curl
|
||||||
http://www.omegahat.org/RCurl/
|
|
||||||
|
|
||||||
Rexx
|
Rexx
|
||||||
|
|
||||||
@@ -234,7 +233,7 @@ Tcl
|
|||||||
Visual Basic
|
Visual Basic
|
||||||
|
|
||||||
libcurl-vb by Jeffrey Phillips
|
libcurl-vb by Jeffrey Phillips
|
||||||
http://sourceforge.net/projects/libcurl-vb/
|
https://sourceforge.net/projects/libcurl-vb/
|
||||||
|
|
||||||
Visual Foxpro
|
Visual Foxpro
|
||||||
|
|
||||||
@@ -254,3 +253,8 @@ XBLite
|
|||||||
|
|
||||||
Written by David Szafranski
|
Written by David Szafranski
|
||||||
http://perso.wanadoo.fr/xblite/libraries.html
|
http://perso.wanadoo.fr/xblite/libraries.html
|
||||||
|
|
||||||
|
Xojo
|
||||||
|
|
||||||
|
Written by Andrew Lambert
|
||||||
|
https://github.com/charonn0/RB-libcURL
|
||||||
|
@@ -203,7 +203,7 @@
|
|||||||
|
|
||||||
You need to first checkout the repository:
|
You need to first checkout the repository:
|
||||||
|
|
||||||
git clone git://github.com/bagder/curl.git
|
git clone https://github.com/bagder/curl.git
|
||||||
|
|
||||||
You then proceed and edit all the files you like and you commit them to your
|
You then proceed and edit all the files you like and you commit them to your
|
||||||
local repository:
|
local repository:
|
||||||
@@ -245,8 +245,8 @@
|
|||||||
|
|
||||||
For unix-like operating systems:
|
For unix-like operating systems:
|
||||||
|
|
||||||
http://www.gnu.org/software/patch/patch.html
|
https://savannah.gnu.org/projects/patch/
|
||||||
http://www.gnu.org/directory/diffutils.html
|
https://www.gnu.org/software/diffutils/
|
||||||
|
|
||||||
For Windows:
|
For Windows:
|
||||||
|
|
||||||
|
@@ -112,7 +112,7 @@ The Better License, Original BSD, GPL or LGPL?
|
|||||||
In Debian land, there seems to be a common opinion that LGPL is "maximally
|
In Debian land, there seems to be a common opinion that LGPL is "maximally
|
||||||
compatible" with apps while Original BSD is not. Like this:
|
compatible" with apps while Original BSD is not. Like this:
|
||||||
|
|
||||||
http://lists.debian.org/debian-devel/2005/09/msg01417.html
|
https://lists.debian.org/debian-devel/2005/09/msg01417.html
|
||||||
|
|
||||||
More SSL Libraries
|
More SSL Libraries
|
||||||
|
|
||||||
@@ -163,13 +163,13 @@ Distro Angle of this Problem
|
|||||||
Footnotes
|
Footnotes
|
||||||
|
|
||||||
[1] = http://www.xfree86.org/3.3.6/COPYRIGHT2.html#6
|
[1] = http://www.xfree86.org/3.3.6/COPYRIGHT2.html#6
|
||||||
[2] = http://www.fsf.org/licensing/essays/bsd.html
|
[2] = https://www.gnu.org/philosophy/bsd.html
|
||||||
[3] = http://www.fsf.org/licensing/licenses/gpl.html
|
[3] = https://www.gnu.org/licenses/gpl.html
|
||||||
[4] = http://curl.haxx.se/docs/copyright.html
|
[4] = http://curl.haxx.se/docs/copyright.html
|
||||||
[5] = http://www.openssl.org/source/license.html
|
[5] = https://www.openssl.org/source/license.html
|
||||||
[6] = http://www.fsf.org/licensing/licenses/gpl.html end of section 3
|
[6] = https://www.gnu.org/licenses/gpl.html end of section 3
|
||||||
[7] = http://www.fsf.org/licensing/licenses/lgpl.html
|
[7] = https://www.gnu.org/licenses/lgpl.html
|
||||||
[8] = http://en.wikipedia.org/wiki/OpenSSL_exception
|
[8] = https://en.wikipedia.org/wiki/OpenSSL_exception
|
||||||
|
|
||||||
Feedback/Updates provided by
|
Feedback/Updates provided by
|
||||||
|
|
||||||
|
12
docs/FAQ
12
docs/FAQ
@@ -352,7 +352,7 @@ FAQ
|
|||||||
cryptography. When doing so, the Export Control Classification Number (ECCN)
|
cryptography. When doing so, the Export Control Classification Number (ECCN)
|
||||||
is used to identify the level of export control etc.
|
is used to identify the level of export control etc.
|
||||||
|
|
||||||
ASF gives a good explanation at http://www.apache.org/dev/crypto.html
|
ASF gives a good explanation at https://www.apache.org/dev/crypto.html
|
||||||
|
|
||||||
We believe curl's number might be ECCN 5D002, another possibility is
|
We believe curl's number might be ECCN 5D002, another possibility is
|
||||||
5D992. It seems necessary to write them, asking to confirm.
|
5D992. It seems necessary to write them, asking to confirm.
|
||||||
@@ -1042,7 +1042,7 @@ FAQ
|
|||||||
timeout is set.
|
timeout is set.
|
||||||
|
|
||||||
See option TcpMaxConnectRetransmissions on this page:
|
See option TcpMaxConnectRetransmissions on this page:
|
||||||
http://support.microsoft.com/?scid=kb%3Ben-us%3B175523&x=6&y=7
|
https://support.microsoft.com/en-us/kb/175523/en-us
|
||||||
|
|
||||||
Also, even on non-Windows systems there may run a firewall or anti-virus
|
Also, even on non-Windows systems there may run a firewall or anti-virus
|
||||||
software or similar that accepts the connection but does not actually do
|
software or similar that accepts the connection but does not actually do
|
||||||
@@ -1059,7 +1059,7 @@ FAQ
|
|||||||
You'll find that even if D:\blah.txt does exist, cURL returns a 'file
|
You'll find that even if D:\blah.txt does exist, cURL returns a 'file
|
||||||
not found' error.
|
not found' error.
|
||||||
|
|
||||||
According to RFC 1738 (http://www.faqs.org/rfcs/rfc1738.html),
|
According to RFC 1738 (https://www.ietf.org/rfc/rfc1738.txt),
|
||||||
file:// URLs must contain a host component, but it is ignored by
|
file:// URLs must contain a host component, but it is ignored by
|
||||||
most implementations. In the above example, 'D:' is treated as the
|
most implementations. In the above example, 'D:' is treated as the
|
||||||
host component, and is taken away. Thus, cURL tries to open '/blah.txt'.
|
host component, and is taken away. Thus, cURL tries to open '/blah.txt'.
|
||||||
@@ -1163,13 +1163,13 @@ FAQ
|
|||||||
If you use a OpenSSL-powered libcurl in a multi-threaded environment, you
|
If you use a OpenSSL-powered libcurl in a multi-threaded environment, you
|
||||||
need to provide one or two locking functions:
|
need to provide one or two locking functions:
|
||||||
|
|
||||||
http://www.openssl.org/docs/crypto/threads.html
|
https://www.openssl.org/docs/crypto/threads.html
|
||||||
|
|
||||||
If you use a GnuTLS-powered libcurl in a multi-threaded environment, you
|
If you use a GnuTLS-powered libcurl in a multi-threaded environment, you
|
||||||
need to provide locking function(s) for libgcrypt (which is used by GnuTLS
|
need to provide locking function(s) for libgcrypt (which is used by GnuTLS
|
||||||
for the crypto functions).
|
for the crypto functions).
|
||||||
|
|
||||||
http://www.gnu.org/software/gnutls/manual/html_node/Multi_002dthreaded-applications.html
|
https://web.archive.org/web/20111103083330/http://www.gnu.org/software/gnutls/manual/html_node/Multi_002dthreaded-applications.html
|
||||||
|
|
||||||
No special locking is needed with a NSS-powered libcurl. NSS is thread-safe.
|
No special locking is needed with a NSS-powered libcurl. NSS is thread-safe.
|
||||||
|
|
||||||
@@ -1345,7 +1345,7 @@ FAQ
|
|||||||
Also note that on many networks NATs or other IP-munging techniques are used
|
Also note that on many networks NATs or other IP-munging techniques are used
|
||||||
that makes you see and use a different IP address locally than what the
|
that makes you see and use a different IP address locally than what the
|
||||||
remote server will see you coming from. You may also consider using
|
remote server will see you coming from. You may also consider using
|
||||||
http://www.torproject.org .
|
https://www.torproject.org/ .
|
||||||
|
|
||||||
5.13 How do I stop an ongoing transfer?
|
5.13 How do I stop an ongoing transfer?
|
||||||
|
|
||||||
|
@@ -36,7 +36,7 @@ HTTP Cookies
|
|||||||
For a very long time, the only spec explaining how to use cookies was the
|
For a very long time, the only spec explaining how to use cookies was the
|
||||||
original Netscape spec from 1994: http://curl.haxx.se/rfc/cookie_spec.html
|
original Netscape spec from 1994: http://curl.haxx.se/rfc/cookie_spec.html
|
||||||
|
|
||||||
In 2011, RFC6265 (http://www.ietf.org/rfc/rfc6265.txt) was finally published
|
In 2011, RFC6265 (https://www.ietf.org/rfc/rfc6265.txt) was finally published
|
||||||
and details how cookies work within HTTP.
|
and details how cookies work within HTTP.
|
||||||
|
|
||||||
1.2 Cookies saved to disk
|
1.2 Cookies saved to disk
|
||||||
|
@@ -1,7 +1,7 @@
|
|||||||
HTTP/2 with curl
|
HTTP/2 with curl
|
||||||
================
|
================
|
||||||
|
|
||||||
[HTTP/2 Spec](http://www.rfc-editor.org/rfc/rfc7540.txt)
|
[HTTP/2 Spec](https://www.rfc-editor.org/rfc/rfc7540.txt)
|
||||||
[http2 explained](http://daniel.haxx.se/http2/)
|
[http2 explained](http://daniel.haxx.se/http2/)
|
||||||
|
|
||||||
Build prerequisites
|
Build prerequisites
|
||||||
@@ -95,7 +95,7 @@ same origin server that you get the response from. A browser or long-living
|
|||||||
client can use that hint to create a new connection asynchronously. For
|
client can use that hint to create a new connection asynchronously. For
|
||||||
libcurl, we may introduce a way to bring such clues to the applicaton and/or
|
libcurl, we may introduce a way to bring such clues to the applicaton and/or
|
||||||
let a subsequent request use the alternate route
|
let a subsequent request use the alternate route
|
||||||
automatically. [Spec](http://tools.ietf.org/html/draft-ietf-httpbis-alt-svc-05)
|
automatically. [Spec](https://tools.ietf.org/html/draft-ietf-httpbis-alt-svc-05)
|
||||||
|
|
||||||
TODO
|
TODO
|
||||||
----
|
----
|
||||||
|
53
docs/INSTALL
53
docs/INSTALL
@@ -173,13 +173,13 @@ Win32
|
|||||||
advice given above.
|
advice given above.
|
||||||
|
|
||||||
KB94248 - How To Use the C Run-Time
|
KB94248 - How To Use the C Run-Time
|
||||||
http://support.microsoft.com/kb/94248/en-us
|
https://support.microsoft.com/kb/94248/en-us
|
||||||
|
|
||||||
KB140584 - How to link with the correct C Run-Time (CRT) library
|
KB140584 - How to link with the correct C Run-Time (CRT) library
|
||||||
http://support.microsoft.com/kb/140584/en-us
|
https://support.microsoft.com/kb/140584/en-us
|
||||||
|
|
||||||
KB190799 - Potential Errors Passing CRT Objects Across DLL Boundaries
|
KB190799 - Potential Errors Passing CRT Objects Across DLL Boundaries
|
||||||
http://msdn.microsoft.com/en-us/library/ms235460
|
https://msdn.microsoft.com/en-us/library/ms235460
|
||||||
|
|
||||||
If your app is misbehaving in some strange way, or it is suffering
|
If your app is misbehaving in some strange way, or it is suffering
|
||||||
from memory corruption, before asking for further help, please try
|
from memory corruption, before asking for further help, please try
|
||||||
@@ -209,8 +209,8 @@ Win32
|
|||||||
environment variables, for example:
|
environment variables, for example:
|
||||||
|
|
||||||
set ZLIB_PATH=c:\zlib-1.2.8
|
set ZLIB_PATH=c:\zlib-1.2.8
|
||||||
set OPENSSL_PATH=c:\openssl-0.9.8zc
|
set OPENSSL_PATH=c:\openssl-1.0.2c
|
||||||
set LIBSSH2_PATH=c:\libssh2-1.4.3
|
set LIBSSH2_PATH=c:\libssh2-1.6.0
|
||||||
|
|
||||||
ATTENTION: if you want to build with libssh2 support you have to use latest
|
ATTENTION: if you want to build with libssh2 support you have to use latest
|
||||||
version 0.17 - previous versions will NOT work with 7.17.0 and later!
|
version 0.17 - previous versions will NOT work with 7.17.0 and later!
|
||||||
@@ -232,7 +232,7 @@ Win32
|
|||||||
- optional MingW32-built OpenLDAP SDK available from:
|
- optional MingW32-built OpenLDAP SDK available from:
|
||||||
http://www.gknw.net/mirror/openldap/
|
http://www.gknw.net/mirror/openldap/
|
||||||
- optional recent Novell CLDAP SDK available from:
|
- optional recent Novell CLDAP SDK available from:
|
||||||
http://developer.novell.com/ndk/cldap.htm
|
https://www.novell.com/developer/ndk/ldap_libraries_for_c.html
|
||||||
|
|
||||||
Cygwin
|
Cygwin
|
||||||
------
|
------
|
||||||
@@ -254,7 +254,7 @@ Win32
|
|||||||
If you use MSVC 6 it is required that you use the February 2003 edition of
|
If you use MSVC 6 it is required that you use the February 2003 edition of
|
||||||
the 'Platform SDK' which can be downloaded from:
|
the 'Platform SDK' which can be downloaded from:
|
||||||
|
|
||||||
http://www.microsoft.com/en-us/download/details.aspx?id=12261
|
https://www.microsoft.com/en-us/download/details.aspx?id=12261
|
||||||
|
|
||||||
Building any software with MSVC 6 without having PSDK installed is just
|
Building any software with MSVC 6 without having PSDK installed is just
|
||||||
asking for trouble down the road once you have released it, you might notice
|
asking for trouble down the road once you have released it, you might notice
|
||||||
@@ -263,7 +263,7 @@ Win32
|
|||||||
software built in such way will at some point regret having done so.
|
software built in such way will at some point regret having done so.
|
||||||
|
|
||||||
If the compiler has been updated with the installation of a service pack as
|
If the compiler has been updated with the installation of a service pack as
|
||||||
those mentioned in http://support.microsoft.com/kb/194022 the compiler can be
|
those mentioned in https://support.microsoft.com/kb/194022 the compiler can be
|
||||||
safely used to read source code, translate and make it object code.
|
safely used to read source code, translate and make it object code.
|
||||||
|
|
||||||
But, even with the service packs mentioned above installed, the resulting
|
But, even with the service packs mentioned above installed, the resulting
|
||||||
@@ -299,7 +299,7 @@ Win32
|
|||||||
Then run 'nmake vc' in curl's root directory.
|
Then run 'nmake vc' in curl's root directory.
|
||||||
|
|
||||||
If you want to compile with zlib support, you will need to build
|
If you want to compile with zlib support, you will need to build
|
||||||
zlib (http://www.gzip.org/zlib/) as well. Please read the zlib
|
zlib (http://www.zlib.net/) as well. Please read the zlib
|
||||||
documentation on how to compile zlib. Define the ZLIB_PATH environment
|
documentation on how to compile zlib. Define the ZLIB_PATH environment
|
||||||
variable to the location of zlib.h and zlib.lib, for example:
|
variable to the location of zlib.h and zlib.lib, for example:
|
||||||
|
|
||||||
@@ -471,6 +471,15 @@ Win32
|
|||||||
add '-DCURL_STATICLIB' to your CFLAGS. Otherwise the linker will look for
|
add '-DCURL_STATICLIB' to your CFLAGS. Otherwise the linker will look for
|
||||||
dynamic import symbols.
|
dynamic import symbols.
|
||||||
|
|
||||||
|
Legacy Windows and SSL
|
||||||
|
----------------------
|
||||||
|
WinSSL (Windows SSPI, more specifically Schannel), is the native SSL library
|
||||||
|
that comes with the Windows OS. WinSSL in Windows <= XP is not able to
|
||||||
|
connect to servers that no longer support the legacy handshakes and
|
||||||
|
algorithms used by those versions. If you will be using curl in one of those
|
||||||
|
earlier versions of Windows you should choose another SSL backend like
|
||||||
|
OpenSSL.
|
||||||
|
|
||||||
Apple iOS and Mac OS X
|
Apple iOS and Mac OS X
|
||||||
======================
|
======================
|
||||||
|
|
||||||
@@ -665,12 +674,10 @@ NetWare
|
|||||||
- gnu make and awk running on the platform you compile on;
|
- gnu make and awk running on the platform you compile on;
|
||||||
native Win32 versions can be downloaded from:
|
native Win32 versions can be downloaded from:
|
||||||
http://www.gknw.net/development/prgtools/
|
http://www.gknw.net/development/prgtools/
|
||||||
- recent Novell LibC SDK available from:
|
- recent Novell LibC or Novell CLib SDK available from:
|
||||||
http://developer.novell.com/ndk/libc.htm
|
https://www.novell.com/developer/ndk/
|
||||||
- or recent Novell CLib SDK available from:
|
|
||||||
http://developer.novell.com/ndk/clib.htm
|
|
||||||
- optional recent Novell CLDAP SDK available from:
|
- optional recent Novell CLDAP SDK available from:
|
||||||
http://developer.novell.com/ndk/cldap.htm
|
https://www.novell.com/developer/ndk/ldap_libraries_for_c.html
|
||||||
- optional zlib sources (static or dynamic linking with zlib.imp);
|
- optional zlib sources (static or dynamic linking with zlib.imp);
|
||||||
sources with NetWare Makefile can be obtained from:
|
sources with NetWare Makefile can be obtained from:
|
||||||
http://www.gknw.net/mirror/zlib/
|
http://www.gknw.net/mirror/zlib/
|
||||||
@@ -825,7 +832,7 @@ VxWorks
|
|||||||
|
|
||||||
To build libcurl for VxWorks you need:
|
To build libcurl for VxWorks you need:
|
||||||
|
|
||||||
- CYGWIN (free, http://cygwin.com/)
|
- CYGWIN (free, https://cygwin.com/)
|
||||||
- Wind River Workbench (commercial)
|
- Wind River Workbench (commercial)
|
||||||
|
|
||||||
If you have CYGWIN and Workbench installed on you machine
|
If you have CYGWIN and Workbench installed on you machine
|
||||||
@@ -1086,18 +1093,18 @@ Useful URLs
|
|||||||
|
|
||||||
axTLS http://axtls.sourceforge.net/
|
axTLS http://axtls.sourceforge.net/
|
||||||
c-ares http://c-ares.haxx.se/
|
c-ares http://c-ares.haxx.se/
|
||||||
GNU GSS http://www.gnu.org/software/gss/
|
GNU GSS https://www.gnu.org/software/gss/
|
||||||
GnuTLS http://www.gnu.org/software/gnutls/
|
GnuTLS https://www.gnu.org/software/gnutls/
|
||||||
Heimdal http://www.pdc.kth.se/heimdal/
|
Heimdal http://www.h5l.org/
|
||||||
libidn http://www.gnu.org/software/libidn/
|
libidn https://www.gnu.org/software/libidn/
|
||||||
libmetalink https://launchpad.net/libmetalink/
|
libmetalink https://launchpad.net/libmetalink/
|
||||||
libssh2 http://www.libssh2.org/
|
libssh2 http://www.libssh2.org/
|
||||||
MIT Kerberos http://web.mit.edu/kerberos/www/dist/
|
MIT Kerberos http://web.mit.edu/kerberos/www/dist/
|
||||||
NSS http://www.mozilla.org/projects/security/pki/nss/
|
NSS https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS
|
||||||
OpenLDAP http://www.openldap.org/
|
OpenLDAP http://www.openldap.org/
|
||||||
OpenSSL http://www.openssl.org/
|
OpenSSL https://www.openssl.org/
|
||||||
PolarSSL http://polarssl.org/
|
PolarSSL https://tls.mbed.org/
|
||||||
yassl http://www.yassl.com/
|
wolfSSL https://www.wolfssl.com/wolfSSL/
|
||||||
Zlib http://www.zlib.net/
|
Zlib http://www.zlib.net/
|
||||||
|
|
||||||
MingW http://www.mingw.org/
|
MingW http://www.mingw.org/
|
||||||
|
@@ -95,7 +95,7 @@ install instructions may produce erratic behaviour in DevCpp. For further info
|
|||||||
check the following sites
|
check the following sites
|
||||||
|
|
||||||
http://aditsu.freeunixhost.com/dev-cpp-faq.html
|
http://aditsu.freeunixhost.com/dev-cpp-faq.html
|
||||||
http://sourceforge.net/forum/message.php?msg_id=3252213
|
https://sourceforge.net/p/dev-cpp/discussion/48211/thread/2a85ea46
|
||||||
|
|
||||||
As I have mentioned before I will confine this to the SSL Library compilations
|
As I have mentioned before I will confine this to the SSL Library compilations
|
||||||
but the process is very similar for compilation of the executable - curl.exe;
|
but the process is very similar for compilation of the executable - curl.exe;
|
||||||
|
907
docs/INTERNALS
907
docs/INTERNALS
File diff suppressed because it is too large
Load Diff
@@ -97,7 +97,7 @@ may have been fixed since this was written!
|
|||||||
something beyond ascii but currently libcurl will only pass in the verbatim
|
something beyond ascii but currently libcurl will only pass in the verbatim
|
||||||
string the app provides. There are several browsers that already do this
|
string the app provides. There are several browsers that already do this
|
||||||
encoding. The key seems to be the updated draft to RFC2231:
|
encoding. The key seems to be the updated draft to RFC2231:
|
||||||
http://tools.ietf.org/html/draft-reschke-rfc2231-in-http-02
|
https://tools.ietf.org/html/draft-reschke-rfc2231-in-http-02
|
||||||
|
|
||||||
66. When using telnet, the time limitation options don't work.
|
66. When using telnet, the time limitation options don't work.
|
||||||
http://curl.haxx.se/bug/view.cgi?id=846
|
http://curl.haxx.se/bug/view.cgi?id=846
|
||||||
|
@@ -1,248 +0,0 @@
|
|||||||
_ _ ____ _
|
|
||||||
___| | | | _ \| |
|
|
||||||
/ __| | | | |_) | |
|
|
||||||
| (__| |_| | _ <| |___
|
|
||||||
\___|\___/|_| \_\_____|
|
|
||||||
|
|
||||||
Structs in libcurl
|
|
||||||
|
|
||||||
This document should cover 7.32.0 pretty accurately, but will make sense even
|
|
||||||
for older and later versions as things don't change drastically that often.
|
|
||||||
|
|
||||||
1. The main structs in libcurl
|
|
||||||
1.1 SessionHandle
|
|
||||||
1.2 connectdata
|
|
||||||
1.3 Curl_multi
|
|
||||||
1.4 Curl_handler
|
|
||||||
1.5 conncache
|
|
||||||
1.6 Curl_share
|
|
||||||
1.7 CookieInfo
|
|
||||||
|
|
||||||
==============================================================================
|
|
||||||
|
|
||||||
1. The main structs in libcurl
|
|
||||||
|
|
||||||
1.1 SessionHandle
|
|
||||||
|
|
||||||
The SessionHandle handle struct is the one returned to the outside in the
|
|
||||||
external API as a "CURL *". This is usually known as an easy handle in API
|
|
||||||
documentations and examples.
|
|
||||||
|
|
||||||
Information and state that is related to the actual connection is in the
|
|
||||||
'connectdata' struct. When a transfer is about to be made, libcurl will
|
|
||||||
either create a new connection or re-use an existing one. The particular
|
|
||||||
connectdata that is used by this handle is pointed out by
|
|
||||||
SessionHandle->easy_conn.
|
|
||||||
|
|
||||||
Data and information that regard this particular single transfer is put in
|
|
||||||
the SingleRequest sub-struct.
|
|
||||||
|
|
||||||
When the SessionHandle struct is added to a multi handle, as it must be in
|
|
||||||
order to do any transfer, the ->multi member will point to the Curl_multi
|
|
||||||
struct it belongs to. The ->prev and ->next members will then be used by the
|
|
||||||
multi code to keep a linked list of SessionHandle structs that are added to
|
|
||||||
that same multi handle. libcurl always uses multi so ->multi *will* point to
|
|
||||||
a Curl_multi when a transfer is in progress.
|
|
||||||
|
|
||||||
->mstate is the multi state of this particular SessionHandle. When
|
|
||||||
multi_runsingle() is called, it will act on this handle according to which
|
|
||||||
state it is in. The mstate is also what tells which sockets to return for a
|
|
||||||
specific SessionHandle when curl_multi_fdset() is called etc.
|
|
||||||
|
|
||||||
The libcurl source code generally use the name 'data' for the variable that
|
|
||||||
points to the SessionHandle.
|
|
||||||
|
|
||||||
When doing multiplexed HTTP/2 transfers, each SessionHandle is associated
|
|
||||||
with an individual stream, sharing the same connectdata struct. Multiplexing
|
|
||||||
makes it even more important to keep things associated with the right thing!
|
|
||||||
|
|
||||||
1.2 connectdata
|
|
||||||
|
|
||||||
A general idea in libcurl is to keep connections around in a connection
|
|
||||||
"cache" after they have been used in case they will be used again and then
|
|
||||||
re-use an existing one instead of creating a new as it creates a significant
|
|
||||||
performance boost.
|
|
||||||
|
|
||||||
Each 'connectdata' identifies a single physical connection to a server. If
|
|
||||||
the connection can't be kept alive, the connection will be closed after use
|
|
||||||
and then this struct can be removed from the cache and freed.
|
|
||||||
|
|
||||||
Thus, the same SessionHandle can be used multiple times and each time select
|
|
||||||
another connectdata struct to use for the connection. Keep this in mind, as
|
|
||||||
it is then important to consider if options or choices are based on the
|
|
||||||
connection or the SessionHandle.
|
|
||||||
|
|
||||||
Functions in libcurl will assume that connectdata->data points to the
|
|
||||||
SessionHandle that uses this connection (for the moment).
|
|
||||||
|
|
||||||
As a special complexity, some protocols supported by libcurl require a
|
|
||||||
special disconnect procedure that is more than just shutting down the
|
|
||||||
socket. It can involve sending one or more commands to the server before
|
|
||||||
doing so. Since connections are kept in the connection cache after use, the
|
|
||||||
original SessionHandle may no longer be around when the time comes to shut
|
|
||||||
down a particular connection. For this purpose, libcurl holds a special
|
|
||||||
dummy 'closure_handle' SessionHandle in the Curl_multi struct to
|
|
||||||
|
|
||||||
FTP uses two TCP connections for a typical transfer but it keeps both in
|
|
||||||
this single struct and thus can be considered a single connection for most
|
|
||||||
internal concerns.
|
|
||||||
|
|
||||||
The libcurl source code generally use the name 'conn' for the variable that
|
|
||||||
points to the connectdata.
|
|
||||||
|
|
||||||
|
|
||||||
1.3 Curl_multi
|
|
||||||
|
|
||||||
Internally, the easy interface is implemented as a wrapper around multi
|
|
||||||
interface functions. This makes everything multi interface.
|
|
||||||
|
|
||||||
Curl_multi is the multi handle struct exposed as "CURLM *" in external APIs.
|
|
||||||
|
|
||||||
This struct holds a list of SessionHandle structs that have been added to
|
|
||||||
this handle with curl_multi_add_handle(). The start of the list is ->easyp
|
|
||||||
and ->num_easy is a counter of added SessionHandles.
|
|
||||||
|
|
||||||
->msglist is a linked list of messages to send back when
|
|
||||||
curl_multi_info_read() is called. Basically a node is added to that list
|
|
||||||
when an individual SessionHandle's transfer has completed.
|
|
||||||
|
|
||||||
->hostcache points to the name cache. It is a hash table for looking up name
|
|
||||||
to IP. The nodes have a limited life time in there and this cache is meant
|
|
||||||
to reduce the time for when the same name is wanted within a short period of
|
|
||||||
time.
|
|
||||||
|
|
||||||
->timetree points to a tree of SessionHandles, sorted by the remaining time
|
|
||||||
until it should be checked - normally some sort of timeout. Each
|
|
||||||
SessionHandle has one node in the tree.
|
|
||||||
|
|
||||||
->sockhash is a hash table to allow fast lookups of socket descriptor to
|
|
||||||
which SessionHandle that uses that descriptor. This is necessary for the
|
|
||||||
multi_socket API.
|
|
||||||
|
|
||||||
->conn_cache points to the connection cache. It keeps track of all
|
|
||||||
connections that are kept after use. The cache has a maximum size.
|
|
||||||
|
|
||||||
->closure_handle is described in the 'connectdata' section.
|
|
||||||
|
|
||||||
The libcurl source code generally use the name 'multi' for the variable that
|
|
||||||
points to the Curl_multi struct.
|
|
||||||
|
|
||||||
|
|
||||||
1.4 Curl_handler
|
|
||||||
|
|
||||||
Each unique protocol that is supported by libcurl needs to provide at least
|
|
||||||
one Curl_handler struct. It defines what the protocol is called and what
|
|
||||||
functions the main code should call to deal with protocol specific issues.
|
|
||||||
In general, there's a source file named [protocol].c in which there's a
|
|
||||||
"struct Curl_handler Curl_handler_[protocol]" declared. In url.c there's
|
|
||||||
then the main array with all individual Curl_handler structs pointed to from
|
|
||||||
a single array which is scanned through when a URL is given to libcurl to
|
|
||||||
work with.
|
|
||||||
|
|
||||||
->scheme is the URL scheme name, usually spelled out in uppercase. That's
|
|
||||||
"HTTP" or "FTP" etc. SSL versions of the protcol need its own Curl_handler
|
|
||||||
setup so HTTPS separate from HTTP.
|
|
||||||
|
|
||||||
->setup_connection is called to allow the protocol code to allocate protocol
|
|
||||||
specific data that then gets associated with that SessionHandle for the rest
|
|
||||||
of this transfer. It gets freed again at the end of the transfer. It will be
|
|
||||||
called before the 'connectdata' for the transfer has been selected/created.
|
|
||||||
Most protocols will allocate its private 'struct [PROTOCOL]' here and assign
|
|
||||||
SessionHandle->req.protop to point to it.
|
|
||||||
|
|
||||||
->connect_it allows a protocol to do some specific actions after the TCP
|
|
||||||
connect is done, that can still be considered part of the connection phase.
|
|
||||||
|
|
||||||
Some protocols will alter the connectdata->recv[] and connectdata->send[]
|
|
||||||
function pointers in this function.
|
|
||||||
|
|
||||||
->connecting is similarly a function that keeps getting called as long as the
|
|
||||||
protocol considers itself still in the connecting phase.
|
|
||||||
|
|
||||||
->do_it is the function called to issue the transfer request. What we call
|
|
||||||
the DO action internally. If the DO is not enough and things need to be kept
|
|
||||||
getting done for the entire DO sequence to complete, ->doing is then usually
|
|
||||||
also provided. Each protocol that needs to do multiple commands or similar
|
|
||||||
for do/doing need to implement their own state machines (see SCP, SFTP,
|
|
||||||
FTP). Some protocols (only FTP and only due to historical reasons) has a
|
|
||||||
separate piece of the DO state called DO_MORE.
|
|
||||||
|
|
||||||
->doing keeps getting called while issuing the transfer request command(s)
|
|
||||||
|
|
||||||
->done gets called when the transfer is complete and DONE. That's after the
|
|
||||||
main data has been transferred.
|
|
||||||
|
|
||||||
->do_more gets called during the DO_MORE state. The FTP protocol uses this
|
|
||||||
state when setting up the second connection.
|
|
||||||
|
|
||||||
->proto_getsock
|
|
||||||
->doing_getsock
|
|
||||||
->domore_getsock
|
|
||||||
->perform_getsock
|
|
||||||
Functions that return socket information. Which socket(s) to wait for which
|
|
||||||
action(s) during the particular multi state.
|
|
||||||
|
|
||||||
->disconnect is called immediately before the TCP connection is shutdown.
|
|
||||||
|
|
||||||
->readwrite gets called during transfer to allow the protocol to do extra
|
|
||||||
reads/writes
|
|
||||||
|
|
||||||
->defport is the default report TCP or UDP port this protocol uses
|
|
||||||
|
|
||||||
->protocol is one or more bits in the CURLPROTO_* set. The SSL versions have
|
|
||||||
their "base" protocol set and then the SSL variation. Like "HTTP|HTTPS".
|
|
||||||
|
|
||||||
->flags is a bitmask with additional information about the protocol that will
|
|
||||||
make it get treated differently by the generic engine:
|
|
||||||
|
|
||||||
PROTOPT_SSL - will make it connect and negotiate SSL
|
|
||||||
|
|
||||||
PROTOPT_DUAL - this protocol uses two connections
|
|
||||||
|
|
||||||
PROTOPT_CLOSEACTION - this protocol has actions to do before closing the
|
|
||||||
connection. This flag is no longer used by code, yet still set for a bunch
|
|
||||||
protocol handlers.
|
|
||||||
|
|
||||||
PROTOPT_DIRLOCK - "direction lock". The SSH protocols set this bit to
|
|
||||||
limit which "direction" of socket actions that the main engine will
|
|
||||||
concern itself about.
|
|
||||||
|
|
||||||
PROTOPT_NONETWORK - a protocol that doesn't use network (read file:)
|
|
||||||
|
|
||||||
PROTOPT_NEEDSPWD - this protocol needs a password and will use a default
|
|
||||||
one unless one is provided
|
|
||||||
|
|
||||||
PROTOPT_NOURLQUERY - this protocol can't handle a query part on the URL
|
|
||||||
(?foo=bar)
|
|
||||||
|
|
||||||
|
|
||||||
1.5 conncache
|
|
||||||
|
|
||||||
Is a hash table with connections for later re-use. Each SessionHandle has
|
|
||||||
a pointer to its connection cache. Each multi handle sets up a connection
|
|
||||||
cache that all added SessionHandles share by default.
|
|
||||||
|
|
||||||
|
|
||||||
1.6 Curl_share
|
|
||||||
|
|
||||||
The libcurl share API allocates a Curl_share struct, exposed to the external
|
|
||||||
API as "CURLSH *".
|
|
||||||
|
|
||||||
The idea is that the struct can have a set of own versions of caches and
|
|
||||||
pools and then by providing this struct in the CURLOPT_SHARE option, those
|
|
||||||
specific SessionHandles will use the caches/pools that this share handle
|
|
||||||
holds.
|
|
||||||
|
|
||||||
Then individual SessionHandle structs can be made to share specific things
|
|
||||||
that they otherwise wouldn't, such as cookies.
|
|
||||||
|
|
||||||
The Curl_share struct can currently hold cookies, DNS cache and the SSL
|
|
||||||
session cache.
|
|
||||||
|
|
||||||
|
|
||||||
1.7 CookieInfo
|
|
||||||
|
|
||||||
This is the main cookie struct. It holds all known cookies and related
|
|
||||||
information. Each SessionHandle has its own private CookieInfo even when
|
|
||||||
they are added to a multi handle. They can be made to share cookies by using
|
|
||||||
the share API.
|
|
@@ -23,29 +23,29 @@ libcurl http://curl.haxx.se/docs/copyright.html
|
|||||||
Uses an MIT (or Modified BSD)-style license that is as liberal as
|
Uses an MIT (or Modified BSD)-style license that is as liberal as
|
||||||
possible.
|
possible.
|
||||||
|
|
||||||
OpenSSL http://www.openssl.org/source/license.html
|
OpenSSL https://www.openssl.org/source/license.html
|
||||||
|
|
||||||
(May be used for SSL/TLS support) Uses an Original BSD-style license
|
(May be used for SSL/TLS support) Uses an Original BSD-style license
|
||||||
with an announcement clause that makes it "incompatible" with GPL. You
|
with an announcement clause that makes it "incompatible" with GPL. You
|
||||||
are not allowed to ship binaries that link with OpenSSL that includes
|
are not allowed to ship binaries that link with OpenSSL that includes
|
||||||
GPL code (unless that specific GPL code includes an exception for
|
GPL code (unless that specific GPL code includes an exception for
|
||||||
OpenSSL - a habit that is growing more and more common). If OpenSSL's
|
OpenSSL - a habit that is growing more and more common). If OpenSSL's
|
||||||
licensing is a problem for you, consider using GnuTLS or yassl
|
licensing is a problem for you, consider using another TLS library.
|
||||||
instead.
|
|
||||||
|
|
||||||
GnuTLS http://www.gnutls.org/
|
GnuTLS http://www.gnutls.org/
|
||||||
|
|
||||||
(May be used for SSL/TLS support) Uses the LGPL[3] license. If this is
|
(May be used for SSL/TLS support) Uses the LGPL[3] license. If this is
|
||||||
a problem for you, consider using OpenSSL instead. Also note that
|
a problem for you, consider using another TLS library. Also note that
|
||||||
GnuTLS itself depends on and uses other libs (libgcrypt and
|
GnuTLS itself depends on and uses other libs (libgcrypt and
|
||||||
libgpg-error) and they too are LGPL- or GPL-licensed.
|
libgpg-error) and they too are LGPL- or GPL-licensed.
|
||||||
|
|
||||||
yassl http://www.yassl.com/
|
WolfSSL https://www.wolfssl.com/
|
||||||
|
|
||||||
(May be used for SSL/TLS support) Uses the GPL[1] license. If this is
|
(May be used for SSL/TLS support) Uses the GPL[1] license or a
|
||||||
a problem for you, consider using OpenSSL or GnuTLS instead.
|
propietary license. If this is a problem for you, consider using
|
||||||
|
another TLS library.
|
||||||
|
|
||||||
NSS http://www.mozilla.org/projects/security/pki/nss/
|
NSS https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS
|
||||||
|
|
||||||
(May be used for SSL/TLS support) Is covered by the MPL[4] license,
|
(May be used for SSL/TLS support) Is covered by the MPL[4] license,
|
||||||
the GPL[1] license and the LGPL[3] license. You may choose to license
|
the GPL[1] license and the LGPL[3] license. You may choose to license
|
||||||
@@ -57,13 +57,29 @@ axTLS http://axtls.sourceforge.net/
|
|||||||
|
|
||||||
(May be used for SSL/TLS support) Uses a Modified BSD-style license.
|
(May be used for SSL/TLS support) Uses a Modified BSD-style license.
|
||||||
|
|
||||||
|
mbedTLS https://tls.mbed.org/
|
||||||
|
|
||||||
|
(May be used for SSL/TLS support) Uses the GPL[1] license or a
|
||||||
|
propietary license. If this is a problem for you, consider using
|
||||||
|
another TLS library.
|
||||||
|
|
||||||
|
BoringSSL https://boringssl.googlesource.com/
|
||||||
|
|
||||||
|
(May be used for SSL/TLS support) As an OpenSSL fork, it has the same
|
||||||
|
license as that.
|
||||||
|
|
||||||
|
libressl http://www.libressl.org/
|
||||||
|
|
||||||
|
(May be used for SSL/TLS support) As an OpenSSL fork, it has the same
|
||||||
|
license as that.
|
||||||
|
|
||||||
c-ares http://daniel.haxx.se/projects/c-ares/license.html
|
c-ares http://daniel.haxx.se/projects/c-ares/license.html
|
||||||
|
|
||||||
(Used for asynchronous name resolves) Uses an MIT license that is very
|
(Used for asynchronous name resolves) Uses an MIT license that is very
|
||||||
liberal and imposes no restrictions on any other library or part you
|
liberal and imposes no restrictions on any other library or part you
|
||||||
may link with.
|
may link with.
|
||||||
|
|
||||||
zlib http://www.gzip.org/zlib/zlib_license.html
|
zlib http://www.zlib.net/zlib_license.html
|
||||||
|
|
||||||
(Used for compressed Transfer-Encoding support) Uses an MIT-style
|
(Used for compressed Transfer-Encoding support) Uses an MIT-style
|
||||||
license that shouldn't collide with any other library.
|
license that shouldn't collide with any other library.
|
||||||
@@ -73,12 +89,12 @@ MIT Kerberos http://web.mit.edu/kerberos/www/dist/
|
|||||||
(May be used for GSS support) MIT licensed, that shouldn't collide
|
(May be used for GSS support) MIT licensed, that shouldn't collide
|
||||||
with any other parts.
|
with any other parts.
|
||||||
|
|
||||||
Heimdal http://www.pdc.kth.se/heimdal/
|
Heimdal http://www.h5l.org
|
||||||
|
|
||||||
(May be used for GSS support) Heimdal is Original BSD licensed with
|
(May be used for GSS support) Heimdal is Original BSD licensed with
|
||||||
the announcement clause.
|
the announcement clause.
|
||||||
|
|
||||||
GNU GSS http://www.gnu.org/software/gss/
|
GNU GSS https://www.gnu.org/software/gss/
|
||||||
|
|
||||||
(May be used for GSS support) GNU GSS is GPL licensed. Note that you
|
(May be used for GSS support) GNU GSS is GPL licensed. Note that you
|
||||||
may not distribute binary curl packages that uses this if you build
|
may not distribute binary curl packages that uses this if you build
|
||||||
@@ -105,10 +121,10 @@ libssh2 http://www.libssh2.org/
|
|||||||
(Used for scp and sftp support) libssh2 uses a Modified BSD-style
|
(Used for scp and sftp support) libssh2 uses a Modified BSD-style
|
||||||
license.
|
license.
|
||||||
|
|
||||||
[1] = GPL - GNU General Public License: http://www.gnu.org/licenses/gpl.html
|
[1] = GPL - GNU General Public License: https://www.gnu.org/licenses/gpl.html
|
||||||
[2] = http://www.fsf.org/licenses/gpl-faq.html#GPLIncompatibleLibs details on
|
[2] = https://www.gnu.org/licenses/gpl-faq.html#GPLIncompatibleLibs details on
|
||||||
how to write such an exception to the GPL
|
how to write such an exception to the GPL
|
||||||
[3] = LGPL - GNU Lesser General Public License:
|
[3] = LGPL - GNU Lesser General Public License:
|
||||||
http://www.gnu.org/licenses/lgpl.html
|
https://www.gnu.org/licenses/lgpl.html
|
||||||
[4] = MPL - Mozilla Public License:
|
[4] = MPL - Mozilla Public License:
|
||||||
http://www.mozilla.org/MPL/
|
https://www.mozilla.org/MPL/
|
||||||
|
@@ -230,7 +230,7 @@ MAIL ETIQUETTE
|
|||||||
Quote as little as possible. Just enough to provide the context you cannot
|
Quote as little as possible. Just enough to provide the context you cannot
|
||||||
leave out. A lengthy description can be found here:
|
leave out. A lengthy description can be found here:
|
||||||
|
|
||||||
http://www.netmeister.org/news/learn2quote.html
|
https://www.netmeister.org/news/learn2quote.html
|
||||||
|
|
||||||
2.7 Digest
|
2.7 Digest
|
||||||
|
|
||||||
|
@@ -37,7 +37,7 @@ EXTRA_DIST = MANUAL BUGS CONTRIBUTE FAQ FEATURES INTERNALS SSLCERTS \
|
|||||||
README.win32 RESOURCES TODO TheArtOfHttpScripting THANKS VERSIONS \
|
README.win32 RESOURCES TODO TheArtOfHttpScripting THANKS VERSIONS \
|
||||||
KNOWN_BUGS BINDINGS $(man_MANS) $(HTMLPAGES) HISTORY INSTALL \
|
KNOWN_BUGS BINDINGS $(man_MANS) $(HTMLPAGES) HISTORY INSTALL \
|
||||||
$(PDFPAGES) LICENSE-MIXING README.netware DISTRO-DILEMMA INSTALL.devcpp \
|
$(PDFPAGES) LICENSE-MIXING README.netware DISTRO-DILEMMA INSTALL.devcpp \
|
||||||
MAIL-ETIQUETTE HTTP-COOKIES LIBCURL-STRUCTS SECURITY RELEASE-PROCEDURE \
|
MAIL-ETIQUETTE HTTP-COOKIES SECURITY RELEASE-PROCEDURE \
|
||||||
SSL-PROBLEMS HTTP2.md ROADMAP.md
|
SSL-PROBLEMS HTTP2.md ROADMAP.md
|
||||||
|
|
||||||
MAN2HTML= roffit < $< >$@
|
MAN2HTML= roffit < $< >$@
|
||||||
|
@@ -1,9 +1,3 @@
|
|||||||
_ _ ____ _
|
|
||||||
___| | | | _ \| |
|
|
||||||
/ __| | | | |_) | |
|
|
||||||
| (__| |_| | _ <| |___
|
|
||||||
\___|\___/|_| \_\_____|
|
|
||||||
|
|
||||||
curl release procedure - how to do a release
|
curl release procedure - how to do a release
|
||||||
============================================
|
============================================
|
||||||
|
|
||||||
|
@@ -53,7 +53,7 @@ SSL ciphers
|
|||||||
|
|
||||||
References:
|
References:
|
||||||
|
|
||||||
http://tools.ietf.org/html/draft-popov-tls-prohibiting-rc4-01
|
https://tools.ietf.org/html/draft-popov-tls-prohibiting-rc4-01
|
||||||
|
|
||||||
Allow BEAST
|
Allow BEAST
|
||||||
|
|
||||||
|
23
docs/THANKS
23
docs/THANKS
@@ -36,6 +36,7 @@ Alex Suykov
|
|||||||
Alex Vinnik
|
Alex Vinnik
|
||||||
Alex aka WindEagle
|
Alex aka WindEagle
|
||||||
Alexander Beedie
|
Alexander Beedie
|
||||||
|
Alexander Dyagilev
|
||||||
Alexander Elgert
|
Alexander Elgert
|
||||||
Alexander Klauer
|
Alexander Klauer
|
||||||
Alexander Kourakos
|
Alexander Kourakos
|
||||||
@@ -55,6 +56,7 @@ Alona Rossen
|
|||||||
Amol Pattekar
|
Amol Pattekar
|
||||||
Amr Shahin
|
Amr Shahin
|
||||||
Anatoli Tubman
|
Anatoli Tubman
|
||||||
|
Anders Bakken
|
||||||
Anders Gustafsson
|
Anders Gustafsson
|
||||||
Anders Havn
|
Anders Havn
|
||||||
Andi Jahja
|
Andi Jahja
|
||||||
@@ -90,6 +92,7 @@ Andy Serpa
|
|||||||
Andy Tsouladze
|
Andy Tsouladze
|
||||||
Angus Mackay
|
Angus Mackay
|
||||||
Anthon Pang
|
Anthon Pang
|
||||||
|
Anthony Avina
|
||||||
Anthony Bryan
|
Anthony Bryan
|
||||||
Anthony G. Basile
|
Anthony G. Basile
|
||||||
Antoine Calando
|
Antoine Calando
|
||||||
@@ -104,6 +107,7 @@ Arnaud Ebalard
|
|||||||
Arthur Murray
|
Arthur Murray
|
||||||
Arve Knudsen
|
Arve Knudsen
|
||||||
Arvid Norberg
|
Arvid Norberg
|
||||||
|
Ashish Shukla
|
||||||
Ask Bjørn Hansen
|
Ask Bjørn Hansen
|
||||||
Askar Safin
|
Askar Safin
|
||||||
Ates Goral
|
Ates Goral
|
||||||
@@ -131,6 +135,7 @@ Benoit Neil
|
|||||||
Benoit Sigoure
|
Benoit Sigoure
|
||||||
Bernard Leak
|
Bernard Leak
|
||||||
Bernhard Reutner-Fischer
|
Bernhard Reutner-Fischer
|
||||||
|
Bert Huijben
|
||||||
Bertrand Demiddelaer
|
Bertrand Demiddelaer
|
||||||
Bill Doyle
|
Bill Doyle
|
||||||
Bill Egert
|
Bill Egert
|
||||||
@@ -157,8 +162,10 @@ Brandon Wang
|
|||||||
Brendan Jurd
|
Brendan Jurd
|
||||||
Brent Beardsley
|
Brent Beardsley
|
||||||
Brian Akins
|
Brian Akins
|
||||||
|
Brian Chrisman
|
||||||
Brian Dessent
|
Brian Dessent
|
||||||
Brian J. Murrell
|
Brian J. Murrell
|
||||||
|
Brian Prodoehl
|
||||||
Brian R Duffy
|
Brian R Duffy
|
||||||
Brian Ulm
|
Brian Ulm
|
||||||
Brock Noland
|
Brock Noland
|
||||||
@@ -182,6 +189,7 @@ Charles Romestant
|
|||||||
Chen Prog
|
Chen Prog
|
||||||
Chih-Chung Chang
|
Chih-Chung Chang
|
||||||
Chris "Bob Bob"
|
Chris "Bob Bob"
|
||||||
|
Chris Araman
|
||||||
Chris Combes
|
Chris Combes
|
||||||
Chris Conlon
|
Chris Conlon
|
||||||
Chris Deidun
|
Chris Deidun
|
||||||
@@ -245,6 +253,7 @@ Daniel Black
|
|||||||
Daniel Cater
|
Daniel Cater
|
||||||
Daniel Egger
|
Daniel Egger
|
||||||
Daniel Johnson
|
Daniel Johnson
|
||||||
|
Daniel Melani
|
||||||
Daniel Mentz
|
Daniel Mentz
|
||||||
Daniel Steinberg
|
Daniel Steinberg
|
||||||
Daniel Stenberg
|
Daniel Stenberg
|
||||||
@@ -306,6 +315,7 @@ Dirk Manske
|
|||||||
Dmitri Shubin
|
Dmitri Shubin
|
||||||
Dmitriy Sergeyev
|
Dmitriy Sergeyev
|
||||||
Dmitry Bartsevich
|
Dmitry Bartsevich
|
||||||
|
Dmitry Eremin-Solenikov
|
||||||
Dmitry Falko
|
Dmitry Falko
|
||||||
Dmitry Kurochkin
|
Dmitry Kurochkin
|
||||||
Dmitry Popov
|
Dmitry Popov
|
||||||
@@ -321,6 +331,7 @@ Douglas Kilpatrick
|
|||||||
Douglas R. Horner
|
Douglas R. Horner
|
||||||
Douglas Steinwand
|
Douglas Steinwand
|
||||||
Dov Murik
|
Dov Murik
|
||||||
|
Drake Arconis
|
||||||
Duane Cathey
|
Duane Cathey
|
||||||
Duncan Mac-Vicar Prett
|
Duncan Mac-Vicar Prett
|
||||||
Dustin Boswell
|
Dustin Boswell
|
||||||
@@ -335,6 +346,7 @@ Edward Rudd
|
|||||||
Edward Sheldrake
|
Edward Sheldrake
|
||||||
Eelco Dolstra
|
Eelco Dolstra
|
||||||
Eetu Ojanen
|
Eetu Ojanen
|
||||||
|
Egon Eckert
|
||||||
Eldar Zaitov
|
Eldar Zaitov
|
||||||
Ellis Pritchard
|
Ellis Pritchard
|
||||||
Elmira A Semenova
|
Elmira A Semenova
|
||||||
@@ -390,6 +402,7 @@ François Charlier
|
|||||||
Fred Machado
|
Fred Machado
|
||||||
Fred New
|
Fred New
|
||||||
Fred Noz
|
Fred Noz
|
||||||
|
Fred Stluka
|
||||||
Frederic Lepied
|
Frederic Lepied
|
||||||
Fredrik Thulin
|
Fredrik Thulin
|
||||||
Gabriel Kuri
|
Gabriel Kuri
|
||||||
@@ -427,6 +440,7 @@ Glenn Sheridan
|
|||||||
Gordon Marler
|
Gordon Marler
|
||||||
Gorilla Maguila
|
Gorilla Maguila
|
||||||
Grant Erickson
|
Grant Erickson
|
||||||
|
Grant Pannell
|
||||||
Greg Hewgill
|
Greg Hewgill
|
||||||
Greg Morse
|
Greg Morse
|
||||||
Greg Onufer
|
Greg Onufer
|
||||||
@@ -540,6 +554,7 @@ Jeff Lawson
|
|||||||
Jeff Phillips
|
Jeff Phillips
|
||||||
Jeff Pohlmeyer
|
Jeff Pohlmeyer
|
||||||
Jeff Weber
|
Jeff Weber
|
||||||
|
Jens Rantil
|
||||||
Jeremy Friesner
|
Jeremy Friesner
|
||||||
Jeremy Huddleston
|
Jeremy Huddleston
|
||||||
Jeremy Lin
|
Jeremy Lin
|
||||||
@@ -567,6 +582,7 @@ Joe Halpin
|
|||||||
Joe Malicki
|
Joe Malicki
|
||||||
Joe Mason
|
Joe Mason
|
||||||
Joel Chen
|
Joel Chen
|
||||||
|
Joel Depooter
|
||||||
Jofell Gallardo
|
Jofell Gallardo
|
||||||
Johan Anderson
|
Johan Anderson
|
||||||
Johan Lantz
|
Johan Lantz
|
||||||
@@ -705,6 +721,7 @@ Lindley French
|
|||||||
Ling Thio
|
Ling Thio
|
||||||
Linus Nielsen Feltzing
|
Linus Nielsen Feltzing
|
||||||
Lisa Xu
|
Lisa Xu
|
||||||
|
Liviu Chircu
|
||||||
Liza Alenchery
|
Liza Alenchery
|
||||||
Lluís Batlle i Rossell
|
Lluís Batlle i Rossell
|
||||||
Loic Dachary
|
Loic Dachary
|
||||||
@@ -888,6 +905,7 @@ Oliver Schindler
|
|||||||
Olivier Berger
|
Olivier Berger
|
||||||
Oren Souroujon
|
Oren Souroujon
|
||||||
Oren Tirosh
|
Oren Tirosh
|
||||||
|
Orgad Shaneh
|
||||||
Ori Avtalion
|
Ori Avtalion
|
||||||
Oscar Koeroo
|
Oscar Koeroo
|
||||||
Oscar Norlander
|
Oscar Norlander
|
||||||
@@ -916,6 +934,7 @@ Paul Marks
|
|||||||
Paul Marquis
|
Paul Marquis
|
||||||
Paul Moore
|
Paul Moore
|
||||||
Paul Nolan
|
Paul Nolan
|
||||||
|
Paul Oliver
|
||||||
Paul Querna
|
Paul Querna
|
||||||
Paul Saab
|
Paul Saab
|
||||||
Pavel Cenek
|
Pavel Cenek
|
||||||
@@ -973,6 +992,7 @@ Quinn Slack
|
|||||||
Radu Simionescu
|
Radu Simionescu
|
||||||
Rafa Muyo
|
Rafa Muyo
|
||||||
Rafael Sagula
|
Rafael Sagula
|
||||||
|
Rafayel Mkrtchyan
|
||||||
Rafaël Carré
|
Rafaël Carré
|
||||||
Rainer Canavan
|
Rainer Canavan
|
||||||
Rainer Jung
|
Rainer Jung
|
||||||
@@ -1076,6 +1096,7 @@ Scott Barrett
|
|||||||
Scott Cantor
|
Scott Cantor
|
||||||
Scott Davis
|
Scott Davis
|
||||||
Scott McCreary
|
Scott McCreary
|
||||||
|
Sean Boudreau
|
||||||
Sebastian Rasmussen
|
Sebastian Rasmussen
|
||||||
Senthil Raja Velu
|
Senthil Raja Velu
|
||||||
Sergei Nikulov
|
Sergei Nikulov
|
||||||
@@ -1191,6 +1212,7 @@ Tomas Hoger
|
|||||||
Tomas Mlcoch
|
Tomas Mlcoch
|
||||||
Tomas Pospisek
|
Tomas Pospisek
|
||||||
Tomas Szepe
|
Tomas Szepe
|
||||||
|
Tomas Tomecek
|
||||||
Tomasz Kojm
|
Tomasz Kojm
|
||||||
Tomasz Lacki
|
Tomasz Lacki
|
||||||
Tommie Gannert
|
Tommie Gannert
|
||||||
@@ -1218,6 +1240,7 @@ Victor Snezhko
|
|||||||
Vijay Panghal
|
Vijay Panghal
|
||||||
Vikram Saxena
|
Vikram Saxena
|
||||||
Viktor Szakáts
|
Viktor Szakáts
|
||||||
|
Ville Skyttä
|
||||||
Vilmos Nebehaj
|
Vilmos Nebehaj
|
||||||
Vincent Bronner
|
Vincent Bronner
|
||||||
Vincent Le Normand
|
Vincent Le Normand
|
||||||
|
@@ -49,3 +49,4 @@ s/tetetest tetetest//
|
|||||||
s/Jiří Hruška/Jiri Hruska/
|
s/Jiří Hruška/Jiri Hruska/
|
||||||
s/Viktor Szakats/Viktor Szakáts/
|
s/Viktor Szakats/Viktor Szakáts/
|
||||||
s/Jonathan Cardoso/Jonathan Cardoso Machado/
|
s/Jonathan Cardoso/Jonathan Cardoso Machado/
|
||||||
|
s/Linus Nielsen/Linus Nielsen Feltzing/
|
||||||
|
19
docs/TODO
19
docs/TODO
@@ -25,6 +25,7 @@
|
|||||||
1.7 Detect when called from within callbacks
|
1.7 Detect when called from within callbacks
|
||||||
1.8 Allow SSL (HTTPS) to proxy
|
1.8 Allow SSL (HTTPS) to proxy
|
||||||
1.9 Cache negative name resolves
|
1.9 Cache negative name resolves
|
||||||
|
1.10 Support IDNA2008
|
||||||
|
|
||||||
2. libcurl - multi interface
|
2. libcurl - multi interface
|
||||||
2.1 More non-blocking
|
2.1 More non-blocking
|
||||||
@@ -208,7 +209,7 @@
|
|||||||
|
|
||||||
To prevent local users from snooping on your traffic to the proxy. Supported
|
To prevent local users from snooping on your traffic to the proxy. Supported
|
||||||
by Chrome already:
|
by Chrome already:
|
||||||
http://www.chromium.org/developers/design-documents/secure-web-proxy
|
https://www.chromium.org/developers/design-documents/secure-web-proxy
|
||||||
|
|
||||||
...and by Firefox soon:
|
...and by Firefox soon:
|
||||||
https://bugzilla.mozilla.org/show_bug.cgi?id=378637
|
https://bugzilla.mozilla.org/show_bug.cgi?id=378637
|
||||||
@@ -218,6 +219,12 @@
|
|||||||
A name resolve that has failed is likely to fail when made again within a
|
A name resolve that has failed is likely to fail when made again within a
|
||||||
short period of time. Currently we only cache positive responses.
|
short period of time. Currently we only cache positive responses.
|
||||||
|
|
||||||
|
1.10 Support IDNA2008
|
||||||
|
|
||||||
|
International Domain Names are supported in libcurl since years back, powered
|
||||||
|
by libidn. libidn implements IDNA2003 which has been superseded by IDNA2008.
|
||||||
|
libidn2 is an existing library offering support for IDNA2008.
|
||||||
|
|
||||||
|
|
||||||
2. libcurl - multi interface
|
2. libcurl - multi interface
|
||||||
|
|
||||||
@@ -265,7 +272,7 @@
|
|||||||
HOST is a command for a client to tell which host name to use, to offer FTP
|
HOST is a command for a client to tell which host name to use, to offer FTP
|
||||||
servers named-based virtual hosting:
|
servers named-based virtual hosting:
|
||||||
|
|
||||||
http://tools.ietf.org/html/rfc7151
|
https://tools.ietf.org/html/rfc7151
|
||||||
|
|
||||||
4.2 Alter passive/active on failure and retry
|
4.2 Alter passive/active on failure and retry
|
||||||
|
|
||||||
@@ -493,7 +500,7 @@ Currently the SMB authentication uses NTLMv1.
|
|||||||
|
|
||||||
DNS-Based Authentication of Named Entities (DANE) is a way to provide SSL
|
DNS-Based Authentication of Named Entities (DANE) is a way to provide SSL
|
||||||
keys and certs over DNS using DNSSEC as an alternative to the CA model.
|
keys and certs over DNS using DNSSEC as an alternative to the CA model.
|
||||||
http://www.rfc-editor.org/rfc/rfc6698.txt
|
https://www.rfc-editor.org/rfc/rfc6698.txt
|
||||||
|
|
||||||
An initial patch was posted by Suresh Krishnaswamy on March 7th 2013
|
An initial patch was posted by Suresh Krishnaswamy on March 7th 2013
|
||||||
(http://curl.haxx.se/mail/lib-2013-03/0075.html) but it was a too simple
|
(http://curl.haxx.se/mail/lib-2013-03/0075.html) but it was a too simple
|
||||||
@@ -523,7 +530,7 @@ Currently the SMB authentication uses NTLMv1.
|
|||||||
Therefore support for the existing -E/--cert and --key options should be
|
Therefore support for the existing -E/--cert and --key options should be
|
||||||
implemented by supplying a custom certificate to the SChannel APIs, see:
|
implemented by supplying a custom certificate to the SChannel APIs, see:
|
||||||
- Getting a Certificate for Schannel
|
- Getting a Certificate for Schannel
|
||||||
http://msdn.microsoft.com/en-us/library/windows/desktop/aa375447.aspx
|
https://msdn.microsoft.com/en-us/library/windows/desktop/aa375447.aspx
|
||||||
|
|
||||||
15.2 Add support for custom server certificate validation
|
15.2 Add support for custom server certificate validation
|
||||||
|
|
||||||
@@ -534,7 +541,7 @@ Currently the SMB authentication uses NTLMv1.
|
|||||||
Therefore support for the existing --cacert or --capath options should be
|
Therefore support for the existing --cacert or --capath options should be
|
||||||
implemented by supplying a custom certificate to the SChannel APIs, see:
|
implemented by supplying a custom certificate to the SChannel APIs, see:
|
||||||
- Getting a Certificate for Schannel
|
- Getting a Certificate for Schannel
|
||||||
http://msdn.microsoft.com/en-us/library/windows/desktop/aa375447.aspx
|
https://msdn.microsoft.com/en-us/library/windows/desktop/aa375447.aspx
|
||||||
|
|
||||||
15.3 Add support for the --ciphers option
|
15.3 Add support for the --ciphers option
|
||||||
|
|
||||||
@@ -545,7 +552,7 @@ Currently the SMB authentication uses NTLMv1.
|
|||||||
Therefore support for the existing --ciphers option should be implemented
|
Therefore support for the existing --ciphers option should be implemented
|
||||||
by mapping the OpenSSL/GnuTLS cipher suites to the SChannel APIs, see
|
by mapping the OpenSSL/GnuTLS cipher suites to the SChannel APIs, see
|
||||||
- Specifying Schannel Ciphers and Cipher Strengths
|
- Specifying Schannel Ciphers and Cipher Strengths
|
||||||
http://msdn.microsoft.com/en-us/library/windows/desktop/aa380161.aspx
|
https://msdn.microsoft.com/en-us/library/windows/desktop/aa380161.aspx
|
||||||
|
|
||||||
16. SASL
|
16. SASL
|
||||||
|
|
||||||
|
@@ -1,22 +1,18 @@
|
|||||||
_ _ ____ _
|
|
||||||
___| | | | _ \| |
|
|
||||||
/ __| | | | |_) | |
|
|
||||||
| (__| |_| | _ <| |___
|
|
||||||
\___|\___/|_| \_\_____|
|
|
||||||
|
|
||||||
Version Numbers and Releases
|
Version Numbers and Releases
|
||||||
|
============================
|
||||||
|
|
||||||
Curl is not only curl. Curl is also libcurl. They're actually individually
|
Curl is not only curl. Curl is also libcurl. They're actually individually
|
||||||
versioned, but they mostly follow each other rather closely.
|
versioned, but they mostly follow each other rather closely.
|
||||||
|
|
||||||
The version numbering is always built up using the same system:
|
The version numbering is always built up using the same system:
|
||||||
|
|
||||||
X.Y[.Z]
|
X.Y.Z
|
||||||
|
|
||||||
Where
|
- X is main version number
|
||||||
X is main version number
|
- Y is release number
|
||||||
Y is release number
|
- Z is patch number
|
||||||
Z is patch number
|
|
||||||
|
## Bumping numbers
|
||||||
|
|
||||||
One of these numbers will get bumped in each new release. The numbers to the
|
One of these numbers will get bumped in each new release. The numbers to the
|
||||||
right of a bumped number will be reset to zero. If Z is zero, it may not be
|
right of a bumped number will be reset to zero. If Z is zero, it may not be
|
||||||
@@ -57,4 +53,4 @@ Version Numbers and Releases
|
|||||||
release. It makes comparisons with greater than and less than work.
|
release. It makes comparisons with greater than and less than work.
|
||||||
|
|
||||||
This number is also available as three separate defines:
|
This number is also available as three separate defines:
|
||||||
LIBCURL_VERSION_MAJOR, LIBCURL_VERSION_MINOR and LIBCURL_VERSION_PATCH.
|
`LIBCURL_VERSION_MAJOR`, `LIBCURL_VERSION_MINOR` and `LIBCURL_VERSION_PATCH`.
|
||||||
|
18
docs/curl.1
18
docs/curl.1
@@ -39,8 +39,7 @@ resume, Metalink, and more. As you will see below, the number of features will
|
|||||||
make your head spin!
|
make your head spin!
|
||||||
|
|
||||||
curl is powered by libcurl for all transfer-related features. See
|
curl is powered by libcurl for all transfer-related features. See
|
||||||
.BR libcurl (3)
|
\fIlibcurl(3)\fP for details.
|
||||||
for details.
|
|
||||||
.SH URL
|
.SH URL
|
||||||
The URL syntax is protocol-dependent. You'll find a detailed description in
|
The URL syntax is protocol-dependent. You'll find a detailed description in
|
||||||
RFC 3986.
|
RFC 3986.
|
||||||
@@ -269,11 +268,11 @@ If this option is used several times, the last one will be used.
|
|||||||
.IP "--ciphers <list of ciphers>"
|
.IP "--ciphers <list of ciphers>"
|
||||||
(SSL) Specifies which ciphers to use in the connection. The list of ciphers
|
(SSL) Specifies which ciphers to use in the connection. The list of ciphers
|
||||||
must specify valid ciphers. Read up on SSL cipher list details on this URL:
|
must specify valid ciphers. Read up on SSL cipher list details on this URL:
|
||||||
\fIhttp://www.openssl.org/docs/apps/ciphers.html\fP
|
\fIhttps://www.openssl.org/docs/apps/ciphers.html\fP
|
||||||
|
|
||||||
NSS ciphers are done differently than OpenSSL and GnuTLS. The full list of NSS
|
NSS ciphers are done differently than OpenSSL and GnuTLS. The full list of NSS
|
||||||
ciphers is in the NSSCipherSuite entry at this URL:
|
ciphers is in the NSSCipherSuite entry at this URL:
|
||||||
\fIhttp://git.fedorahosted.org/cgit/mod_nss.git/plain/docs/mod_nss.html#Directives\fP
|
\fIhttps://git.fedorahosted.org/cgit/mod_nss.git/plain/docs/mod_nss.html#Directives\fP
|
||||||
|
|
||||||
If this option is used several times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "--compressed"
|
.IP "--compressed"
|
||||||
@@ -1060,13 +1059,10 @@ in Metalink file, hash check will fail.
|
|||||||
Makes curl scan the \fI.netrc\fP (\fI_netrc\fP on Windows) file in the user's
|
Makes curl scan the \fI.netrc\fP (\fI_netrc\fP on Windows) file in the user's
|
||||||
home directory for login name and password. This is typically used for FTP on
|
home directory for login name and password. This is typically used for FTP on
|
||||||
Unix. If used with HTTP, curl will enable user authentication. See
|
Unix. If used with HTTP, curl will enable user authentication. See
|
||||||
.BR netrc(4)
|
\fInetrc(5)\fP \fIftp(1)\fP for details on the file format. Curl will not
|
||||||
or
|
complain if that file doesn't have the right permissions (it should not be
|
||||||
.BR ftp(1)
|
either world- or group-readable). The environment variable "HOME" is used to
|
||||||
for details on the file format. Curl will not complain if that file
|
find the home directory.
|
||||||
doesn't have the right permissions (it should not be either world- or
|
|
||||||
group-readable). The environment variable "HOME" is used to find the home
|
|
||||||
directory.
|
|
||||||
|
|
||||||
A quick and very simple example of how to setup a \fI.netrc\fP to allow curl
|
A quick and very simple example of how to setup a \fI.netrc\fP to allow curl
|
||||||
to FTP to the machine host.domain.com with user name \&'myself' and password
|
to FTP to the machine host.domain.com with user name \&'myself' and password
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -19,9 +19,10 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
/* Example application source code using the multi interface to download many
|
/* <DESC>
|
||||||
* files, but with a capped maximum amount of simultaneous transfers.
|
* Source code using the multi interface to download many
|
||||||
*
|
* files, with a capped maximum amount of simultaneous transfers.
|
||||||
|
* </DESC>
|
||||||
* Written by Michael Wallner
|
* Written by Michael Wallner
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -19,6 +19,11 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
/* <DESC>
|
||||||
|
* HTTP PUT upload with authentiction using "any" method. libcurl picks the
|
||||||
|
* one the server supports/wants.
|
||||||
|
* </DESC>
|
||||||
|
*/
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 2012 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 2012 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -20,11 +20,11 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
|
/* <DESC>
|
||||||
|
* demonstrate the use of multi socket interface with boost::asio
|
||||||
|
* </DESC>
|
||||||
|
*/
|
||||||
/*
|
/*
|
||||||
* file: asiohiper.cpp
|
|
||||||
* Example program to demonstrate the use of multi socket interface
|
|
||||||
* with boost::asio
|
|
||||||
*
|
|
||||||
* This program is in c++ and uses boost::asio instead of libevent/libev.
|
* This program is in c++ and uses boost::asio instead of libevent/libev.
|
||||||
* Requires boost::asio, boost::bind and boost::system
|
* Requires boost::asio, boost::bind and boost::system
|
||||||
*
|
*
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -19,17 +19,11 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
/* Example using a "in core" PEM certificate to retrieve a https page.
|
/* <DESC>
|
||||||
* Written by Theo Borm
|
* CA cert in memory with OpenSSL to get a HTTPS page.
|
||||||
|
* </DESC>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* on a netBSD system with OPENSSL& LIBCURL installed from
|
|
||||||
* pkgsrc (using default paths) this program can be compiled using:
|
|
||||||
* gcc -I/usr/pkg/include -L/usr/pkg/lib -lcurl -Wl,-R/usr/pkg/lib -lssl
|
|
||||||
* -lcrypto -lz -o curlcacerttest curlcacerttest.c
|
|
||||||
* on other operating systems you may want to change paths to headers
|
|
||||||
* and libraries
|
|
||||||
*/
|
|
||||||
#include <openssl/ssl.h>
|
#include <openssl/ssl.h>
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -19,6 +19,10 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
/* <DESC>
|
||||||
|
* Extract lots of TLS certificate info.
|
||||||
|
* </DESC>
|
||||||
|
*/
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -19,6 +19,10 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
/* <DESC>
|
||||||
|
* Show transfer timing info after download completes.
|
||||||
|
* </DESC>
|
||||||
|
*/
|
||||||
/* Example source code to show how the callback function can be used to
|
/* Example source code to show how the callback function can be used to
|
||||||
* download data into a chunk of memory instead of storing it in a file.
|
* download data into a chunk of memory instead of storing it in a file.
|
||||||
* After successful download we use curl_easy_getinfo() calls to get the
|
* After successful download we use curl_easy_getinfo() calls to get the
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -19,7 +19,10 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
/* This example shows usage of simple cookie interface. */
|
/* <DESC>
|
||||||
|
* Import and export cookies with COOKIELIST.
|
||||||
|
* </DESC>
|
||||||
|
*/
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
@@ -5,9 +5,12 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
|
* Copyright (c) 2000 David Odin (aka DindinX) for MandrakeSoft
|
||||||
|
*/
|
||||||
|
/* <DESC>
|
||||||
|
* use the libcurl in a gtk-threaded application
|
||||||
|
* </DESC>
|
||||||
*/
|
*/
|
||||||
/* Copyright (c) 2000 David Odin (aka DindinX) for MandrakeSoft */
|
|
||||||
/* an attempt to use the curl library in concert with a gtk-threaded application */
|
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <gtk/gtk.h>
|
#include <gtk/gtk.h>
|
||||||
|
@@ -9,7 +9,10 @@
|
|||||||
certificate presented during ssl session establishment.
|
certificate presented during ssl session establishment.
|
||||||
|
|
||||||
*/
|
*/
|
||||||
|
/* <DESC>
|
||||||
|
* demonstrates use of SSL context callback, requires OpenSSL
|
||||||
|
* </DESC>
|
||||||
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2003 The OpenEvidence Project. All rights reserved.
|
* Copyright (c) 2003 The OpenEvidence Project. All rights reserved.
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2013, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -19,6 +19,10 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
/* <DESC>
|
||||||
|
* Show how CURLOPT_DEBUGFUNCTION can be used.
|
||||||
|
* </DESC>
|
||||||
|
*/
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -19,6 +19,10 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
/* <DESC>
|
||||||
|
* multi socket interface together with libev
|
||||||
|
* </DESC>
|
||||||
|
*/
|
||||||
/* Example application source code using the multi socket interface to
|
/* Example application source code using the multi socket interface to
|
||||||
* download many files at once.
|
* download many files at once.
|
||||||
*
|
*
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -19,9 +19,10 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
/*
|
/* <DESC>
|
||||||
* This is an example demonstrating how an application can pass in a custom
|
* An example demonstrating how an application can pass in a custom
|
||||||
* socket to libcurl to use. This example also handles the connect itself.
|
* socket to libcurl to use. This example also handles the connect itself.
|
||||||
|
* </DESC>
|
||||||
*/
|
*/
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -19,6 +19,10 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
/* <DESC>
|
||||||
|
* Upload to a file:// URL
|
||||||
|
* </DESC>
|
||||||
|
*/
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
@@ -42,6 +42,10 @@
|
|||||||
*
|
*
|
||||||
* This example requires libcurl 7.9.7 or later.
|
* This example requires libcurl 7.9.7 or later.
|
||||||
*/
|
*/
|
||||||
|
/* <DESC>
|
||||||
|
* implements an fopen() abstraction allowing reading from URLs
|
||||||
|
* </DESC>
|
||||||
|
*/
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -19,6 +19,10 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
/* <DESC>
|
||||||
|
* FTP wildcard pattern matching
|
||||||
|
* </DESC>
|
||||||
|
*/
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -23,11 +23,9 @@
|
|||||||
|
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
|
|
||||||
/*
|
/* <DESC>
|
||||||
* This is an example showing how to get a single file from an FTP server.
|
* Get a single file from an FTP server.
|
||||||
* It delays the actual destination file creation until the first write
|
* </DESC>
|
||||||
* callback so that it won't create an empty file in case the remote file
|
|
||||||
* doesn't exist or something else fails.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
struct FtpFile {
|
struct FtpFile {
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -24,9 +24,9 @@
|
|||||||
|
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
|
|
||||||
/*
|
/* <DESC>
|
||||||
* This is an example showing how to check a single file's size and mtime
|
* Checks a single file's size and mtime from an FTP server.
|
||||||
* from an FTP server.
|
* </DESC>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static size_t throw_away(void *ptr, size_t size, size_t nmemb, void *data)
|
static size_t throw_away(void *ptr, size_t size, size_t nmemb, void *data)
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -23,13 +23,11 @@
|
|||||||
|
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
|
|
||||||
/*
|
/* <DESC>
|
||||||
* Similar to ftpget.c but this also stores the received response-lines
|
* Similar to ftpget.c but also stores the received response-lines
|
||||||
* in a separate file using our own callback!
|
* in a separate file using our own callback!
|
||||||
*
|
* </DESC>
|
||||||
* This functionality was introduced in libcurl 7.9.3.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static size_t
|
static size_t
|
||||||
write_response(void *ptr, size_t size, size_t nmemb, void *data)
|
write_response(void *ptr, size_t size, size_t nmemb, void *data)
|
||||||
{
|
{
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -24,11 +24,9 @@
|
|||||||
|
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
|
|
||||||
/*
|
/* <DESC>
|
||||||
* This is an example showing how to get a single file from an FTPS server.
|
* Get a single file from an FTPS server.
|
||||||
* It delays the actual destination file creation until the first write
|
* </DESC>
|
||||||
* callback so that it won't create an empty file in case the remote file
|
|
||||||
* doesn't exist or something else fails.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
struct FtpFile {
|
struct FtpFile {
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -33,11 +33,10 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
/* <DESC>
|
||||||
* This example shows an FTP upload, with a rename of the file just after
|
* Performs an FTP upload and renames the file just after a successful
|
||||||
* a successful upload.
|
* transfer.
|
||||||
*
|
* </DESC>
|
||||||
* Example based on source code provided by Erick Nuwendam. Thanks!
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define LOCAL_FILE "/tmp/uploadthis.txt"
|
#define LOCAL_FILE "/tmp/uploadthis.txt"
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -19,13 +19,9 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
/* Upload to FTP, resuming failed transfers
|
/* <DESC>
|
||||||
*
|
* Upload to FTP, resuming failed transfers.
|
||||||
* Compile for MinGW like this:
|
* </DESC>
|
||||||
* gcc -Wall -pedantic -std=c99 ftpuploadwithresume.c -o ftpuploadresume.exe
|
|
||||||
* -lcurl -lmsvcr70
|
|
||||||
*
|
|
||||||
* Written by Philip Bock
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -19,6 +19,10 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
/* <DESC>
|
||||||
|
* Use getinfo to get content-type after completed transfer.
|
||||||
|
* </DESC>
|
||||||
|
*/
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
|
|
||||||
@@ -27,18 +31,14 @@ int main(void)
|
|||||||
CURL *curl;
|
CURL *curl;
|
||||||
CURLcode res;
|
CURLcode res;
|
||||||
|
|
||||||
/* http://curl.haxx.se/libcurl/c/curl_easy_init.html */
|
|
||||||
curl = curl_easy_init();
|
curl = curl_easy_init();
|
||||||
if(curl) {
|
if(curl) {
|
||||||
/* http://curl.haxx.se/libcurl/c/curl_easy_setopt.html#CURLOPTURL */
|
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "http://www.example.com/");
|
curl_easy_setopt(curl, CURLOPT_URL, "http://www.example.com/");
|
||||||
/* http://curl.haxx.se/libcurl/c/curl_easy_perform.html */
|
|
||||||
res = curl_easy_perform(curl);
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
if(CURLE_OK == res) {
|
if(CURLE_OK == res) {
|
||||||
char *ct;
|
char *ct;
|
||||||
/* ask for the content-type */
|
/* ask for the content-type */
|
||||||
/* http://curl.haxx.se/libcurl/c/curl_easy_getinfo.html */
|
|
||||||
res = curl_easy_getinfo(curl, CURLINFO_CONTENT_TYPE, &ct);
|
res = curl_easy_getinfo(curl, CURLINFO_CONTENT_TYPE, &ct);
|
||||||
|
|
||||||
if((CURLE_OK == res) && ct)
|
if((CURLE_OK == res) && ct)
|
||||||
@@ -46,7 +46,6 @@ int main(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* always cleanup */
|
/* always cleanup */
|
||||||
/* http://curl.haxx.se/libcurl/c/curl_easy_cleanup.html */
|
|
||||||
curl_easy_cleanup(curl);
|
curl_easy_cleanup(curl);
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2013, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -19,8 +19,10 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
/* Example source code to show how the callback function can be used to
|
/* <DESC>
|
||||||
* download data into a chunk of memory instead of storing it in a file.
|
* Shows how the write callback function can be used to download data into a
|
||||||
|
* chunk of memory instead of storing it in a file.
|
||||||
|
* </DESC>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
@@ -34,7 +36,6 @@ struct MemoryStruct {
|
|||||||
size_t size;
|
size_t size;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
static size_t
|
static size_t
|
||||||
WriteMemoryCallback(void *contents, size_t size, size_t nmemb, void *userp)
|
WriteMemoryCallback(void *contents, size_t size, size_t nmemb, void *userp)
|
||||||
{
|
{
|
||||||
@@ -55,7 +56,6 @@ WriteMemoryCallback(void *contents, size_t size, size_t nmemb, void *userp)
|
|||||||
return realsize;
|
return realsize;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int main(void)
|
int main(void)
|
||||||
{
|
{
|
||||||
CURL *curl_handle;
|
CURL *curl_handle;
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -19,6 +19,10 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
/* <DESC>
|
||||||
|
* multi socket API usage together with with glib2
|
||||||
|
* </DESC>
|
||||||
|
*/
|
||||||
/* Example application source code using the multi socket interface to
|
/* Example application source code using the multi socket interface to
|
||||||
* download many files at once.
|
* download many files at once.
|
||||||
*
|
*
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -19,6 +19,10 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
/* <DESC>
|
||||||
|
* multi socket API usage with libevent 2
|
||||||
|
* </DESC>
|
||||||
|
*/
|
||||||
/* Example application source code using the multi socket interface to
|
/* Example application source code using the multi socket interface to
|
||||||
download many files at once.
|
download many files at once.
|
||||||
|
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 2012 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -20,13 +20,13 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
|
/* <DESC>
|
||||||
|
* Uses the "Streaming HTML parser" to extract the href pieces in a streaming
|
||||||
|
* manner from a downloaded HTML.
|
||||||
|
* </DESC>
|
||||||
|
*/
|
||||||
/*
|
/*
|
||||||
* This example uses the "Streaming HTML parser" to extract the href pieces in
|
* The HTML parser is found at http://code.google.com/p/htmlstreamparser/
|
||||||
* a streaming manner from a downloaded HTML. Kindly donated by Michał
|
|
||||||
* Kowalczyk.
|
|
||||||
*
|
|
||||||
* The parser is found at
|
|
||||||
* http://code.google.com/p/htmlstreamparser/
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -19,13 +19,12 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
/* Download a document and use libtidy to parse the HTML.
|
/* <DESC>
|
||||||
* Written by Jeff Pohlmeyer
|
* Download a document and use libtidy to parse the HTML.
|
||||||
*
|
* </DESC>
|
||||||
|
*/
|
||||||
|
/*
|
||||||
* LibTidy => http://tidy.sourceforge.net
|
* LibTidy => http://tidy.sourceforge.net
|
||||||
*
|
|
||||||
* gcc -Wall -I/usr/local/include tidycurl.c -lcurl -ltidy -o tidycurl
|
|
||||||
*
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
.\" * | (__| |_| | _ <| |___
|
.\" * | (__| |_| | _ <| |___
|
||||||
.\" * \___|\___/|_| \_\_____|
|
.\" * \___|\___/|_| \_\_____|
|
||||||
.\" *
|
.\" *
|
||||||
.\" * Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al.
|
.\" * Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
.\" *
|
.\" *
|
||||||
.\" * This software is licensed as described in the file COPYING, which
|
.\" * This software is licensed as described in the file COPYING, which
|
||||||
.\" * you should have received as part of this distribution. The terms
|
.\" * you should have received as part of this distribution. The terms
|
||||||
@@ -63,5 +63,6 @@ if(curl) {
|
|||||||
}
|
}
|
||||||
.fi
|
.fi
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
.BR curl_easy_init "(3), "
|
.BR curl_easy_init "(3), " curl_easy_duphandle "(3), "
|
||||||
|
.BR curl_easy_reset "(3), "
|
||||||
|
.BR curl_multi_cleanup "(3), " curl_multi_remove_handle "(3) "
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
.\" * | (__| |_| | _ <| |___
|
.\" * | (__| |_| | _ <| |___
|
||||||
.\" * \___|\___/|_| \_\_____|
|
.\" * \___|\___/|_| \_\_____|
|
||||||
.\" *
|
.\" *
|
||||||
.\" * Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al.
|
.\" * Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
.\" *
|
.\" *
|
||||||
.\" * This software is licensed as described in the file COPYING, which
|
.\" * This software is licensed as described in the file COPYING, which
|
||||||
.\" * you should have received as part of this distribution. The terms
|
.\" * you should have received as part of this distribution. The terms
|
||||||
@@ -47,4 +47,6 @@ in a synchronous way, the input handle may not be in use when cloned.
|
|||||||
If this function returns NULL, something went wrong and no valid handle was
|
If this function returns NULL, something went wrong and no valid handle was
|
||||||
returned.
|
returned.
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
.BR curl_easy_init "(3)," curl_easy_cleanup "(3)," curl_global_init "(3)"
|
.BR curl_easy_init "(3)," curl_easy_cleanup "(3)," curl_easy_reset "(3),"
|
||||||
|
.BR curl_global_init "(3)"
|
||||||
|
|
||||||
|
@@ -50,6 +50,8 @@ really \fICURLOPT_POSTFIELDS(3)\fP, but the alternative that copies the string
|
|||||||
\fICURLOPT_COPYPOSTFIELDS(3)\fP has some usage characteristics you need to
|
\fICURLOPT_COPYPOSTFIELDS(3)\fP has some usage characteristics you need to
|
||||||
read up on.
|
read up on.
|
||||||
|
|
||||||
|
The order in which the options are set does not matter.
|
||||||
|
|
||||||
Before version 7.17.0, strings were not copied. Instead the user was forced
|
Before version 7.17.0, strings were not copied. Instead the user was forced
|
||||||
keep them available until libcurl no longer needed them.
|
keep them available until libcurl no longer needed them.
|
||||||
|
|
||||||
@@ -291,6 +293,8 @@ Disable Content decoding. See \fICURLOPT_HTTP_CONTENT_DECODING(3)\fP
|
|||||||
Disable Transfer decoding. See \fICURLOPT_HTTP_TRANSFER_DECODING(3)\fP
|
Disable Transfer decoding. See \fICURLOPT_HTTP_TRANSFER_DECODING(3)\fP
|
||||||
.IP CURLOPT_EXPECT_100_TIMEOUT_MS
|
.IP CURLOPT_EXPECT_100_TIMEOUT_MS
|
||||||
100-continue timeout. See \fICURLOPT_EXPECT_100_TIMEOUT_MS(3)\fP
|
100-continue timeout. See \fICURLOPT_EXPECT_100_TIMEOUT_MS(3)\fP
|
||||||
|
.IP CURLOPT_PIPEWAIT
|
||||||
|
Wait on connection to pipeline on it. See \fICURLOPT_PIPEWAIT(3)\fP
|
||||||
.SH SMTP OPTIONS
|
.SH SMTP OPTIONS
|
||||||
.IP CURLOPT_MAIL_FROM
|
.IP CURLOPT_MAIL_FROM
|
||||||
Address of the sender. See \fICURLOPT_MAIL_FROM(3)\fP
|
Address of the sender. See \fICURLOPT_MAIL_FROM(3)\fP
|
||||||
|
@@ -69,6 +69,7 @@ that just completed.
|
|||||||
|
|
||||||
At this point, there are no other \fBmsg\fP types defined.
|
At this point, there are no other \fBmsg\fP types defined.
|
||||||
.SH EXAMPLE
|
.SH EXAMPLE
|
||||||
|
.nf
|
||||||
struct CURLMsg *m;
|
struct CURLMsg *m;
|
||||||
|
|
||||||
/* call curl_multi_perform or curl_multi_socket_action first, then loop
|
/* call curl_multi_perform or curl_multi_socket_action first, then loop
|
||||||
@@ -84,7 +85,7 @@ do {
|
|||||||
curl_easy_cleanup(e);
|
curl_easy_cleanup(e);
|
||||||
}
|
}
|
||||||
} while(m);
|
} while(m);
|
||||||
|
.fi
|
||||||
.SH "RETURN VALUE"
|
.SH "RETURN VALUE"
|
||||||
A pointer to a filled-in struct, or NULL if it failed or ran out of
|
A pointer to a filled-in struct, or NULL if it failed or ran out of
|
||||||
structs. It also writes the number of messages left in the queue (after this
|
structs. It also writes the number of messages left in the queue (after this
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
.\" * | (__| |_| | _ <| |___
|
.\" * | (__| |_| | _ <| |___
|
||||||
.\" * \___|\___/|_| \_\_____|
|
.\" * \___|\___/|_| \_\_____|
|
||||||
.\" *
|
.\" *
|
||||||
.\" * Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al.
|
.\" * Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
.\" *
|
.\" *
|
||||||
.\" * This software is licensed as described in the file COPYING, which
|
.\" * This software is licensed as described in the file COPYING, which
|
||||||
.\" * you should have received as part of this distribution. The terms
|
.\" * you should have received as part of this distribution. The terms
|
||||||
@@ -74,7 +74,7 @@ After having sent the FTP password to the server, libcurl expects a proper
|
|||||||
reply. This error code indicates that an unexpected code was returned.
|
reply. This error code indicates that an unexpected code was returned.
|
||||||
.IP "CURLE_FTP_ACCEPT_TIMEOUT (12)"
|
.IP "CURLE_FTP_ACCEPT_TIMEOUT (12)"
|
||||||
During an active FTP session while waiting for the server to connect, the
|
During an active FTP session while waiting for the server to connect, the
|
||||||
\fICURLOPT_ACCEPTTIMOUT_MS(3)\fP (or the internal default) timeout expired.
|
\fICURLOPT_ACCEPTTIMEOUT_MS(3)\fP (or the internal default) timeout expired.
|
||||||
.IP "CURLE_FTP_WEIRD_PASV_REPLY (13)"
|
.IP "CURLE_FTP_WEIRD_PASV_REPLY (13)"
|
||||||
libcurl failed to get a sensible result back from the server as a response to
|
libcurl failed to get a sensible result back from the server as a response to
|
||||||
either a PASV or a EPSV command. The server is flawed.
|
either a PASV or a EPSV command. The server is flawed.
|
||||||
|
@@ -136,7 +136,7 @@ normal multi interface. Then you also set two callbacks with the
|
|||||||
CURLMOPT_SOCKETFUNCTION and CURLMOPT_TIMERFUNCTION options to
|
CURLMOPT_SOCKETFUNCTION and CURLMOPT_TIMERFUNCTION options to
|
||||||
\fIcurl_multi_setopt(3)\fP. They are two callback functions that libcurl will
|
\fIcurl_multi_setopt(3)\fP. They are two callback functions that libcurl will
|
||||||
call with information about what sockets to wait for, and for what activity,
|
call with information about what sockets to wait for, and for what activity,
|
||||||
and what the curret timeout time is - if that expires libcurl should be
|
and what the current timeout time is - if that expires libcurl should be
|
||||||
notified.
|
notified.
|
||||||
|
|
||||||
The multi_socket API is designed to inform your application about which
|
The multi_socket API is designed to inform your application about which
|
||||||
|
@@ -51,15 +51,33 @@ All
|
|||||||
.nf
|
.nf
|
||||||
curl = curl_easy_init();
|
curl = curl_easy_init();
|
||||||
if(curl) {
|
if(curl) {
|
||||||
char error[CURL_ERROR_SIZE]
|
CURLcode res;
|
||||||
|
char errbuf[CURL_ERROR_SIZE];
|
||||||
|
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "http://example.com");
|
curl_easy_setopt(curl, CURLOPT_URL, "http://example.com");
|
||||||
|
|
||||||
/* provide a buffer to store errors in */
|
/* provide a buffer to store errors in */
|
||||||
curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, error);
|
curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, errbuf);
|
||||||
|
|
||||||
/* Perform the request */
|
/* set the error buffer as empty before performing a request */
|
||||||
curl_easy_perform(curl);
|
errbuf[0] = 0;
|
||||||
|
|
||||||
|
/* perform the request */
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
|
/* if the request did not complete correctly, show the error
|
||||||
|
information. if no detailed error information was written to errbuf
|
||||||
|
show the more generic information from curl_easy_strerror instead.
|
||||||
|
*/
|
||||||
|
if(res != CURLE_OK) {
|
||||||
|
size_t len = strlen(errbuf);
|
||||||
|
fprintf(stderr, "\\nlibcurl: (%d) ", res);
|
||||||
|
if(len)
|
||||||
|
fprintf(stderr, "%s%s", errbuf,
|
||||||
|
((errbuf[len - 1] != '\\n') ? "\\n" : ""));
|
||||||
|
else
|
||||||
|
fprintf(stderr, "%s\\n", curl_easy_strerror(res));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
.fi
|
.fi
|
||||||
.SH AVAILABILITY
|
.SH AVAILABILITY
|
||||||
|
@@ -30,12 +30,12 @@
|
|||||||
|
|
||||||
/* This is the version number of the libcurl package from which this header
|
/* This is the version number of the libcurl package from which this header
|
||||||
file origins: */
|
file origins: */
|
||||||
#define LIBCURL_VERSION "7.43.0-DEV"
|
#define LIBCURL_VERSION "7.44.0-DEV"
|
||||||
|
|
||||||
/* The numeric version number is also available "in parts" by using these
|
/* The numeric version number is also available "in parts" by using these
|
||||||
defines: */
|
defines: */
|
||||||
#define LIBCURL_VERSION_MAJOR 7
|
#define LIBCURL_VERSION_MAJOR 7
|
||||||
#define LIBCURL_VERSION_MINOR 43
|
#define LIBCURL_VERSION_MINOR 44
|
||||||
#define LIBCURL_VERSION_PATCH 0
|
#define LIBCURL_VERSION_PATCH 0
|
||||||
|
|
||||||
/* This is the numeric version of the libcurl version number, meant for easier
|
/* This is the numeric version of the libcurl version number, meant for easier
|
||||||
@@ -57,7 +57,7 @@
|
|||||||
CURL_VERSION_BITS() macro since curl's own configure script greps for it
|
CURL_VERSION_BITS() macro since curl's own configure script greps for it
|
||||||
and needs it to contain the full number.
|
and needs it to contain the full number.
|
||||||
*/
|
*/
|
||||||
#define LIBCURL_VERSION_NUM 0x072B00
|
#define LIBCURL_VERSION_NUM 0x072C00
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This is the date and time when the full source package was created. The
|
* This is the date and time when the full source package was created. The
|
||||||
|
@@ -21,9 +21,6 @@
|
|||||||
###########################################################################
|
###########################################################################
|
||||||
AUTOMAKE_OPTIONS = foreign nostdinc
|
AUTOMAKE_OPTIONS = foreign nostdinc
|
||||||
|
|
||||||
DOCS = README.encoding README.memoryleak README.ares README.curlx \
|
|
||||||
README.hostip README.multi_socket README.httpauth README.curl_off_t
|
|
||||||
|
|
||||||
CMAKE_DIST = CMakeLists.txt curl_config.h.cmake
|
CMAKE_DIST = CMakeLists.txt curl_config.h.cmake
|
||||||
|
|
||||||
EXTRA_DIST = Makefile.b32 Makefile.m32 Makefile.vc6 config-win32.h \
|
EXTRA_DIST = Makefile.b32 Makefile.m32 Makefile.vc6 config-win32.h \
|
||||||
@@ -31,7 +28,7 @@ EXTRA_DIST = Makefile.b32 Makefile.m32 Makefile.vc6 config-win32.h \
|
|||||||
makefile.dj config-dos.h libcurl.plist libcurl.rc config-amigaos.h \
|
makefile.dj config-dos.h libcurl.plist libcurl.rc config-amigaos.h \
|
||||||
makefile.amiga Makefile.netware nwlib.c nwos.c config-win32ce.h \
|
makefile.amiga Makefile.netware nwlib.c nwos.c config-win32ce.h \
|
||||||
config-os400.h setup-os400.h config-symbian.h Makefile.Watcom \
|
config-os400.h setup-os400.h config-symbian.h Makefile.Watcom \
|
||||||
config-tpf.h $(DOCS) mk-ca-bundle.pl mk-ca-bundle.vbs $(CMAKE_DIST) \
|
config-tpf.h mk-ca-bundle.pl mk-ca-bundle.vbs $(CMAKE_DIST) \
|
||||||
firefox-db2pem.sh config-vxworks.h Makefile.vxworks checksrc.pl \
|
firefox-db2pem.sh config-vxworks.h Makefile.vxworks checksrc.pl \
|
||||||
objnames-test08.sh objnames-test10.sh objnames.inc checksrc.whitelist
|
objnames-test08.sh objnames-test10.sh objnames.inc checksrc.whitelist
|
||||||
|
|
||||||
|
@@ -58,7 +58,7 @@ CC = $(CROSSPREFIX)gcc
|
|||||||
CFLAGS = $(CURL_CFLAG_EXTRAS) -g -O2 -Wall
|
CFLAGS = $(CURL_CFLAG_EXTRAS) -g -O2 -Wall
|
||||||
CFLAGS += -fno-strict-aliasing
|
CFLAGS += -fno-strict-aliasing
|
||||||
# comment LDFLAGS below to keep debug info
|
# comment LDFLAGS below to keep debug info
|
||||||
LDFLAGS = -s
|
LDFLAGS = $(CURL_LDFLAG_EXTRAS) -s
|
||||||
AR = $(CROSSPREFIX)ar
|
AR = $(CROSSPREFIX)ar
|
||||||
RANLIB = $(CROSSPREFIX)ranlib
|
RANLIB = $(CROSSPREFIX)ranlib
|
||||||
RC = $(CROSSPREFIX)windres
|
RC = $(CROSSPREFIX)windres
|
||||||
|
@@ -1,69 +0,0 @@
|
|||||||
_ _ ____ _
|
|
||||||
___| | | | _ \| |
|
|
||||||
/ __| | | | |_) | |
|
|
||||||
| (__| |_| | _ <| |___
|
|
||||||
\___|\___/|_| \_\_____|
|
|
||||||
|
|
||||||
How To Build libcurl to Use c-ares For Asynch Name Resolves
|
|
||||||
===========================================================
|
|
||||||
|
|
||||||
c-ares:
|
|
||||||
http://c-ares.haxx.se/
|
|
||||||
|
|
||||||
NOTE
|
|
||||||
The latest libcurl version requires c-ares 1.6.0 or later.
|
|
||||||
|
|
||||||
Once upon the time libcurl built fine with the "original" ares. That is no
|
|
||||||
longer true. You need to use c-ares.
|
|
||||||
|
|
||||||
Build c-ares
|
|
||||||
============
|
|
||||||
|
|
||||||
1. unpack the c-ares archive
|
|
||||||
2. cd c-ares-dir
|
|
||||||
3. ./configure
|
|
||||||
4. make
|
|
||||||
5. make install
|
|
||||||
|
|
||||||
Build libcurl to use c-ares in the curl source tree
|
|
||||||
===================================================
|
|
||||||
|
|
||||||
1. name or symlink the c-ares source directory 'ares' in the curl source
|
|
||||||
directory
|
|
||||||
2. ./configure --enable-ares
|
|
||||||
|
|
||||||
Optionally, you can point out the c-ares install tree root with the the
|
|
||||||
--enable-ares option.
|
|
||||||
|
|
||||||
3. make
|
|
||||||
|
|
||||||
Build libcurl to use an installed c-ares
|
|
||||||
========================================
|
|
||||||
|
|
||||||
1. ./configure --enable-ares=/path/to/ares/install
|
|
||||||
2. make
|
|
||||||
|
|
||||||
c-ares on win32
|
|
||||||
===============
|
|
||||||
(description brought by Dominick Meglio)
|
|
||||||
|
|
||||||
First I compiled c-ares. I changed the default C runtime library to be the
|
|
||||||
single-threaded rather than the multi-threaded (this seems to be required to
|
|
||||||
prevent linking errors later on). Then I simply build the areslib project (the
|
|
||||||
other projects adig/ahost seem to fail under MSVC).
|
|
||||||
|
|
||||||
Next was libcurl. I opened lib/config-win32.h and I added a:
|
|
||||||
#define USE_ARES 1
|
|
||||||
|
|
||||||
Next thing I did was I added the path for the ares includes to the include
|
|
||||||
path, and the libares.lib to the libraries.
|
|
||||||
|
|
||||||
Lastly, I also changed libcurl to be single-threaded rather than
|
|
||||||
multi-threaded, again this was to prevent some duplicate symbol errors. I'm
|
|
||||||
not sure why I needed to change everything to single-threaded, but when I
|
|
||||||
didn't I got redefinition errors for several CRT functions (malloc, stricmp,
|
|
||||||
etc.)
|
|
||||||
|
|
||||||
I would have modified the MSVC++ project files, but I only have VC.NET and it
|
|
||||||
uses a different format than VC6.0 so I didn't want to go and change
|
|
||||||
everything and remove VC6.0 support from libcurl.
|
|
@@ -1,68 +0,0 @@
|
|||||||
|
|
||||||
curl_off_t explained
|
|
||||||
====================
|
|
||||||
|
|
||||||
curl_off_t is a data type provided by the external libcurl include headers. It
|
|
||||||
is the type meant to be used for the curl_easy_setopt() options that end with
|
|
||||||
LARGE. The type is 64bit large on most modern platforms.
|
|
||||||
|
|
||||||
Transition from < 7.19.0 to >= 7.19.0
|
|
||||||
-------------------------------------
|
|
||||||
|
|
||||||
Applications that used libcurl before 7.19.0 that are rebuilt with a libcurl
|
|
||||||
that is 7.19.0 or later may or may not have to worry about anything of
|
|
||||||
this. We have made a significant effort to make the transition really seamless
|
|
||||||
and transparent.
|
|
||||||
|
|
||||||
You have have to take notice if you are in one of the following situations:
|
|
||||||
|
|
||||||
o Your app is using or will after the transition use a libcurl that is built
|
|
||||||
with LFS (large file support) disabled even though your system otherwise
|
|
||||||
supports it.
|
|
||||||
|
|
||||||
o Your app is using or will after the transition use a libcurl that doesn't
|
|
||||||
support LFS at all, but your system and compiler support 64bit data types.
|
|
||||||
|
|
||||||
In both these cases, the curl_off_t type will now (after the transition) be
|
|
||||||
64bit where it previously was 32bit. This will cause a binary incompatibility
|
|
||||||
that you MAY need to deal with.
|
|
||||||
|
|
||||||
Benefits
|
|
||||||
--------
|
|
||||||
|
|
||||||
This new way has several benefits:
|
|
||||||
|
|
||||||
o Platforms without LFS support can still use libcurl to do >32 bit file
|
|
||||||
transfers and range operations etc as long as they have >32 bit data-types
|
|
||||||
supported.
|
|
||||||
|
|
||||||
o Applications will no longer easily build with the curl_off_t size
|
|
||||||
mismatched, which has been a very frequent (and annoying) problem with
|
|
||||||
libcurl <= 7.18.2
|
|
||||||
|
|
||||||
Historically
|
|
||||||
------------
|
|
||||||
|
|
||||||
Previously, before 7.19.0, the curl_off_t type would be rather strongly
|
|
||||||
connected to the size of the system off_t type, where currently curl_off_t is
|
|
||||||
independent of that.
|
|
||||||
|
|
||||||
The strong connection to off_t made it troublesome for application authors
|
|
||||||
since when they did mistakes, they could get curl_off_t type of different
|
|
||||||
sizes in the app vs libcurl, and that caused strange effects that were hard to
|
|
||||||
track and detect by users of libcurl.
|
|
||||||
|
|
||||||
SONAME
|
|
||||||
------
|
|
||||||
|
|
||||||
We opted to not bump the soname for the library unconditionally, simply
|
|
||||||
because soname bumping is causing a lot of grief and moaning all over the
|
|
||||||
community so we try to keep that at minimum. Also, our selected design path
|
|
||||||
should be 100% backwards compatible for the vast majority of all libcurl
|
|
||||||
users.
|
|
||||||
|
|
||||||
Enforce SONAME bump
|
|
||||||
-------------------
|
|
||||||
|
|
||||||
If configure doesn't detect your case where a bump is necessary, re-run it
|
|
||||||
with the --enable-soname-bump command line option!
|
|
@@ -1,61 +0,0 @@
|
|||||||
_ _ ____ _
|
|
||||||
___| | | | _ \| |
|
|
||||||
/ __| | | | |_) | |
|
|
||||||
| (__| |_| | _ <| |___
|
|
||||||
\___|\___/|_| \_\_____|
|
|
||||||
|
|
||||||
Source Code Functions Apps Might Use
|
|
||||||
====================================
|
|
||||||
|
|
||||||
The libcurl source code offers a few functions by source only. They are not
|
|
||||||
part of the official libcurl API, but the source files might be useful for
|
|
||||||
others so apps can optionally compile/build with these sources to gain
|
|
||||||
additional functions.
|
|
||||||
|
|
||||||
We provide them through a single header file for easy access for apps:
|
|
||||||
"curlx.h"
|
|
||||||
|
|
||||||
curlx_strtoofft()
|
|
||||||
|
|
||||||
A macro that converts a string containing a number to a curl_off_t number.
|
|
||||||
This might use the curlx_strtoll() function which is provided as source
|
|
||||||
code in strtoofft.c. Note that the function is only provided if no
|
|
||||||
strtoll() (or equivalent) function exist on your platform. If curl_off_t
|
|
||||||
is only a 32 bit number on your platform, this macro uses strtol().
|
|
||||||
|
|
||||||
curlx_tvnow()
|
|
||||||
|
|
||||||
returns a struct timeval for the current time.
|
|
||||||
|
|
||||||
curlx_tvdiff()
|
|
||||||
|
|
||||||
returns the difference between two timeval structs, in number of
|
|
||||||
milliseconds.
|
|
||||||
|
|
||||||
curlx_tvdiff_secs()
|
|
||||||
|
|
||||||
returns the same as curlx_tvdiff but with full usec resolution (as a
|
|
||||||
double)
|
|
||||||
|
|
||||||
FUTURE
|
|
||||||
======
|
|
||||||
|
|
||||||
Several functions will be removed from the public curl_ name space in a
|
|
||||||
future libcurl release. They will then only become available as curlx_
|
|
||||||
functions instead. To make the transition easier, we already today provide
|
|
||||||
these functions with the curlx_ prefix to allow sources to get built properly
|
|
||||||
with the new function names. The functions this concerns are:
|
|
||||||
|
|
||||||
curlx_getenv
|
|
||||||
curlx_strequal
|
|
||||||
curlx_strnequal
|
|
||||||
curlx_mvsnprintf
|
|
||||||
curlx_msnprintf
|
|
||||||
curlx_maprintf
|
|
||||||
curlx_mvaprintf
|
|
||||||
curlx_msprintf
|
|
||||||
curlx_mprintf
|
|
||||||
curlx_mfprintf
|
|
||||||
curlx_mvsprintf
|
|
||||||
curlx_mvprintf
|
|
||||||
curlx_mvfprintf
|
|
@@ -1,60 +0,0 @@
|
|||||||
|
|
||||||
Content Encoding Support for libcurl
|
|
||||||
|
|
||||||
* About content encodings:
|
|
||||||
|
|
||||||
HTTP/1.1 [RFC 2616] specifies that a client may request that a server encode
|
|
||||||
its response. This is usually used to compress a response using one of a set
|
|
||||||
of commonly available compression techniques. These schemes are `deflate' (the
|
|
||||||
zlib algorithm), `gzip' and `compress' [sec 3.5, RFC 2616]. A client requests
|
|
||||||
that the sever perform an encoding by including an Accept-Encoding header in
|
|
||||||
the request document. The value of the header should be one of the recognized
|
|
||||||
tokens `deflate', ... (there's a way to register new schemes/tokens, see sec
|
|
||||||
3.5 of the spec). A server MAY honor the client's encoding request. When a
|
|
||||||
response is encoded, the server includes a Content-Encoding header in the
|
|
||||||
response. The value of the Content-Encoding header indicates which scheme was
|
|
||||||
used to encode the data.
|
|
||||||
|
|
||||||
A client may tell a server that it can understand several different encoding
|
|
||||||
schemes. In this case the server may choose any one of those and use it to
|
|
||||||
encode the response (indicating which one using the Content-Encoding header).
|
|
||||||
It's also possible for a client to attach priorities to different schemes so
|
|
||||||
that the server knows which it prefers. See sec 14.3 of RFC 2616 for more
|
|
||||||
information on the Accept-Encoding header.
|
|
||||||
|
|
||||||
* Current support for content encoding:
|
|
||||||
|
|
||||||
Support for the 'deflate' and 'gzip' content encoding are supported by
|
|
||||||
libcurl. Both regular and chunked transfers should work fine. The library
|
|
||||||
zlib is required for this feature. 'deflate' support was added by James
|
|
||||||
Gallagher, and support for the 'gzip' encoding was added by Dan Fandrich.
|
|
||||||
|
|
||||||
* The libcurl interface:
|
|
||||||
|
|
||||||
To cause libcurl to request a content encoding use:
|
|
||||||
|
|
||||||
curl_easy_setopt(curl, CURLOPT_ACCEPT_ENCODING, <string>)
|
|
||||||
|
|
||||||
where <string> is the intended value of the Accept-Encoding header.
|
|
||||||
|
|
||||||
Currently, libcurl only understands how to process responses that use the
|
|
||||||
"deflate" or "gzip" Content-Encoding, so the only values for
|
|
||||||
CURLOPT_ACCEPT_ENCODING that will work (besides "identity," which does
|
|
||||||
nothing) are "deflate" and "gzip" If a response is encoded using the
|
|
||||||
"compress" or methods, libcurl will return an error indicating that the
|
|
||||||
response could not be decoded. If <string> is NULL no Accept-Encoding header
|
|
||||||
is generated. If <string> is a zero-length string, then an Accept-Encoding
|
|
||||||
header containing all supported encodings will be generated.
|
|
||||||
|
|
||||||
The CURLOPT_ACCEPT_ENCODING must be set to any non-NULL value for content to
|
|
||||||
be automatically decoded. If it is not set and the server still sends encoded
|
|
||||||
content (despite not having been asked), the data is returned in its raw form
|
|
||||||
and the Content-Encoding type is not checked.
|
|
||||||
|
|
||||||
* The curl interface:
|
|
||||||
|
|
||||||
Use the --compressed option with curl to cause it to ask servers to compress
|
|
||||||
responses using any format supported by curl.
|
|
||||||
|
|
||||||
James Gallagher <jgallagher@gso.uri.edu>
|
|
||||||
Dan Fandrich <dan@coneharvesters.com>
|
|
@@ -1,35 +0,0 @@
|
|||||||
hostip.c explained
|
|
||||||
==================
|
|
||||||
|
|
||||||
The main COMPILE-TIME DEFINES to keep in mind when reading the host*.c
|
|
||||||
source file are these:
|
|
||||||
|
|
||||||
CURLRES_IPV6 - this host has getaddrinfo() and family, and thus we use
|
|
||||||
that. The host may not be able to resolve IPv6, but we don't really have to
|
|
||||||
take that into account. Hosts that aren't IPv6-enabled have CURLRES_IPV4
|
|
||||||
defined.
|
|
||||||
|
|
||||||
CURLRES_ARES - is defined if libcurl is built to use c-ares for asynchronous
|
|
||||||
name resolves. This can be Windows or *nix.
|
|
||||||
|
|
||||||
CURLRES_THREADED - is defined if libcurl is built to use threading for
|
|
||||||
asynchronous name resolves. The name resolve will be done in a new thread,
|
|
||||||
and the supported asynch API will be the same as for ares-builds. This is
|
|
||||||
the default under (native) Windows.
|
|
||||||
|
|
||||||
If any of the two previous are defined, CURLRES_ASYNCH is defined too. If
|
|
||||||
libcurl is not built to use an asynchronous resolver, CURLRES_SYNCH is
|
|
||||||
defined.
|
|
||||||
|
|
||||||
The host*.c sources files are split up like this:
|
|
||||||
|
|
||||||
hostip.c - method-independent resolver functions and utility functions
|
|
||||||
hostasyn.c - functions for asynchronous name resolves
|
|
||||||
hostsyn.c - functions for synchronous name resolves
|
|
||||||
asyn-ares.c - functions for asynchronous name resolves using c-ares
|
|
||||||
asyn-thread.c - functions for asynchronous name resolves using threads
|
|
||||||
hostip4.c - IPv4 specific functions
|
|
||||||
hostip6.c - IPv6 specific functions
|
|
||||||
|
|
||||||
The hostip.h is the single united header file for all this. It defines the
|
|
||||||
CURLRES_* defines based on the config*.h and curl_setup.h defines.
|
|
@@ -1,74 +0,0 @@
|
|||||||
|
|
||||||
1. PUT/POST without a known auth to use (possibly no auth required):
|
|
||||||
|
|
||||||
(When explicitly set to use a multi-pass auth when doing a POST/PUT,
|
|
||||||
libcurl should immediately go the Content-Length: 0 bytes route to avoid
|
|
||||||
the first send all data phase, step 2. If told to use a single-pass auth,
|
|
||||||
goto step 3.)
|
|
||||||
|
|
||||||
Issue the proper PUT/POST request immediately, with the correct
|
|
||||||
Content-Length and Expect: headers.
|
|
||||||
|
|
||||||
If a 100 response is received or the wait for one times out, start sending
|
|
||||||
the request-body.
|
|
||||||
|
|
||||||
If a 401 (or 407 when talking through a proxy) is received, then:
|
|
||||||
|
|
||||||
If we have "more than just a little" data left to send, close the
|
|
||||||
connection. Exactly what "more than just a little" means will have to be
|
|
||||||
determined. Possibly the current transfer speed should be taken into
|
|
||||||
account as well.
|
|
||||||
|
|
||||||
NOTE: if the size of the POST data is less than MAX_INITIAL_POST_SIZE (when
|
|
||||||
CURLOPT_POSTFIELDS is used), libcurl will send everything in one single
|
|
||||||
write() (all request-headers and request-body) and thus it will
|
|
||||||
unconditionally send the full post data here.
|
|
||||||
|
|
||||||
2. PUT/POST with multi-pass auth but not yet completely negotiated:
|
|
||||||
|
|
||||||
Send a PUT/POST request, we know that it will be rejected and thus we claim
|
|
||||||
Content-Length zero to avoid having to send the request-body. (This seems
|
|
||||||
to be what IE does.)
|
|
||||||
|
|
||||||
3. PUT/POST as the last step in the auth negotiation, that is when we have
|
|
||||||
what we believe is a completed negotiation:
|
|
||||||
|
|
||||||
Send a full and proper PUT/POST request (again) with the proper
|
|
||||||
Content-Length and a following request-body.
|
|
||||||
|
|
||||||
NOTE: this may very well be the second (or even third) time the whole or at
|
|
||||||
least parts of the request body is sent to the server. Since the data may
|
|
||||||
be provided to libcurl with a callback, we need a way to tell the app that
|
|
||||||
the upload is to be restarted so that the callback will provide data from
|
|
||||||
the start again. This requires an API method/mechanism that libcurl
|
|
||||||
doesn't have today. See below.
|
|
||||||
|
|
||||||
Data Rewind
|
|
||||||
|
|
||||||
It will be troublesome for some apps to deal with a rewind like this in all
|
|
||||||
circumstances. I'm thinking for example when using 'curl' to upload data
|
|
||||||
from stdin. If libcurl ends up having to rewind the reading for a request
|
|
||||||
to succeed, of course a lack of this callback or if it returns failure, will
|
|
||||||
cause the request to fail completely.
|
|
||||||
|
|
||||||
The new callback is set with CURLOPT_IOCTLFUNCTION (in an attempt to add a
|
|
||||||
more generic function that might be used for other IO-related controls in
|
|
||||||
the future):
|
|
||||||
|
|
||||||
curlioerr curl_ioctl(CURL *handle, curliocmd cmd, void *clientp);
|
|
||||||
|
|
||||||
And in the case where the read is to be rewinded, it would be called with a
|
|
||||||
cmd named CURLIOCMD_RESTARTREAD. The callback would then return CURLIOE_OK,
|
|
||||||
if things are fine, or CURLIOE_FAILRESTART if not.
|
|
||||||
|
|
||||||
Backwards Compatibility
|
|
||||||
|
|
||||||
The approach used until now, that issues a HEAD on the given URL to trigger
|
|
||||||
the auth negotiation could still be supported and encouraged, but it would
|
|
||||||
be up to the app to first fetch a URL with GET/HEAD to negotiate on, since
|
|
||||||
then a following PUT/POST wouldn't need to negotiate authentication and
|
|
||||||
thus avoid double-sending data.
|
|
||||||
|
|
||||||
Optionally, we keep the current approach if some option is set
|
|
||||||
(CURLOPT_HEADBEFOREAUTH or similar), since it seems to work fairly well for
|
|
||||||
POST on most servers.
|
|
@@ -1,55 +0,0 @@
|
|||||||
_ _ ____ _
|
|
||||||
___| | | | _ \| |
|
|
||||||
/ __| | | | |_) | |
|
|
||||||
| (__| |_| | _ <| |___
|
|
||||||
\___|\___/|_| \_\_____|
|
|
||||||
|
|
||||||
How To Track Down Suspected Memory Leaks in libcurl
|
|
||||||
===================================================
|
|
||||||
|
|
||||||
Single-threaded
|
|
||||||
|
|
||||||
Please note that this memory leak system is not adjusted to work in more
|
|
||||||
than one thread. If you want/need to use it in a multi-threaded app. Please
|
|
||||||
adjust accordingly.
|
|
||||||
|
|
||||||
|
|
||||||
Build
|
|
||||||
|
|
||||||
Rebuild libcurl with -DCURLDEBUG (usually, rerunning configure with
|
|
||||||
--enable-debug fixes this). 'make clean' first, then 'make' so that all
|
|
||||||
files actually are rebuilt properly. It will also make sense to build
|
|
||||||
libcurl with the debug option (usually -g to the compiler) so that debugging
|
|
||||||
it will be easier if you actually do find a leak in the library.
|
|
||||||
|
|
||||||
This will create a library that has memory debugging enabled.
|
|
||||||
|
|
||||||
Modify Your Application
|
|
||||||
|
|
||||||
Add a line in your application code:
|
|
||||||
|
|
||||||
curl_memdebug("dump");
|
|
||||||
|
|
||||||
This will make the malloc debug system output a full trace of all resource
|
|
||||||
using functions to the given file name. Make sure you rebuild your program
|
|
||||||
and that you link with the same libcurl you built for this purpose as
|
|
||||||
described above.
|
|
||||||
|
|
||||||
Run Your Application
|
|
||||||
|
|
||||||
Run your program as usual. Watch the specified memory trace file grow.
|
|
||||||
|
|
||||||
Make your program exit and use the proper libcurl cleanup functions etc. So
|
|
||||||
that all non-leaks are returned/freed properly.
|
|
||||||
|
|
||||||
Analyze the Flow
|
|
||||||
|
|
||||||
Use the tests/memanalyze.pl perl script to analyze the dump file:
|
|
||||||
|
|
||||||
tests/memanalyze.pl dump
|
|
||||||
|
|
||||||
This now outputs a report on what resources that were allocated but never
|
|
||||||
freed etc. This report is very fine for posting to the list!
|
|
||||||
|
|
||||||
If this doesn't produce any output, no leak was detected in libcurl. Then
|
|
||||||
the leak is mostly likely to be in your code.
|
|
@@ -1,53 +0,0 @@
|
|||||||
Implementation of the curl_multi_socket API
|
|
||||||
|
|
||||||
The main ideas of the new API are simply:
|
|
||||||
|
|
||||||
1 - The application can use whatever event system it likes as it gets info
|
|
||||||
from libcurl about what file descriptors libcurl waits for what action
|
|
||||||
on. (The previous API returns fd_sets which is very select()-centric).
|
|
||||||
|
|
||||||
2 - When the application discovers action on a single socket, it calls
|
|
||||||
libcurl and informs that there was action on this particular socket and
|
|
||||||
libcurl can then act on that socket/transfer only and not care about
|
|
||||||
any other transfers. (The previous API always had to scan through all
|
|
||||||
the existing transfers.)
|
|
||||||
|
|
||||||
The idea is that curl_multi_socket_action() calls a given callback with
|
|
||||||
information about what socket to wait for what action on, and the callback
|
|
||||||
only gets called if the status of that socket has changed.
|
|
||||||
|
|
||||||
We also added a timer callback that makes libcurl call the application when
|
|
||||||
the timeout value changes, and you set that with curl_multi_setopt() and the
|
|
||||||
CURLMOPT_TIMERFUNCTION option. To get this to work, Internally, there's an
|
|
||||||
added a struct to each easy handle in which we store an "expire time" (if
|
|
||||||
any). The structs are then "splay sorted" so that we can add and remove
|
|
||||||
times from the linked list and yet somewhat swiftly figure out both how long
|
|
||||||
time there is until the next nearest timer expires and which timer (handle)
|
|
||||||
we should take care of now. Of course, the upside of all this is that we get
|
|
||||||
a curl_multi_timeout() that should also work with old-style applications
|
|
||||||
that use curl_multi_perform().
|
|
||||||
|
|
||||||
We created an internal "socket to easy handles" hash table that given
|
|
||||||
a socket (file descriptor) return the easy handle that waits for action on
|
|
||||||
that socket. This hash is made using the already existing hash code
|
|
||||||
(previously only used for the DNS cache).
|
|
||||||
|
|
||||||
To make libcurl able to report plain sockets in the socket callback, we had
|
|
||||||
to re-organize the internals of the curl_multi_fdset() etc so that the
|
|
||||||
conversion from sockets to fd_sets for that function is only done in the
|
|
||||||
last step before the data is returned. I also had to extend c-ares to get a
|
|
||||||
function that can return plain sockets, as that library too returned only
|
|
||||||
fd_sets and that is no longer good enough. The changes done to c-ares are
|
|
||||||
available in c-ares 1.3.1 and later.
|
|
||||||
|
|
||||||
We have done a test runs with up to 9000 connections (with a single active
|
|
||||||
one). The curl_multi_socket_action() invoke then takes less than 10
|
|
||||||
microseconds in average (using the read-only-1-byte-at-a-time hack). We are
|
|
||||||
now below the 60 microseconds "per socket action" goal (the extra 50 is the
|
|
||||||
time libevent needs).
|
|
||||||
|
|
||||||
Documentation
|
|
||||||
|
|
||||||
http://curl.haxx.se/libcurl/c/curl_multi_socket_action.html
|
|
||||||
http://curl.haxx.se/libcurl/c/curl_multi_timeout.html
|
|
||||||
http://curl.haxx.se/libcurl/c/curl_multi_setopt.html
|
|
@@ -1274,9 +1274,8 @@ static int cookie_output(struct CookieInfo *c, const char *dumphere)
|
|||||||
"# http://curl.haxx.se/docs/http-cookies.html\n"
|
"# http://curl.haxx.se/docs/http-cookies.html\n"
|
||||||
"# This file was generated by libcurl! Edit at your own risk.\n\n",
|
"# This file was generated by libcurl! Edit at your own risk.\n\n",
|
||||||
out);
|
out);
|
||||||
co = c->cookies;
|
|
||||||
|
|
||||||
while(co) {
|
for(co = c->cookies; co; co = co->next) {
|
||||||
if(!co->domain)
|
if(!co->domain)
|
||||||
continue;
|
continue;
|
||||||
format_ptr = get_netscape_format(co);
|
format_ptr = get_netscape_format(co);
|
||||||
@@ -1288,7 +1287,6 @@ static int cookie_output(struct CookieInfo *c, const char *dumphere)
|
|||||||
}
|
}
|
||||||
fprintf(out, "%s\n", format_ptr);
|
fprintf(out, "%s\n", format_ptr);
|
||||||
free(format_ptr);
|
free(format_ptr);
|
||||||
co=co->next;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1309,9 +1307,7 @@ struct curl_slist *Curl_cookie_list(struct SessionHandle *data)
|
|||||||
(data->cookies->numcookies == 0))
|
(data->cookies->numcookies == 0))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
c = data->cookies->cookies;
|
for(c = data->cookies->cookies; c; c = c->next) {
|
||||||
|
|
||||||
while(c) {
|
|
||||||
if(!c->domain)
|
if(!c->domain)
|
||||||
continue;
|
continue;
|
||||||
line = get_netscape_format(c);
|
line = get_netscape_format(c);
|
||||||
@@ -1326,7 +1322,6 @@ struct curl_slist *Curl_cookie_list(struct SessionHandle *data)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
list = beg;
|
list = beg;
|
||||||
c = c->next;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return list;
|
return list;
|
||||||
|
@@ -1887,7 +1887,7 @@ static CURLcode proxy_magic(struct connectdata *conn,
|
|||||||
memset(&http_proxy, 0, sizeof(http_proxy));
|
memset(&http_proxy, 0, sizeof(http_proxy));
|
||||||
data->req.protop = &http_proxy;
|
data->req.protop = &http_proxy;
|
||||||
|
|
||||||
result = Curl_proxyCONNECT(conn, SECONDARYSOCKET, newhost, newport);
|
result = Curl_proxyCONNECT(conn, SECONDARYSOCKET, newhost, newport, TRUE);
|
||||||
|
|
||||||
data->req.protop = ftp_save;
|
data->req.protop = ftp_save;
|
||||||
|
|
||||||
@@ -3645,7 +3645,7 @@ static CURLcode ftp_do_more(struct connectdata *conn, int *completep)
|
|||||||
if(conn->tunnel_state[SECONDARYSOCKET] == TUNNEL_CONNECT) {
|
if(conn->tunnel_state[SECONDARYSOCKET] == TUNNEL_CONNECT) {
|
||||||
/* As we're in TUNNEL_CONNECT state now, we know the proxy name and port
|
/* As we're in TUNNEL_CONNECT state now, we know the proxy name and port
|
||||||
aren't used so we blank their arguments. TODO: make this nicer */
|
aren't used so we blank their arguments. TODO: make this nicer */
|
||||||
result = Curl_proxyCONNECT(conn, SECONDARYSOCKET, NULL, 0);
|
result = Curl_proxyCONNECT(conn, SECONDARYSOCKET, NULL, 0, FALSE);
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
26
lib/http.c
26
lib/http.c
@@ -427,8 +427,8 @@ static CURLcode http_perhapsrewind(struct connectdata *conn)
|
|||||||
/* figure out how much data we are expected to send */
|
/* figure out how much data we are expected to send */
|
||||||
switch(data->set.httpreq) {
|
switch(data->set.httpreq) {
|
||||||
case HTTPREQ_POST:
|
case HTTPREQ_POST:
|
||||||
if(data->set.postfieldsize != -1)
|
if(data->state.infilesize != -1)
|
||||||
expectsend = data->set.postfieldsize;
|
expectsend = data->state.infilesize;
|
||||||
else if(data->set.postfields)
|
else if(data->set.postfields)
|
||||||
expectsend = (curl_off_t)strlen(data->set.postfields);
|
expectsend = (curl_off_t)strlen(data->set.postfields);
|
||||||
break;
|
break;
|
||||||
@@ -2317,20 +2317,12 @@ CURLcode Curl_http(struct connectdata *conn, bool *done)
|
|||||||
te
|
te
|
||||||
);
|
);
|
||||||
|
|
||||||
/*
|
/* clear userpwd to avoid re-using credentials from re-used connections */
|
||||||
* Free userpwd for Negotiate/NTLM. Cannot reuse as it is associated with
|
Curl_safefree(conn->allocptr.userpwd);
|
||||||
* the connection and shouldn't be repeated over it either.
|
|
||||||
*/
|
|
||||||
switch (data->state.authhost.picked) {
|
|
||||||
case CURLAUTH_NEGOTIATE:
|
|
||||||
case CURLAUTH_NTLM:
|
|
||||||
case CURLAUTH_NTLM_WB:
|
|
||||||
Curl_safefree(conn->allocptr.userpwd);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Same for proxyuserpwd
|
* Free proxyuserpwd for Negotiate/NTLM. Cannot reuse as it is associated
|
||||||
|
* with the connection and shouldn't be repeated over it either.
|
||||||
*/
|
*/
|
||||||
switch (data->state.authproxy.picked) {
|
switch (data->state.authproxy.picked) {
|
||||||
case CURLAUTH_NEGOTIATE:
|
case CURLAUTH_NEGOTIATE:
|
||||||
@@ -2577,8 +2569,8 @@ CURLcode Curl_http(struct connectdata *conn, bool *done)
|
|||||||
postsize = 0;
|
postsize = 0;
|
||||||
else {
|
else {
|
||||||
/* figure out the size of the postfields */
|
/* figure out the size of the postfields */
|
||||||
postsize = (data->set.postfieldsize != -1)?
|
postsize = (data->state.infilesize != -1)?
|
||||||
data->set.postfieldsize:
|
data->state.infilesize:
|
||||||
(data->set.postfields? (curl_off_t)strlen(data->set.postfields):-1);
|
(data->set.postfields? (curl_off_t)strlen(data->set.postfields):-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -2701,7 +2693,7 @@ CURLcode Curl_http(struct connectdata *conn, bool *done)
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
else if(data->set.postfieldsize) {
|
else if(data->state.infilesize) {
|
||||||
/* set the upload size to the progress meter */
|
/* set the upload size to the progress meter */
|
||||||
Curl_pgrsSetUploadSize(data, postsize?postsize:-1);
|
Curl_pgrsSetUploadSize(data, postsize?postsize:-1);
|
||||||
|
|
||||||
|
@@ -68,7 +68,7 @@ CURLcode Curl_proxy_connect(struct connectdata *conn)
|
|||||||
conn->data->req.protop = &http_proxy;
|
conn->data->req.protop = &http_proxy;
|
||||||
connkeep(conn, "HTTP proxy CONNECT");
|
connkeep(conn, "HTTP proxy CONNECT");
|
||||||
result = Curl_proxyCONNECT(conn, FIRSTSOCKET,
|
result = Curl_proxyCONNECT(conn, FIRSTSOCKET,
|
||||||
conn->host.name, conn->remote_port);
|
conn->host.name, conn->remote_port, FALSE);
|
||||||
conn->data->req.protop = prot_save;
|
conn->data->req.protop = prot_save;
|
||||||
if(CURLE_OK != result)
|
if(CURLE_OK != result)
|
||||||
return result;
|
return result;
|
||||||
@@ -85,12 +85,16 @@ CURLcode Curl_proxy_connect(struct connectdata *conn)
|
|||||||
* Curl_proxyCONNECT() requires that we're connected to a HTTP proxy. This
|
* Curl_proxyCONNECT() requires that we're connected to a HTTP proxy. This
|
||||||
* function will issue the necessary commands to get a seamless tunnel through
|
* function will issue the necessary commands to get a seamless tunnel through
|
||||||
* this proxy. After that, the socket can be used just as a normal socket.
|
* this proxy. After that, the socket can be used just as a normal socket.
|
||||||
|
*
|
||||||
|
* 'blocking' set to TRUE means that this function will do the entire CONNECT
|
||||||
|
* + response in a blocking fashion. Should be avoided!
|
||||||
*/
|
*/
|
||||||
|
|
||||||
CURLcode Curl_proxyCONNECT(struct connectdata *conn,
|
CURLcode Curl_proxyCONNECT(struct connectdata *conn,
|
||||||
int sockindex,
|
int sockindex,
|
||||||
const char *hostname,
|
const char *hostname,
|
||||||
int remote_port)
|
int remote_port,
|
||||||
|
bool blocking)
|
||||||
{
|
{
|
||||||
int subversion=0;
|
int subversion=0;
|
||||||
struct SessionHandle *data=conn->data;
|
struct SessionHandle *data=conn->data;
|
||||||
@@ -225,12 +229,14 @@ CURLcode Curl_proxyCONNECT(struct connectdata *conn,
|
|||||||
return CURLE_RECV_ERROR;
|
return CURLE_RECV_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(0 == Curl_socket_ready(tunnelsocket, CURL_SOCKET_BAD, 0))
|
if(!blocking) {
|
||||||
/* return so we'll be called again polling-style */
|
if(0 == Curl_socket_ready(tunnelsocket, CURL_SOCKET_BAD, 0))
|
||||||
return CURLE_OK;
|
/* return so we'll be called again polling-style */
|
||||||
else {
|
return CURLE_OK;
|
||||||
DEBUGF(infof(data,
|
else {
|
||||||
"Read response immediately from proxy CONNECT\n"));
|
DEBUGF(infof(data,
|
||||||
|
"Read response immediately from proxy CONNECT\n"));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* at this point, the tunnel_connecting phase is over. */
|
/* at this point, the tunnel_connecting phase is over. */
|
||||||
|
@@ -7,7 +7,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -26,7 +26,8 @@
|
|||||||
/* ftp can use this as well */
|
/* ftp can use this as well */
|
||||||
CURLcode Curl_proxyCONNECT(struct connectdata *conn,
|
CURLcode Curl_proxyCONNECT(struct connectdata *conn,
|
||||||
int tunnelsocket,
|
int tunnelsocket,
|
||||||
const char *hostname, int remote_port);
|
const char *hostname, int remote_port,
|
||||||
|
bool blocking);
|
||||||
|
|
||||||
/* Default proxy timeout in milliseconds */
|
/* Default proxy timeout in milliseconds */
|
||||||
#define PROXY_TIMEOUT (3600*1000)
|
#define PROXY_TIMEOUT (3600*1000)
|
||||||
@@ -34,7 +35,7 @@ CURLcode Curl_proxyCONNECT(struct connectdata *conn,
|
|||||||
CURLcode Curl_proxy_connect(struct connectdata *conn);
|
CURLcode Curl_proxy_connect(struct connectdata *conn);
|
||||||
|
|
||||||
#else
|
#else
|
||||||
#define Curl_proxyCONNECT(x,y,z,w) CURLE_NOT_BUILT_IN
|
#define Curl_proxyCONNECT(x,y,z,w,v) CURLE_NOT_BUILT_IN
|
||||||
#define Curl_proxy_connect(x) CURLE_OK
|
#define Curl_proxy_connect(x) CURLE_OK
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@@ -400,7 +400,10 @@ CURLMcode curl_multi_add_handle(CURLM *multi_handle,
|
|||||||
/* Point to the multi's connection cache */
|
/* Point to the multi's connection cache */
|
||||||
data->state.conn_cache = &multi->conn_cache;
|
data->state.conn_cache = &multi->conn_cache;
|
||||||
|
|
||||||
data->state.infilesize = data->set.filesize;
|
if(data->set.httpreq == HTTPREQ_PUT)
|
||||||
|
data->state.infilesize = data->set.filesize;
|
||||||
|
else
|
||||||
|
data->state.infilesize = data->set.postfieldsize;
|
||||||
|
|
||||||
/* This adds the new entry at the 'end' of the doubly-linked circular
|
/* This adds the new entry at the 'end' of the doubly-linked circular
|
||||||
list of SessionHandle structs to try and maintain a FIFO queue so
|
list of SessionHandle structs to try and maintain a FIFO queue so
|
||||||
@@ -1529,9 +1532,6 @@ static CURLMcode multi_runsingle(struct Curl_multi *multi,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
DEBUGF(infof(data, "multi_runsingle:%d call Curl_readwrite\n",
|
|
||||||
__LINE__));
|
|
||||||
|
|
||||||
/* read/write data if it is ready to do so */
|
/* read/write data if it is ready to do so */
|
||||||
result = Curl_readwrite(data->easy_conn, data, &done);
|
result = Curl_readwrite(data->easy_conn, data, &done);
|
||||||
|
|
||||||
|
@@ -322,7 +322,7 @@ static CURLcode rtsp_do(struct connectdata *conn, bool *done)
|
|||||||
if(!p_session_id &&
|
if(!p_session_id &&
|
||||||
(rtspreq & ~(RTSPREQ_OPTIONS | RTSPREQ_DESCRIBE | RTSPREQ_SETUP))) {
|
(rtspreq & ~(RTSPREQ_OPTIONS | RTSPREQ_DESCRIBE | RTSPREQ_SETUP))) {
|
||||||
failf(data, "Refusing to issue an RTSP request [%s] without a session ID.",
|
failf(data, "Refusing to issue an RTSP request [%s] without a session ID.",
|
||||||
p_request ? p_request : "");
|
p_request);
|
||||||
return CURLE_BAD_FUNCTION_ARGUMENT;
|
return CURLE_BAD_FUNCTION_ARGUMENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -440,8 +440,7 @@ static CURLcode rtsp_do(struct connectdata *conn, bool *done)
|
|||||||
Curl_add_bufferf(req_buffer,
|
Curl_add_bufferf(req_buffer,
|
||||||
"%s %s RTSP/1.0\r\n" /* Request Stream-URI RTSP/1.0 */
|
"%s %s RTSP/1.0\r\n" /* Request Stream-URI RTSP/1.0 */
|
||||||
"CSeq: %ld\r\n", /* CSeq */
|
"CSeq: %ld\r\n", /* CSeq */
|
||||||
(p_request ? p_request : ""), p_stream_uri,
|
p_request, p_stream_uri, rtsp->CSeq_sent);
|
||||||
rtsp->CSeq_sent);
|
|
||||||
if(result)
|
if(result)
|
||||||
return result;
|
return result;
|
||||||
|
|
||||||
@@ -495,8 +494,8 @@ static CURLcode rtsp_do(struct connectdata *conn, bool *done)
|
|||||||
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
postsize = (data->set.postfieldsize != -1)?
|
postsize = (data->state.infilesize != -1)?
|
||||||
data->set.postfieldsize:
|
data->state.infilesize:
|
||||||
(data->set.postfields? (curl_off_t)strlen(data->set.postfields):0);
|
(data->set.postfields? (curl_off_t)strlen(data->set.postfields):0);
|
||||||
data->set.httpreq = HTTPREQ_POST;
|
data->set.httpreq = HTTPREQ_POST;
|
||||||
}
|
}
|
||||||
|
@@ -480,56 +480,54 @@ static CURLcode choose_mech(struct connectdata *conn)
|
|||||||
void *tmp_allocation;
|
void *tmp_allocation;
|
||||||
const struct Curl_sec_client_mech *mech = &Curl_krb5_client_mech;
|
const struct Curl_sec_client_mech *mech = &Curl_krb5_client_mech;
|
||||||
|
|
||||||
do {
|
tmp_allocation = realloc(conn->app_data, mech->size);
|
||||||
tmp_allocation = realloc(conn->app_data, mech->size);
|
if(tmp_allocation == NULL) {
|
||||||
if(tmp_allocation == NULL) {
|
failf(data, "Failed realloc of size %u", mech->size);
|
||||||
failf(data, "Failed realloc of size %u", mech->size);
|
mech = NULL;
|
||||||
mech = NULL;
|
return CURLE_OUT_OF_MEMORY;
|
||||||
return CURLE_OUT_OF_MEMORY;
|
}
|
||||||
}
|
conn->app_data = tmp_allocation;
|
||||||
conn->app_data = tmp_allocation;
|
|
||||||
|
|
||||||
if(mech->init) {
|
if(mech->init) {
|
||||||
ret = mech->init(conn->app_data);
|
ret = mech->init(conn->app_data);
|
||||||
if(ret) {
|
if(ret) {
|
||||||
infof(data, "Failed initialization for %s. Skipping it.\n",
|
infof(data, "Failed initialization for %s. Skipping it.\n",
|
||||||
mech->name);
|
mech->name);
|
||||||
continue;
|
return CURLE_FAILED_INIT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
infof(data, "Trying mechanism %s...\n", mech->name);
|
||||||
|
ret = ftp_send_command(conn, "AUTH %s", mech->name);
|
||||||
|
if(ret < 0)
|
||||||
|
/* FIXME: This error is too generic but it is OK for now. */
|
||||||
|
return CURLE_COULDNT_CONNECT;
|
||||||
|
|
||||||
|
if(ret/100 != 3) {
|
||||||
|
switch(ret) {
|
||||||
|
case 504:
|
||||||
|
infof(data, "Mechanism %s is not supported by the server (server "
|
||||||
|
"returned ftp code: 504).\n", mech->name);
|
||||||
|
break;
|
||||||
|
case 534:
|
||||||
|
infof(data, "Mechanism %s was rejected by the server (server returned "
|
||||||
|
"ftp code: 534).\n", mech->name);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
if(ret/100 == 5) {
|
||||||
|
infof(data, "server does not support the security extensions\n");
|
||||||
|
return CURLE_USE_SSL_FAILED;
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
return CURLE_LOGIN_DENIED;
|
||||||
|
}
|
||||||
|
|
||||||
infof(data, "Trying mechanism %s...\n", mech->name);
|
/* Authenticate */
|
||||||
ret = ftp_send_command(conn, "AUTH %s", mech->name);
|
ret = mech->auth(conn->app_data, conn);
|
||||||
if(ret < 0)
|
|
||||||
/* FIXME: This error is too generic but it is OK for now. */
|
|
||||||
return CURLE_COULDNT_CONNECT;
|
|
||||||
|
|
||||||
if(ret/100 != 3) {
|
if(ret != AUTH_CONTINUE) {
|
||||||
switch(ret) {
|
if(ret != AUTH_OK) {
|
||||||
case 504:
|
|
||||||
infof(data, "Mechanism %s is not supported by the server (server "
|
|
||||||
"returned ftp code: 504).\n", mech->name);
|
|
||||||
break;
|
|
||||||
case 534:
|
|
||||||
infof(data, "Mechanism %s was rejected by the server (server returned "
|
|
||||||
"ftp code: 534).\n", mech->name);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
if(ret/100 == 5) {
|
|
||||||
infof(data, "server does not support the security extensions\n");
|
|
||||||
return CURLE_USE_SSL_FAILED;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Authenticate */
|
|
||||||
ret = mech->auth(conn->app_data, conn);
|
|
||||||
|
|
||||||
if(ret == AUTH_CONTINUE)
|
|
||||||
continue;
|
|
||||||
else if(ret != AUTH_OK) {
|
|
||||||
/* Mechanism has dumped the error to stderr, don't error here. */
|
/* Mechanism has dumped the error to stderr, don't error here. */
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@@ -545,8 +543,7 @@ static CURLcode choose_mech(struct connectdata *conn)
|
|||||||
/* Set the requested protection level */
|
/* Set the requested protection level */
|
||||||
/* BLOCKING */
|
/* BLOCKING */
|
||||||
(void)sec_set_protection_level(conn);
|
(void)sec_set_protection_level(conn);
|
||||||
|
}
|
||||||
} WHILE_FALSE;
|
|
||||||
|
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
|
12
lib/smb.c
12
lib/smb.c
@@ -783,9 +783,15 @@ static CURLcode smb_request_state(struct connectdata *conn, bool *done)
|
|||||||
off = Curl_read16_le(((unsigned char *) msg) +
|
off = Curl_read16_le(((unsigned char *) msg) +
|
||||||
sizeof(struct smb_header) + 13);
|
sizeof(struct smb_header) + 13);
|
||||||
if(len > 0) {
|
if(len > 0) {
|
||||||
result = Curl_client_write(conn, CLIENTWRITE_BODY,
|
struct smb_conn *smbc = &conn->proto.smbc;
|
||||||
(char *)msg + off + sizeof(unsigned int),
|
if(off + sizeof(unsigned int) + len > smbc->got) {
|
||||||
len);
|
failf(conn->data, "Invalid input packet");
|
||||||
|
result = CURLE_RECV_ERROR;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
result = Curl_client_write(conn, CLIENTWRITE_BODY,
|
||||||
|
(char *)msg + off + sizeof(unsigned int),
|
||||||
|
len);
|
||||||
if(result) {
|
if(result) {
|
||||||
req->result = result;
|
req->result = result;
|
||||||
next_state = SMB_CLOSE;
|
next_state = SMB_CLOSE;
|
||||||
|
@@ -1053,9 +1053,6 @@ CURLcode Curl_readwrite(struct connectdata *conn,
|
|||||||
return CURLE_SEND_ERROR;
|
return CURLE_SEND_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
DEBUGF(infof(data, "Curl_readwrite: keepon: %x select_res %x\n", k->keepon,
|
|
||||||
select_res));
|
|
||||||
|
|
||||||
/* We go ahead and do a read if we have a readable socket or if
|
/* We go ahead and do a read if we have a readable socket or if
|
||||||
the stream was rewound (in which case we have data in a
|
the stream was rewound (in which case we have data in a
|
||||||
buffer) */
|
buffer) */
|
||||||
|
@@ -324,6 +324,9 @@ struct ssl_connect_data {
|
|||||||
size_t encdata_offset, decdata_offset;
|
size_t encdata_offset, decdata_offset;
|
||||||
unsigned char *encdata_buffer, *decdata_buffer;
|
unsigned char *encdata_buffer, *decdata_buffer;
|
||||||
unsigned long req_flags, ret_flags;
|
unsigned long req_flags, ret_flags;
|
||||||
|
CURLcode recv_unrecoverable_err; /* schannel_recv had an unrecoverable err */
|
||||||
|
bool recv_sspi_close_notify; /* true if connection closed by close_notify */
|
||||||
|
bool recv_connection_closed; /* true if connection closed, regardless how */
|
||||||
#endif /* USE_SCHANNEL */
|
#endif /* USE_SCHANNEL */
|
||||||
#ifdef USE_DARWINSSL
|
#ifdef USE_DARWINSSL
|
||||||
SSLContextRef ssl_ctx;
|
SSLContextRef ssl_ctx;
|
||||||
|
@@ -136,6 +136,11 @@
|
|||||||
#define CONF_modules_load_file(a,b,c)
|
#define CONF_modules_load_file(a,b,c)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef OPENSSL_IS_BORINGSSL
|
||||||
|
/* not present in BoringSSL */
|
||||||
|
#define OPENSSL_load_builtin_modules(x)
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Number of bytes to read from the random number seed file. This must be
|
* Number of bytes to read from the random number seed file. This must be
|
||||||
* a finite value (because some entropy "files" like /dev/urandom have
|
* a finite value (because some entropy "files" like /dev/urandom have
|
||||||
@@ -1427,8 +1432,10 @@ static const char *ssl_msg_type(int ssl_ver, int msg)
|
|||||||
return "Client hello";
|
return "Client hello";
|
||||||
case SSL3_MT_SERVER_HELLO:
|
case SSL3_MT_SERVER_HELLO:
|
||||||
return "Server hello";
|
return "Server hello";
|
||||||
|
#ifdef SSL3_MT_NEWSESSION_TICKET
|
||||||
case SSL3_MT_NEWSESSION_TICKET:
|
case SSL3_MT_NEWSESSION_TICKET:
|
||||||
return "Newsession Ticket";
|
return "Newsession Ticket";
|
||||||
|
#endif
|
||||||
case SSL3_MT_CERTIFICATE:
|
case SSL3_MT_CERTIFICATE:
|
||||||
return "Certificate";
|
return "Certificate";
|
||||||
case SSL3_MT_SERVER_KEY_EXCHANGE:
|
case SSL3_MT_SERVER_KEY_EXCHANGE:
|
||||||
@@ -2130,10 +2137,9 @@ static CURLcode ossl_connect_step2(struct connectdata *conn, int sockindex)
|
|||||||
else {
|
else {
|
||||||
/* untreated error */
|
/* untreated error */
|
||||||
unsigned long errdetail;
|
unsigned long errdetail;
|
||||||
char error_buffer[256]; /* OpenSSL documents that this must be at least
|
char error_buffer[256]=""; /* OpenSSL documents that this must be at
|
||||||
256 bytes long. */
|
least 256 bytes long. */
|
||||||
CURLcode result;
|
CURLcode result;
|
||||||
const char *cert_problem = NULL;
|
|
||||||
long lerr;
|
long lerr;
|
||||||
|
|
||||||
connssl->connecting_state = ssl_connect_2; /* the connection failed,
|
connssl->connecting_state = ssl_connect_2; /* the connection failed,
|
||||||
@@ -2165,9 +2171,10 @@ static CURLcode ossl_connect_step2(struct connectdata *conn, int sockindex)
|
|||||||
X509_verify_cert_error_string(lerr));
|
X509_verify_cert_error_string(lerr));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
cert_problem = "SSL certificate problem, verify that the CA cert is"
|
/* strcpy() is fine here as long as the string fits within
|
||||||
" OK.";
|
error_buffer */
|
||||||
|
strcpy(error_buffer,
|
||||||
|
"SSL certificate problem, check your CA cert");
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
result = CURLE_SSL_CONNECT_ERROR;
|
result = CURLE_SSL_CONNECT_ERROR;
|
||||||
@@ -2188,7 +2195,7 @@ static CURLcode ossl_connect_step2(struct connectdata *conn, int sockindex)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Could be a CERT problem */
|
/* Could be a CERT problem */
|
||||||
failf(data, "%s%s", cert_problem ? cert_problem : "", error_buffer);
|
failf(data, "%s", error_buffer);
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@@ -268,6 +268,10 @@ schannel_connect_step1(struct connectdata *conn, int sockindex)
|
|||||||
infof(data, "schannel: sent initial handshake data: "
|
infof(data, "schannel: sent initial handshake data: "
|
||||||
"sent %zd bytes\n", written);
|
"sent %zd bytes\n", written);
|
||||||
|
|
||||||
|
connssl->recv_unrecoverable_err = CURLE_OK;
|
||||||
|
connssl->recv_sspi_close_notify = false;
|
||||||
|
connssl->recv_connection_closed = false;
|
||||||
|
|
||||||
/* continue to second handshake step */
|
/* continue to second handshake step */
|
||||||
connssl->connecting_state = ssl_connect_2;
|
connssl->connecting_state = ssl_connect_2;
|
||||||
|
|
||||||
@@ -300,6 +304,17 @@ schannel_connect_step2(struct connectdata *conn, int sockindex)
|
|||||||
if(!connssl->cred || !connssl->ctxt)
|
if(!connssl->cred || !connssl->ctxt)
|
||||||
return CURLE_SSL_CONNECT_ERROR;
|
return CURLE_SSL_CONNECT_ERROR;
|
||||||
|
|
||||||
|
/* buffer to store previously received and decrypted data */
|
||||||
|
if(connssl->decdata_buffer == NULL) {
|
||||||
|
connssl->decdata_offset = 0;
|
||||||
|
connssl->decdata_length = CURL_SCHANNEL_BUFFER_INIT_SIZE;
|
||||||
|
connssl->decdata_buffer = malloc(connssl->decdata_length);
|
||||||
|
if(connssl->decdata_buffer == NULL) {
|
||||||
|
failf(data, "schannel: unable to allocate memory");
|
||||||
|
return CURLE_OUT_OF_MEMORY;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* buffer to store previously received and encrypted data */
|
/* buffer to store previously received and encrypted data */
|
||||||
if(connssl->encdata_buffer == NULL) {
|
if(connssl->encdata_buffer == NULL) {
|
||||||
connssl->encdata_offset = 0;
|
connssl->encdata_offset = 0;
|
||||||
@@ -403,6 +418,17 @@ schannel_connect_step2(struct connectdata *conn, int sockindex)
|
|||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* If the server has requested a client certificate, attempt to continue
|
||||||
|
the handshake without one. This will allow connections to servers which
|
||||||
|
request a client certificate but do not require it. */
|
||||||
|
if(sspi_status == SEC_I_INCOMPLETE_CREDENTIALS &&
|
||||||
|
!(connssl->req_flags & ISC_REQ_USE_SUPPLIED_CREDS)) {
|
||||||
|
connssl->req_flags |= ISC_REQ_USE_SUPPLIED_CREDS;
|
||||||
|
connssl->connecting_state = ssl_connect_2_writing;
|
||||||
|
infof(data, "schannel: a client certificate has been requested\n");
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
/* check if the handshake needs to be continued */
|
/* check if the handshake needs to be continued */
|
||||||
if(sspi_status == SEC_I_CONTINUE_NEEDED || sspi_status == SEC_E_OK) {
|
if(sspi_status == SEC_I_CONTINUE_NEEDED || sspi_status == SEC_E_OK) {
|
||||||
for(i = 0; i < 3; i++) {
|
for(i = 0; i < 3; i++) {
|
||||||
@@ -823,8 +849,7 @@ schannel_recv(struct connectdata *conn, int sockindex,
|
|||||||
char *buf, size_t len, CURLcode *err)
|
char *buf, size_t len, CURLcode *err)
|
||||||
{
|
{
|
||||||
size_t size = 0;
|
size_t size = 0;
|
||||||
ssize_t nread = 0;
|
ssize_t nread = -1;
|
||||||
CURLcode result;
|
|
||||||
struct SessionHandle *data = conn->data;
|
struct SessionHandle *data = conn->data;
|
||||||
struct ssl_connect_data *connssl = &conn->ssl[sockindex];
|
struct ssl_connect_data *connssl = &conn->ssl[sockindex];
|
||||||
unsigned char *reallocated_buffer;
|
unsigned char *reallocated_buffer;
|
||||||
@@ -833,72 +858,103 @@ schannel_recv(struct connectdata *conn, int sockindex,
|
|||||||
SecBuffer inbuf[4];
|
SecBuffer inbuf[4];
|
||||||
SecBufferDesc inbuf_desc;
|
SecBufferDesc inbuf_desc;
|
||||||
SECURITY_STATUS sspi_status = SEC_E_OK;
|
SECURITY_STATUS sspi_status = SEC_E_OK;
|
||||||
|
/* we want the length of the encrypted buffer to be at least large enough
|
||||||
|
that it can hold all the bytes requested and some TLS record overhead. */
|
||||||
|
size_t min_encdata_length = len + CURL_SCHANNEL_BUFFER_FREE_SIZE;
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Don't return or set connssl->recv_unrecoverable_err unless in the cleanup.
|
||||||
|
* The pattern for return error is set *err, optional infof, goto cleanup.
|
||||||
|
*
|
||||||
|
* Our priority is to always return as much decrypted data to the caller as
|
||||||
|
* possible, even if an error occurs. The state of the decrypted buffer must
|
||||||
|
* always be valid. Transfer of decrypted data to the caller's buffer is
|
||||||
|
* handled in the cleanup.
|
||||||
|
*/
|
||||||
|
|
||||||
infof(data, "schannel: client wants to read %zu bytes\n", len);
|
infof(data, "schannel: client wants to read %zu bytes\n", len);
|
||||||
*err = CURLE_OK;
|
*err = CURLE_OK;
|
||||||
|
|
||||||
/* buffer to store previously received and decrypted data */
|
if(len && len <= connssl->decdata_offset) {
|
||||||
if(connssl->decdata_buffer == NULL) {
|
infof(data, "schannel: enough decrypted data is already available\n");
|
||||||
connssl->decdata_offset = 0;
|
goto cleanup;
|
||||||
connssl->decdata_length = CURL_SCHANNEL_BUFFER_INIT_SIZE;
|
|
||||||
connssl->decdata_buffer = malloc(connssl->decdata_length);
|
|
||||||
if(connssl->decdata_buffer == NULL) {
|
|
||||||
failf(data, "schannel: unable to allocate memory");
|
|
||||||
*err = CURLE_OUT_OF_MEMORY;
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
else if(connssl->recv_unrecoverable_err) {
|
||||||
|
*err = connssl->recv_unrecoverable_err;
|
||||||
|
infof(data, "schannel: an unrecoverable error occurred in a prior call\n");
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
else if(connssl->recv_sspi_close_notify) {
|
||||||
|
/* once a server has indicated shutdown there is no more encrypted data */
|
||||||
|
infof(data, "schannel: server indicated shutdown in a prior call\n");
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
else if(!len) {
|
||||||
|
/* It's debatable what to return when !len. Regardless we can't return
|
||||||
|
immediately because there may be data to decrypt (in the case we want to
|
||||||
|
decrypt all encrypted cached data) so handle !len later in cleanup.
|
||||||
|
*/
|
||||||
|
; /* do nothing */
|
||||||
|
}
|
||||||
|
else if(!connssl->recv_connection_closed) {
|
||||||
|
/* increase enc buffer in order to fit the requested amount of data */
|
||||||
|
size = connssl->encdata_length - connssl->encdata_offset;
|
||||||
|
if(size < CURL_SCHANNEL_BUFFER_FREE_SIZE ||
|
||||||
|
connssl->encdata_length < min_encdata_length) {
|
||||||
|
reallocated_length = connssl->encdata_offset +
|
||||||
|
CURL_SCHANNEL_BUFFER_FREE_SIZE;
|
||||||
|
if(reallocated_length < min_encdata_length) {
|
||||||
|
reallocated_length = min_encdata_length;
|
||||||
|
}
|
||||||
|
reallocated_buffer = realloc(connssl->encdata_buffer,
|
||||||
|
reallocated_length);
|
||||||
|
if(reallocated_buffer == NULL) {
|
||||||
|
*err = CURLE_OUT_OF_MEMORY;
|
||||||
|
failf(data, "schannel: unable to re-allocate memory");
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
|
||||||
/* increase buffer in order to fit the requested amount of data */
|
|
||||||
if(connssl->encdata_length - connssl->encdata_offset <
|
|
||||||
CURL_SCHANNEL_BUFFER_FREE_SIZE || connssl->encdata_length < len) {
|
|
||||||
/* increase internal encrypted data buffer */
|
|
||||||
reallocated_length = connssl->encdata_offset +
|
|
||||||
CURL_SCHANNEL_BUFFER_FREE_SIZE;
|
|
||||||
/* make sure that the requested amount of data fits */
|
|
||||||
if(reallocated_length < len) {
|
|
||||||
reallocated_length = len;
|
|
||||||
}
|
|
||||||
reallocated_buffer = realloc(connssl->encdata_buffer,
|
|
||||||
reallocated_length);
|
|
||||||
|
|
||||||
if(reallocated_buffer == NULL) {
|
|
||||||
failf(data, "schannel: unable to re-allocate memory");
|
|
||||||
*err = CURLE_OUT_OF_MEMORY;
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
connssl->encdata_buffer = reallocated_buffer;
|
connssl->encdata_buffer = reallocated_buffer;
|
||||||
connssl->encdata_length = reallocated_length;
|
connssl->encdata_length = reallocated_length;
|
||||||
|
size = connssl->encdata_length - connssl->encdata_offset;
|
||||||
|
infof(data, "schannel: encdata_buffer resized %zu\n",
|
||||||
|
connssl->encdata_length);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/* read encrypted data from socket */
|
infof(data, "schannel: encrypted data buffer: offset %zu length %zu\n",
|
||||||
infof(data, "schannel: encrypted data buffer: offset %zu length %zu\n",
|
connssl->encdata_offset, connssl->encdata_length);
|
||||||
connssl->encdata_offset, connssl->encdata_length);
|
|
||||||
size = connssl->encdata_length - connssl->encdata_offset;
|
/* read encrypted data from socket */
|
||||||
if(size > 0) {
|
|
||||||
*err = Curl_read_plain(conn->sock[sockindex],
|
*err = Curl_read_plain(conn->sock[sockindex],
|
||||||
(char *) (connssl->encdata_buffer +
|
(char *)(connssl->encdata_buffer +
|
||||||
connssl->encdata_offset),
|
connssl->encdata_offset),
|
||||||
size, &nread);
|
size, &nread);
|
||||||
/* check for received data */
|
if(*err) {
|
||||||
if(*err != CURLE_OK) {
|
nread = -1;
|
||||||
return -1;
|
if(*err == CURLE_AGAIN)
|
||||||
|
infof(data, "schannel: Curl_read_plain returned CURLE_AGAIN\n");
|
||||||
|
else if(*err == CURLE_RECV_ERROR)
|
||||||
|
infof(data, "schannel: Curl_read_plain returned CURLE_RECV_ERROR\n");
|
||||||
|
else
|
||||||
|
infof(data, "schannel: Curl_read_plain returned error %d\n", *err);
|
||||||
|
}
|
||||||
|
else if(nread == 0) {
|
||||||
|
connssl->recv_connection_closed = true;
|
||||||
|
infof(data, "schannel: server closed the connection\n");
|
||||||
}
|
}
|
||||||
else if(nread > 0) {
|
else if(nread > 0) {
|
||||||
/* increase encrypted data buffer offset */
|
connssl->encdata_offset += (size_t)nread;
|
||||||
connssl->encdata_offset += nread;
|
infof(data, "schannel: encrypted data got %zd\n", nread);
|
||||||
}
|
}
|
||||||
infof(data, "schannel: encrypted data got %zd\n", nread);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
infof(data, "schannel: encrypted data buffer: offset %zu length %zu\n",
|
infof(data, "schannel: encrypted data buffer: offset %zu length %zu\n",
|
||||||
connssl->encdata_offset, connssl->encdata_length);
|
connssl->encdata_offset, connssl->encdata_length);
|
||||||
|
|
||||||
/* check if we still have some data in our buffers */
|
/* decrypt loop */
|
||||||
while(connssl->encdata_offset > 0 && sspi_status == SEC_E_OK &&
|
while(connssl->encdata_offset > 0 && sspi_status == SEC_E_OK &&
|
||||||
connssl->decdata_offset < len) {
|
(!len || connssl->decdata_offset < len ||
|
||||||
|
connssl->recv_connection_closed)) {
|
||||||
/* prepare data buffer for DecryptMessage call */
|
/* prepare data buffer for DecryptMessage call */
|
||||||
InitSecBuffer(&inbuf[0], SECBUFFER_DATA, connssl->encdata_buffer,
|
InitSecBuffer(&inbuf[0], SECBUFFER_DATA, connssl->encdata_buffer,
|
||||||
curlx_uztoul(connssl->encdata_offset));
|
curlx_uztoul(connssl->encdata_offset));
|
||||||
@@ -913,13 +969,6 @@ schannel_recv(struct connectdata *conn, int sockindex,
|
|||||||
sspi_status = s_pSecFn->DecryptMessage(&connssl->ctxt->ctxt_handle,
|
sspi_status = s_pSecFn->DecryptMessage(&connssl->ctxt->ctxt_handle,
|
||||||
&inbuf_desc, 0, NULL);
|
&inbuf_desc, 0, NULL);
|
||||||
|
|
||||||
/* check if we need more data */
|
|
||||||
if(sspi_status == SEC_E_INCOMPLETE_MESSAGE) {
|
|
||||||
infof(data, "schannel: failed to decrypt data, need more data\n");
|
|
||||||
*err = CURLE_AGAIN;
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* check if everything went fine (server may want to renegotiate
|
/* check if everything went fine (server may want to renegotiate
|
||||||
or shutdown the connection context) */
|
or shutdown the connection context) */
|
||||||
if(sspi_status == SEC_E_OK || sspi_status == SEC_I_RENEGOTIATE ||
|
if(sspi_status == SEC_E_OK || sspi_status == SEC_I_RENEGOTIATE ||
|
||||||
@@ -932,7 +981,7 @@ schannel_recv(struct connectdata *conn, int sockindex,
|
|||||||
|
|
||||||
/* increase buffer in order to fit the received amount of data */
|
/* increase buffer in order to fit the received amount of data */
|
||||||
size = inbuf[1].cbBuffer > CURL_SCHANNEL_BUFFER_FREE_SIZE ?
|
size = inbuf[1].cbBuffer > CURL_SCHANNEL_BUFFER_FREE_SIZE ?
|
||||||
inbuf[1].cbBuffer : CURL_SCHANNEL_BUFFER_FREE_SIZE;
|
inbuf[1].cbBuffer : CURL_SCHANNEL_BUFFER_FREE_SIZE;
|
||||||
if(connssl->decdata_length - connssl->decdata_offset < size ||
|
if(connssl->decdata_length - connssl->decdata_offset < size ||
|
||||||
connssl->decdata_length < len) {
|
connssl->decdata_length < len) {
|
||||||
/* increase internal decrypted data buffer */
|
/* increase internal decrypted data buffer */
|
||||||
@@ -943,21 +992,18 @@ schannel_recv(struct connectdata *conn, int sockindex,
|
|||||||
}
|
}
|
||||||
reallocated_buffer = realloc(connssl->decdata_buffer,
|
reallocated_buffer = realloc(connssl->decdata_buffer,
|
||||||
reallocated_length);
|
reallocated_length);
|
||||||
|
|
||||||
if(reallocated_buffer == NULL) {
|
if(reallocated_buffer == NULL) {
|
||||||
failf(data, "schannel: unable to re-allocate memory");
|
|
||||||
*err = CURLE_OUT_OF_MEMORY;
|
*err = CURLE_OUT_OF_MEMORY;
|
||||||
return -1;
|
failf(data, "schannel: unable to re-allocate memory");
|
||||||
}
|
goto cleanup;
|
||||||
else {
|
|
||||||
connssl->decdata_buffer = reallocated_buffer;
|
|
||||||
connssl->decdata_length = reallocated_length;
|
|
||||||
}
|
}
|
||||||
|
connssl->decdata_buffer = reallocated_buffer;
|
||||||
|
connssl->decdata_length = reallocated_length;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* copy decrypted data to internal buffer */
|
/* copy decrypted data to internal buffer */
|
||||||
size = inbuf[1].cbBuffer;
|
size = inbuf[1].cbBuffer;
|
||||||
if(size > 0) {
|
if(size) {
|
||||||
memcpy(connssl->decdata_buffer + connssl->decdata_offset,
|
memcpy(connssl->decdata_buffer + connssl->decdata_offset,
|
||||||
inbuf[1].pvBuffer, size);
|
inbuf[1].pvBuffer, size);
|
||||||
connssl->decdata_offset += size;
|
connssl->decdata_offset += size;
|
||||||
@@ -996,56 +1042,117 @@ schannel_recv(struct connectdata *conn, int sockindex,
|
|||||||
/* check if server wants to renegotiate the connection context */
|
/* check if server wants to renegotiate the connection context */
|
||||||
if(sspi_status == SEC_I_RENEGOTIATE) {
|
if(sspi_status == SEC_I_RENEGOTIATE) {
|
||||||
infof(data, "schannel: remote party requests renegotiation\n");
|
infof(data, "schannel: remote party requests renegotiation\n");
|
||||||
|
if(*err && *err != CURLE_AGAIN) {
|
||||||
|
infof(data, "schannel: can't renogotiate, an error is pending\n");
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
if(connssl->encdata_offset) {
|
||||||
|
*err = CURLE_RECV_ERROR;
|
||||||
|
infof(data, "schannel: can't renogotiate, "
|
||||||
|
"encrypted data available\n");
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
/* begin renegotiation */
|
/* begin renegotiation */
|
||||||
infof(data, "schannel: renegotiating SSL/TLS connection\n");
|
infof(data, "schannel: renegotiating SSL/TLS connection\n");
|
||||||
connssl->state = ssl_connection_negotiating;
|
connssl->state = ssl_connection_negotiating;
|
||||||
connssl->connecting_state = ssl_connect_2_writing;
|
connssl->connecting_state = ssl_connect_2_writing;
|
||||||
result = schannel_connect_common(conn, sockindex, FALSE, &done);
|
*err = schannel_connect_common(conn, sockindex, FALSE, &done);
|
||||||
if(result)
|
if(*err) {
|
||||||
*err = result;
|
infof(data, "schannel: renegotiation failed\n");
|
||||||
else {
|
goto cleanup;
|
||||||
infof(data, "schannel: SSL/TLS connection renegotiated\n");
|
|
||||||
/* now retry receiving data */
|
|
||||||
return schannel_recv(conn, sockindex, buf, len, err);
|
|
||||||
}
|
}
|
||||||
|
/* now retry receiving data */
|
||||||
|
sspi_status = SEC_E_OK;
|
||||||
|
infof(data, "schannel: SSL/TLS connection renegotiated\n");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
/* check if the server closed the connection */
|
||||||
|
else if(sspi_status == SEC_I_CONTEXT_EXPIRED) {
|
||||||
|
/* In Windows 2000 SEC_I_CONTEXT_EXPIRED (close_notify) is not
|
||||||
|
returned so we have to work around that in cleanup. */
|
||||||
|
connssl->recv_sspi_close_notify = true;
|
||||||
|
if(!connssl->recv_connection_closed) {
|
||||||
|
connssl->recv_connection_closed = true;
|
||||||
|
infof(data, "schannel: server closed the connection\n");
|
||||||
|
}
|
||||||
|
goto cleanup;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if(sspi_status == SEC_E_INCOMPLETE_MESSAGE) {
|
||||||
|
if(!*err)
|
||||||
|
*err = CURLE_AGAIN;
|
||||||
|
infof(data, "schannel: failed to decrypt data, need more data\n");
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
else {
|
else {
|
||||||
/* something went wrong and we need to return an error */
|
*err = CURLE_RECV_ERROR;
|
||||||
infof(data, "schannel: failed to read data from server: %s\n",
|
infof(data, "schannel: failed to read data from server: %s\n",
|
||||||
Curl_sspi_strerror(conn, sspi_status));
|
Curl_sspi_strerror(conn, sspi_status));
|
||||||
*err = CURLE_RECV_ERROR;
|
goto cleanup;
|
||||||
return -1;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
infof(data, "schannel: encrypted data buffer: offset %zu length %zu\n",
|
||||||
|
connssl->encdata_offset, connssl->encdata_length);
|
||||||
|
|
||||||
infof(data, "schannel: decrypted data buffer: offset %zu length %zu\n",
|
infof(data, "schannel: decrypted data buffer: offset %zu length %zu\n",
|
||||||
connssl->decdata_offset, connssl->decdata_length);
|
connssl->decdata_offset, connssl->decdata_length);
|
||||||
|
|
||||||
/* copy requested decrypted data to supplied buffer */
|
cleanup:
|
||||||
size = len < connssl->decdata_offset ? len : connssl->decdata_offset;
|
/* Warning- there is no guarantee the encdata state is valid at this point */
|
||||||
if(size > 0) {
|
infof(data, "schannel: schannel_recv cleanup\n");
|
||||||
memcpy(buf, connssl->decdata_buffer, size);
|
|
||||||
|
|
||||||
/* move remaining decrypted data forward to the beginning of buffer */
|
/* Error if the connection has closed without a close_notify.
|
||||||
|
Behavior here is a matter of debate. We don't want to be vulnerable to a
|
||||||
|
truncation attack however there's some browser precedent for ignoring the
|
||||||
|
close_notify for compatibility reasons.
|
||||||
|
Additionally, Windows 2000 (v5.0) is a special case since it seems it doesn't
|
||||||
|
return close_notify. In that case if the connection was closed we assume it
|
||||||
|
was graceful (close_notify) since there doesn't seem to be a way to tell.
|
||||||
|
*/
|
||||||
|
if(len && !connssl->decdata_offset && connssl->recv_connection_closed &&
|
||||||
|
!connssl->recv_sspi_close_notify) {
|
||||||
|
DWORD winver_full, winver_major, winver_minor;
|
||||||
|
winver_full = GetVersion();
|
||||||
|
winver_major = (DWORD)(LOBYTE(LOWORD(winver_full)));
|
||||||
|
winver_minor = (DWORD)(HIBYTE(LOWORD(winver_full)));
|
||||||
|
|
||||||
|
if(winver_major == 5 && winver_minor == 0 && sspi_status == SEC_E_OK)
|
||||||
|
connssl->recv_sspi_close_notify = true;
|
||||||
|
else {
|
||||||
|
*err = CURLE_RECV_ERROR;
|
||||||
|
infof(data, "schannel: server closed abruptly (missing close_notify)\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Any error other than CURLE_AGAIN is an unrecoverable error. */
|
||||||
|
if(*err && *err != CURLE_AGAIN)
|
||||||
|
connssl->recv_unrecoverable_err = *err;
|
||||||
|
|
||||||
|
size = len < connssl->decdata_offset ? len : connssl->decdata_offset;
|
||||||
|
if(size) {
|
||||||
|
memcpy(buf, connssl->decdata_buffer, size);
|
||||||
memmove(connssl->decdata_buffer, connssl->decdata_buffer + size,
|
memmove(connssl->decdata_buffer, connssl->decdata_buffer + size,
|
||||||
connssl->decdata_offset - size);
|
connssl->decdata_offset - size);
|
||||||
connssl->decdata_offset -= size;
|
connssl->decdata_offset -= size;
|
||||||
|
|
||||||
infof(data, "schannel: decrypted data returned %zd\n", size);
|
infof(data, "schannel: decrypted data returned %zu\n", size);
|
||||||
infof(data, "schannel: decrypted data buffer: offset %zu length %zu\n",
|
infof(data, "schannel: decrypted data buffer: offset %zu length %zu\n",
|
||||||
connssl->decdata_offset, connssl->decdata_length);
|
connssl->decdata_offset, connssl->decdata_length);
|
||||||
}
|
|
||||||
/* check if the server closed the connection, */
|
|
||||||
/* including special check for Windows 2000 Professional */
|
|
||||||
else if(sspi_status == SEC_I_CONTEXT_EXPIRED || (sspi_status == SEC_E_OK &&
|
|
||||||
connssl->encdata_offset && connssl->encdata_buffer[0] == 0x15)) {
|
|
||||||
infof(data, "schannel: server closed the connection\n");
|
|
||||||
*err = CURLE_OK;
|
*err = CURLE_OK;
|
||||||
|
return (ssize_t)size;
|
||||||
}
|
}
|
||||||
|
|
||||||
return size;
|
if(!*err && !connssl->recv_connection_closed)
|
||||||
|
*err = CURLE_AGAIN;
|
||||||
|
|
||||||
|
/* It's debatable what to return when !len. We could return whatever error we
|
||||||
|
got from decryption but instead we override here so the return is consistent.
|
||||||
|
*/
|
||||||
|
if(!len)
|
||||||
|
*err = CURLE_OK;
|
||||||
|
|
||||||
|
return *err ? -1 : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
CURLcode
|
CURLcode
|
||||||
|
@@ -72,6 +72,7 @@
|
|||||||
#define SECBUFFER_ALERT 17
|
#define SECBUFFER_ALERT 17
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* Both schannel buffer sizes must be > 0 */
|
||||||
#define CURL_SCHANNEL_BUFFER_INIT_SIZE 4096
|
#define CURL_SCHANNEL_BUFFER_INIT_SIZE 4096
|
||||||
#define CURL_SCHANNEL_BUFFER_FREE_SIZE 1024
|
#define CURL_SCHANNEL_BUFFER_FREE_SIZE 1024
|
||||||
|
|
||||||
|
@@ -67,6 +67,7 @@ AC_DEFUN([CURL_CHECK_OPENSSL_API_HEADERS], [
|
|||||||
esac
|
esac
|
||||||
case $tst_api in
|
case $tst_api in
|
||||||
0x110) tst_show="1.1.0" ;;
|
0x110) tst_show="1.1.0" ;;
|
||||||
|
0x102) tst_show="1.0.2" ;;
|
||||||
0x101) tst_show="1.0.1" ;;
|
0x101) tst_show="1.0.1" ;;
|
||||||
0x100) tst_show="1.0.0" ;;
|
0x100) tst_show="1.0.0" ;;
|
||||||
0x099) tst_show="0.9.9" ;;
|
0x099) tst_show="0.9.9" ;;
|
||||||
@@ -138,6 +139,13 @@ AC_DEFUN([CURL_CHECK_OPENSSL_API_LIBRARY], [
|
|||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
fi
|
fi
|
||||||
|
if test "$tst_api" = "unknown"; then
|
||||||
|
AC_LINK_IFELSE([
|
||||||
|
AC_LANG_FUNC_LINK_TRY([SSL_CONF_CTX_new])
|
||||||
|
],[
|
||||||
|
tst_api="0x102"
|
||||||
|
])
|
||||||
|
fi
|
||||||
if test "$tst_api" = "unknown"; then
|
if test "$tst_api" = "unknown"; then
|
||||||
AC_LINK_IFELSE([
|
AC_LINK_IFELSE([
|
||||||
AC_LANG_FUNC_LINK_TRY([SSL_renegotiate_abbreviated])
|
AC_LANG_FUNC_LINK_TRY([SSL_renegotiate_abbreviated])
|
||||||
@@ -210,6 +218,7 @@ AC_DEFUN([CURL_CHECK_OPENSSL_API_LIBRARY], [
|
|||||||
fi
|
fi
|
||||||
case $tst_api in
|
case $tst_api in
|
||||||
0x110) tst_show="1.1.0" ;;
|
0x110) tst_show="1.1.0" ;;
|
||||||
|
0x102) tst_show="1.0.2" ;;
|
||||||
0x101) tst_show="1.0.1" ;;
|
0x101) tst_show="1.0.1" ;;
|
||||||
0x100) tst_show="1.0.0" ;;
|
0x100) tst_show="1.0.0" ;;
|
||||||
0x099) tst_show="0.9.9" ;;
|
0x099) tst_show="0.9.9" ;;
|
||||||
|
@@ -110,6 +110,15 @@ Notes
|
|||||||
stored in the git repositoty) will need to be modified rather than the
|
stored in the git repositoty) will need to be modified rather than the
|
||||||
generated project files that Visual Studio uses.
|
generated project files that Visual Studio uses.
|
||||||
|
|
||||||
|
Legacy Windows and SSL
|
||||||
|
======================
|
||||||
|
Some of the project configurations use as an SSL backend WinSSL (Windows SSPI,
|
||||||
|
more specifically Schannel), the native SSL library that comes with the Windows
|
||||||
|
OS. WinSSL in Windows <= XP is not able to connect to servers that no longer
|
||||||
|
support the legacy handshakes and algorithms used by those versions. If you
|
||||||
|
will be using curl in one of those earlier versions of Windows you should
|
||||||
|
choose another SSL backend like OpenSSL.
|
||||||
|
|
||||||
TODO
|
TODO
|
||||||
====
|
====
|
||||||
|
|
||||||
|
@@ -158,12 +158,10 @@ static const struct LongShort aliases[]= {
|
|||||||
{"$3", "keepalive-time", TRUE},
|
{"$3", "keepalive-time", TRUE},
|
||||||
{"$4", "post302", FALSE},
|
{"$4", "post302", FALSE},
|
||||||
{"$5", "noproxy", TRUE},
|
{"$5", "noproxy", TRUE},
|
||||||
#if defined(HAVE_GSSAPI) || defined(USE_WINDOWS_SSPI)
|
|
||||||
{"$6", "socks5-gssapi-service", TRUE},
|
{"$6", "socks5-gssapi-service", TRUE},
|
||||||
{"$7", "socks5-gssapi-nec", FALSE},
|
{"$7", "socks5-gssapi-nec", FALSE},
|
||||||
{"$O", "proxy-service-name", TRUE},
|
{"$O", "proxy-service-name", TRUE},
|
||||||
{"$P", "service-name", TRUE},
|
{"$P", "service-name", TRUE},
|
||||||
#endif
|
|
||||||
{"$8", "proxy1.0", TRUE},
|
{"$8", "proxy1.0", TRUE},
|
||||||
{"$9", "tftp-blksize", TRUE},
|
{"$9", "tftp-blksize", TRUE},
|
||||||
{"$A", "mail-from", TRUE},
|
{"$A", "mail-from", TRUE},
|
||||||
@@ -898,7 +896,6 @@ ParameterError getparameter(char *flag, /* f or -long-flag */
|
|||||||
/* This specifies the noproxy list */
|
/* This specifies the noproxy list */
|
||||||
GetStr(&config->noproxy, nextarg);
|
GetStr(&config->noproxy, nextarg);
|
||||||
break;
|
break;
|
||||||
#if defined(HAVE_GSSAPI) || defined(USE_WINDOWS_SSPI)
|
|
||||||
case '6': /* --socks5-gssapi-service */
|
case '6': /* --socks5-gssapi-service */
|
||||||
GetStr(&config->socks5_gssapi_service, nextarg);
|
GetStr(&config->socks5_gssapi_service, nextarg);
|
||||||
break;
|
break;
|
||||||
@@ -911,7 +908,6 @@ ParameterError getparameter(char *flag, /* f or -long-flag */
|
|||||||
case 'P': /* --service-name */
|
case 'P': /* --service-name */
|
||||||
GetStr(&config->service_name, nextarg);
|
GetStr(&config->service_name, nextarg);
|
||||||
break;
|
break;
|
||||||
#endif
|
|
||||||
case '8': /* --proxy1.0 */
|
case '8': /* --proxy1.0 */
|
||||||
/* http 1.0 proxy */
|
/* http 1.0 proxy */
|
||||||
GetStr(&config->proxy, nextarg);
|
GetStr(&config->proxy, nextarg);
|
||||||
|
@@ -174,10 +174,8 @@ static const char *const helptext[] = {
|
|||||||
" --proxy-negotiate "
|
" --proxy-negotiate "
|
||||||
"Use HTTP Negotiate (SPNEGO) authentication on the proxy (H)",
|
"Use HTTP Negotiate (SPNEGO) authentication on the proxy (H)",
|
||||||
" --proxy-ntlm Use NTLM authentication on the proxy (H)",
|
" --proxy-ntlm Use NTLM authentication on the proxy (H)",
|
||||||
#if defined(HAVE_GSSAPI) || defined(USE_WINDOWS_SSPI)
|
|
||||||
" --proxy-service-name NAME SPNEGO proxy service name",
|
" --proxy-service-name NAME SPNEGO proxy service name",
|
||||||
" --service-name NAME SPNEGO service name",
|
" --service-name NAME SPNEGO service name",
|
||||||
#endif
|
|
||||||
" -U, --proxy-user USER[:PASSWORD] Proxy user and password",
|
" -U, --proxy-user USER[:PASSWORD] Proxy user and password",
|
||||||
" --proxy1.0 HOST[:PORT] Use HTTP/1.0 proxy on given port",
|
" --proxy1.0 HOST[:PORT] Use HTTP/1.0 proxy on given port",
|
||||||
" -p, --proxytunnel Operate through a HTTP proxy tunnel (using CONNECT)",
|
" -p, --proxytunnel Operate through a HTTP proxy tunnel (using CONNECT)",
|
||||||
@@ -206,10 +204,8 @@ static const char *const helptext[] = {
|
|||||||
" --socks5 HOST[:PORT] SOCKS5 proxy on given host + port",
|
" --socks5 HOST[:PORT] SOCKS5 proxy on given host + port",
|
||||||
" --socks5-hostname HOST[:PORT] "
|
" --socks5-hostname HOST[:PORT] "
|
||||||
"SOCKS5 proxy, pass host name to proxy",
|
"SOCKS5 proxy, pass host name to proxy",
|
||||||
#if defined(HAVE_GSSAPI) || defined(USE_WINDOWS_SSPI)
|
|
||||||
" --socks5-gssapi-service NAME SOCKS5 proxy service name for GSS-API",
|
" --socks5-gssapi-service NAME SOCKS5 proxy service name for GSS-API",
|
||||||
" --socks5-gssapi-nec Compatibility with NEC SOCKS5 server",
|
" --socks5-gssapi-nec Compatibility with NEC SOCKS5 server",
|
||||||
#endif
|
|
||||||
" -Y, --speed-limit RATE "
|
" -Y, --speed-limit RATE "
|
||||||
"Stop transfers below RATE for 'speed-time' secs",
|
"Stop transfers below RATE for 'speed-time' secs",
|
||||||
" -y, --speed-time SECONDS "
|
" -y, --speed-time SECONDS "
|
||||||
@@ -224,7 +220,7 @@ static const char *const helptext[] = {
|
|||||||
" -t, --telnet-option OPT=VAL Set telnet option",
|
" -t, --telnet-option OPT=VAL Set telnet option",
|
||||||
" --tftp-blksize VALUE Set TFTP BLKSIZE option (must be >512)",
|
" --tftp-blksize VALUE Set TFTP BLKSIZE option (must be >512)",
|
||||||
" -z, --time-cond TIME Transfer based on a time condition",
|
" -z, --time-cond TIME Transfer based on a time condition",
|
||||||
" -1, --tlsv1 Use => TLSv1 (SSL)",
|
" -1, --tlsv1 Use >= TLSv1 (SSL)",
|
||||||
" --tlsv1.0 Use TLSv1.0 (SSL)",
|
" --tlsv1.0 Use TLSv1.0 (SSL)",
|
||||||
" --tlsv1.1 Use TLSv1.1 (SSL)",
|
" --tlsv1.1 Use TLSv1.1 (SSL)",
|
||||||
" --tlsv1.2 Use TLSv1.2 (SSL)",
|
" --tlsv1.2 Use TLSv1.2 (SSL)",
|
||||||
|
@@ -1204,32 +1204,26 @@ static CURLcode operate_do(struct GlobalConfig *global,
|
|||||||
my_setopt_enum(curl, CURLOPT_FTP_SSL_CCC,
|
my_setopt_enum(curl, CURLOPT_FTP_SSL_CCC,
|
||||||
(long)config->ftp_ssl_ccc_mode);
|
(long)config->ftp_ssl_ccc_mode);
|
||||||
|
|
||||||
#if defined(HAVE_GSSAPI) || defined(USE_WINDOWS_SSPI)
|
/* new in curl 7.19.4 */
|
||||||
{
|
if(config->socks5_gssapi_service)
|
||||||
/* TODO: Make this a run-time check instead of compile-time one. */
|
my_setopt_str(curl, CURLOPT_SOCKS5_GSSAPI_SERVICE,
|
||||||
|
config->socks5_gssapi_service);
|
||||||
|
|
||||||
/* new in curl 7.19.4 */
|
/* new in curl 7.19.4 */
|
||||||
if(config->socks5_gssapi_service)
|
if(config->socks5_gssapi_nec)
|
||||||
my_setopt_str(curl, CURLOPT_SOCKS5_GSSAPI_SERVICE,
|
my_setopt_str(curl, CURLOPT_SOCKS5_GSSAPI_NEC,
|
||||||
config->socks5_gssapi_service);
|
config->socks5_gssapi_nec);
|
||||||
|
|
||||||
/* new in curl 7.19.4 */
|
/* new in curl 7.43.0 */
|
||||||
if(config->socks5_gssapi_nec)
|
if(config->proxy_service_name)
|
||||||
my_setopt_str(curl, CURLOPT_SOCKS5_GSSAPI_NEC,
|
my_setopt_str(curl, CURLOPT_PROXY_SERVICE_NAME,
|
||||||
config->socks5_gssapi_nec);
|
config->proxy_service_name);
|
||||||
|
|
||||||
/* new in curl 7.43.0 */
|
/* new in curl 7.43.0 */
|
||||||
if(config->proxy_service_name)
|
if(config->service_name)
|
||||||
my_setopt_str(curl, CURLOPT_PROXY_SERVICE_NAME,
|
my_setopt_str(curl, CURLOPT_SERVICE_NAME,
|
||||||
config->proxy_service_name);
|
config->service_name);
|
||||||
|
|
||||||
/* new in curl 7.43.0 */
|
|
||||||
if(config->service_name)
|
|
||||||
my_setopt_str(curl, CURLOPT_SERVICE_NAME,
|
|
||||||
config->service_name);
|
|
||||||
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
/* curl 7.13.0 */
|
/* curl 7.13.0 */
|
||||||
my_setopt_str(curl, CURLOPT_FTP_ACCOUNT, config->ftp_account);
|
my_setopt_str(curl, CURLOPT_FTP_ACCOUNT, config->ftp_account);
|
||||||
|
|
||||||
|
@@ -165,4 +165,5 @@ test2000 test2001 test2002 test2003 test2004 test2005 test2006 test2007 \
|
|||||||
test2008 test2009 test2010 test2011 test2012 test2013 test2014 test2015 \
|
test2008 test2009 test2010 test2011 test2012 test2013 test2014 test2015 \
|
||||||
test2016 test2017 test2018 test2019 test2020 test2021 test2022 test2023 \
|
test2016 test2017 test2018 test2019 test2020 test2021 test2022 test2023 \
|
||||||
test2024 test2025 test2026 test2027 test2028 test2029 test2030 test2031 \
|
test2024 test2025 test2026 test2027 test2028 test2029 test2030 test2031 \
|
||||||
test2032 test2033 test2034 test2035 test2036 test2037 test2038 test2039
|
test2032 test2033 test2034 test2035 test2036 test2037 test2038 test2039 \
|
||||||
|
test2040
|
||||||
|
@@ -9,6 +9,9 @@ CURLOPT_OPENSOCKETFUNCTION
|
|||||||
<server>
|
<server>
|
||||||
none
|
none
|
||||||
</server>
|
</server>
|
||||||
|
<features>
|
||||||
|
http
|
||||||
|
</features>
|
||||||
<tool>
|
<tool>
|
||||||
lib1530
|
lib1530
|
||||||
</tool>
|
</tool>
|
||||||
|
69
tests/data/test2040
Normal file
69
tests/data/test2040
Normal file
@@ -0,0 +1,69 @@
|
|||||||
|
<testcase>
|
||||||
|
<info>
|
||||||
|
<keywords>
|
||||||
|
HTTP
|
||||||
|
HTTP GET
|
||||||
|
HTTP Basic auth
|
||||||
|
</keywords>
|
||||||
|
</info>
|
||||||
|
# Server-side
|
||||||
|
<reply>
|
||||||
|
|
||||||
|
<!-- First request has Basic auth, right password -->
|
||||||
|
<data100>
|
||||||
|
HTTP/1.1 200 Things are fine in server land
|
||||||
|
Server: Microsoft-IIS/5.0
|
||||||
|
Content-Type: text/html; charset=iso-8859-1
|
||||||
|
Content-Length: 32
|
||||||
|
|
||||||
|
Finally, this is the real page!
|
||||||
|
</data100>
|
||||||
|
|
||||||
|
<!-- Second request with Basic auth disabled -->
|
||||||
|
<data200>
|
||||||
|
HTTP/1.1 401 Sorry wrong password (2)
|
||||||
|
Server: Microsoft-IIS/5.0
|
||||||
|
Content-Type: text/html; charset=iso-8859-1
|
||||||
|
Content-Length: 29
|
||||||
|
WWW-Authenticate: Basic realm="testrealm"
|
||||||
|
|
||||||
|
This is a bad password page!
|
||||||
|
</data200>
|
||||||
|
|
||||||
|
</reply>
|
||||||
|
|
||||||
|
# Client-side
|
||||||
|
<client>
|
||||||
|
<server>
|
||||||
|
http
|
||||||
|
</server>
|
||||||
|
<name>
|
||||||
|
HTTP Basic authorization, then without authorization
|
||||||
|
</name>
|
||||||
|
<command option="no-output,no-include">
|
||||||
|
-u testuser:testpass http://%HOSTIP:%HTTPPORT/20400100 --next --no-basic http://%HOSTIP:%HTTPPORT/20400200
|
||||||
|
</command>
|
||||||
|
</client>
|
||||||
|
|
||||||
|
# Verify data after the test has been "shot"
|
||||||
|
<verify>
|
||||||
|
<strip>
|
||||||
|
^User-Agent:.*
|
||||||
|
</strip>
|
||||||
|
<protocol>
|
||||||
|
GET /20400100 HTTP/1.1
|
||||||
|
Host: %HOSTIP:%HTTPPORT
|
||||||
|
Authorization: Basic dGVzdHVzZXI6dGVzdHBhc3M=
|
||||||
|
Accept: */*
|
||||||
|
|
||||||
|
GET /20400200 HTTP/1.1
|
||||||
|
Host: %HOSTIP:%HTTPPORT
|
||||||
|
Accept: */*
|
||||||
|
|
||||||
|
</protocol>
|
||||||
|
<stdout>
|
||||||
|
Finally, this is the real page!
|
||||||
|
This is a bad password page!
|
||||||
|
</stdout>
|
||||||
|
</verify>
|
||||||
|
</testcase>
|
@@ -1,5 +1,5 @@
|
|||||||
Building with Visual C++, prerequises
|
Building with Visual C++, prerequisites
|
||||||
=====================================
|
=======================================
|
||||||
|
|
||||||
This document describes how to compile, build and install curl and libcurl
|
This document describes how to compile, build and install curl and libcurl
|
||||||
from sources using the Visual C++ build tool. To build with VC++, you will
|
from sources using the Visual C++ build tool. To build with VC++, you will
|
||||||
@@ -87,3 +87,12 @@ therefore rarely tested. When passing RTLIBCFG for a configuration that was
|
|||||||
already built but not with that option, or if the option was specified
|
already built but not with that option, or if the option was specified
|
||||||
differently, you must destroy the build directory containing the configuration
|
differently, you must destroy the build directory containing the configuration
|
||||||
so that nmake can build it from scratch.
|
so that nmake can build it from scratch.
|
||||||
|
|
||||||
|
Legacy Windows and SSL
|
||||||
|
======================
|
||||||
|
When you build curl using the build files in this directory the default SSL
|
||||||
|
backend will be WinSSL (Windows SSPI, more specifically Schannel), the native
|
||||||
|
SSL library that comes with the Windows OS. WinSSL in Windows <= XP is not able
|
||||||
|
to connect to servers that no longer support the legacy handshakes and
|
||||||
|
algorithms used by those versions. If you will be using curl in one of those
|
||||||
|
earlier versions of Windows you should choose another SSL backend like OpenSSL.
|
||||||
|
Reference in New Issue
Block a user