Description
js-libp2p is the official javascript Implementation of libp2p networking stack. Versions older than `v0.38.0` of js-libp2p are vulnerable to targeted resource exhaustion attacks. These attacks target libp2p’s connection, stream, peer, and memory management. An attacker can cause the allocation of large amounts of memory, ultimately leading to the process getting killed by the host’s operating system. While a connection manager tasked with keeping the number of connections within manageable limits has been part of js-libp2p, this component was designed to handle the regular churn of peers, not a targeted resource exhaustion attack. Users are advised to update their js-libp2p dependency to `v0.38.0` or greater. There are no known workarounds for this vulnerability.
Remediation
References
https://github.com/libp2p/js-libp2p/security/advisories/GHSA-f44q-634c-jvwv
Related Vulnerabilities
CVE-2016-10735 Vulnerability in maven package org.webjars.bower:bootstrap
CVE-2016-6794 Vulnerability in maven package org.apache.tomcat.embed:tomcat-embed-core
CVE-2019-9512 Vulnerability in maven package io.netty:netty-codec-http2
CVE-2020-27223 Vulnerability in maven package org.eclipse.jetty:jetty-server
CVE-2021-32827 Vulnerability in maven package org.mock-server:mockserver-core