web3.py позволяет вам взаимодействовать с блокчейном Ethereum с помощью Python. Начиная с версий 6.0.0b3 и до версий 7.15.0 и 8.0.0b2, web3.py реализует CCIP Read/OffchainLookup (EIP-3668), выполняя HTTP-запросы к URL-адресам, предоставленным смарт-контрактами в offchain_lookup_payload["urls"]. Реализация использует эти URL-адреса, предоставленные контрактом, напрямую (после замены шаблона {sender} / {data}) без какой-либо проверки места назначения.
Чтение CCIP включено по умолчанию (global_ccip_read_enabled = True для всех поставщиков), что означает, что любое приложение, использующее метод .call() в web3.py, предоставляется без явного согласия. Это приводит к подделке запросов на стороне сервера (SSRF), когда web3.py используется во внутренних службах, индексаторах, API или любой среде, которая выполняет eth_call/.call() для ненадежных или предоставленных пользователем адресов контракта. Вредоносный контракт может заставить процесс web3.py отправлять HTTP-запросы в произвольные места назначения, включая внутренние сетевые службы и конечные точки облачных метаданных.
Эта уязвимость исправлена в версиях 7.15.0 и 8.0.0b2.
Показать оригинальное описание (EN)
web3.py allows you to interact with the Ethereum blockchain using Python. From 6.0.0b3 to before 7.15.0 and 8.0.0b2, web3.py implements CCIP Read / OffchainLookup (EIP-3668) by performing HTTP requests to URLs supplied by smart contracts in offchain_lookup_payload["urls"]. The implementation uses these contract-supplied URLs directly (after {sender} / {data} template substitution) without any destination validation. CCIP Read is enabled by default (global_ccip_read_enabled = True on all providers), meaning any application using web3.py's .call() method is exposed without explicit opt-in. This results in Server-Side Request Forgery (SSRF) when web3.py is used in backend services, indexers, APIs, or any environment that performs eth_call / .call() against untrusted or user-supplied contract addresses. A malicious contract can force the web3.py process to issue HTTP requests to arbitrary destinations, including internal network services and cloud metadata endpoints. This vulnerability is fixed in 7.15.0 and 8.0.0b2.
Характеристики атаки
Последствия
Строка CVSS v4.0