【eos全家桶系列】eos系统合约介绍 — 发币合约eosio.token

简介

本章将深入源码,为大家分析eos的系统合约eosio.token的实现细节。eosio.token是eos的发币合约,这个合约主要实现了EOS代币的创建、发行、转账等功能。

主要合约方法

eosio.token系统合约的源码在eos/contracts/eosio.token中,eos项目方独立开了github,负责eosio.token合约的更新和维护。

eosio.token合约,在eosio.token.hpp头文件中,主要定义了以下三个合约方法:

- create:负责创建资产

- issue:负责发行资产

- transfer:负责资产转账

eosio.token.hpp头文件中定义的主要方法

下面,将为大家一一介绍各个方法的功能实现细节

create方法

create方法的实现在eosio.token.cpp中,需要传入两个参数完成币种创建:

- issuer:资产发行账户

- maximum_supply:最大发行量

create方法实现细节

ceate方法调用实例如下,eosio.token合约部署在eosio.token账户,资产发行账户为eosio,最大发行量10亿,币种精度4,币种符号EOS

cleos push action eosio.token create '[ "eosio", "1000000000.0000 EOS"]' -p eosio.token

深入源码来看,create方法通过以下步骤完成了资产的创建:

- 获取eosio.token合约部署账户的授权

- 判断币种符号 (sysmol name) 是否合法,币种符号必须是大写字母,长度小于8位

- 判断发行量是否越界且是否为正数,支持的最大发行量 amount <= 2^62-1

- 查询statstable表,判断代币符号是否存在,eosio.token支持发行多资产

- 建表,将代币符号、发行总量、发行方存入数据库

以上步骤,主要逻辑详见:eos/contracts/eosiolib/symbol.hppeos/contracts/eosiolib/asset.hppeos/contracts/eosiolib/multi_index.hpp

issue方法

create方法的实现在eosio.token.cpp中,需要传入两个参数完成币种的发行:

- to:发行金额打入的账户

- quantity:发行金额

- memo:交易备注

issue方法实现细节

issue方法调用实例如下,资产发行账户eosio授权,将10亿EOS打入eosio账户中,备注是test issue

cleos push action eosio.token issue '[ "eosio", "1000000000.0000 EOS", "test issue"]' -p eosio

深入源码来看,issue方法通过以下步骤完成了资产的发行:

- 前置检查:查表判断币种是否存在、memo最大长度不能超过256字节

- 查表获取币种信息:发行账户、最大发行量、币种精度、币种符号

- 获取发行账户的授权

- 前置检查:发行金额为正数且不超过最大发行量、币种精度校验

- 更新表,增加发行资产的余额

- 如果to账户和发行账户不一致,调用内联合约转账

以上步骤,主要逻辑详见:eos/contracts/eosiolib/symbol.hppeos/contracts/eosiolib/asset.hppeos/contracts/eosiolib/multi_index.hppeos/contracts/eosiolib/currency.hpp

这里特别要说明最后一个步骤,内联合约的调用。实现逻辑在eos/contracts/eosiolib/currency.hpp

issue方法最后调用的inline合约方法 - eosio.token的transfer方法

eos智能合约之间,通过action通信,共享数据库存储。一个智能合约,可以异步的读取另一个智能合约的数据库状态。智能合约有两种通信状态:

- Inline 内联合约。指的是在一个已有的交易里调用其他智能合约的方法。如果当前交易失败了,内联合约的执行也不受影响,内联合约执行失败或成功并没有通知,但执行成功会上链

- Deffered 延迟合约。指的是不是立即执行,而是在未来的某个时间计划去执行的合约。当前,可以构造一个交易去发送延迟合约交易,也可以发送一个交易去取消延迟合约。延迟合约也不能保证执行成功,执行失败或者成功并没有通知,但执行成功会上链

在issue方法中,当发现issuer账户和to账户不一致时,会调用lnline合约,触发eosio.token合约的transfer方法,将发行的金额转入to账户。当我们执行issue方法后,会发现除了产生issue的action后,还会有transfer的action:

inline合约方法调用成功后会上链

transfer方法

transfer方法的实现在eosio.token.cpp中,需要传入四个参数完成币种的转账:

- from:出币账户

- to:入金账户

- quantity:转账金额

- memo:交易备注

transfer方法的实现细节

深入源码来看,issue方法通过以下步骤完成了资产的转账:

- 前置检查:判断是否转账给自己、判断to账户是否存在

- 获得from账户的授权

- 获取币种信息:发行账户、最大发行量、币种精度、币种符号

- 分别通知from、to账户合约调用结果

- 前置检查:转账金额为正且不超过最大发行量、币种精度正确、memo长度不大于256

- 加减from和to地址账户余额

以上步骤,主要逻辑详见:eos/contracts/eosiolib/symbol.hppeos/contracts/eosiolib/asset.hppeos/contracts/eosiolib/multi_index.hppeos/contracts/eosiolib/currency.hpp

这里特别要说明第四个步骤,通知from、to账户合约调用结果。实现逻辑在eos/contracts/eosiolib/action.hppeos/libraries/chain/apply_context.cppeos/libraries/chain/transaction_context.cpp

eosio.token的transfer方法调用require_recipient
将相关账户放入_notified数组中
封装好trace通知内容,并执行通知
trace通知内容封装过程

首先,eosio智能合约的执行结果,会分别通知from、to、eosio.token。我们发送转账交易,会发现有三条actions,通知所有涉及的账户,这是eos系统合约设计的通知机制。大家在执行cleos get actions获取交易结果时,可以通过receiver过滤出发给自己账户的通知。

transfer方法调用成功后,发送给所有相关账户的通知上链

receipt的通知详情,调用cleos get actions bp1 -j 获取:

后记

本章为大家介绍了eosio.token合约的实现细节,从源码层面为大家分析了eosio.token如何实现资产的创建、发行、转账的。

目前,基于eos发行资产的项目方,都会参考eosio.token的实现,去实现自己的发币合约。但是,由于eos是一个刚刚完成主网上线的新项目,有许多隐藏的bug有待发现。例如,我们最后讲到的transfer方法的receipt通知机制,由于实现过于复杂,前段时间就被慢雾发现了有严重的安全漏洞,会使交易所的提币账户ram被耗尽,详细issue

因此,大家在编写自己的发币合约时,务必要检查好相关逻辑,以免被恶意攻击造成资产的损失。eos社区目前还没有出合约代码的标准规范,但我相信不久的将来,一定会有详细的规范出台。

接下来的文章,将继续从源码层面为大家讲解eos的系统合约实现细节,尽请期待!

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

推荐阅读更多精彩内容