Expand description
TLS fingerprint profile types with JA3/JA4 representation.
ALPN preferences that match genuine browsers.
§Built-in profiles
Four static profiles ship with real-world TLS parameters:
| Profile | Browser |
|---|---|
CHROME_131 | Google Chrome 131 |
FIREFOX_133 | Mozilla Firefox 133 |
SAFARI_18 | Apple Safari 18 |
EDGE_131 | Microsoft Edge 131 |
§Example
use stygian_browser::tls::{CHROME_131, TlsProfile};
let profile: &TlsProfile = &*CHROME_131;
assert_eq!(profile.name, "Chrome 131");
let ja3 = profile.ja3();
assert!(!ja3.raw.is_empty());
assert!(!ja3.hash.is_empty());
let ja4 = profile.ja4();
assert!(ja4.fingerprint.starts_with("t13"));Structs§
- Cipher
Suite Id - TLS cipher-suite identifier (IANA two-byte code point).
- Http3
Perk SETTINGS|PSEUDO_HEADERS.- Http3
Perk Comparison - Result of comparing expected and observed HTTP/3 perk data.
- Ja4
- Example
- Ja3Hash
- Fields within each section are dash-separated.
- Signature
Algorithm - TLS signature algorithm identifier (IANA two-byte code point).
- TlsExtension
Id - TLS extension identifier (IANA two-byte code point).
- TlsProfile
- A complete TLS fingerprint profile matching a real browser’s
ClientHello.
Enums§
- Alpn
Protocol - Example
- Supported
Group - Named group (elliptic curve / key-exchange group) identifier.
- TlsVersion
- Example
Statics§
- CHROME_
131 - Google Chrome 131 TLS fingerprint profile.
- EDGE_
131 - Microsoft Edge 131 TLS fingerprint profile.
- FIREFOX_
133 - Mozilla Firefox 133 TLS fingerprint profile.
- SAFARI_
18 - Apple Safari 18 TLS fingerprint profile.
Functions§
- chrome_
tls_ args - What flags control
- expected_
http3_ perk_ from_ user_ agent - Build an expected HTTP/3 perk fingerprint from a User-Agent string.
- expected_
ja3_ from_ user_ agent - expected_
ja4_ from_ user_ agent - expected_
tls_ profile_ from_ user_ agent - Returns the
TlsProfilefor the given user-agent string, if known.