mirror of
https://github.com/refraction-networking/utls.git
synced 2025-04-04 04:27:36 +03:00
feat: add GREASEEncryptedClientHelloExtension (#266)
* dicttls: update ECH-related entries * wip: GREASE ECH extension * new: GREASE ECH extension * fix: GREASE ECH Read must succeed with io.EOF * new: GREASE ECH multiple payload len * new: parse ECH in EncryptedExtensions * fix: ECHConfig Length always 0 * new: GREASE ECH parrots * new: (*Config).ECHConfigs Add (*Config).ECHConfigs for future full ECH extension. * new: add GREASE ECH example Add an incomplete example of using GREASE ECH extension (Chrome 120 parrot). * fix: invalid httpGetOverConn call fix a problem in old example where httpGetOverConn was called with uTlsConn.HandshakeState.ServerHello.AlpnProtocol, which will not be populated in case TLS 1.3 is used. * new: possible InnerClientHello length
This commit is contained in:
parent
9521fba944
commit
b4de442d02
19 changed files with 925 additions and 51 deletions
17
common.go
17
common.go
|
@ -306,6 +306,11 @@ type ConnectionState struct {
|
|||
|
||||
// ekm is a closure exposed via ExportKeyingMaterial.
|
||||
ekm func(label string, context []byte, length int) ([]byte, error)
|
||||
|
||||
// ECHRetryConfigs contains the ECH retry configurations sent by the server in
|
||||
// EncryptedExtensions message. It is only populated if the server sent the
|
||||
// ech extension in EncryptedExtensions message.
|
||||
ECHRetryConfigs []ECHConfig // [uTLS]
|
||||
}
|
||||
|
||||
// ExportKeyingMaterial returns length bytes of exported key material in a new
|
||||
|
@ -836,6 +841,17 @@ type Config struct {
|
|||
// autoSessionTicketKeys is like sessionTicketKeys but is owned by the
|
||||
// auto-rotation logic. See Config.ticketKeys.
|
||||
autoSessionTicketKeys []ticketKey
|
||||
|
||||
// ECHConfigs contains the ECH configurations to be used by the ECH
|
||||
// extension if any.
|
||||
// It could either be distributed by the server in EncryptedExtensions
|
||||
// message or out-of-band.
|
||||
//
|
||||
// If ECHConfigs is nil and an ECH extension is present, GREASEd ECH
|
||||
// extension will be sent.
|
||||
//
|
||||
// If GREASE ECH extension is present, this field will be ignored.
|
||||
ECHConfigs []ECHConfig // [uTLS]
|
||||
}
|
||||
|
||||
const (
|
||||
|
@ -921,6 +937,7 @@ func (c *Config) Clone() *Config {
|
|||
autoSessionTicketKeys: c.autoSessionTicketKeys,
|
||||
|
||||
PreferSkipResumptionOnNilExtension: c.PreferSkipResumptionOnNilExtension, // [UTLS]
|
||||
ECHConfigs: c.ECHConfigs, // [uTLS]
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue