本文由CertiK安全验证团队撰稿,授权金色财经首发。
最近小区出现了一些流浪狗,听说邻居家有孩子看到狗吓得就跑,结果反而被狗狂追咬了一口。
还好父母机智,给孩子上了个意外险,几针狂犬病疫苗下来没怎么花钱。
作为币民如果加密资产不幸被盗,但项目方或者你个人购买了保险,那么也大可放心让保险公司偿还损失的资产。
可还有最差的一种情况:但是如果连保险公司都出了安全事故,受到攻击了呢?
北京时间12月28日晚, CertiK安全技术团队发现Cover Protocol发生代币无限增发漏洞攻击。
攻击者通过反复对项目智能合约进行质押和取回操作,触发其中包含铸造代币的操作,对Cover代币进行无限增发,导致Cover代币价格崩盘。
金色晨讯 | 11月16日隔夜重要动态一览:21:00-7:00关键词:BCH分叉完成、Stellar、SUSHI、波卡周报
1.Yearn.finance已通过YIP-54治理提案;
2.SUSHI一度触及1.6美元,24H最高涨幅超50%;
3.Stellar将于11月24日发起将公共网络升级至协议15的投票;
4.BCH正式完成硬分叉后 BCHA首次达到硬分叉区块高度;
5.WillyWoo:流入比特币的资本达到上次牛市以来的最高水平;
6.波卡周报:11号公投通过 波卡高优先级升级0.8.26-1已发布;
7.数据:10月1日以来灰度比特币信托GBTC交易价格上涨63%;
8.比特币持续震荡,日内最低报15777.77美元,最高报16115美元。[2020/11/16 20:54:37]
主要攻击分为以下步骤:
1. 攻击者设置攻击必要的NOCLAIM代币。
金色财经行情播报 | BTC行情窄幅震荡,MA60构成压制:据火币行情显示,今日BTC行情窄幅震荡,从日线图看,均线开始聚拢,从区间来看,MA30构成支撑,MA60构成压制,多空博弈方向暂不明确。但此前7200USDT上方压力较大,对多头形成较大威慑,虽然有昨日的反包线作为支持,多头依然乏力。截至18:30,火币平台的主流币的具体表现如下。[2020/4/23]
2. 攻击者使用NOCLAIM代币,为Balancer Pool提供流动性:
①总计向Balancer Pool提供了2,573个DAI的流动性
②攻击者通过向Balancer Pool提供流动性,获得了约132,688个Balancer流动性证明代币BPT
3. 攻击者向Cover Protocal中的Blacksmith.sol智能合约质押(stake)前一步中所得的所有Balancer流动性证明代币。
假冒Uniswap网站在谷歌搜索中显示为广告:金色财经报道,加密影响者BitBoy发现,去中心化交易所Uniswap的用户可能面临假冒UniSwap网站的风险,该假冒网站在谷歌搜索中显示为广告。根据BitBoy的说法,在谷歌搜索“UniSwap”时,第一个搜索结果是一个广告链接,点击该链接会进入一个假冒的Uniswap网站,并索要钱包的助记词。如果输入助记词,加密资金将会被盗。[2020/8/13]
质押时,攻击者调用位于0xe0b94a7bb45dd905c79bb1992c9879f40f1caed5的Blacksmith.sol智能合约中的deposit函数,如图一所示:
图一:The deposit() function in blacksmith.sol
首发 | 刘尧:百度区块链推出天链平台赋能链上业务:12月20日,由CSDN主办的“2019中国区块链开发者大会”12月20日在北京举行。百度智能云区块链产品负责人刘尧以《企业区块链赋能产业创新落地》为主题进行了演讲,他指出:2020年将是区块链企业落地的元年,为了支持中国区块链的产业落地,百度将区块链进行平台化战略升级,依托百度智能云推出天链平台,就是要赋能360行的链上业务创新落地。[2019/12/20]
通过调用deposit函数,攻击者将得到的BPT流动性证明质押到cover protocol中。
首先通过图一中118行将当前流动性证明代币的pool数据读取到memory,然后调用121行代码对当前pool的数据进行更新。
图二:blacksmith.sol中的updatePool()函数
首发 | 百度推动246家博物馆线上藏品上链:金色财经讯,近日,百度超级链联合百度百科,基于区块链技术创建 “文博艺术链”,推动百科博物馆计划中的246家博物馆线上藏品上链。基于“文博艺术链”,百度将与博物馆共同推动线上藏品版权的确权与维护,同时探索线上藏品版权数字化交易方式,为合作的博物馆提供更全面的服务和更多的权益。据介绍,此项目将分阶段进行,一期将完成线上藏品的入链确权,为每一件藏品生产专属的版权存证证书。让每一名用户可以在百度百科博物馆计划的PC端和WAP端的藏品页查看证书。后续,百度还将推动AI与区块链技术在文博领域的结合应用,用来保障上链数据与藏品相匹配,为后续进行藏品图像版权数字化交易奠定基础。[2019/1/30]
如图二第75行所示,在updatePool()函数中修改的当前流动性证明代币的pool数据是一份存储在storage中的数据,与在deposit()中存储在memory中当前流动性证明代币的pool数据是两份数据。
在图二第84行lpTotal的值代表当前合同中总共存入的流动性证明代币数目,由于该变量数值较小,因此通过84行公式pool.accRewardsPerToken的数值将会增大,更新过的accRewardsPerToken值存储在storage中。
图三:blacksmith.sol中的_claimCoverRewards()函数
接下来如图三中318行所示,deposit()通过调用_claimCoverRewards()函数,向函数调用者(msg.sender)铸造一定数目的cover代币。
铸造cover代币的数目与pool.accRewardsPerToken, CAL_MULTIPLIER以及miner.rewardWriteoff三个变量相关。
请注意这里pool.accRewardsPerToken的数值是使用了存放在memory中的pool数据,并非使用图二中update()函数更新之后的数值。
同时,通过图1中deposit函数得知,miner.rewardWriteoff的数值更新是在_claimCoverRewards()函数执行完成之后发生。
因此原本设计上应使用更新过的miner.rewardWriteoff的数值计算需要铸造cover代币的数目,这里错误的使用了未更新过的miner.rewardWriteoff的数据,导致实际铸造cover代币数目比应铸造代币数目增多,最终导致了代币增发。
质押成功之后,攻击者通过调用blacksmith.sol智能合约中的withdraw()函数,将质押的BPT取回,同时取得额外铸造的cover代币,完成攻击。
通过对比执行deposit()函数和执行withdraw()函数之后的代币结余表,我们可以发现通过这一组deposit和withdraw函数调用之后,攻击者可以获得约704个COVER代币。
deposit()之后:
withdraw()之后:
攻击者通过反复执行deposit和withdraw函数,可以使Blacksmith函数无限铸造代币,并将代币转到自己的地址中,由此获利。
攻击发生后,截止发稿时,cover官方已经将blacksmith迁移到安全版本:
有漏洞的blacksmith地址:
临时修复后的blacksmith地址:
0x1d5fab8a0e88020309e52b77b9c8edf63c519a26
临时修复后的blacksmith合同临时禁止了一切质押和取回操作,以此阻止攻击者继续实行攻击。
本次攻击最初攻击者共获利440万美金,约合人民币2900万人民币。
有其他攻击者利用该漏洞发动类似攻击,例如Grap.finance项目官方参与了利用该漏洞的攻击,获利4350个ETH代币。
在攻击发生后几个小时,Grap.finance项目官方通过Twitter声称对本次攻击负责,并表示已将所有的获利退回给了Cover Protocol。
为了确保数字资产不因任何非技术原因遭受损失,项目方应及时为项目产品购买保险,增加项目方和投资者的安全保障方案,确保其因受到攻击所造成的损失可以被及时补偿。
作为世界顶尖的审计公司,CertiK目前已经进行了超过369次安全审计,审计了超过198,000行代码,并保护了价值超过100亿美元的加密资产。
近期,CeritK推出了CertiKShield去中心化资金保障计划。
CertiKShield不仅可以为项目及其社区成员提供保障,同时,CertiK作为主营业务为审计的安全公司,我们确保自己的保险项目拥有更高的安全性。
相比于纯粹的保险公司,安全技术的背书及团队对于安全的重视和一系列的保障,CertiKShield是安全领域内构建的保险,并且有着巨大的成长和发展空间。
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。