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.
Configurations

Configuration 1 (hide)

cpe:2.3:a:quinn_project:quinn:*:*:*:*:*:rust:*:*

History

No history.

Information

Published : 2024-09-02 18:15

Updated : 2024-09-25 17:03


NVD link : CVE-2024-45311

Mitre link : CVE-2024-45311

CVE.ORG link : CVE-2024-45311


JSON object : View

Products Affected

quinn_project

  • quinn
CWE
CWE-670

Always-Incorrect Control Flow Implementation