SDT:Yearn Finance 被黑简析

据慢雾区情报,2023 年 4 月 13 日,去中心化收益聚合平台 Yearn Finance 遭到攻击,攻击者获利超千万美金。慢雾安全团队以简讯的形式分享如下:

相关信息

Yearn 的 yUSDT 合约设计存在 aUSDT、dydx 头寸、iUSDC 与 cUSDT 储备,用户在 deposit/withdraw 时会根据上述储备余额计算用户所能获得的份额/所需存款的数额。

攻击核心点

此次攻击的原因在于攻击者利用 yUSDT 合约被错误设置了 fulcrum 地址,从而操控 yUSDT 合约中的稳定币储备余额,通过在 yUSDT 中存入 USDT,以获得大量的非预期的 yUSDT 代币进行获利。

Yearn Finance:因Euler被盗间接损失138万美元,将使用Treasury资金足额承担:金色财经报道,Yearn Finance发推称,虽然对Euler没有直接的风险敞口,但一些vaults却间接暴露于黑客攻击。

采用Idle和Angle策略的vaults在yvUSDT和yvUSDC上的风险敞口总计138万美元。

开发者目前正在积极处理受影响的协议,任何剩余的坏账将由Yearn Treasury承担,所有vaults都将保持开放并全面运作,用户可以照常使用。[2023/3/14 13:01:53]

OKCoin:未受Yearn v1 yDAI vault遭攻击事件影响,资金安全:针对Yearn v1 yDAI vault遭攻击事件,OKCoin发推表示,根据调查,可以确认所有OKCoin的帐户和资金都是安全的。此前消息,2月4日,Yearn v1 yDAI vault遭到攻击,攻击者窃取280万美元。[2021/2/8 19:11:45]

具体细节分析

1、攻击者首先通过闪电贷借出大量的 DAI、USDC 和 USDT,接着通过 Curve 的 ySwap 将 DAI 和 USDC 换成 USDT,以消耗 yUSDT 合约中的 aUSDT 储备。

2、接着攻击者为 Aave Pool v1 上存在负债的用户还款,目的是增加 Aave Pool v1 中的 USDT 数额,以便 yUSDT 中的 aUSDT 能够顺利被赎回。

独家 | yearn锁仓金额较上周上涨6倍:据DappBirds DeFi Data专题数据显示,yearn锁仓金额较上周上涨6倍,DeFi中锁定资产总价值达82.44亿美元,较昨日上涨1.68%,其中Maker,Aave,Curve,Synthetix,Compound分别以14.60亿美元,12.80亿美元,10.70亿美元,8.58亿美元,7.95亿美元位列前五名[2020/8/21]

3、紧跟着调用 yUSDT 合约的 deposit 函数进行 USDT 存款,得到相对应的 yUSDT 代币。为后续通过 withdraw 清空 yUSDT 中 aUSDT 储备做准备。

yearn.finance为DAI和USDT增加Vault:yearn.finance发推称,现已增加DAI和USDT的Vault。LINK的存款Vault已被禁用(取款仍可用)。你可以保留资金,没有风险,我们将转移到一个新的Vault,以避免存款-0.5% APR显示(当Gas较低时)。[2020/8/13]

4、为了确保 withdraw 时能够清空 yUSDT 中 aUSDT 储备,攻击者调用 iUSDC 合约的 mint 函数铸造 iUSDC 后,将 iUSDC 直接转给 yUSDT 合约,为 yUSDT 合约增加储备深度。

5、随后攻击者调用 yUSDT 合约的 withdraw 函数进行取款,由于此时 provider 指定为 AAVE,因此 yUSDT 会通过 Aave Pool v1 赎回 USDT 给提款人。

6、由于攻击者在之前通过 iUSDC 增加了合约中的储备,因此在此次提现中可以将 yUSDT 里的 aUSDT 储备全部清空。

7、此时 yUSDT 合约中的 aUSDT、dydx 头寸与 cUSDT 储备都被操控为 0 了。最后,为清空 iUSDC 储备,攻击者调用 yUSDT 合约的 rebalance 函数,进行储备更新。

8、由于此时 yUSDT 中只剩余 iUSDC,因此合约的新 provider 将会被指向iUSDC,导致 Rebalance 函数会先进行 _withdrawAll 操作,再通过余额获取的方式更新储备。

9、而在 _withdrawAll 操作中会燃烧掉 iUSDC 以获得 USDC 代币,但在更新储备时获取的是 yUSDT 合约中 USDT 的余额。因此 fulcrum 储备被错误的指向了 iUSDC,导致此时 yUSDT 合约储备被操控为 0。

10、攻击者为确保能通过存款获得大量的 yUSDT,向 yUSDT 合约中转入 1 wei 的 USDT。

11、最后,攻击者调用 yUSDT 的存款函数,存入 10,000 枚 USDT,获得 1,252,660,242,850,000 枚 yUSDT,并通过 curve 将 yUSDT 换成大量的 yDAI、yUSDC、yTUSD。

总结

本次攻击事件是由于 Yearn Finance 的 yUSDT 合约错误的配置导致的。慢雾安全团队建议在对协议进行配置时,应仔细检查所有参数是否符合预期并进行充分的测试以确保协议的安全。

慢雾科技

个人专栏

阅读更多

金色财经 善欧巴

Chainlink预言机

金色早8点

白话区块链

Odaily星球日报

Arcane Labs

深潮TechFlow

欧科云链

BTCStudy

MarsBit

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

链链资讯

[0:0ms0-2:533ms