4. 发起提案

XuperChain中有多种提案-投票操作场景,但原理都是一致的,我们以通过提案更改共识算法(single改为tdpos)来介绍具体的操作流程

部署一个Single共识的 XuperChain 环境已经在“快速入门”一节有介绍

首先我们需要准备一个tdpos共识的配置,包括出块时间、代表名单等(假设文件名为proposal.json)

 1{
 2    "module": "proposal",
 3    "method": "Propose",
 4    "args" : {
 5        "min_vote_percent": 51,                 # 生效的资源比例
 6        "stop_vote_height": 800                 # 计票截至的高度
 7    },
 8    "trigger": {
 9        "height": 1000,                         # 期望生效的高度
10        "module": "consensus",
11        "method": "update_consensus",
12        "args" : {
13            "name": "tdpos",
14            "config": {
15                "version":"2",
16                "proposer_num":"2",             # 代表个数
17                "period":"3000",
18                "alternate_interval":"6000",
19                "term_interval":"9000",
20                "block_num":"20",
21                "vote_unit_price":"1",
22                "init_proposer": {              # 出块的代表名单
23                    "1":["dpzuVdosQrF2kmzumhVeFQZa1aYcdgFpN", "U5SHuTiiSP1JAAHVMknqrm66QXk2VhXsK"]
24                }
25            }
26        }
27    }
28}

需要注意的是当前的区块高度,来设置合理的截至计票高度和生效高度。然后在矿工节点下,执行给自己转账的操作,并在 --desc 参数里传入提案

1./xchain-cli transfer --to dpzuVdosQrF2kmzumhVeFQZa1aYcdgFpN --desc proposal.json --amount 100

运行后会得到本次提案的交易id,需要记录下来供投票使用

对提案进行投票操作由如下命令执行

1./xchain-cli vote f26d670b695d9fd5da503a34d130ef19e738b35e031b18b70ad4cbbf6dfe2656 --frozen 1100 --amount 100002825031900000000

这里需要注意进行投票的节点需要有矿工账号的密钥对,以及 --frozen 参数的冻结高度大于提案生效的高度。因为最终通过的规则是投票资源大于总资源的51%,所以需要初始token量最多的矿工账号来进行投票,并保证token数符合要求。

如此进行后,等到区块出到设定的生效高度,便完成了提案-投票的整个流程。其他场景的提案机制都是类似的,仅是json配置文件不同而已。