本文由【区块链研习社】优质内容计划支持,更多关于区块链的深度好文,请点击《区块链研习社》。
和前面的文章一样,这里使用的系统依然是ubuntu16.04。
DAWN3.0的编译相当方便,下载代码后直接编译就可以了。
$ git clone https://github.com/EOSIO/eos --recursive
$ cd eos
$ ./eosio_build.sh
值得注意的是,DAWN3.0要求至少20G硬盘空间以及8G的内存,对CPU也有一定的要求。
代码编译好之后,在build/program目录下会生成很多工具,如cleos和nodeos(对应DAWN2.0的eosc和eosd),为了使用的方便,建议把这些工具装到系统中,以后就可以在任何路径使用它们。在build目录下执行:
$ sudo make install
小tips:
运行脚本过程中遇到的问题,如果eosd(DAWN2.0)还在跑,下载MongoDB时会失败。
经过摸索,发现eosd跑的时候,ubuntu网络连接就会有问题,很多软件包无法下载。
DAWN3.0的环境搭建好后,发现智能合约这一块有了不小的改动。
DAWN2.0的EOS token智能合约,在eosd跑起来时自动部署;而DAWN3.0需要自行部署。
cleos set contract eosio ../../contracts/eosio.bios -p eosio
对于currency智能合约,也有了很多的变化,首先代码变得极其简洁,也就是说现在几行代码就可以发币了。
/**
* @file
* @copyright defined in eos/LICENSE.txt
*/
#include
extern "C" {
/// The apply method implements the dispatch of events to this contract
void apply( uint64_t receiver, uint64_t code, uint64_t action ) {
eosio::currency(receiver).apply( code, action );
}
}
有效代码也就4行。
由于现在没有初始化函数init,也就没得创建token,这部分需要手动指定:
$ cleos push action currency create '{"issuer":"currency","maximum_supply":"1000000.0000 CUR","can_freeze":"0","can_recall":"0","can_whitelist":"0"}' --permission currency@active
$ cleos push action currency issue '{"to":"currency","quantity":"1000.0000 CUR","memo":""}' --permission currency@active
DAWN2.0中在init函数创建token,创建的token直接在currency账下;
DAWN3.0把创建token和分配token分开,currency账户创建token,token在智能合约账下,可由currency账户分配。
currency也可以授权从智能合约给eosio(默认区块生产者):
$ cleos push action currency issue '{"to":"eosio","quantity":"1000.0000 CUR","memo":""}' --permission currency@active
通过以下命令,我们可以知道当前分配了多少token,token总量和分配者等信息。
$ cleos get table currency CUR stat
{
"rows": [{
"supply": "2000.0000 CUR",
"max_supply": "1000000.0000 CUR",
"issuer": "currency",
"can_freeze": 0,
"can_recall": 0,
"can_whitelist": 0,
"is_frozen": 0,
"enforce_whitelist": 0
}
],
"more": false
}
好了,currency智能合约操作层面上的变动就介绍到这里。