summaryrefslogtreecommitdiff
path: root/docs/cmdline-opts/ech.md
blob: 3d8f3873af4d97d22eab7aefaf622bb2849a95fc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
---
c: Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al.
SPDX-License-Identifier: curl
Long: ech
Arg: <config>
Help: Configure ECH
Added: 8.8.0
Category: tls
Protocols: HTTPS
Multi: single
See-also:
  - doh-url
Example:
  - --ech true $URL
---

# `--ech`

Specify how to do ECH (Encrypted Client Hello).

The values allowed for \<config\> can be:

## `false`

Do not attempt ECH. The is the default.

## `grease`

Send a GREASE ECH extension

## `true`

Attempt ECH if possible, but do not fail if ECH is not attempted.
(The connection fails if ECH is attempted but fails.)

## `hard`

Attempt ECH and fail if that is not possible. ECH only works with TLS 1.3 and
also requires using DoH or providing an ECHConfigList on the command line.

## `ecl:<b64val>`

A base64 encoded ECHConfigList that is used for ECH.

## `pn:<name>`

A name to use to over-ride the `public_name` field of an ECHConfigList (only
available with OpenSSL TLS support)

##

Most ECH related errors cause error *CURLE_ECH_REQUIRED* (101).