]> granicus.if.org Git - curl/log
curl
8 years agocurl: -h output lacked --proxy-header
Daniel Stenberg [Thu, 28 Apr 2016 21:31:53 +0000 (23:31 +0200)]
curl: -h output lacked --proxy-header

8 years agocurl.1: document --ntlm-wb
Daniel Stenberg [Thu, 28 Apr 2016 21:26:52 +0000 (23:26 +0200)]
curl.1: document --ntlm-wb

8 years agocurl.1: document the long format of -q: --disable
Daniel Stenberg [Thu, 28 Apr 2016 21:23:44 +0000 (23:23 +0200)]
curl.1: document the long format of -q: --disable

8 years agocurl.1: mention the deprecated --krb4 option
Daniel Stenberg [Thu, 28 Apr 2016 21:23:17 +0000 (23:23 +0200)]
curl.1: mention the deprecated --krb4 option

8 years agocurl.1: document --ftp-ssl-reqd
Daniel Stenberg [Thu, 28 Apr 2016 21:18:28 +0000 (23:18 +0200)]
curl.1: document --ftp-ssl-reqd

Even if deprecated, document it so that people will find it as old
scripts may still use it.

8 years agocurl: use --telnet-option as documented
Daniel Stenberg [Thu, 28 Apr 2016 21:13:55 +0000 (23:13 +0200)]
curl: use --telnet-option as documented

The code said "telnet-options" but no documentation ever said so. It
worked fine since the code is fine with a unique match of the first
part.

8 years agogetparam: remove support for --ftpport
Daniel Stenberg [Thu, 28 Apr 2016 21:08:42 +0000 (23:08 +0200)]
getparam: remove support for --ftpport

It has been deprecated and undocumented since commit ad5ead8bed7 (Dec
2003). --ftp-port is the proper long option name.

8 years agocurl: make --disable work as long form of -q
Daniel Stenberg [Thu, 28 Apr 2016 20:32:05 +0000 (22:32 +0200)]
curl: make --disable work as long form of -q

To make the aliases list reflect reality.

8 years agoaliases: remove trailing space from capath string
Daniel Stenberg [Thu, 28 Apr 2016 20:28:37 +0000 (22:28 +0200)]
aliases: remove trailing space from capath string

8 years agocmdline parse: only single letter options have single-letter strings
Daniel Stenberg [Thu, 28 Apr 2016 20:24:10 +0000 (22:24 +0200)]
cmdline parse: only single letter options have single-letter strings

... moved around options so that parsing the code to find all
single-letter options easier.

8 years agoCURLINFO_TLS_SSL_PTR.3: Clarify SSL pointer availability
Jay Satiro [Thu, 28 Apr 2016 20:48:38 +0000 (16:48 -0400)]
CURLINFO_TLS_SSL_PTR.3: Clarify SSL pointer availability

Bug: https://curl.haxx.se/mail/lib-2016-04/0126.html
Reported-by: Bru Rom
8 years agocurl_easy_getinfo.3: remove superfluous blank lines
Daniel Stenberg [Thu, 28 Apr 2016 14:31:37 +0000 (16:31 +0200)]
curl_easy_getinfo.3: remove superfluous blank lines

8 years agotest1139: verifies libcurl option man page presence
Daniel Stenberg [Thu, 28 Apr 2016 14:27:51 +0000 (16:27 +0200)]
test1139: verifies libcurl option man page presence

- checks that each option has its own man page present

- checks that each option is mentioned in its corresponding index man
  page

8 years agocurl_easy_getinfo.3: added missing mention of CURLINFO_TLS_SESSION
Daniel Stenberg [Thu, 28 Apr 2016 14:26:42 +0000 (16:26 +0200)]
curl_easy_getinfo.3: added missing mention of CURLINFO_TLS_SESSION

... although it is deprecated.

8 years agombedtls: Fix session resume
Jay Satiro [Thu, 28 Apr 2016 06:57:12 +0000 (02:57 -0400)]
mbedtls: Fix session resume

This also fixes PolarSSL session resume.

Prior to this change the TLS session information wasn't properly
saved and restored for PolarSSL and mbedTLS.

Bug: https://curl.haxx.se/mail/lib-2016-01/0070.html
Reported-by: Thomas Glanzmann
Bug: https://curl.haxx.se/mail/lib-2016-04/0095.html
Reported-by: Moti Avrahami
8 years agoRELEASE-NOTES: synced with f4298fcc6d2
Daniel Stenberg [Wed, 27 Apr 2016 13:31:38 +0000 (15:31 +0200)]
RELEASE-NOTES: synced with f4298fcc6d2

8 years agoopts: Fix some syntax errors in example code fragments
Michael Kaufmann [Tue, 26 Apr 2016 21:51:50 +0000 (23:51 +0200)]
opts: Fix some syntax errors in example code fragments

Fixes #779

8 years agoopenssl: avoid BN_print a NULL bignum
Daniel Stenberg [Tue, 26 Apr 2016 21:55:31 +0000 (23:55 +0200)]
openssl: avoid BN_print a NULL bignum

OpenSSL 1.1.0-pre seems to return NULL(?) for a whole lot of those
numbers so make sure the function handles this.

Reported-by: Linus Nordberg
8 years agoCONNECT_ONLY: don't close connection on GSS 401/407 reponses
Marcel Raad [Mon, 15 Feb 2016 07:58:36 +0000 (08:58 +0100)]
CONNECT_ONLY: don't close connection on GSS 401/407 reponses

Previously, connections were closed immediately before the user had a
chance to extract the socket when the proxy required Negotiate
authentication.

This regression was brought in with the security fix in commit
79b9d5f1a42578f

Closes #655

8 years agoCURLINFO_TLS_SESSION.3: clarify TLS library support before 7.48.0
Daniel Stenberg [Tue, 26 Apr 2016 13:17:07 +0000 (15:17 +0200)]
CURLINFO_TLS_SESSION.3: clarify TLS library support before 7.48.0

8 years agombedtls.c: silly spellfix of a comment
Daniel Stenberg [Mon, 25 Apr 2016 22:28:40 +0000 (00:28 +0200)]
mbedtls.c: silly spellfix of a comment

8 years agoKNOWN_BUGS: 1.10 Strips trailing dot from host name
Daniel Stenberg [Mon, 25 Apr 2016 22:07:40 +0000 (00:07 +0200)]
KNOWN_BUGS: 1.10 Strips trailing dot from host name

Closes #716

8 years agotest1322: verify stripping of trailing dot from host name
Daniel Stenberg [Mon, 25 Apr 2016 21:51:33 +0000 (23:51 +0200)]
test1322: verify stripping of trailing dot from host name

While being debated (in #716) and a violation of RFC 7230 section 5.4,
this test verifies that the existing functionality works as intended. It
strips the dot from the host name and uses the host without dot
throughout the internals.

8 years agomulti: accidentally used resolved host name instead of proxy
Daniel Stenberg [Sat, 23 Apr 2016 20:46:15 +0000 (22:46 +0200)]
multi: accidentally used resolved host name instead of proxy

Regression introduced in 09b5a998

Bug: https://curl.haxx.se/mail/lib-2016-04/0084.html
Reported-by: BoBo
8 years agosymbols-in-versions: added new CURLSSLBACKEND_ symbols
Daniel Stenberg [Mon, 25 Apr 2016 21:15:00 +0000 (23:15 +0200)]
symbols-in-versions: added new CURLSSLBACKEND_ symbols

8 years agotest148: fixed after the --ftp-create-dirs retry change
Daniel Stenberg [Mon, 25 Apr 2016 21:10:13 +0000 (23:10 +0200)]
test148: fixed after the --ftp-create-dirs retry change

follow-up commit to 3c1e84f569 as it made curl try a little harder

8 years agocurl.h: clarify curl_sslbackend for openssl clones and renames
Daniel Stenberg [Mon, 25 Apr 2016 09:35:12 +0000 (11:35 +0200)]
curl.h: clarify curl_sslbackend for openssl clones and renames

8 years agourl.c: fixed DEBUGASSERT() for WinSock workaround
Karlson2k [Mon, 25 Apr 2016 09:12:26 +0000 (12:12 +0300)]
url.c: fixed DEBUGASSERT() for WinSock workaround

If buffer is allocated, but nothing is received during prereceive
stage, than number of processed bytes must be zero.

Closes #778

8 years agoKNOWN_BUGS: --interface for ipv6 binds to unusable IP address
Daniel Stenberg [Mon, 25 Apr 2016 09:20:23 +0000 (11:20 +0200)]
KNOWN_BUGS: --interface for ipv6 binds to unusable IP address

Closes #686 for now.

8 years agoTODO: 1.17 Add support for IRIs
Daniel Stenberg [Sun, 24 Apr 2016 21:51:34 +0000 (23:51 +0200)]
TODO: 1.17 Add support for IRIs

Adding support for IRIs is a mouthful, but is probably interesting at
least for areas and countries where the use of such "URLs" are growing
popularity.

Closes #776

8 years agoTHANKS-filter: Travis Burtrum
Daniel Stenberg [Sun, 24 Apr 2016 10:46:41 +0000 (12:46 +0200)]
THANKS-filter: Travis Burtrum

8 years agolib1517: checksrc compliance
Daniel Stenberg [Sun, 24 Apr 2016 10:27:22 +0000 (12:27 +0200)]
lib1517: checksrc compliance

8 years agoPolarSSL: Implement public key pinning
moparisthebest [Fri, 22 Apr 2016 01:21:45 +0000 (21:21 -0400)]
PolarSSL: Implement public key pinning

8 years agoos400: upgrade ILE/RPG binding
Patrick Monnerat [Fri, 22 Apr 2016 14:50:30 +0000 (16:50 +0200)]
os400: upgrade ILE/RPG binding

8 years agocurl.h: CURLOPT_CONNECT_TO sets a struct slist *, not a string
Patrick Monnerat [Fri, 22 Apr 2016 14:49:02 +0000 (16:49 +0200)]
curl.h: CURLOPT_CONNECT_TO sets a struct slist *, not a string

8 years agocontributors.sh: make --releasenotes implied
Daniel Stenberg [Fri, 22 Apr 2016 13:53:42 +0000 (15:53 +0200)]
contributors.sh: make --releasenotes implied

It got too annoying to type =)

8 years agoRELEASE-NOTES: synced with 3c1e84f5693d8093
Daniel Stenberg [Fri, 22 Apr 2016 13:46:34 +0000 (15:46 +0200)]
RELEASE-NOTES: synced with 3c1e84f5693d8093

8 years agocurl: make --ftp-create-dirs retry on failure
Daniel Stenberg [Fri, 22 Apr 2016 13:25:13 +0000 (15:25 +0200)]
curl: make --ftp-create-dirs retry on failure

The underlying libcurl option used for this feature is
CURLOPT_FTP_CREATE_MISSING_DIRS which has the ability to retry the dir
creation, but it was never set to do that by the command line tool.

Now it does.

Bug: https://curl.haxx.se/mail/archive-2016-04/0021.html
Reported-by: John Wanghui
Help-by: Leif W
8 years agowinbuild: add mbedtls support
Henrik Gaßmann [Thu, 21 Apr 2016 21:23:49 +0000 (23:23 +0200)]
winbuild: add mbedtls support

Add WITH_MBEDTLS option. Make WITH_SSL, WITH_MBEDTLS and ENABLE_WINSSL
options mutual exclusive.

Closes #606

8 years agoKNOWN_BUGS: fixed "5.6 Improper use of Autoconf cache variables"
Daniel Stenberg [Thu, 21 Apr 2016 21:14:13 +0000 (23:14 +0200)]
KNOWN_BUGS: fixed "5.6 Improper use of Autoconf cache variables"

As of commit d9f3b365a3

8 years agoconfigure: ac_cv_ -> curl_cv_ for write-only vars
Irfan Adilovic [Sun, 17 Apr 2016 20:05:15 +0000 (22:05 +0200)]
configure: ac_cv_ -> curl_cv_ for write-only vars

These configure vars are modified in a curl-specific way but never
evaluated or loaded from cache, even though they are designated as
_cv_. We could either implement proper AC_CACHE_CHECKs for them, or
remove them completely.

Fixes #603 as ac_cv_func_gethostbyname is no longer clobbered, and
AC_CHECK_FUNC(gethostbyname...) will no longer spuriously succeed after
the first configure run with caching.

`ac_cv_func_strcasecmp` is curious, see #770.

`eval "ac_cv_func_$func=yes"` can still cause problems as it works in
tandem with AC_CHECK_FUNCS and then potentially modifies its result. It
would be best to rewrite this test to use a new CURL_CHECK_FUNCS macro,
which works the same as AC_CHECK_FUNCS but relies on caching the values
of curl_cv_func_* variables, without modifiying ac_cv_func_*.

8 years agoconfigure: ac_cv_ -> curl_cv_ for r/w vars
Irfan Adilovic [Sun, 17 Apr 2016 19:58:15 +0000 (21:58 +0200)]
configure: ac_cv_ -> curl_cv_ for r/w vars

These configure vars are modified in a curl-specific way and modified by
the configure process, but are never loaded from cache, even though they
are designated as _cv_. We should implement proper AC_CACHE_CHECKs for
them eventually.

8 years agoconfigure: ac_cv_func_clock_gettime -> curl_...
Irfan Adilovic [Sun, 17 Apr 2016 15:01:13 +0000 (17:01 +0200)]
configure: ac_cv_func_clock_gettime -> curl_...

This variable must not be cached in its current form, as any cached
information will prevent the next configure run from determining the
correct LIBS needed for the function. Thus, rename prefix `ac_cv_` to
just `curl_`.

8 years agoconfigure: ac_cv_ -> curl_cv_ for all cached vars
Irfan Adilovic [Fri, 15 Apr 2016 14:37:20 +0000 (16:37 +0200)]
configure: ac_cv_ -> curl_cv_ for all cached vars

This was automated by:

sed -b -i -f <(ack -A1 AC_CACHE_CHECK | \
               ack -o 'ac_cv_.*?\b' | \
               sort -u | xargs -n1 bash -c \
                    'echo "s/$0/curl_cv_${0#ac_cv_}/g"') \
    $(git ls-files)

This only changed the prefix for 16 variables actually checked with
AC_CACHE_CHECK.

8 years agoopenssl: builds with OpenSSL 1.1.0-pre5
Daniel Stenberg [Thu, 21 Apr 2016 08:24:23 +0000 (10:24 +0200)]
openssl: builds with OpenSSL 1.1.0-pre5

The RSA, DSA and DH structs are now opaque and require use of new APIs

Fixes #763

8 years agourl.c: Prefer we don't use explicit NULLs in conditions
Steve Holme [Wed, 20 Apr 2016 17:07:05 +0000 (18:07 +0100)]
url.c: Prefer we don't use explicit NULLs in conditions

Fixed commit fa5fa65a30 to not use NULLs in if condition.

8 years agoNTLM: check for NULL pointer before deferencing
Isaac Boukris [Sat, 16 Apr 2016 08:49:09 +0000 (11:49 +0300)]
NTLM: check for NULL pointer before deferencing

At ConnectionExists, both check->proxyuser and check->proxypasswd
could be NULL, so make sure to check first.

Fixes #765

8 years agotests: added test1517
Karlson2k [Thu, 17 Mar 2016 17:04:20 +0000 (20:04 +0300)]
tests: added test1517

... for checking ability to receive full HTTP response when POST request
is used with slow read callback function.

This test checks for bug #657 and verifies the work-around from
72d5e144fbc6.

Closes #720

8 years agosendf.c: added ability to call recv() before send() as workaround
Karlson2k [Fri, 19 Feb 2016 19:38:20 +0000 (22:38 +0300)]
sendf.c: added ability to call recv() before send() as workaround

WinSock destroys recv() buffer if send() is failed. As result - server
response may be lost if server sent it while curl is still sending
request. This behavior noticeable on HTTP server short replies if
libcurl use several send() for request (usually for POST request).
To workaround this problem, libcurl use recv() before every send() and
keeps received data in intermediate buffer for further processing.

Fixes: #657
Closes: #668
8 years agoconnect: make sure that rc is initialized in singleipconnect()
Kamil Dudka [Tue, 19 Apr 2016 07:38:44 +0000 (09:38 +0200)]
connect: make sure that rc is initialized in singleipconnect()

This commit fixes a Clang warning introduced in curl-7_48_0-190-g8f72b13:

Error: CLANG_WARNING:
lib/connect.c:1120:11: warning: The right operand of '==' is a garbage value
1118|       }
1119|
1120|->     if(-1 == rc)
1121|         error = SOCKERRNO;
1122|     }

8 years agomake/checksrc: use $srcdir, not $top_srcdir
Daniel Stenberg [Tue, 19 Apr 2016 06:48:36 +0000 (08:48 +0200)]
make/checksrc: use $srcdir, not $top_srcdir

8 years agosrc/checksrc.whitelist: removed
Daniel Stenberg [Tue, 19 Apr 2016 06:43:13 +0000 (08:43 +0200)]
src/checksrc.whitelist: removed

8 years agotool_operate: switch to inline checksrc ignore
Daniel Stenberg [Tue, 19 Apr 2016 06:42:55 +0000 (08:42 +0200)]
tool_operate: switch to inline checksrc ignore

8 years agolib/checksrc.whitelist: not needed anymore
Daniel Stenberg [Tue, 19 Apr 2016 06:30:43 +0000 (08:30 +0200)]
lib/checksrc.whitelist: not needed anymore

... as checksrc now skips comments

8 years agovtls.h: remove a space before semicolon
Daniel Stenberg [Tue, 19 Apr 2016 06:41:15 +0000 (08:41 +0200)]
vtls.h: remove a space before semicolon

... that the new checksrc detected

8 years agodarwinssl: removed commented out code
Daniel Stenberg [Tue, 19 Apr 2016 06:32:14 +0000 (08:32 +0200)]
darwinssl: removed commented out code

8 years agohttp_chunks: removed checksrc disable
Daniel Stenberg [Tue, 19 Apr 2016 06:31:33 +0000 (08:31 +0200)]
http_chunks: removed checksrc disable

... since checksrc now skips comments

8 years agoimap: inlined checksrc disable instead of whitelist edit
Daniel Stenberg [Tue, 19 Apr 2016 06:31:11 +0000 (08:31 +0200)]
imap: inlined checksrc disable instead of whitelist edit

8 years agochecksrc: taught to skip comments
Daniel Stenberg [Tue, 19 Apr 2016 06:30:13 +0000 (08:30 +0200)]
checksrc: taught to skip comments

... but output non-stripped version of the line, even if that then can
make the script identify the wrong position in the line at
times. Showing the line stripped (ie without comments) is just too
surprising.

8 years agoopts/Makefile.am: list all docs file one by one
Daniel Stenberg [Tue, 19 Apr 2016 05:59:35 +0000 (07:59 +0200)]
opts/Makefile.am: list all docs file one by one

... to make it easier to add lines in patches that won't just break all
other patches trying to add lines too.

8 years agocurl_easy_setopt.3: mention CURLOPT_TCP_FASTOPEN
Daniel Stenberg [Mon, 18 Apr 2016 22:48:56 +0000 (00:48 +0200)]
curl_easy_setopt.3: mention CURLOPT_TCP_FASTOPEN

8 years agoRELEASE-NOTES: synced with 03de4e4b219
Daniel Stenberg [Mon, 18 Apr 2016 22:39:27 +0000 (00:39 +0200)]
RELEASE-NOTES: synced with 03de4e4b219

(since we just merged two major features)

8 years agoconnect: implement TCP Fast Open for Linux
Alessandro Ghedini [Sun, 3 Apr 2016 12:08:28 +0000 (13:08 +0100)]
connect: implement TCP Fast Open for Linux

Closes #660

8 years agotool: add --tcp-fastopen option
Alessandro Ghedini [Tue, 16 Feb 2016 12:21:34 +0000 (12:21 +0000)]
tool: add --tcp-fastopen option

8 years agoconnect: implement TCP Fast Open for OS X
Alessandro Ghedini [Tue, 16 Feb 2016 12:21:22 +0000 (12:21 +0000)]
connect: implement TCP Fast Open for OS X

8 years agourl: add CURLOPT_TCP_FASTOPEN option
Alessandro Ghedini [Tue, 16 Feb 2016 12:21:03 +0000 (12:21 +0000)]
url: add CURLOPT_TCP_FASTOPEN option

8 years agochecksrc: pass on -D so the whitelists are found correctly
Daniel Stenberg [Mon, 18 Apr 2016 18:10:52 +0000 (20:10 +0200)]
checksrc: pass on -D so the whitelists are found correctly

8 years agoconfigure: remove check for libresolve
Daniel Stenberg [Mon, 18 Apr 2016 13:53:24 +0000 (15:53 +0200)]
configure: remove check for libresolve

'strncasecmp' was once provided by libresolv (no trailing e) for SunOS,
but this check is broken and most likely adds nothing useful. Removing
now.

Reported-by: Irfan Adilovic
Discussed in #770

8 years agoscripts/make: use $(EXEEXT) for executables
Daniel Stenberg [Mon, 18 Apr 2016 13:50:57 +0000 (15:50 +0200)]
scripts/make: use $(EXEEXT) for executables

Reported-by: bodop
Fixes #771

8 years agoincludes: avoid duplicate memory callback typdefs even harder
Daniel Stenberg [Mon, 18 Apr 2016 13:04:17 +0000 (15:04 +0200)]
includes: avoid duplicate memory callback typdefs even harder

8 years agochecksrc/makefile.am: use $top_srcdir to find source files
Daniel Stenberg [Mon, 18 Apr 2016 12:58:11 +0000 (14:58 +0200)]
checksrc/makefile.am: use $top_srcdir to find source files

... to properly support out of source tree builds.

8 years agoRELEASE-NOTES: synced with 26ec93dd6aeba8dfb5
Daniel Stenberg [Mon, 18 Apr 2016 10:38:22 +0000 (12:38 +0200)]
RELEASE-NOTES: synced with 26ec93dd6aeba8dfb5

8 years agoopts: fix option references missing (section)
Daniel Stenberg [Sun, 17 Apr 2016 22:02:29 +0000 (00:02 +0200)]
opts: fix option references missing (section)

8 years agonews: CURLOPT_CONNECT_TO and --connect-to
Michael Kaufmann [Mon, 25 Jan 2016 13:37:24 +0000 (14:37 +0100)]
news: CURLOPT_CONNECT_TO and --connect-to

Makes curl connect to the given host+port instead of the host+port found
in the URL.

8 years agomakefile.vc6: use d suffix on debug object
Daniel Stenberg [Sun, 17 Apr 2016 15:16:21 +0000 (17:16 +0200)]
makefile.vc6: use d suffix on debug object

To allow both release and debug builds in parallel.

Reported-by: Rod Widdowson
Fixes #769

8 years agohttp2: Use size_t type for data drain count
Jay Satiro [Tue, 12 Apr 2016 04:37:44 +0000 (00:37 -0400)]
http2: Use size_t type for data drain count

Ref: https://github.com/curl/curl/issues/659
Ref: https://github.com/curl/curl/pull/663

8 years agohttp2: Improve header parsing
Jay Satiro [Thu, 3 Mar 2016 06:24:27 +0000 (01:24 -0500)]
http2: Improve header parsing

- Error if a header line is larger than supported.

- Warn if cumulative header line length may be larger than supported.

- Allow spaces when parsing the path component.

- Make sure each header line ends in \r\n. This fixes an out of bounds.

- Disallow header continuation lines until we decide what to do.

Ref: https://github.com/curl/curl/issues/659
Ref: https://github.com/curl/curl/pull/663

8 years agohttp2: Add Curl_http2_strerror for HTTP/2 error codes
Jay Satiro [Thu, 3 Mar 2016 05:47:46 +0000 (00:47 -0500)]
http2: Add Curl_http2_strerror for HTTP/2 error codes

Ref: https://github.com/curl/curl/issues/659
Ref: https://github.com/curl/curl/pull/663

8 years agohttp2: Don't increment drain when one header field is received
Tatsuhiro Tsujikawa [Wed, 24 Feb 2016 13:10:37 +0000 (22:10 +0900)]
http2: Don't increment drain when one header field is received

Sicne we write header field in temporary location, not in the memory
that upper layer provides, incrementing drain should not happen.

Ref: https://github.com/curl/curl/issues/659
Ref: https://github.com/curl/curl/pull/663

8 years agohttp2: Ensure that http2_handle_stream_close is called
Tatsuhiro Tsujikawa [Tue, 23 Feb 2016 14:33:04 +0000 (23:33 +0900)]
http2: Ensure that http2_handle_stream_close is called

This commit ensures that streams which was closed in on_stream_close
callback gets passed to http2_handle_stream_close.  Previously, this
might not happen.  To achieve this, we increment drain property to
forcibly call recv function for that stream.

To more accurately check that we have no pending event before shutting
down HTTP/2 session, we sum up drain property into
http_conn.drain_total.  We only shutdown session if that value is 0.

With this commit, when stream was closed before reading response
header fields, error code CURLE_HTTP2_STREAM is returned even if
HTTP/2 level error is NO_ERROR.  This signals the upper layer that
stream was closed by error just like TCP connection close in HTTP/1.

Ref: https://github.com/curl/curl/issues/659
Ref: https://github.com/curl/curl/pull/663

8 years agohttp2: Process paused data first before tear down http2 session
Tatsuhiro Tsujikawa [Mon, 22 Feb 2016 12:20:38 +0000 (21:20 +0900)]
http2: Process paused data first before tear down http2 session

This commit ensures that data from network are processed before HTTP/2
session is terminated.  This is achieved by pausing nghttp2 whenever
different stream than current easy handle receives data.

This commit also fixes the bug that sometimes processing hangs when
multiple HTTP/2 streams are multiplexed.

Ref: https://github.com/curl/curl/issues/659
Ref: https://github.com/curl/curl/pull/663

8 years agohttp2: Check session closure early in http2_recv
Tatsuhiro Tsujikawa [Fri, 19 Feb 2016 15:05:47 +0000 (00:05 +0900)]
http2: Check session closure early in http2_recv

Ref: https://github.com/curl/curl/issues/659
Ref: https://github.com/curl/curl/pull/663

8 years agohttp2: Add handling stream level error
Tatsuhiro Tsujikawa [Wed, 17 Feb 2016 12:36:59 +0000 (21:36 +0900)]
http2: Add handling stream level error

Previously, when a stream was closed with other than NGHTTP2_NO_ERROR
by RST_STREAM, underlying TCP connection was dropped.  This is
undesirable since there may be other streams multiplexed and they are
very much fine.  This change introduce new error code
CURLE_HTTP2_STREAM, which indicates stream error that only affects the
relevant stream, and connection should be kept open.  The existing
CURLE_HTTP2 means connection error in general.

Ref: https://github.com/curl/curl/issues/659
Ref: https://github.com/curl/curl/pull/663

8 years agohttp2: drain the socket better...
Daniel Stenberg [Mon, 11 Apr 2016 14:00:15 +0000 (16:00 +0200)]
http2: drain the socket better...

... but ignore EAGAIN if the stream has ended so that we don't end up in
a loop. This is a follow-up to c8ab613 in order to avoid the problem
d261652 was made to fix.

Reported-by: Jay Satiro
Clues-provided-by: Tatsuhiro Tsujikawa
Discussed in #750

8 years agoKNOWN_BUGS: added info for "Hangs with PolarSSL"
Daniel Stenberg [Sun, 10 Apr 2016 22:06:37 +0000 (00:06 +0200)]
KNOWN_BUGS: added info for "Hangs with PolarSSL"

8 years agoKNOWN_BUGS: 1.9 HTTP/2 frames while in the connection pool kill reuse
Daniel Stenberg [Sun, 10 Apr 2016 21:52:40 +0000 (23:52 +0200)]
KNOWN_BUGS: 1.9 HTTP/2 frames while in the connection pool kill reuse

Closes #750

8 years agobuild: include scripts/ in the dist
Daniel Stenberg [Sat, 9 Apr 2016 21:44:53 +0000 (23:44 +0200)]
build: include scripts/ in the dist

8 years agoCURLOPT_SOCKS5_GSSAPI_SERVICE: Merged with CURLOPT_PROXY_SERVICE_NAME
Steve Holme [Sat, 9 Apr 2016 19:47:05 +0000 (20:47 +0100)]
CURLOPT_SOCKS5_GSSAPI_SERVICE: Merged with CURLOPT_PROXY_SERVICE_NAME

As these two options provide identical functionality, the former for
SOCK5 proxies and the latter for HTTP proxies, merged the two options
together.

As such CURLOPT_SOCKS5_GSSAPI_SERVICE is marked as deprecated as of
7.49.0.

8 years agourldata: Use bool for socks5_gssapi_nec as it is a flag
Steve Holme [Sat, 9 Apr 2016 16:19:21 +0000 (17:19 +0100)]
urldata: Use bool for socks5_gssapi_nec as it is a flag

This value is set to TRUE or FALSE so should be a bool and not a long.

8 years agourl: Ternary operator code style changes
Steve Holme [Sat, 9 Apr 2016 16:17:37 +0000 (17:17 +0100)]
url: Ternary operator code style changes

8 years agoCODE_STYLE: Added ternary operator example to 'Space around operators'
Steve Holme [Sat, 9 Apr 2016 16:04:46 +0000 (17:04 +0100)]
CODE_STYLE: Added ternary operator example to 'Space around operators'

Following conversation on the libcurl mailing list.

8 years agosasl: Fixed compilation errors from commit 9d89a0387
Steve Holme [Sat, 9 Apr 2016 04:57:10 +0000 (05:57 +0100)]
sasl: Fixed compilation errors from commit 9d89a0387

...when GSS-API or Windows SSPI are not used.

8 years agourl: Corrected comments following 9d89a0387
Steve Holme [Sat, 9 Apr 2016 04:33:03 +0000 (05:33 +0100)]
url: Corrected comments following 9d89a0387

8 years agodocs: Added clarification following commit 9d89a0387
Steve Holme [Fri, 8 Apr 2016 20:45:08 +0000 (21:45 +0100)]
docs: Added clarification following commit 9d89a0387

8 years agoMakefile: Fixed echo of checksrc check
Steve Holme [Fri, 8 Apr 2016 19:36:29 +0000 (20:36 +0100)]
Makefile: Fixed echo of checksrc check

8 years agochecksrc: Fix issue with the autobuilds not picking up the whitelist
Steve Holme [Fri, 8 Apr 2016 19:32:40 +0000 (20:32 +0100)]
checksrc: Fix issue with the autobuilds not picking up the whitelist

8 years agochecksrc: Added missing vauth and vtls directories
Steve Holme [Fri, 8 Apr 2016 19:22:14 +0000 (20:22 +0100)]
checksrc: Added missing vauth and vtls directories

8 years agoftp/imap/pop3/smtp: Allow the service name to be overridden
Steve Holme [Fri, 8 Apr 2016 17:59:33 +0000 (18:59 +0100)]
ftp/imap/pop3/smtp: Allow the service name to be overridden

Allow the service name to be overridden for DIGIST-MD5 and Kerberos 5
authentication in FTP, IMAP, POP3 and SMTP.

8 years agohttp_negotiate: Calculate service name and proxy service name locally
Steve Holme [Fri, 8 Apr 2016 17:41:41 +0000 (18:41 +0100)]
http_negotiate: Calculate service name and proxy service name locally

Calculate the service name and proxy service names locally, rather than
in url.c which will allow for us to support overriding the service name
for other protocols such as FTP, IMAP, POP3 and SMTP.

8 years agoROADMAP: Updated following the move of the authentication code
Steve Holme [Fri, 8 Apr 2016 16:04:25 +0000 (17:04 +0100)]
ROADMAP: Updated following the move of the authentication code