01前言
在之前的技术视点文章中,我们介绍了目前本体主网支持的智能合约体系以及相应的智能合约开发工具SmartX。很多小伙伴都想上手练一练。在本期的技术视点中,我们将正式开始讲述智能合约语法部分。
本体的智能合约API分为7个模块,分别是Blockchain&BlockAPI、RuntimeAPI、StorageAPI、NativeAPI、UpgradeAPI、ExecutionEngineAPI以及Static&DynamicCallAPI。本期我们将介绍
?Blockchain&BlockAPI
,这是本体智能合约体系中最基础的部分。其中,BlockchainAPI支持基本的区块链查询操作,如获取当前块高等;BlockAPI支持基本的区块查询操作,如查询指定区块交易数等。
在这之前,小伙伴们可以在本体智能合约开发工具SmartX中新建一个合约,跟着我们进行操作。
02?BlockchainAPI使用方法
智能合约函数的引用与Python的引用如出一辙。开发者可以根据需要引入相应的函数。例如,下面语句引入了获取当前最新块高函数GetHeight和获取区块头函数GetHeader。
fromontology.interop.System.BlockchainimportGetHeight,GetHeader
2.1?GetHeight
开发者可以使用GetHeight来获取当前最新块高,具体例子如下。在后面的例子中,为了节省空间,我们将省略Main函数,小伙伴在练习的时候可以根据需要加入。
美众议院和参议院就加密货币法案达成两党协议:金色财经报道,Bitcoin News称,美国众议院和参议院就加密货币法案达成两党协议,该法案将要求加密货币交易所向商品期货交易委员会(CFTC)注册,并为比特币和整个\"另类\"行业创建一个新的监管框架。
据金色财经观察,该法案的核心是授予CFTC监管涉及加密资产交易的专属管辖权,只要发行商遵循某些SEC披露要求,代币就被假定为商品并属于CFTC的管辖范围。此外,法案还包括:
1.CFTC对”加密资产交易所\"的注册要求,但不包括DEX。
2.客户资产隔离要求和借贷限制,包括禁止中介机构对加密资产进行再抵押。
3.单独处理支付稳定币,只能由受联邦和州银行当局监管的存款机构发行,但CFTC对CFTC注册商开展的与支付稳定币有关的任何活动拥有专属管辖权。
4.为仅从事发行支付稳定币及相关服务的潜在存款机构提供注册途径。
5.将洗售税规则扩展到数字资产的购买和销售。
此外,根据该法案,美SEC会仍将保留对数字资产的部分管辖权。如果数字资产赋予“商业实体”“任何的财务利益”,包括“债务或股权”、“清算权”或“利息或股息支付的权利”,则该资产不会被视为加密资产或辅助资产,而是会像传统证券一样受到SEC的管辖。[2023/7/26 15:59:00]
fromontology.interop.System.RuntimeimportNotify
fromontology.interop.System.BlockchainimportGetHeight
defMain(operation):
Acala将在社区投票通过后于8月15日进行Acala2.0:Exodus升级:7月12日消息,Acala发推称,Acala2.0:Exodus升级将在社区投票通过后于8月15日进行,此次升级将优化网络增长、可持续性和安全性,并且通过质押、调整激励措施等来提高ACA的效用。
此外,ACA每年解锁的50%将用于ACA质押,50%预留给流动性池、建立在通用资产中心(UAH)上的dApps等的流动性挖矿。部分未使用的ACA用于销毁,例如每月销毁1%,在一段时间内积累的部分网络费用也将通过治理进行销毁,例如每六个月销毁20%。[2023/7/12 10:49:58]
ifoperation=='demo':
returndemo()
returnFalse
defdemo():
height=GetHeight()
Notify(height)#打印height
returnheight#在函数运行结束后返回height
2.2?GetHeader
开发者可以使用GetHeader来获取区块头,参数是某个块的块高。具体例子如下:
fromontology.interop.System.RuntimeimportNotify
fromontology.interop.System.BlockchainimportGetHeader
defdemo():
Arbitrum One链上交易总量目前达到1,006,599笔:金色财经报道,Dune数据显示,Arbitrum One链上交易总量已突破100万笔,目前达到1,006,599笔。[2023/5/1 14:37:14]
block_height=10
header=GetHeader(block_height)
Notify(header)
returnheader
2.3GetTransactionByHash
开发者可以使用GetTransactionByHash函数通过交易哈希获取交易。交易哈希以bytearray的格式,作为参数传入GetTransactionByHash。这个函数的关键在于如何转换将十六进制格式的交易哈希转变为bytearray格式的交易哈希。
我们以16进制格式的交易哈希为例,实现将十六进制格式的交易哈希转变为bytearray格式的交易哈希。示例哈希如下:
9f270aa3a4c13c46891ff0e1a2bdb3ea0525669d414994aadf2606734d0c89c1
首先,将该交易哈希反序得到:
c1890c4d730626dfaa9449419d662505eab3bda2e1f01f89463cc1a4a30a279
开发者可以通过SmartX提供的转换工具HexNumber(littleendian)<-->Number实现这一步。
特斯拉跌幅扩大至超10%:金色财经报道,特斯拉跌幅扩大至超10%,刷新1月下旬以来低点至163美元下方,拖累美股大盘指数保持跌势。马斯克此前表示,特斯拉将继续追求销量,而不是利润率。[2023/4/21 14:17:16]
然后,将其转成bytearray格式:
{0xc1,0x89,0x0c,0x4d,0x73,0x06,0x26,0xdf,0xaa,0x94,0x49,0x41,0x9d,0x66,0x25,0x05,0xea,0xb3,0xbd,0xa2,0xe1,0xf0,0x1f,0x89,0x46,0x3c,0xc1,0xa4,0xa3,0x0a,0x27,0x9f}
开发者可以通过SmartX提供的转换工具String<-->ByteArray实现这一步。
最后,将得到的bytearray转换成相应的字符串:
\xc1\x89\x0c\x4d\x73\x06\x26\xdf\xaa\x94\x49\x41\x9d\x66\x25\x05\xea\xb3\xbd\xa2\xe1\xa2\xe1\xf0\x1f\x89\x46\x3c\xc1\xa4\xa3\x0a\x27\x9f
GetTransactionByHash函数通过交易哈希获取交易的例子如下:
fromontology.interop.System.BlockchainimportGetTransactionByHash
defdemo():
#tx_hash="9f270aa3a4c13c46891ff0e1a2bdb3ea0525669d414994aadf2606734d0c89c1"
开头为TKHuVq地址从币安地址提取25亿USDT:据欧科云链OKLink数据显示,12月11日至13日期间币安POR地址总流出金额约129亿美元,净流出金额约56.5亿美元。其中约11.3%的流出资金(15亿美元)流入其他中心化机构地址,约0.1%资金(1000万美元)流入链上项目地址。据统计,TKHuVq开头的地址链上转账记录显示提取了25亿的USDT,占转出资金排名前100的地址总流出金额的50%左右。[2022/12/15 21:45:15]
tx_hash=bytearray(b"\xc1\x89\x0c\x4d\x73\x06\x26\xdf\xaa\x94\x49\x41\x9d\x66\x25\x05\xea\xb3\xbd\xa2\xe1\xf0\x1f\x89\x46\x3c\xc1\xa4\xa3\x0a\x27\x9f")
tx=GetTransactionByHash(tx_hash)
returntx
2.4?GetTransactionHeight
开发者可以使用GetTransactionHeight函数通过交易哈希获取交易高度。我们还是以上个例子中的哈希为例:
fromontology.interop.System.BlockchainimportGetTransactionHeight
defdemo():
#tx_hash="9f270aa3a4c13c46891ff0e1a2bdb3ea0525669d414994aadf2606734d0c89c1"
tx_hash=bytearray(b"\xc1\x89\x0c\x4d\x73\x06\x26\xdf\xaa\x94\x49\x41\x9d\x66\x25\x05\xea\xb3\xbd\xa2\xe1\xf0\x1f\x89\x46\x3c\xc1\xa4\xa3\x0a\x27\x9f")
height=GetTransactionHeight(tx_hash)
returnheight
2.5?GetContract
开发者可以使用GetContract函数通过合约哈希获取合约。其中,合约哈希的转换过程与上面讲到的交易哈希转换过程一致。
fromontology.interop.System.BlockchainimportGetContract
defdemo():
#contract_hash="d81a75a5ff9b95effa91239ff0bb3232219698fa"
contract_hash=bytearray(b"\xfa\x98\x96\x21\x32\x32\xbb\xf0\x9f\x23\x91\xfa\xef\x95\x9b\xff\xa5\x75\x1a\xd8")
contract=GetContract(contract_hash)
returncontract
?2.6?GetBlock
开发者可以使用GetBlock函数获取区块。有两种方法可以获取指定区块:
1.通过块高获取区块:
fromontology.interop.System.BlockchainimportGetBlock
defdemo():
block=GetBlock(1408)
returnblock
2.通过区块哈希获取区块:
fromontology.interop.System.BlockchainimportGetBlock
defdemo():
block_hash=bytearray(b'\x16\xe0\xc5\x40\x82\x79\x77\x30\x44\xea\x66\xc8\xc4\x5d\x17\xf7\x17\x73\x92\x33\x6d\x54\xe3\x48\x46\x0b\xc3\x2f\xe2\x15\x03\xe4')
block=GetBlock(block_hash)
03?BlockAPI使用方法
BlockAPI中可供引用的函数有三个,它们分别是GetTransactions、GetTransactionCount和GetTransactionByIndex。我们依次介绍下这三个函数。
3.1?GetTransactionCount
开发者可以使用GetTransactionCount函数获取指定区块的交易数量。
fromontology.interop.System.BlockchainimportGetBlock
fromontology.interop.System.BlockimportGetTransactionCount
defdemo():
block=GetBlock(1408)
count=GetTransactionCount(block)
returncount
3.2?GetTransactions
开发者可以使用GetTransactions函数获取获取指定区块的所有交易。
fromontology.interop.System.BlockchainimportGetBlock
fromontology.interop.System.BlockimportGetTransactions
defdemo():
block=GetBlock(1408)
txs=GetTransactions(block)
returntxs
3.3GetTransactionByIndex
开发者可以使用GetTransactionByIndex函数获取指定区块的指定交易。
fromontology.interop.System.BlockchainimportGetBlock
fromontology.interop.System.BlockimportGetTransactionByIndex
defdemo():
block=GetBlock(1408)
tx=GetTransactionByIndex(block,0)#indexstartsfrom0.
returntx
04?后记
Blockchain&BlockAPI在智能合约中起到查询区块链数据和区块数据的作用,是智能合约最不可缺少的一部分。在后面的技术视点中,我们将讨论如何使用其它API,探讨它们和本体区块链的交互。本期讲述的所有语法部分我们提供了中文视频,小伙伴们可以观看和学习。
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。