据 Beosin Alert 监测,Pendle 上的 DeFi 协议 Penpie 遭遇黑客攻击,损失约 2700 万美元的加密资产。Beosin 对本次事件进行了如下简析:
攻击者利用 market 合约中的 claimRewards 函数进行重入质押,以增加 staking 合约的余额,随后将 taking 合约中多余的代币和质押资产提取,实现获利。
具体步骤如下:
1. 攻击者创建攻击合约,并通过官方的 factory 构建对应的 market 合约。
2. 调用 staking 合约的 batchHarvestMarketRewards 函数对该 market 进行奖励更新。
3. 在更新奖励时,会回调攻击合约的 claimRewards 函数,攻击者利用此函数进行重入,将闪电贷获取的资产进行质押,导致 staking 合约的资产数量出现差异,并将多余的部分提取出来。
4. 攻击者将质押的资产提取,并归还闪电贷,从而实现获利。