Euler Finance подвергся флеш-атаке займа, потеряв почти 200 миллионов долларов.

robot
Генерация тезисов в процессе

Проект Euler Finance стал жертвой флеш-атаки займа, убытки составили почти 200 миллионов долларов

13 марта 2023 года проект Euler Finance подвергся флеш-атака займа из-за уязвимости в контракте, что привело к убыткам в размере до 197 миллионов долларов. Атакующий воспользовался уязвимостью в функции donateToReserves контракта проекта, в которой отсутствовала проверка ликвидности, и получил огромную прибыль за счет многократных операций.

Анализ уязвимости Euler Finance: как произошла флеш-атака займа, убытки составили 197 миллионов долларов!

Анализ процесса атаки

  1. Нападающий сначала взял в долг 30 миллионов DAI через Срочные займы на одной из платформ, а затем развернул два контракта: контракт займа и контракт ликвидации.

  2. Атакующий заложил заимствованные 20 миллионов DAI в контракт Euler Protocol и получил 195000 eDAI.

  3. Используя функцию 10-кратного кредитного плеча протокола Euler, злоумышленник занял 1,956,000 eDAI и 2,000,000 dDAI.

  4. Нападающий использует оставшиеся 10 миллионов DAI для частичного погашения долга, уничтожает соответствующее количество dDAI, а затем снова занимает эквивалентное количество eDAI и dDAI.

  5. Ключевые шаги: злоумышленник вызывает функцию donateToReserves, жертвует 1 миллион eDAI, а затем через функцию liquidate ликвидирует, получая 3,1 миллиона dDAI и 2,5 миллиона eDAI.

  6. В конце концов, злоумышленник извлек 389000 DAI, вернул 300000 DAI по Срочным займам и в конечном итоге получил прибыль в 88700 DAI.

Анализ уязвимости Euler Finance: как произошла флеш-атака займа, убытки составили 197 миллионов долларов!

Анализ уязвимостей Euler Finance: как произошла флеш-атака займа, убыток составил 197 миллионов долларов!

Анализ уязвимости Euler Finance: как произошла флеш-атака займа, убыток составил 197 миллионов долларов!

Анализ уязвимости Euler Finance: как произошла флеш-атака займа, убыток составил 197 миллионов долларов!

Анализ уязвимостей Euler Finance: как произошла флеш-атака займа, убытки составили 197 миллионов долларов!

Анализ уязвимости Euler Finance: как произошла флеш-атака займа, убыток составил 197 миллионов долларов!

Анализ уязвимости Euler Finance: как произошла флеш-атака займа, убыток составил 197 миллионов долларов!

Анализ уязвимости Euler Finance: как произошла флеш-атака займа, убыток составил 197 миллионов долларов!

Анализ уязвимости Euler Finance: как произошла флеш-атака займа, убытки составили 1,97 миллиарда долларов!

Причины уязвимости

Основной уязвимостью данной атаки является отсутствие необходимых проверок ликвидности в функции donateToReserves контракта Euler Finance. В отличие от других ключевых функций, таких как mint, функция donateToReserves не выполняет операцию checkLiquidity. Это позволяет злоумышленникам обходить обычные проверки ликвидности, искусственно создавая состояние, которое можно ликвидировать, а затем завершать ликвидацию с прибылью.

В нормальных условиях функция checkLiquidity вызывает модуль RiskManager, чтобы обеспечить, что количество Etoken у пользователя больше, чем количество Dtoken, для поддержания безопасности контракта. Однако из-за отсутствия этого ключевого шага в функции donateToReserves злоумышленник смог воспользоваться этой уязвимостью для атаки.

Анализ уязвимости Euler Finance: как произошла флеш-атака займа, убытки составили 197 миллионов долларов!

Рекомендации по безопасности

В связи с такими атаками мы рекомендуем проектам на блокчейне:

  1. Провести полную безопасность аудит перед запуском контракта, чтобы гарантировать его безопасность.

  2. Для кредитных проектов необходимо особое внимание уделять таким ключевым аспектам, как погашение средств, ликвидность и ликвидация долгов.

  3. Убедитесь, что все функции, которые могут повлиять на состояние активов пользователей, содержат необходимые проверки безопасности, такие как проверка ликвидности.

  4. Регулярно проводить проверку и обновление кода, своевременно устранять обнаруженные уязвимости.

  5. Создание механизма экстренного реагирования, чтобы быстро реагировать и справляться с безопасностными инцидентами.

Приняв эти меры, проектная команда может значительно снизить риск遭受类似攻击 и повысить общую безопасность контракта.

EUL0.63%
Посмотреть Оригинал
На этой странице может содержаться сторонний контент, который предоставляется исключительно в информационных целях (не в качестве заявлений/гарантий) и не должен рассматриваться как поддержка взглядов компании Gate или как финансовый или профессиональный совет. Подробности смотрите в разделе «Отказ от ответственности» .
  • Награда
  • 5
  • Репост
  • Поделиться
комментарий
0/400
WhaleWatchervip
· 08-11 16:40
Снова пришли неудачники.
Посмотреть ОригиналОтветить0
Lonely_Validatorvip
· 08-10 08:22
Блокчейн безопасность сейчас такая плохая? Без слов.
Посмотреть ОригиналОтветить0
StakeWhisperervip
· 08-10 08:10
Еще одна ловушка для токенов
Посмотреть ОригиналОтветить0
GweiWatchervip
· 08-10 07:58
Снова запускают без проверки контракта?
Посмотреть ОригиналОтветить0
HalfBuddhaMoneyvip
· 08-10 07:54
Еще один проект с падением до нуля… собака в поводке
Посмотреть ОригиналОтветить0
  • Закрепить