93 releases
new 0.16.0 | Jan 12, 2025 |
---|---|
0.16.0-rc.1 | Feb 21, 2024 |
0.15.4 | Sep 10, 2023 |
0.15.2 | Apr 27, 2023 |
0.2.5 | Nov 29, 2020 |
#10 in HTTP client
36,576 downloads per month
Used in 22 crates
(20 directly)
3MB
61K
SLoC
twilight-http
HTTP support for the twilight ecosystem.
Examples
There are a few usage examples located in the root of the twilight
repository.
Features
Crypto provider
Using rustls
for TLS requires configuring a crypto provider via crate
features or manually installing a global default. The default is rustls-ring
.
rustls-ring
The rustls-ring
feature will enable the use of ring
as the crypto
provider. This is recommended for platform compatibility.
rustls-aws_lc_rs
The rustls-aws_lc_rs
feature will enable the use of aws-lc-rs
as the
crypto provider. This is recommended for performance and on widely used
platforms.
Manual installation
If none of the other crypto providers are enabled, a custom one must be
installed by the application using CryptoProvider::install_default
.
Decompression
The decompression
feature enables brotli decompression support via the brotli
crate.
This is enabled by default.
Deserialization
twilight-http
supports serde_json
and simd-json
for deserializing
responses.
simd-json
The simd-json
feature enables simd-json
support to use simd features
of modern cpus to deserialize responses faster. It is not enabled by
default.
To use this feature you need to also add these lines to
<project root>/.cargo/config
:
[build]
rustflags = ["-C", "target-cpu=native"]
You can also set the environment variable
RUSTFLAGS="-C target-cpu=native"
. If you enable both serde_json
and
simd-json
at the same time, then simd-json
will be used.
To enable simd-json
, do something like this in your Cargo.toml
:
[dependencies]
twilight-http = { default-features = false, features = ["rustls-native-roots", "simd-json"], version = "0.2" }
TLS
Note: not enabling any TLS feature is supported for use behind a proxy; Discord's API is HTTPS only.
twilight-http
has features to enable HTTPS connectivity with hyper
. These
features are mutually exclusive. rustls-platform-verifier
is enabled by default.
native-tls
The native-tls
feature uses a HTTPS connector provided by hyper-tls
.
To enable native-tls
, do something like this in your Cargo.toml
:
[dependencies]
twilight-http = { default-features = false, features = ["native"], version = "0.2" }
rustls-native-roots
The rustls-native-roots
feature uses a HTTPS connector provided by hyper-rustls
, which uses
rustls
as the TLS backend, and enables its native-tokio
feature, which uses rustls-native-certs
for root certificates. This requires configuring a crypto provider.
rustls-platform-verifier
The rustls-platform-verifier
feature uses a HTTPS connector provided by hyper-rustls
, which uses
rustls
as the TLS backend, and enables its rustls-platform-verifier
feature, which uses
rustls-platform-verifier
for certificate validation. This requires configuring a crypto provider.
This is enabled by default.
rustls-webpki-roots
The rustls-webpki-roots
feature uses a HTTPS connector provided by hyper-rustls
, which uses
rustls
as the TLS backend, and enables its webpki-tokio
feature, which uses webpki-roots
for root certificates. This requires configuring a crypto provider.
This should be preferred over rustls-native-roots
in Docker containers based on scratch
.
Trust-DNS
The hickory
feature enables hyper-hickory
, which replaces the default
GaiResolver
in hyper
. hyper-hickory
instead provides a fully async
DNS resolver on the application level.
Dependencies
~8–31MB
~588K SLoC