Description
libp2p is a networking stack and library modularized out of The IPFS Project, and bundled separately for other tools to use. In go-libp2p, by using signed peer records a malicious actor can store an arbitrary amount of data in a remote node’s memory. This memory does not get garbage collected and so the victim can run out of memory and crash. If users of go-libp2p in production are not monitoring memory consumption over time, it could be a silent attack i.e. the attacker could bring down nodes over a period of time (how long depends on the node resources i.e. a go-libp2p node on a virtual server with 4 gb of memory takes about 90 sec to bring down; on a larger server, it might take a bit longer.) This issue was patched in version 0.27.4.
References (4)
Core 4
Core References
Vendor Advisory x_refsource_confirm
https://github.com/libp2p/go-libp2p/security/advisories/GHSA-gcq9-qqwx-rgj3
Patch x_refsource_misc
https://github.com/libp2p/go-libp2p/commit/45d3c6fff662ddd6938982e7e9309ad5fa2ad8dd
Release Notes x_refsource_misc
https://github.com/libp2p/go-libp2p/releases/tag/v0.27.4
Release Notes x_refsource_misc
https://github.com/libp2p/go-libp2p/releases/tag/v0.27.7
Scores
CVSS v3
7.5
EPSS
0.0032
EPSS Percentile
54.6%
Attack Vector
NETWORK
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H
CISA SSVC
Vulnrichment
Exploitation
none
Automatable
yes
Technical Impact
partial
Details
CWE
CWE-400
Status
published
Products (2)
libp2p/go-libp2p
0 - 0.27.4Go
protocol/libp2p
< 0.27.4
Published
Aug 25, 2023
Tracked Since
Feb 18, 2026