Описание
github.com/ipfs/go-bitswap vulnerable to DOS unbounded persistent memory leak
This package has been moved to github.com/ipfs/boxo/bitswap, this vulnerability is tracked there: https://github.com/ipfs/boxo/security/advisories/GHSA-m974-xj4j-7qv5 (CVE-2023-25568)
Remediation
This is a two step process:
- Apply one of:
- (recommended) upgrade from
github.com/ipfs/go-bitswaptogithub.com/ipfs/boxo/bitswap. - If you are still using
github.com/ipfs/go-bitswapand cannot upgrade toboxo, you can upgrade togithub.com/ipfs/go-bitswap@v0.12.0, this will replace thego-bitswapimplementation by stubs which points toboxo.
- (recommended) upgrade from
- Open https://github.com/ipfs/boxo/security/advisories/GHSA-m974-xj4j-7qv5 and then follow
boxo's remediation section.
Vulnerable symbols
>= v0.9.0; < v0.12.0github.com/ipfs/go-bitswap/server/internal/decision.(*Engine).MessageReceivedgithub.com/ipfs/go-bitswap/server/internal/decision.(*Engine).NotifyNewBlocksgithub.com/ipfs/go-bitswap/server/internal/decision.(*Engine).findOrCreategithub.com/ipfs/go-bitswap/server/internal/decision.(*Engine).PeerConnected
v0.8.0github.com/ipfs/go-bitswap/internal/decision.(*Engine).MessageReceivedgithub.com/ipfs/go-bitswap/internal/decision.(*Engine).NotifyNewBlocksgithub.com/ipfs/go-bitswap/internal/decision.(*Engine).findOrCreategithub.com/ipfs/go-bitswap/internal/decision.(*Engine).PeerConnected
< v0.8.0github.com/ipfs/go-bitswap/internal/decision.(*Engine).MessageReceivedgithub.com/ipfs/go-bitswap/internal/decision.(*Engine).receiveBlocksFromgithub.com/ipfs/go-bitswap/internal/decision.(*Engine).findOrCreategithub.com/ipfs/go-bitswap/internal/decision.(*Engine).PeerConnected
Workarounds
If you are using the stubs at github.com/ipfs/go-bitswap and not taking advantage of the features provided by the server, refactoring your code to use the new split API will allows you to run in a client-only mode using: github.com/ipfs/go-bitswap/client.
Ссылки
- https://github.com/ipfs/boxo/security/advisories/GHSA-m974-xj4j-7qv5
- https://github.com/ipfs/go-bitswap/security/advisories/GHSA-q3j6-22wf-3jh9
- https://github.com/ipfs/go-libipfs/security/advisories/GHSA-m974-xj4j-7qv5
- https://nvd.nist.gov/vuln/detail/CVE-2023-25568
- https://github.com/ipfs/boxo/commit/62cbac40b96f49e39cd7fedc77ee6b56adce4916
- https://github.com/ipfs/boxo/commit/9cb5cb54d40b57084d1221ba83b9e6bb3fcc3197
Пакеты
Наименование
github.com/ipfs/go-bitswap
go
Затронутые версииВерсия исправления
< 0.12.0
0.12.0
7.5 High
CVSS3
Дефекты
CWE-400
CWE-770
7.5 High
CVSS3
Дефекты
CWE-400
CWE-770