美文网首页Dapp开发区块链研习社
【EOS开发学习笔记】程序和工具(二)cleos之set用法

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

作者: 面壁者Z | 来源:发表于2018-04-12 10:32 被阅读413次

    先啰嗦几句:本人区块链小白一枚,正在自学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。

    相关文章

      网友评论

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

      本文链接:https://www.haomeiwen.com/subject/dmznhftx.html