CVE-2024-45311
Quinn is a pure-Rust, async-compatible implementation of the IETF QUIC transport protocol. As of quinn-proto 0.11, it is possible for a server to `accept()`, `retry()`, `refuse()`, or `ignore()` an `Incoming` connection. However, calling `retry()` on an unvalidated connection exposes the server to a likely panic in the following situations: 1. Calling `refuse` or `ignore` on the resulting validated connection, if a duplicate initial packet is received. This issue can go undetected until a server's `refuse()`/`ignore()` code path is exercised, such as to stop a denial of service attack. 2. Accepting when the initial packet for the resulting validated connection fails to decrypt or exhausts connection IDs, if a similar initial packet that successfully decrypts and doesn't exhaust connection IDs is received. This issue can go undetected if clients are well-behaved. The former situation was observed in a real application, while the latter is only theoretical.
EPSS 0.58% · 69.1th percentile
Risk Scores
Affected Products
| Vendor | Product | Versions |
|---|---|---|
| crates.io | quinn-proto | 0.11.0 |
| quinn_project | quinn | 0.11.0 |
| quinn_project | quinn | 0.11.0 |
| quinn-rs | quinn | >= 0.11.0, < 0.11.7 |
Timeline
- Jan 21, 1970 Security Advisory
- Sep 2, 2024 CVE Published
- Sep 3, 2024 EPSS Score
- Sep 3, 2024 CVE Updated
- Sep 23, 2024 EPSS Score
- Oct 4, 2024 Coalition ESS Score
- Oct 13, 2024 EPSS Score
- Nov 2, 2024 EPSS Score
- Nov 22, 2024 EPSS Score
- Dec 13, 2024 EPSS Score
- Jan 2, 2025 EPSS Score
- Jan 22, 2025 EPSS Score
References
- https://github.com/quinn-rs/quinn/security/advisories/GHSA-vr26-jcq5-fjj8 url
- https://github.com/quinn-rs/quinn/commit/e01609ccd8738bd438d86fa7185a0f85598cb58f url
- https://github.com/quinn-rs/quinn/blob/bb02a12a8435a7732a1d762783eeacbb7e50418e/quinn-proto/src/endpoint.rs#L213 url
- https://nvd.nist.gov/vuln/detail/CVE-2024-45311 advisory
- https://github.com/quinn-rs/quinn package
- https://rustsec.org/advisories/RUSTSEC-2024-0373.html url