首页 资讯 正文

区块链研究实验室| HyperLedger Fabric架构构建ERC20令牌 part I

链三丰 2019年06月19日 01:37

由于其高TPS和作为区块链作为服务平台的行为,许多新创新者正在选择Hyperledger来部署他们的区块链业务。因此,在本博客中,我们将讨论使用node.js在Hyperledger中创建基于erc20的令牌链代码的方法。

为何选择ERC20?

ERC20是以太坊广泛测试和接受的,将其整合到Hyperledger中,可以轻松地为基于Hyperledger的任何令牌编写安全且可扩展的链码。

我们将在本教程中参考以下开源存储库。

注意:我们假设您已经熟悉Hyperledger结构,并且您的系统配备了启动Hyperledger开发的先决条件。如果没有,请参阅Hyperledger文档中的先决条件、关键概念和教程。

此存储库中的代码已在以下环境中进行了测试:

  1. node:v8.9.3和v8.11.4

  2. Hyperledger:v1.2

  3. Docker:18.06.1-ce

  4. Python:2.7.12

  5. Go:go1.9.3 linux / amd64

  6. curl:7.47.0

我们建议在适应代码的同时使用相同的版本。

确保先决条件安装正确后,请执行以下步骤:

cd path/to/repository/foldercd network

进入网络文件夹后,即可创建超级账本网络环境。 它将分别为您创建2个组织(Org1和Org2),Orderer每个组织有2个对等组。

Housekeeping

如果这是您第二次运行本教程,或者您已成功运行任何其他基于HyperLedger Fabric的代码,那么我们建议您首先运行以下命令:

./buildERC20TokenNetwork.sh down

它将要求确认:

Stopping for channel 'mychannel' with CLI timeout of '10' seconds and CLI delay of '3' secondsContinue? [Y/n]

按Y并继续。

注意:您可以使用以下命令检查Docker有多少个容器或卷正在运行:

  • docker ps

  • docker volume ls

如果使用脚本很难关闭容器和卷,请尝试运行以下命令:

  • docker network prune

  • docker volume prune

  • docker rm -f $(docker ps -aq)

令牌网络设置

完成Housekeeping后,您就可以使用以下命令启动网络了:

dGv6IkC3MOHLkl6lEgirgJPOzwTCq1Y6suYxcrRF.png

执行可能需要一些时间(通常在90到120秒之间执行)。 但是,如果您在终端中看到以下日志,则表示它已成功执行,您的网络已准备就绪。

VuLLXBwgwmk2Cuxfr0ERdGzTZuOMq0axPQwg8hLG.png

使用crypto-config.yaml文件在您的网络目录中名为crypto-config的文件夹中为HyperLedger的每个实体创建了所需的证书。

创建了channel.tx,genesis.block,Org1MSPanchors.tx和Org1MSPanchors.tx。

它还为以下内容创建了Docker容器和卷:

  • peer0 and peer1 or Org1

  • peer0 and peer1 of Org2

  • orderer

  • CLI

  • chaincode

使用docker ps和docker volume ls检查它们。 我们还在Org1和Org2之间创建了一个频道名称mychannel,每个组织的同伴都是该频道的一部分。 然后在每个组织的peer0上安装我们的链代码并实例化我们的链代码,命名为mycc。 您可以使用以下方法查看相应对等/链代码的日志:

docker logs  // type peer and then tab to see your optionsdocker logs  // type dev and then tab to see your options

注意:对于调试,您可以访问您的链代码和对等日志docker logs <按TAB查看选项>; 如果您没有看到链代码的容器(dev-peer0.org1.techracers.com-mycc-1.0),那么实例化我们的令牌链代码就会出现问题。

我们的代币

现在我们的chaincode已经启动并运行,让我们尝试一些getter和setter函数来更好地理解它。为此,我们需要输入我们创建的cli容器。

docker exec -it cli bash

你将会看到以下结果:

root@0e2b84a5cedc:/opt/gopath/src/github.com/hyperledger/fabric/peer#

getter函数

一旦进入了cli,就可以调用simpletoken中提供的getter函数。我们将逐一讨论您可以访问的每一个:

获得所有权人

此函数将返回令牌合同的所有者。现在是MSPID实例化了契约,您可以在这里看到它。

peer chaincode query -C mychannel -n mycc -c '{"Args":["getOwner"]}'Org1MSP

这里,mychannel是我们的通道名称,mycc是我们的chaincode的名称,如您所见,org1msp是我们chaincode的当前所有者。

getName

此函数将返回令牌合同的名称。它在实例化合同时被设置为简单令牌,您可以在这里看到它。

peer chaincode query -C mychannel -n mycc -c '{"Args":["getName"]}'Simple Token

如您所见,Simple Token是我们当前的令牌名称。

getSymbol

此函数将返回我们的令牌合约的符号。 在实例化合同时将其设置为SMT,您可以在此处查看

peer chaincode query -C mychannel -n mycc -c '{"Args":["getSymbol"]}'SMT

如您所见,SMT是我们当前的令牌符号。

getTotalSupply

此函数将返回令牌合同的总供应量。在设置之前,它默认为0。您可以在这里找到所需的逻辑。

peer chaincode query -C mychannel -n mycc -c '{"Args":["getTotalSupply"]}'0

如你所见,0是我们目前的总供应量。

isMintingAllowed

此getter返回存储在Hyperledger上的IsMintingAllowed布尔值。它默认为未定义,直到设置一次。您可以在这里找到所需的逻辑。

peer chaincode query -C mychannel -n mycc -c '{"Args":["isMintingAllowed"]}'undefined

正如你所看到的,isMintingAllowed现在是未定义的。 一旦稍后设置,它将返回true或false。

getAllowance

此getter返回令牌所有者为Spender MSPID设置的津贴值。它将“input the mspid token”owner作为第一个参数,将“mspid of spender”作为第二个参数。在设置之前,它默认为0。

peer chaincode query -C mychannel -n mycc -c '{"Args":["getAllowance", "Org1MSP", "Org2MSP"]}'0

如你所见,getallowance现在是0。稍后设置后,它将返回float。我们还要检查一下还有没有其他组合,看看它是否返回0。

peer chaincode query -C mychannel -n mycc -c '{"Args":["getAllowance", "Org2MSP", "Org1MSP"]}'0

getBalanceOf

最后一个getter是getbalanceof函数,它返回我们输入的每个mspid的令牌平衡。如果mspid没有任何令牌平衡,它也默认为0。

vaUcJQ3cfsWg4I2mlQPtXZtbCsDnDf6V3Yk5k3ys.png

本文转载公众号:区块链研究实验室,专注区块链技术,产品社群,经济模型等全方位的知识体系输出,为大家带来不一样的社群学习体验。欢迎联系作者微信加入社群:csschan1120