TheDAO

DAO

Decentralized Autonomous Organization (DAO),中文翻译是“去中心化自治组织”,是一种通过智能合约将个体与个体、个人与组织、或组织与组织联系在一起的新型组织形式。

国家、股份公司、企业、保险公司只是帮助人们实现大规模合作的几种方法。本质上,它们只是抽象存在,我们利用它们进行自我组织,实现协作。但是,它们的功能与DAO的功能没有不同之处,但是它们所用到的技术(纸质文件、印刷、由司法系统执行)是不同的。

Why

  1. 成本低,智能合约来进行财务和权利等管理,取代传统出纳,人事,股东制度,降低大量成本。
  2. 代码强制性,避免贪腐,保证资金安全。
  3. 无地域性差异。
  4. 高效,节约大量时间,让机器处理繁琐的细节。
  5. 民主,避免多数人绑架少数人。
  6. 未来的世界是人围绕机器进行的。

Slock.it

区块锁Slock.it是本届DEVCON上关注度最高的项目之一。
区块锁Slock.it是一个开放平台,供所有人使用和开发。它以一种完全去中心化的方式运作,将租赁人和产权人直接连接起来。

  1. 去中心化的方式管理租赁人和产权人,避免了中心化机构的高昂成本,以及中心化垄断的问题。
  2. 通过区块链来解决信任问题。

Slock.it 和 TheDAO关系

起初,Slock.it创建了一个DAO,用来众筹,通过DAO来分配DTH的收益。后来,Slock.it希望能将DAO作为一个平台,于是就有了TheDAO,其他项目也可以通过TheDAO来筹集资金。

好戏开场

众筹到超过1.3亿美元的资金,成为有史以来最大的众筹项目!

为什么可以筹集到这么多钱?

  1. 去中心化的共享经济概念
  2. 明星团队
  3. Digix的火爆和成功
  4. SpliteDAO的退出机制
  5. 没有上限

TheDAO

  1. 代码优秀,早期的代码考虑到了gas依赖,去除了循环,获取奖励等都采用withdraw模式。
  2. 法律团队“DAO.Link“,在瑞士的团队,用来专门负责区块链线上资金到线下的转化等相关的法律问题。

暂停 DAO 提案和可能的攻击方式介绍

TheDAO在博弈学上存在漏洞,可能被攻击。具体攻击参见下文:什么是“暂停 DAO”的提案,以及为什么要支持它?

  1. 倾向投赞成票和抑制投反对票
  2. 跟踪攻击
  3. 埋伏攻击
  4. Token 价格攻击
  5. extraBalance 攻击
  6. 多数分裂劫持攻击
  7. 稀释回报
  8. 无风险投票
  9. 并行提案陷阱
  10. 独立性假设

最终结果,该提议未通过。

实际存在的问题

  1. 投票率低
  2. 关于群体智慧的讨论(题外话:脱欧公投)
  3. 对Slock.it proposal的争论
  4. 安全顾问费用的争论
  5. spam proposal等

解决办法:DAO2.0:Liquid Democracy 和 Futarchy。最早在Ethereum的白皮书中,就有介绍Liquid Democracy 和 Futarchy。

DAO 攻击事件经过

  1. The DAO 合约攻击信息汇总
  2. 汇总国内社区对于 DAO 问题的意见,传达给以太坊基金会
  3. 白帽子团队的奇袭
  4. 软分叉(潜在DoS攻击,证明以太坊的天然抗审查性)
  5. 硬分叉

攻击事件过程不是分享重点。重点是,DAO过程中有意义的讨论和发现的问题,以及在DAO安全漏洞给智能合约开发安全性的一些提醒。

漏洞解析

splitDAO

// Burn DAO Tokens
Transfer(msg.sender, 0, balances[msg.sender]);
withdrawRewardFor(msg.sender); // be nice, and get his rewards
totalSupply -= balances[msg.sender];
balances[msg.sender] = 0; // <---------- 看我看我
paidOut[msg.sender] = 0;
return true;
function withdrawRewardFor(address _account) noEther internal returns (bool _success) {  
        if ((balanceOf(_account) * rewardAccount.accumulatedInput()) / totalSupply < paidOut[_account])
            throw;

        uint reward =
            (balanceOf(_account) * rewardAccount.accumulatedInput()) / totalSupply - paidOut[_account];
        if (!rewardAccount.payOut(_account, reward))
            throw;
        paidOut[_account] += reward;
        return true;
    }
function payOut(address _recipient, uint _amount) returns (bool) {  
        if (msg.sender != owner || msg.value > 0 || (payOwnerOnly && _recipient != owner))
            throw;
        if (_recipient.call.value(_amount)()) {  // <---------- 看我看我
            PayOut(_recipient, _amount);
            return true;
        } else {
            return false;
        }
    }

如何编写安全的智能合约

  1. 首先要区别send和call的区别,并理解以太坊的gas机制
  2. 使用正确的顺序或者采用加锁的方式
  3. 合理使用throw
  4. 转换发送模式为提款模式,使收款方控制以太币转移,减少其他逻辑和提款逻辑的耦合
  5. 防范调用栈攻击,判断调用外部合约的结果
  6. 去掉循环处理,或者限制循环防范gas限制攻击或者让合约调用者控制循环

DAO 的未来

TheDAO失败了,并不代表DAO是不可行的。相反,社区的大量有益讨论,让我觉得未来的DAO是更加完善的,或许是Liquid Democracy,Futachy,或者是更为先进的理念。

展望

汽车终究会取代马车,技术进步的道路是无法阻挡的。

DAO代码简析

  1. Token
  2. ManagedAccount
  3. TokenCreation
  4. DAO
  • newProposal
  • vote
  • executeProposal
  • splitDAO

链接:
比特坊 DAO 的创立设想
【白皮书】以太坊 (Ethereum ):下一代智能合约和去中心化应用平台
通过十点向非技术人群解释 DAO
为什么你招聘不到程序员,以及软件如何定义现实世界
Slock - 区块锁,去中心化的共享经济
The DAO
Futarchy: 对价值投票,对赌信念
介绍Futarchy
An Introduction to Futarchy
Liquid Democracy In Simple Terms
Liquid Democracy: True Democracy for the 21st Century
Liquid Democracy for The DAO 1.0
如何使用Solidity编写安全的智能合约代码?
各位 DAO 参与者
Raising the Proposal Deposit to 11 ETH
DAO improvement proposal of Gnosis - shift towards futarchy and proxy voting
Getting to Know DAO 2.0
Slock.it Proposal #1 - Discussion Thread
The DAO: are we taking “The Wisdom of the Crowd” too far?
Slock.It outlines ~$1.5Ms security proposal for the DAO
DAOTokenCreationProxyTransferer.sol
The DAO框架从1.0版本升级到1.1版本的详细步骤
The DAO 合约攻击信息汇总
关于 The DAO 智能合约被攻击事件的反思
汇总国内社区对于 DAO 问题的意见,传达给以太坊基金会
[投票]硬分叉 VS 不分叉?通过 CarbonVote 让你的以太币来说话
以太坊 DAO Wars 软分叉可能会成为潜在的 Dos 攻击载体
DAO战争:矿工请选择
Ethereum天然具有抗审查的安全性
Options in the Hard Fork
从技术角度剖析针对THE DAO的攻击手法
TheDAO 攻击代码简介
send 和 call 的区别
智能合约中常见错误及如何避免
EIPS

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351

推荐阅读更多精彩内容