Dapp开发区块链研习社

【EOS开发学习笔记】程序和工具(二)cleos之set用法

2018-04-12  本文已影响413人  面壁者Z

先啰嗦几句:本人区块链小白一枚,正在自学EOS应用开发(当然目前也没有培训班培训),我的这个系列文章是我的学习笔记,因此,鉴于水平有限,难免有许多错误之处,还希望各位读者海涵,若能留言勘误,更是感激不尽。同时也欢迎热爱EOS开发的朋友加我微信(微信号:361757),暗号EOS,我已经创建了一个交流群,发布本文时(2018年4月12日),群人数已经达到103人!好了,系好安全带,我们的EOS应用开发之旅,马上开始!

本系列文章共分4篇,学习的内容为EOS.IO Programs & Tools

本文为第二部分,重点探索cleos的set的用法。

在学习本文前,您需要先部署好EOS.IO运行环境,测试一下智能合约,然后再开始学习。

老样子,我们先测试一下get有哪些子命令:

$ cleos set
ERROR: RequiredError: Subcommand required
Set or update blockchain state
Usage: cleos set [OPTIONS] SUBCOMMAND

Options:
  -h,--help                   Print this help message and exit

Subcommands:
  contract                    Create or update the contract on an account
  account                     set or update blockchain account state
  action                      set or update blockchain action state

我们看到共有3个subcommand:

  1. contract 创建或更新一个账户的合约
  2. account 创建或更新区块链的账户状态
  3. action 创建或更新区块链的事务状态

接下来我们依次试试:

1. contract

设置合约

$ cleos set contract
ERROR: RequiredError: account
Create or update the contract on an account
Usage: cleos set contract [OPTIONS] account contract-dir [wast-file] [abi-file]

Positionals:
  account TEXT                The account to publish a contract for
  contract-dir TEXT           The the path containing the .wast and .abi
  wast-file TEXT              The file containing the contract WAST or WASM relative to  contract-dir
  abi-file TEXT               The ABI for the contract relative to contract-dir

Options:
  -h,--help                   Print this help message and exit
  -a,--abi TEXT               The ABI for the contract relative to contract-dir
  -x,--expiration             set the time in seconds before a transaction expires, defaults to 30s
  -f,--force-unique           force the transaction to be unique. this will consume extra bandwidth and remove any protections against accidently issuing the same transaction multiple times
  -s,--skip-sign              Specify if unlocked wallet keys should be used to sign transaction
  -j,--json                   print result as json
  -d,--dont-broadcast         don''t broadcast transaction to the network (just print to stdout)
  -p,--permission TEXT ...    An account and permission level to authorize, as in 'account@permission' (defaults to 'account@active')
  --max-cpu-usage UINT        set an upper limit on the cpu usage budget, in instructions-retired, for the execution of the transaction (defaults to 0 which means no limit)
  --max-net-usage UINT        set an upper limit on the net usage budget, in bytes, for the transaction (defaults to 0 which means no limit)

很乱哦,我们先看看命令格式要求:

Usage: cleos set contract [OPTIONS] account contract-dir [wast-file] [abi-file]

下面紧跟着给出了各个参数的解释:
account,文本形式,发行合约的账户
contract-dir,文本形式,合约路径,包含.wast或.abi文件
wast-file,文本形式,包含WAST或WASM的相对目录
abi-file,文本形式,ABI文件的相对目录

由于我没有准备合约文件,这个测试就暂时不做了。

2.account

设置账户

$ cleos set account
ERROR: RequiredError: Subcommand required
set or update blockchain account state
Usage: cleos set account [OPTIONS] SUBCOMMAND

Options:
  -h,--help                   Print this help message and exit

Subcommands:
  permission                  set parameters dealing with account permissions

这个只有一个子命令permission,设置账户权限的参数

$ cleos set account permission
ERROR: RequiredError: account
set parmaters dealing with account permissions
Usage: cleos set account permission [OPTIONS] account permission authority [parent]

Positionals:
  account TEXT                The account to set/delete a permission authority for
  permission TEXT             The permission name to set/delete an authority for
  authority TEXT              [delete] NULL, [create/update] JSON string or filename defining the authority
  parent TEXT                 [create] The permission name of this parents permission (Defaults to: "Active")

Options:
  -h,--help                   Print this help message and exit
  -x,--expiration             set the time in seconds before a transaction expires, defaults to 30s
  -f,--force-unique           force the transaction to be unique. this will consume extra bandwidth and remove any protections against accidently issuing the same transaction multiple times
  -s,--skip-sign              Specify if unlocked wallet keys should be used to sign transaction
  -j,--json                   print result as json
  -d,--dont-broadcast         don''t broadcast transaction to the network (just print to stdout)
  -p,--permission TEXT ...    An account and permission level to authorize, as in 'account@permission' (defaults to 'account@active')
  --max-cpu-usage UINT        set an upper limit on the cpu usage budget, in instructions-retired, for the execution of the transaction (defaults to 0 which means no limit)
  --max-net-usage UINT        set an upper limit on the net usage budget, in bytes, for the transaction (defaults to 0 which means no limit)

这里要求的格式:

$ cleos set account permission [OPTIONS] account permission authority [parent]

其中,account,表示要修改的账户
permission 表示要设置的权限
authority 权限内容,JSON字符串
parent 上级权限

3. action

设置事务状态

$ cleos set action
ERROR: RequiredError: Subcommand required
set or update blockchain action state
Usage: cleos set action [OPTIONS] SUBCOMMAND

Options:
  -h,--help                   Print this help message and exit

Subcommands:
  permission                  set parmaters dealing with account permissions

这里也只有一个子命令:permission,设置账户的详细参数?

$ cleos set acion permission
ERROR: RequiredError: account
set parmaters dealing with account permissions
Usage: cleos set action permission [OPTIONS] account code type requirement

Positionals:
  account TEXT                The account to set/delete a permission authority for
  code TEXT                   The account that owns the code for the action
  type TEXT                   the type of the action
  requirement TEXT            [delete] NULL, [set/update] The permission name require for executing the given action

Options:
  -h,--help                   Print this help message and exit
  -x,--expiration             set the time in seconds before a transaction expires, defaults to 30s
  -f,--force-unique           force the transaction to be unique. this will consume extra     bandwidth and remove any protections against accidently issuing the same transaction multiple times
  -s,--skip-sign              Specify if unlocked wallet keys should be used to sign transaction
  -j,--json                   print result as json
  -d,--dont-broadcast         don''t broadcast transaction to the network (just print to stdout)
  -p,--permission TEXT ...    An account and permission level to authorize, as in 'account@permission' (defaults to 'account@active')
  --max-cpu-usage UINT        set an upper limit on the cpu usage budget, in instructions-retired, for the execution of the transaction (defaults to 0 which means no limit)
  --max-net-usage UINT        set an upper limit on the net usage budget, in bytes, for the transaction (defaults to 0 which means no limit)

要求的格式:

$ cleos set action permission account code type requirement

其中:
account是目标账户。
code是账户拥有者的code
type是action类型
requirement 是权限名称

由于目前的环境,我没有进行set的实际操作测试。暂时先了解一下,后续补充。

本篇完,下一篇一起探索transfer用法。

我是王越,EOS应用开发小白一枚,渴望与你链接,我已经建立了一个交流开发技术的微信群,期待你的加入!请加我微信 361757,暗号EOS。

上一篇 下一篇

猜你喜欢

热点阅读