Go to file
Stefan Eissing af22c2a546
vtls: localization of state data in filters
- almost all backend calls pass the Curl_cfilter intance instead of
   connectdata+sockindex
 - ssl_connect_data is remove from struct connectdata and made internal
   to vtls
 - ssl_connect_data is allocated in the added filter, kept at cf->ctx

 - added function to let a ssl filter access its ssl_primary_config and
   ssl_config_data this selects the propert subfields in conn and data,
   for filters added as plain or proxy
 - adjusted all backends to use the changed api
 - adjusted all backends to access config data via the exposed
   functions, no longer using conn or data directly

cfilter renames for clear purpose:

 - methods `Curl_conn_*(data, conn, sockindex)` work on the complete
   filter chain at `sockindex` and connection `conn`.
 - methods `Curl_cf_*(cf, ...)` work on a specific Curl_cfilter
   instance.
 - methods `Curl_conn_cf()` work on/with filter instances at a
   connection.
 - rebased and resolved some naming conflicts
 - hostname validation (und session lookup) on SECONDARY use the same
   name as on FIRST (again).

new debug macros and removing connectdata from function signatures where not
needed.

adapting schannel for new Curl_read_plain paramter.

Closes #9919
2022-11-22 14:25:50 +01:00
.circleci CI: skip make, do make install at once for dependencies 2022-09-13 15:42:10 +02:00
.github Makefile.mk: portable Makefile.m32 2022-11-22 08:28:41 +00:00
.lift
.reuse
CMake OtherTests.cmake: check for cross-compile, not for toolchain 2022-11-16 16:05:44 +01:00
docs examples/10-at-a-time: fix possible skipped final transfers 2022-11-22 03:34:01 -05:00
include CURLOPT_QUICK_EXIT: don't wait for DNS thread on exit 2022-11-18 00:17:27 +01:00
lib vtls: localization of state data in filters 2022-11-22 14:25:50 +01:00
LICENSES
m4 curl-rustls.m4: on macOS, rustls also needs the Security framework 2022-11-10 17:50:51 +01:00
packages Makefile.mk: portable Makefile.m32 2022-11-22 08:28:41 +00:00
plan9
projects headers: add endif comments 2022-11-09 00:36:33 +01:00
scripts scripts/delta: adapt to curl.h changes for the opt counter 2022-11-17 14:41:04 +01:00
src Makefile.mk: portable Makefile.m32 2022-11-22 08:28:41 +00:00
tests hyper: classify headers as CONNECT and 1XX 2022-11-19 13:01:12 +01:00
winbuild winidn: drop WANT_IDN_PROTOTYPES 2022-10-26 09:45:23 +00:00
zuul.d misc: typo and grammar fixes 2022-10-27 10:01:30 +02:00
.azure-pipelines.yml test972: verify the output without using external tool 2022-09-22 13:46:40 +02:00
.cirrus.yml CI/cirrus: remove superfluous double-quotes and sudo 2022-10-30 22:52:07 +01:00
.dcignore
.dir-locals.el
.git-blame-ignore-revs git: ignore large commit making the curl REUSE compliant 2022-06-13 09:14:07 +02:00
.gitattributes
.gitignore
.lgtm.yml
.mailmap mailmap: unify Stefan Eissing 2022-11-07 12:24:07 +01:00
acinclude.m4 functypes: provide the recv and send arg and return types 2022-09-28 09:06:11 +02:00
appveyor.yml CI: report AppVeyor build status for each job 2022-10-20 20:48:13 +02:00
buildconf
buildconf.bat
CHANGES
CMakeLists.txt lib: sync guard for Curl_getaddrinfo_ex() definition and use 2022-11-01 22:40:36 +00:00
configure.ac configure: require fork for NTLM-WB 2022-11-06 00:04:47 +01:00
COPYING
curl-config.in
GIT-INFO
libcurl.pc.in
MacOSX-Framework
Makefile.am
Makefile.dist Makefile.mk: portable Makefile.m32 2022-11-22 08:28:41 +00:00
maketgz maketgz: set the right version in lib/libcurl.plist 2022-11-08 10:46:12 +01:00
mlc_config.json
README docs: minor grammar fixes 2022-09-29 10:44:12 +02:00
README.md README.md: remove badges and xmas-tree garnish 2022-11-01 16:57:37 +01:00
RELEASE-NOTES RELEASE-NOTES: synced 2022-11-21 13:39:18 +01:00
SECURITY.md docs: spellfixes 2022-09-21 15:20:08 +02:00

curl logo

Curl is a command-line tool for transferring data specified with URL syntax. Find out how to use curl by reading the curl.1 man page or the MANUAL document. Find out how to install Curl by reading the INSTALL document.

libcurl is the library curl is using to do its job. It is readily available to be used by your software. Read the libcurl.3 man page to learn how.

You can find answers to the most frequent questions we get in the FAQ document.

Study the COPYING file for distribution terms.

Contact

If you have problems, questions, ideas or suggestions, please contact us by posting to a suitable mailing list.

All contributors to the project are listed in the THANKS document.

Commercial support

For commercial support, maybe private and dedicated help with your problems or applications using (lib)curl visit the support page.

Website

Visit the curl website for the latest news and downloads.

Git

To download the latest source from the Git server, do this:

git clone https://github.com/curl/curl.git

(you will get a directory named curl created, filled with the source code)

Security problems

Report suspected security problems via our HackerOne page and not in public.

Notice

Curl contains pieces of source code that is Copyright (c) 1998, 1999 Kungliga Tekniska Högskolan. This notice is included here to comply with the distribution terms.

Backers

Thank you to all our backers! 🙏 [Become a backer]

Sponsors

Support this project by becoming a sponsor.