Fork of the Go standard TLS library, providing low-level access to the ClientHello for mimicry purposes.
Find a file
Johan Brandhorst 3b66a0b37e crypto/tls: add HandshakeContext method to Conn
Adds the (*tls.Conn).HandshakeContext method. This allows
us to pass the context provided down the call stack to
eventually reach the tls.ClientHelloInfo and
tls.CertificateRequestInfo structs.
These contexts are exposed to the user as read-only via Context()
methods.

This allows users of (*tls.Config).GetCertificate and
(*tls.Config).GetClientCertificate to use the context for
request scoped parameters and cancellation.

Replace uses of (*tls.Conn).Handshake with (*tls.Conn).HandshakeContext
where appropriate, to propagate existing contexts.

Fixes #32406

Change-Id: I33c228904fe82dcf57683b63627497d3eb841ff2
Reviewed-on: https://go-review.googlesource.com/c/go/+/246338
Run-TryBot: Filippo Valsorda <filippo@golang.org>
TryBot-Result: Go Bot <gobot@golang.org>
Trust: Roland Shoemaker <roland@golang.org>
Reviewed-by: Filippo Valsorda <filippo@golang.org>
2020-11-09 18:34:47 +00:00
testdata crypto/tls: rotate session keys in older TLS versions 2020-05-07 18:33:39 +00:00
alert.go crypto/tls: add missing alert values 2020-04-01 19:32:57 +00:00
auth.go crypto: fix PKCS space in docs 2020-07-08 17:21:49 +00:00
auth_test.go crypto/tls: add {SignatureScheme,CurveID,ClientAuthType}.String() 2020-03-11 20:02:18 +00:00
cipher_suites.go crypto/tls: add CipherSuites, InsecureCipherSuites and CipherSuiteName 2019-11-12 01:09:31 +00:00
common.go crypto/tls: add HandshakeContext method to Conn 2020-11-09 18:34:47 +00:00
common_string.go crypto/tls: add {SignatureScheme,CurveID,ClientAuthType}.String() 2020-03-11 20:02:18 +00:00
conn.go crypto/tls: add HandshakeContext method to Conn 2020-11-09 18:34:47 +00:00
conn_test.go crypto/tls: select only compatible chains from Certificates 2019-11-12 01:08:57 +00:00
example_test.go crypto/tls: replace VerifyPeerCertificate example with VerifyConnection 2020-06-24 20:48:12 +00:00
generate_cert.go crypto/tls: create certs w/o KeyEncipherment KU for non-RSA keys in generate_cert.go 2020-07-03 03:31:29 +00:00
handshake_client.go crypto/tls: add HandshakeContext method to Conn 2020-11-09 18:34:47 +00:00
handshake_client_test.go crypto/tls: add HandshakeContext method to Conn 2020-11-09 18:34:47 +00:00
handshake_client_tls13.go crypto/tls: add HandshakeContext method to Conn 2020-11-09 18:34:47 +00:00
handshake_messages.go crypto/tls: send ec_points_format extension in ServerHello 2019-10-31 15:14:45 +00:00
handshake_messages_test.go crypto/tls: rotate session keys in older TLS versions 2020-05-07 18:33:39 +00:00
handshake_server.go crypto/tls: add HandshakeContext method to Conn 2020-11-09 18:34:47 +00:00
handshake_server_test.go crypto/tls: add HandshakeContext method to Conn 2020-11-09 18:34:47 +00:00
handshake_server_tls13.go crypto/tls: add HandshakeContext method to Conn 2020-11-09 18:34:47 +00:00
handshake_test.go crypto/tls: add no-shared to openssl build instructions 2020-10-24 00:32:11 +00:00
handshake_unix_test.go crypto/tls: retry net.Dial flakes on Dragonfly 2019-10-21 19:06:29 +00:00
key_agreement.go crypto: fix PKCS space in docs 2020-07-08 17:21:49 +00:00
key_schedule.go math/big: add (*Int).FillBytes 2020-05-05 00:36:44 +00:00
key_schedule_test.go crypto/tls: implement TLS 1.3 cryptographic computations 2018-11-02 21:54:52 +00:00
link_test.go crypto/tls: fix TestLinkerGC test 2020-09-29 14:36:12 +00:00
prf.go crypto/tls: improve error messages for invalid certificates and signatures 2019-10-30 20:18:59 +00:00
prf_test.go crypto/tls: remove SSLv3 support 2019-08-27 22:24:05 +00:00
ticket.go crypto/tls: remove version check when unmarshaling sessionState 2020-05-18 23:09:31 +00:00
tls.go crypto/tls: add HandshakeContext method to Conn 2020-11-09 18:34:47 +00:00
tls_test.go all: update references to symbols moved from io/ioutil to io 2020-10-20 18:41:18 +00:00