summaryrefslogtreecommitdiff
path: root/lib/ssl/tls13hashstate.h
diff options
context:
space:
mode:
authorKevin Jacobs <kjacobs@mozilla.com>2020-11-17 23:43:25 +0000
committerKevin Jacobs <kjacobs@mozilla.com>2020-11-17 23:43:25 +0000
commit2bd4e6f231c8e7c262495fed7c147b4cc67c834c (patch)
tree8061769b2983efc148bd7c5e9336d0bb79820e4a /lib/ssl/tls13hashstate.h
parent0961c8ab43fc3d5b8a446364366628035a4a2240 (diff)
downloadnss-hg-2bd4e6f231c8e7c262495fed7c147b4cc67c834c.tar.gz
Bug 1654332 - Update ESNI to draft-08 (ECH). r=mt
This patch adds support for Encrypted Client Hello (draft-ietf-tls-esni-08), replacing the existing ESNI (draft -02) support. There are five new experimental functions to enable this: - SSL_EncodeEchConfig: Generates an encoded (not BASE64) ECHConfig given a set of parameters. - SSL_SetClientEchConfigs: Configures the provided ECHConfig to the given socket. When configured, an ephemeral HPKE keypair will be generated for the CH encryption. - SSL_SetServerEchConfigs: Configures the provided ECHConfig and keypair to the socket. The keypair specified will be used for HPKE operations in order to decrypt encrypted Client Hellos as they are received. - SSL_GetEchRetryConfigs: If ECH is rejected by the server and compatible retry_configs are provided, this API allows the application to extract those retry_configs for use in a new connection. - SSL_EnableTls13GreaseEch: When enabled, non-ECH Client Hellos will have a "GREASE ECH" (i.e. fake) extension appended. GREASE ECH is disabled by default, as there are known compatibility issues that will be addressed in a subsequent draft. The following ESNI experimental functions are deprecated by this update: - SSL_EncodeESNIKeys - SSL_EnableESNI - SSL_SetESNIKeyPair In order to be used, NSS must be compiled with `NSS_ENABLE_DRAFT_HPKE` defined. Differential Revision: https://phabricator.services.mozilla.com/D86106
Diffstat (limited to 'lib/ssl/tls13hashstate.h')
-rw-r--r--lib/ssl/tls13hashstate.h6
1 files changed, 3 insertions, 3 deletions
diff --git a/lib/ssl/tls13hashstate.h b/lib/ssl/tls13hashstate.h
index e9a4aa84f..8126bd0db 100644
--- a/lib/ssl/tls13hashstate.h
+++ b/lib/ssl/tls13hashstate.h
@@ -18,8 +18,8 @@ SECStatus tls13_MakeHrrCookie(sslSocket *ss, const sslNamedGroupDef *selectedGro
PRUint8 *buf, unsigned int *len, unsigned int maxlen);
SECStatus tls13_GetHrrCookieLength(sslSocket *ss, unsigned int *length);
SECStatus tls13_RecoverHashState(sslSocket *ss,
- unsigned char *cookie,
- unsigned int cookieLen,
+ unsigned char *cookie, unsigned int cookieLen,
ssl3CipherSuite *previousCipherSuite,
- const sslNamedGroupDef **previousGroup);
+ const sslNamedGroupDef **previousGroup,
+ PRBool *previousEchOffered);
#endif