Bytom资产发行与部署合约教程
是我859
发表于 2022-12-3 14:38:02
69
0
0
$ F7 T; [, d0 z1 g* g
输入账户的密码,等待交易确认,一旦确认成功资产就会发到刚才指定的地址上。可以只发一个地址,也可以发到多个地址,添加多个Control with address 即可。
编译合约
编译合约通过api进行编译,准备好postman或者其他可以post的工具,笔者使用的是postman。; b. g" a, u/ Q$ ^ i5 u7 Q$ |% Q; S
笔者看了官方的多个合约模版,于是准备部署一个简单的比较数字大小的合约。即是编译合约时会指定数值,如果解锁合约的人带上大于此数值则可以获得合约里的资产。
笔者的合约代码如下:
contract equals(target:Integer) locks value{; b3 k1 Y$ } ?7 D8 F* N+ a6 O
clause reveal(current:Integer){, `* u* B$ Q4 N
verify current >= target
unlock value
}
}0 ^9 L; ?0 N+ p6 ]/ F
写好了合约代码,接下来通过 compile 的api 对合约进行编译+ [) Y- l$ O. S5 h5 R
编译后会返回一个status 成功或者失败,和一串 data,都是为json格式的数据,主要需要 data里面的 program,即是该编译完成的合约程序,在部署合约时需要用到。
2 A3 z W4 i; f( R( Z4 P
部署合约
部署合约其实就是 发起交易,在交易中带上合约程序。通过api发起交易主要有三个步骤,先 build → sign → submit,分别对应的api是 build-transaction、sign-transaction、submit-transaction。9 u+ d$ |( _+ a# }
build-transaction
sign-transaction
build-transaction 返回的数据,全部需要用到,即是 data 的所有数据,对该打包好的数据进行签名,需要创建账号的密钥密码。2 Q+ W4 ]7 U M% V5 ?- T5 D
6 B& k3 E2 A ^9 u: H$ I/ f
如果签名成功的话,要看返回的json里面有个sign_complete字段,此字段为true才代表成功,方可进行submit-transaction。
submit-transaction; V, t' C' e* c- w$ M' o
获取 sign-transaction 签名成功返回的 raw_transaction 字段数据,进行提交交易。; u" v% k) P% E) ]" |
9 A3 P* m& I- [5 E* [4 ~
如果提交成功的话,会返回交易哈希即tx_id,可以通过 get-transaction 获取该交易的详情。
在此合约就部署完成啦,对应数量的资产也已经被锁在合约里面了,等待解锁合约,解锁成功的人可以获得合约里的资产。
获取部署好的合约unspent-output
通过 list-unspent-outputs 获取未花费的合约详情,在解锁合约的时候也需要用到这个 unspent-output id。! u; h& t) w: |; \8 k: i
这里的id 可以在 get-transaction 的outputs 中找到,在outputs中找到 control_program 为刚才部署的合约program,则此笔交易的id就是这个合约的unpsent-output。9 M# h$ c( e! g
解锁合约
build-transaction
根据以上获得的unspent-output来解锁合约,其实解锁合约也是发起交易,和发布合约不同的是不需要编译,只需要build、sign、submit即可。build这里比较不一样,笔者解锁合约时在此处踩过太多的坑~~
7 O( y& A3 w1 e0 R7 v' S
根据以上的参数进行build-transaction即可,注意value需要转为十六进制!!如果符号合约条件即可解锁成功,否则区块确认解锁合约的交易时会失败。: B d Y2 f& ?% C( l5 B
sign-transaction和submit-transaction 参考部署合约的就可以,完全是一样的。到此,发布和解锁合约就全部完成啦。
成为第一个吐槽的人