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