Lucene search

K
vulnrichmentGitHub_MVULNRICHMENT:CVE-2024-22189
HistoryApr 04, 2024 - 2:25 p.m.

CVE-2024-22189 QUIC's Connection ID Mechanism vulnerable to Memory Exhaustion Attack

2024-04-0414:25:43
CWE-770
GitHub_M
github.com
2
quic-go
quic protocol
memory exhaustion attack
new_connection_id frames
retire_connection_id frames
congestion window
rtt estimate

CVSS3

7.5

Attack Vector

NETWORK

Attack Complexity

LOW

Privileges Required

NONE

User Interaction

NONE

Scope

UNCHANGED

Confidentiality Impact

NONE

Integrity Impact

NONE

Availability Impact

HIGH

CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H

SSVC

Exploitation

none

Automatable

yes

Technical Impact

partial

quic-go is an implementation of the QUIC protocol in Go. Prior to version 0.42.0, an attacker can cause its peer to run out of memory sending a large number of NEW_CONNECTION_ID frames that retire old connection IDs. The receiver is supposed to respond to each retirement frame with a RETIRE_CONNECTION_ID frame. The attacker can prevent the receiver from sending out (the vast majority of) these RETIRE_CONNECTION_ID frames by collapsing the peers congestion window (by selectively acknowledging received packets) and by manipulating the peer’s RTT estimate. Version 0.42.0 contains a patch for the issue. No known workarounds are available.

ADP Affected

[
  {
    "cpes": [
      "cpe:2.3:a:quic-go_project:quic-go:*:*:*:*:*:*:*:*"
    ],
    "vendor": "quic-go_project",
    "product": "quic-go",
    "versions": [
      {
        "status": "affected",
        "version": "0",
        "lessThan": "0.42.0",
        "versionType": "custom"
      }
    ],
    "defaultStatus": "unknown"
  }
]

CVSS3

7.5

Attack Vector

NETWORK

Attack Complexity

LOW

Privileges Required

NONE

User Interaction

NONE

Scope

UNCHANGED

Confidentiality Impact

NONE

Integrity Impact

NONE

Availability Impact

HIGH

CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H

SSVC

Exploitation

none

Automatable

yes

Technical Impact

partial