
代币YELD价格直接跳水归零:PolyYeld Finance被攻击事件全解析
北京时间7月28日,安全公司Rugdoc在推特表示,收益耕作协议PolyYeld Finance遭到攻击,所有者已宣布合约已被利用并铸造了大量YELD代币。CoinGeckko行情显示,YELD代币价格直线跳水归零,狂跌100%。
事件概览
攻击如何发生 Event overview
PolyYeld Finance 是 Polygon 网络上的下一代产量农业协议,具有许多独特和创造性的功能,使用户能够获得被动收入。
据悉,项目正在尝试创建一个类似于 Yearn 的协议,以减少对 Polygon Network 用户、LP 提供商和抵押者高价值的代币供应。在 2-3 个月的时间里,只会铸造 62100 个 YELD 代币。
北京时间7月28日,PolyYeld Finance意外遭到黑客“血洗”,被攻击之后,YELD代币价格直线跳水归零,狂跌100% !
这一次,黑客攻击使YELD代币价格直线跳水归零,可谓损失惨重。成都链安再次提醒各大项目方,一定要注意安全防范工作。
事件具体分析
攻击者如何得手 Event overview
整个攻击事件由黑客一手策划。攻击者利用xYELD代币转账时实际到账数量小于发送数量以及MasterChef合约抵押和计算奖励上存在的逻辑缺陷,通过投入大量资金控制MasterChef合约中抵押池的抵押代币数量,进而操纵奖励计算,从而获得巨额的xYELD奖励代币,最后利用QuickSwap套现离场。
攻击者地址:
0xa4bc39ff54e1b682b366b57d1f6b114a829f5c01
攻击合约:
A:0x1BdF24CB4c7395Bf6260Ebb7788c1cBf127E14c7
B:0x56ec01726b15b83c25e8c1db465c3b7f1d094756
攻击交易:
0x3c143d2a211f7448c4de6236e666792e90b2edc8f5035c3aa992fd7d7daca974
0x10eeb698a2cd2a5e23d526b2d59d39a15263be018dbbda97dad4f9fa8c70347f
Round 1
攻击者首先利用QuickSwap交易对将29.75 WETH换成527.695171116557304754 xYELD代币。
接下来,攻击者通过攻击合约在一笔交易反复调用MasterChef合约中的抵押提取函数将MasterChef中PID为16的抵押池中的xYELD代币数量减少0到最小值。
由于xYELD代币在转移时,如果recipient地址不是BURN_ADDRESS地址,变量transferTaxRate的值不为0,recipient地址在_isExcluded映射中对应的值不为true,并且发送者不为合约的拥有者,就会收取一定比例的手续费,当前比例为3%。手续费会转移到代币合约中,在满足特定条件后,会将收取的手续费作为流动性添加到对应交易对中去。
而在MasterChef合约中,抵押数量记录的是代币转移的初始数量,而不是实际到账数量。在进行提取操作时,可提取的数量为记录的数量,超出了用户实际抵押到本合约中的数量,因为在完成一次抵押提取操作后,该抵押池中的xYELD代币便会异常减少。
在进行攻击前MasterChef中的xYELD代币的数量为242.017807511865297458:
在进行攻击后MasterChef中的xYELD代币的数量为0.000000000000000001:
Round 2
攻击者事先通过攻击合约B在该抵押池中抵押0.009789171908299592 xYELD代币,并将推荐人设置为攻击合约A。在攻击合约A攻击完成后,控制攻击合约A在该抵押池中进行奖励领取,由于MasterChef合约中更新抵押池信息时使用的是balanceOf函数获取本合约中抵押代币数量,故获取到的数量是恶意减少之后的数量。
这会造成xYFLD抵押池中accYeldPerShare变量异常增大:
从而使得奖励变为巨额:
Round 3
在进行奖励发放时,由于计算出来的奖励数量远超过实际铸币数量,故将本合约中所有的YELD代币转移给攻击合约B,通过获取奖励得到的奖励代币数量为:3031.194777597579576657 YELD。
同时,因为攻击合约B的推荐人是攻击合约A,故在攻击合约B领取奖励时会对攻击合约A发放推荐奖励,计算方式为被推荐人获取的奖励的2%。由于传入的_pending数量为异常大的值,故攻击合约A获得的推荐奖励也为异常大的数量,攻击合约获得的推荐奖励为:
4995853249752.895065839722805591 YELD。
最后攻击者利用QuickSwap将所有的YELD代币兑换成USDC、WETH和MATIC套现离场。
事件复盘
我们需要注意什么 Case Review
本次事件与之前SafeDollar攻击事件类似,都是使用了相同的攻击手法。不同之处有两点:其一是此次攻击攻击者没有选择利用闪电贷来获取大量资金,而是投入了29.75 WETH作为攻击的初始资金;其二是MasterChef合约中推荐奖励机制的问题,正是这个推荐奖励机制将本次攻击的危害无限放大了。
MasterChef类型抵押池设计之时,还没有通缩通胀类代币的出现,故开发者并没有考虑这类代币可能会造成的影响。部分的项目方在进行代码开发时,直接使用了旧的MasterChef代码,并添加了通缩通胀类代币或者奖励作为抵押代币,这便导致了各种恶意攻击事件或异常情况的产生。就目前来看,MasterChef类型抵押池存在两种类型的问题:一是没有对通胀通缩类代币进行特殊处理,没有检查实际转移到合约中的代币数量是否与函数调用时填写的数量相同;二是添加了奖励代币作为抵押代币,导致奖励计算出现异常。
两种类型问题的根本原因还是在于计算奖励时,获取抵押量使用了balanceOf函数来获取。建议项目方在进行MasterChef类型抵押池代码开发时,使用一个单独的变量作为抵押数量的记录,然后计算奖励时,通过此变量来获取抵押代币数量,而不是使用balanceOf函数。
比推快讯
更多 >>- 标普 500 涨幅扩大至 1%,纳指涨幅扩大至 1.5%
- 某机构地址通过 OSL 买入 1.4 万枚 ETH,约合 5000 万美元
- Sky 上周斥资 139 万美元回购 1655 万枚 SKY
- 数据:灰度向 Coinbase 地址转移总计 24,134 枚 ETH
- 美股加密股开盘涨跌不一,SBET、VAPE 涨超 8%
- 市场消息:欧盟将暂停对美国的贸易反制措施 6 个月
- 加密交易平台 Bullish 拟在 IPO 中筹集 6.29 亿美元资金
- 前高盛 ETF 业务主管加入 Centrifuge 担任首席运营官
- 灰度扩充管理团队并任命创始人为董事会主席
- 瑞银:8 月美股或面临回调压力,或将出现战略性建仓窗口
- 高盛:特朗普解雇美国劳工局局长对美元不利
- 智能机器去中心化操作系统 OpenMind 完成 2000 万美元融资,Pantera Capital 领投
- 数据:过去 24 小时全网爆仓 1.35 亿美元,多单爆仓 4138.53 万美元,空单爆仓 9360.18 万美元
- 两鲸鱼地址过去 6 小时增持 39,921 枚 ETH,约合 1.42 亿美元
- 新TON 版微策略VERB 盘前涨约 70%,市值仅 1348.47 万美元
- MARA 七月比特币产量环比下降 1%,比特币持仓突破 5 万枚
- Empery Digital 增持 110 枚 BTC,目前总共拥有 3,913 枚
- DeFi Development 增持 110,466 枚 SOL,总持有量逾 129 万枚
- Verb Technology 拟进行 5.58 亿美元私募融资以启动 TON 储备策略
- 美股制药公司 Artelo 宣布启动 Solana 储备资产战略
- Ether Machine 再购 1.06 万枚 ETH,总持仓超 34.5 万枚
- 比特币资产管理公司 ProCap BTC 任命 Bitwise Alpha 策略主管 Jeff Park 担任首席投资官
- The Ether Machine 宣布增持 10,605 枚 ETH,总持仓达 345,362 枚
- GameSquare 加仓买入 2717 枚 ETH,总持仓升至 15,630 枚
- Strategy 上周加仓买入 21,021 枚 BTC,花费 24.6 亿美元
- 瑞典上市公司 Goobit 集团启动比特币储备战略
- 过去一个月贝莱德 IBIT、ETHA 净流入仅次于 Vanguard 的 VOO,同为美股净流入 Top3 ETF
- 彭博社:Bitmine 目前持有 83.3 万枚 ETH,价值近 30 亿美元
- 彭博分析师:比特币相对于黄金的年化波动率比值已降至历史新低
- 公平发射平台 Juicy.meme 完成 40 万美元 Pre-Seed 融资,Ju Ventures 参投
- CertiK:CrediX 黑客已将 450 万美元所盗资产桥接至以太坊网络
- CrediX 承诺 24 至 48 小时内全额恢复用户资金
- DeFi 平台 Credix 遭遇攻击,损失约为 450 万美元
- MYX 24 小时涨幅扩大至 140%,市值升至 3660 万美元
- CFTC 启动"加密冲刺"计划,加速推进特朗普政府加密资产监管路线图
- Ourbit SuperCEX 与日本 “知名流浪汉” Fujimoto 达成战略合作,旨在表达对“非精英化”文化的认可
- 上市公司 Sequans 增持 85 枚比特币,总持有量升至 3157 枚
- 上市公司 Coinsilium Group 子公司 Forza 增持 57.54 枚 BTC,总持有量达 181.96 枚
- 《金融时报》:境外买卖股票收入也要缴税,加强个人境外收入监管
- CrediX:已停用网站并禁止用户存款,用户如需操作请通过合约提现
- Cyvers Alerts:检测到 Sonic 网络上出现多笔涉及 CrediX 的可疑交易
- Sei 日活用户数于 8 月 2 日首次超越 Solana
- Camp Network 将于本周六晚举办 AI 原生 IP 电子音乐会,并在 SideKick 直播
- CloneX 24 小时交易量激增 70%,地板价升至 0.3775 ETH
- 欧盟等待特朗普本周就汽车关税及豁免采取行动
- USDe 发行量单月涨超 75%,同期 ENA 涨超 146%
- 比特币期权市场交易量呈爆炸式增长
- CoinShares:数字资产投资产品 15 周来首次出现净流出,比特币周内流出 4.04 亿美元
- 法国农业信贷银行旗下 CACEIS 入股 Kriptown 推动欧洲区块链股权交易所 Lise 落地
- 两地址近期将近 5.4 万枚 ETH 存入 CEX,总价值达 1.89 亿美元
比推专栏
更多 >>观点
比推热门文章
- Sky 上周斥资 139 万美元回购 1655 万枚 SKY
- 数据:灰度向 Coinbase 地址转移总计 24,134 枚 ETH
- 美股加密股开盘涨跌不一,SBET、VAPE 涨超 8%
- 市场消息:欧盟将暂停对美国的贸易反制措施 6 个月
- 加密交易平台 Bullish 拟在 IPO 中筹集 6.29 亿美元资金
- 前高盛 ETF 业务主管加入 Centrifuge 担任首席运营官
- 灰度扩充管理团队并任命创始人为董事会主席
- 瑞银:8 月美股或面临回调压力,或将出现战略性建仓窗口
- 高盛:特朗普解雇美国劳工局局长对美元不利
- 智能机器去中心化操作系统 OpenMind 完成 2000 万美元融资,Pantera Capital 领投