过去几个月来,DeFi 生态经历了巨大的动荡,数次攻击之下,许多未被利用过的缺陷也被报道出来。
虽然代码中无可避免会有 bug,但还是有很多方法能降低缺陷发生的频率,以及降低缺陷带来的负面影响。
作为一个审计员,我们想要帮助 DeFi 用户问一些比较尖锐的问题;问这些问题的目的,一方面是让开发人员认真去考虑系统安全性的优先级,另一方面,让用户能分辨出回答得好的协议,然后把钱投入这些协议。
以下问题能帮助用户了解 DeFi 开发团队对于安全性的立场,答案不一定有对错之分,而且也不是每个团队(or 独立开发者)都有资源全盘顾及所有方面。但不论如何,用户有权利知道这些信息,来决定自己愿意承受的风险。
DeFi协议B.Protocol进行第一次治理投票:DeFi协议B.Protocol今日推特宣布将于4月26日进行第一次治理投票,社区将投票决定下一步的发展方向。据悉,B.Protocol或是首个在项目伊始就将100%的控制权交给用户的项目。[2021/4/8 19:58:56]
我们希望通过以下提问,促使后续开展更多正面的讨论。
管理员权限
大部分的主流 DeFi 协议都存在一些中心化的机制——允许特定的 “管理员” 地址以强硬的手段干预协议的运行。
这样做虽然在安全上有好处,但这意味着你必须相信这些 “管理员” 不会滥用他们的特权;而且但凡这些管理员遭到黑客攻击,他们的私钥泄露所带来的后果会更加严重。
管理员账户可以是以下几种形式:单一地址、多重签名钱包,或是由 DAO 管理的投票过程。那么,
LBTC在英国伦敦银行正式成立DeFi实验室:1月18日消息,LBTC官方Twitter发布公告,LBTC于今日在伦敦银行正式成立DeFi区块链实验室。该实验室由来自亚马逊等著名互联网公司的员工组成,旨在研发基于LBTC的生态产品,包括但不限于DeFi、跨链等技术产品。
目前,LBTC DeFi实验室初期已经获得LBTC基金会的1000万美元研发基金,近期将重点开发基于LBTC的DeFi应用。与此同时,实验室还将发掘其他优质项目,以期在今后开展合作。[2021/1/18 16:27:34]
1.管理员能采取哪些措施?
暂停整个系统?
修改账户余额?
设置 代币/用户 的 白名单/黑名单 ?
升级某个子系统?
升级整个系统?(等同于万能...)
其他权限?
BitMax上线DeFi币 Nsure日内涨幅达33.87%:据BitMax官网显示,截止今日18:50 BitMax上线DeFi币 NSURE 日内涨幅达33.87%,现报价0.83467 USDT。
更多详情请您登录BitMax平台官网BTMX.IO查看。[2020/11/21 21:37:31]
2.如果采取上述行为,是否有延迟执行机制?
3.如果有延迟时间,那是多长?
4.多少人有管理员权限?
5.采取上述行为前,需要经过多少管理员同意?
6.有哪些权限是由链上治理程序(即 DAO)来掌控的吗?
7.我该去哪里了解提议更新协议的提案?
以上某些问题的回答已经可以通过 DefiWatch 跟踪了解。
外部依赖
安全公司:警惕DeFi挖矿钓鱼授权盗币攻击:据慢雾区情报,由于DeFi挖矿项目的火热,除了仿盘以外,目前已经出现了针对以太坊DeFi挖矿的钓鱼攻击,攻击者通过新建一个挖矿项目,诱导用户授权给项目本身,其实是授权给了一个攻击者自己可控的地址,在授权完成后,用户资金会被立即转出。经慢雾安全团队分析,目前该网站诱导用户授权给地址0x59DFd93D34DFF5D36dEdD539425a7D7D2a77B3e5,该地址并为合约地址,而是一个攻击者控制的普通的个人地址。通过区块浏览器查询显示,已有20万枚USDC和52枚YAMV2被转移。慢雾安全团队提醒,用户在操作DeFi项目时,一定要对项目本身进行足够的了解,并需注意该项目是否通过安全审计,并在授权时,对授权对象进行核对,确认是项目方的地址,避免资金损失。[2020/9/6]
因为是公开的网络,以太坊上充斥着不怀好意的攻击者,因此开发者不能假设本系统外的合约一定会采取什么样的行为。但在许多 DeFi 应用中又不得不作出这样的假设,因为服务本身就是在已有的一些合约上建构出来的。
这些问题能帮助用户了解该项目在外部依赖上存在的风险。
1.你的系统依赖什么预言机(Oracle)?
2.你的系统依赖什么交易所?
3.你用什么第三方智能合约(如,OpenZeppelin)来建立系统?
4.你的系统支持哪些代币,你对这些代币(合约)的行为模式有怎样的预期?
可靠的的披露系统和奖励计划
对于才华横溢的黑客来说,攻击 DeFi 协议对他们有着强大的金钱诱惑。制定奖励计划能激励大家发现并揭露漏洞,而非钻漏洞。对于白帽黑客来说,通过激励系统揭露代码漏洞也是提高自身声誉的好方法 —— 既有好处又不违法。
任何公司要运行 DeFi 协议,或是涉及在线托管金钱的业务,都应该设有奖励系统。你可以就他们的奖励计划及披露流程提出以下问题:
1.你们的合约代码能够被所有人看到吗?
2.从你们的网站和 git 代码库,能够很容易找到安全的联系方式吗?
3.你们的合约有没有设置奖励计划?
4.哪些合约在奖励计划内?
5.奖励计划具体金额是?
6.你们是否支付过奖励计划的奖金?
7.对于 bug 报告,你们是否曾拒绝支付过?
8.从你们的网站和 git 代码库,能够很容易地找到奖励计划的详细信息吗?
理想情况下,这些信息应该放在 “website.com/security” 页面下,而且能搭配 Github 的 SECURITY.md 功能使用。
应急预案
当面对某些安全突发状况的时候,新消息如潮水般涌来,用户持续在 Twitter、Telegram、Discord 上提出棘手的问题......,这时候开发者很难头脑清楚地应对突发状况。
所以如果有应急预案的话,就能证明项目正朝着安全方向发展。要求项目公开他们完整的计划可能不太现实,但我们还是能提出以下基础的问题去侧面了解:
1.你们是否有处理突发安全事件的计划提纲?
2.你们的应急预案适用于哪些紧急情况?
3.如果你们的系统是可升级的,这些升级步骤是否记录在案?
4.如果你们发现某个系统漏洞可能让资金面临风险,你们是否能通过应急预案先发制人,保护资金安全?
审计与安全发展
审计并非万灵丹,而且审计的内容总多多少少有点区别,但对于部署任何的 DeFi 合约之前,进行审计是至关重要的一步。
下面的问题不一定有 “正确答案”,但学识渊博的社区群众们,应该能从项目的回答中看出开发团队对于安全性的立场。
1.你们最近一次审计是什么时候?
2.这次审计投入了多少精力(以标准开发者的一小时来做单位)?
3.哪个机构做的审计?
4.审计报告公开吗?
5.你们系统中有任何部分是没有被涵盖在审计的范围内吗?
6.最近一次审计之后,你们有对合约进行更新吗?如果有,更新了什么?
7.你们有和哪个安全团队进行长期合作吗?
8.在合并代码之前,开发者会彼此做 code review 吗(至少检查 Solidity 文件)?
9.你们的合约代码中,做过单元测试的比重是多少?
10.审计过程中,你们用过其他的安全分析工具吗?
编者注:本文为 John Adler 代表 Fuel Labs 在 EthCC3 大会上的演讲。Fuel 是一个志在用 rollup 方法提供稳定币支付服务的项目.
1900/1/1 0:00:00USDT,是Tether发行的稳定币,与美元USD挂钩,1USDT约等于1美金。之所以称之稳定,是因为它的价格波动性较低,Tether公司对外称将严格遵守1:1准备金保证,每发行1USDT,其银.
1900/1/1 0:00:00分析312大跌的本质原因:换了人间导语:小时候我痴迷于一个叫做“死穿白”的桌游,这名字的来由源于桌游中“被杀”的人脸上要贴着一张白纸条,这游戏据说一生只能玩一次,因为游戏的剧情是固定好的.
1900/1/1 0:00:00去中心化金融(Defi)衍生品交易平台dYdX创始人Antonio Juliano,今日在网站上发布公告称,会从2020年3月10日开始收取交易费用.
1900/1/1 0:00:00原标题:见证历史 | 金融危机来了我们知道它会来,但是不知道它会以这样的形式来,但是我们终于还是见面了,和比特币一起。毫无疑问,我们碰上金融危机了。2020年以来,我们已经见证了好多个历史了.
1900/1/1 0:00:00比特币挖矿难度的动态调整机制是这一共识机制获得成功的关键所在,昨日比特币挖矿难度一次性上调近7%至16.55T,btc.com数据显示,目前比特币全网算力为121.95EH/s.
1900/1/1 0:00:00