• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# Hyper
2
3Hyper is a separate HTTP library written in Rust. curl can be told to use this
4library as a backend to deal with HTTP.
5
6## Experimental!
7
8Hyper support in curl is considered **EXPERIMENTAL** until further notice. It
9needs to be explicitly enabled at build-time.
10
11Further development and tweaking of the Hyper backend support in curl will
12happen in the master branch using pull-requests, just like ordinary
13changes.
14
15## Hyper version
16
17The C API for Hyper is brand new and is still under development.
18
19## build curl with hyper
20
21Using Rust 1.64.0 or later, build hyper and enable its C API like this:
22
23     % git clone https://github.com/hyperium/hyper
24     % cd hyper
25     % RUSTFLAGS="--cfg hyper_unstable_ffi" cargo rustc --features client,http1,http2,ffi --crate-type cdylib
26
27Also, `--release` can be added for a release (optimized) build.
28
29Build curl to use hyper's C API:
30
31     % git clone https://github.com/curl/curl
32     % cd curl
33     % autoreconf -fi
34     % ./configure LDFLAGS="-Wl,-rpath,<hyper-dir>/target/debug -Wl,-rpath,<hyper-dir>/target/release" --with-openssl --with-hyper=<hyper-dir>
35     % make
36
37# using Hyper internally
38
39Hyper is a low level HTTP transport library. curl itself provides all HTTP
40headers and Hyper provides all received headers back to curl.
41
42Therefore, most of the "header logic" in curl as in responding to and acting
43on specific input and output headers are done the same way in curl code.
44
45The API in Hyper delivers received HTTP headers as (cleaned up) name=value
46pairs, making it impossible for curl to know the exact byte representation
47over the wire with Hyper.
48
49## Limitations
50
51The hyper backend does not support
52
53- `CURLOPT_IGNORE_CONTENT_LENGTH`
54- `--raw` and disabling `CURLOPT_HTTP_TRANSFER_DECODING`
55- RTSP
56- hyper is much stricter about what HTTP header contents it allows
57- leading whitespace in first HTTP/1 response header
58- HTTP/0.9
59- HTTP/2 upgrade using HTTP:// URLs. Aka 'h2c'
60- HTTP/2 in general. Hyper has support for HTTP/2 but the curl side
61  needs changes so that a `hyper_clientconn` can last for the duration
62  of a connection. Probably this means turning the Hyper HTTP/2 backend
63  into a connection filter.
64
65## Remaining issues
66
67This backend is still not feature complete with the native backend. Areas that
68still need attention and verification include:
69
70- multiplexed HTTP/2
71- h2 Upgrade:
72- receiving HTTP/1 trailers
73- sending HTTP/1 trailers
74