mirror of
https://github.com/refraction-networking/utls.git
synced 2025-04-03 20:17:36 +03:00
feat: Convert raw bytes or tlsfingerprint record to ClientHelloSpec (#168)
* feat: byte to clienthellospecs conversion * feat: specific case for GREASE and ALPS Will automatically add "h2" to ALPS and write to log when GREASE extension is imported in `ImportTLSClientHello()` * fix: ReadCompressionMethods ReadCompressionMethods didn't advance the s and fails reading extensions * fix: remove debug log * fix: use cryptobyte for internal helper `helper.Uint8to16()` now calls `(*cryptobyte.String).ReadUint16()` * fix: preshared key fingerprinter test updated fingerprinter test to test with PreSharedKey extension * fix: naming of FakePreSharedKeyExt It is a Fake extension since `crypto/tls` doesn't really implement PSK-based resumption and neither do we. * feat: Properly check GREASE Adopted from #148. Co-Authored-By: gfw-report <gfw.report@protonmail.com> * feat: add fakeExtensionEncryptThenMAC And reordered `fakeExtensionDelegatedCredentials`. The new `Fingerprinter` is expected to account for the `fakeExtensionEncryptThenMAC` using a `GenericExtension` when `allowBluntMimicry` is set. Co-Authored-By: gfw-report <gfw.report@protonmail.com> * fix: remove keepPSK and minor - Removed all presence of keepPSK flag. - Added check before using the field of a map. --------- Co-authored-by: gfw-report <gfw.report@protonmail.com>
This commit is contained in:
parent
71b4ad3909
commit
dae72adb81
10 changed files with 961 additions and 366 deletions
|
@ -501,12 +501,6 @@ func TestUTLSFingerprintClientHelloKeepPSK(t *testing.T) {
|
|||
}
|
||||
|
||||
f := &Fingerprinter{}
|
||||
_, err = f.FingerprintClientHello(helloBytes)
|
||||
if err == nil {
|
||||
t.Errorf("expected error generating spec from client hello with PSK")
|
||||
}
|
||||
|
||||
f = &Fingerprinter{KeepPSK: true}
|
||||
generatedSpec, err := f.FingerprintClientHello(helloBytes)
|
||||
if err != nil {
|
||||
t.Errorf("got error: %v; expected to succeed", err)
|
||||
|
@ -514,10 +508,8 @@ func TestUTLSFingerprintClientHelloKeepPSK(t *testing.T) {
|
|||
}
|
||||
|
||||
for _, ext := range generatedSpec.Extensions {
|
||||
if genericExtension, ok := (ext).(*GenericExtension); ok {
|
||||
if genericExtension.Id == extensionPreSharedKey {
|
||||
return
|
||||
}
|
||||
if _, ok := (ext).(*FakePreSharedKeyExtension); ok {
|
||||
return
|
||||
}
|
||||
}
|
||||
t.Errorf("generated ClientHelloSpec with KeepPSK does not include preshared key extension")
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue