Skip to content

Cocos-BCX/JSSDK

Repository files navigation

Part 1. Cocos-BCX链系统互操作API -- BCXJS

Javascript API,用于使用COCOS-BCX RPC API与基于COCOS-BCX的区块链集成。

Preparation:

Node.js版本8.9.3或更高版本

Build:

使用npm install安装本地依赖项。 使用开发构建npm run dev。

Browser Distribution

构建用于发布npm run release。 构建将在./build中找到

NPM

构建用于发布npm run release-npm。 构建将在./build-npm中找到

Import

Browser

 <script type="text/javascript" src="bcx.min.js"></script>

NPM

在用 bcxjs 构建大型应用时推荐使用 NPM 安装。NPM 能很好地和诸如 webpack 或 Browserify 模块打包器配合使用

# 最新稳定版
$ npm install bcxjs-api

如果您有一个转换器,例如Babel,则支持在浏览器中使用ES6模块语法导入。

import BCX from "bcxjs-api"

Start:

实例化类库对象

var bcx=new BCX({
		default_ws_node:”ws://XXXXXXXXX” //节点rpc地址,选填。如果没有指定此项则会自动连接ws_node_list中速度最快的节点
		ws_node_list:[{url:"ws://xxxxxxx",name:"xxxxx"}]//API服务器节点列表,必填
		faucet_url:"http://xxx.xxx.xxx.xxx:xxxx", //注册入口
		networks:[{
			core_asset:"xxx",//核心资产符号
			chain_id:"xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"//链id   
		}], 
		auto_reconnect:false,//当RPC断开时是否自动连接,默认为true
		app_keys:["xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"],//合约授权,不进行合约授权,则不用配置此选项
		real_sub:true//true:实时订阅,false:区块订阅,订阅通知频率为出块频率
		sub_max_op:13//订阅时最大处理OP数量
});

调用实例-转账

bcx.transferAsset({
     to:"test2",
     amount:1,
     assetId:"COCOS",
     memo:""
}).then(res=>{
     console.log('transferAsset res',res);
})

API说明

1.没有特殊说明均有一个可选参数callback

callback返回的result为Object对象,结构为{code:0,message:””}。 code=1时表示成功,无message状态描述。 code!=1时意味执行失败,message为失败状态描述。

2.没有殊说明均只有一个参数,该参数为一个对象,对象包含所有相关参数,其中也包含callback

调用示例:

bcl.getPrivateKey().then(res=>{});

3.除订阅类接口,其他接口在不传callback参数时均返回promise对象

4.接口的参数类型没有特殊说明均为字符串

5.接口的参数没有特殊说明均不能为空,callback为可选参数

6.查询类接口返回数据实例:{code:1,data:[]}

7.非查询类接口返回数据会多一个数据字段trxData,值为一个对象

示例:

trx_data:{
 block_num:*****,//区块高度
 trx_id:"************************"//交易ID
}

8.非查询类接口若涉及关联ID业务(如创建NH资产产生的ID)返回的数据中将包含data对象

//示例

data:{
  real_running_time: 387//运行时间
  result: "4.2.288"//关联业务id
}

状态码说明

code message 说明 关联API
300 Chain sync error, please check your system clock 链同步错误,请检查您的系统时钟 *
301 RPC connection failed. Please check your network 连接RPC失败,请检查你的网络 *
1 操作成功 * 
0 failed 操作失败,返回错误状态描述不固定,可直接提示res.message或统一提示为操作失败 * 
101 Parameter is missing 参数缺失 * 
1011 Parameter error 参数错误 *
102 The network is busy, please check your network connection 网络繁忙,请检查你的网络连接 *
103 Please enter the correct account name(/^a-z{4,63}/$) 请输入正确的账户名(正则/^a-z{4,63}/$) CreateAccountWithPassword
104 XX not found XX 不存在 passwordLogin等
105 wrong password 密码错误 passwordLogin,unlockAccount
106 The account is already unlocked 账户已经处于解锁状态 unlockAccount
107 Please import the private key 请先导入私钥 unlockAccount
108 User name or password error (please confirm that your account is registered in account mode, and the account registered in wallet mode cannot be logged in using account mode) 用户名或密码错误(请确认你的账户是通过账户模式注册的,钱包模式注册的账户不能使用账户模式登录) passwordLogin
109 Please enter the correct private key 请输入正确的私钥 keyLogin
110 The private key has no account information 该私钥没有对应的账户信息 keyLogin
111 Please login first 请先登录 changePassword
112 Must have owner permission to change the password, please confirm that you imported the ownerPrivateKey 必须拥有owner权限才可以进行密码修改,请确认你导入的是ownerPrivateKey changePassword
113 Please enter the correct original/temporary password 请输入正确的原始密码/临时密码 changePassword
114 Account is locked or not logged in. 帐户被锁定或未登录 changePasswor、transferAsset、getPrivateKey等
115 There is no asset XX on block chain 区块链上不存在资产 XX transferAsset等
116 Account receivable does not exist 收款方账户不存在 transferAsset等
117 The current asset precision is configured as X ,and the decimal cannot exceed X 当前资产精度配置为 X ,小数点不能超过 X transferAsset等
118 Encrypt memo failed 备注加密失败 transferAsset等
119 Expiry of the transaction 交易过期 transferAsset等
120 Error fetching account record 获取帐户记录错误 queryAccountOperations
121 block and transaction information cannot be found 查询不到相关区块及交易信息 queryBlockTXID
122 Parameter blockOrTXID is incorrect 参数blockOrTXID不正确 queryBlockTXID
123 Parameter account can not be empty 参数account不能为空 queryAccountInfo
124 Receivables account name can not be empty 收款方账户名不能为空 transferAsset
125 Users do not own XX assets 用户未拥有 XX 资产 queryAccountBalances
127 No reward available 没有可领取的奖励 getVestingBalances,claimVestingBalance
129 Parameter 'memo' can not be empty memo不能为空 decodeMemo
130 Please enter the correct contract name(/^a-z{4,63}$/) 请输入正确的合约名称(正则/^a-z{4,63}$/) createContract
131 Parameter 'worldView' can not be empty 世界观名称不能为空 creatWorldView
133 Parameter 'toAccount' can not be empty toAccount不能为空 transferNHAsset
135 Please check parameter data type 请检查参数数据类型 creatNHAssetOrder
136 Parameter 'orderId' can not be empty orderId不能为空 cancelNHAssetOrder
137 Parameter 'NHAssetHashOrIds' can not be empty NHAssetHashOrIds不能为空 lookupNHAssets
138 Parameter 'url' can not be empty 接入点地址不能为空 switchAPINode
139 Node address must start with ws:// or wss:// 节点地址必须以 ws:// 或 wss:// 开头 addAPINode
140 API server node address already exists API服务器节点地址已经存在 switchAPINode
141 Please check the data in parameter NHAssets 请检查参数NHAssets中的数据 creatNHAsset批量创建NH
142 Please check the data type of parameter NHAssets 请检查参数NHAssets的数据类型 creatNHAsset批量创建NH
144 Your current batch creation / deletion / transfer number is X , and batch operations can not exceed X 您当前批量 创建/删除/转移 NH资产数量为 X ,批量操作数量不能超过 X creatNHAsset、deleteNHAsset、transferNHAsset
145 XX contract not found XX 合约不存在 callContractFunction, queryContract, queryAccountContractData
146 The account does not contain information about the contract 账户没有该合约相关的信息 queryAccountContractData
147 NHAsset do not exist 非同质资产不存在 queryNHAssets
148 Request timeout, please try to unlock the account or login the account 请求超时,请尝试解锁账户或登录账户 queryVotes
149 This wallet has already been imported 此私钥已导入过钱包 importPrivateKey
150 Key import error 导入私钥失败 importPrivateKey
151 File saving is not supported 您的浏览器不支持文件保存 backupDownload
152 Invalid backup to download conversion 无效的备份下载转换 backupDownload
153 Please unlock your wallet first 请先解锁钱包 importPrivateKey
154 Please restore your wallet first 请先恢复你的钱包 backupDownload、unlockAccount
155 Your browser may not support wallet file recovery 浏览器不支持钱包文件恢复 loadWalletFile
156 The wallet has been imported. Do not repeat import 该钱包已经导入,请勿重复导入 restoreWallet
157 Can't delete wallet, does not exist in index 请求超时,请尝试解锁账户或登录账户 deleteWallet
158 Imported Wallet core assets can not be XX , and it should be XX 导入的钱包核心资产不能为 XX ,应为 XX restoreWallet
159 Account exists 账户已存在 createAccountWithWallet
160 You are not the creator of the Asset XX . 你不是该资产的创建者 issueAsset
161 Orders do not exist 订单不存在 fillNHAssetOrder
162 The asset already exists 资产已存在 createAsset
163 The wallet already exists. Please try importing the private key 钱包已经存在,请尝试导入私钥 restoreWallet
164 worldViews do not exist 世界观不存在 queryWorldViews
165 There is no wallet account information on the chain 链上没有该钱包账户信息 restoreWallet
166 The Wallet Chain ID does not match the current chain configuration information. The chain ID of the wallet is: XX 该钱包链id与当前链配置信息不匹配,该钱包的链id为: XXX restoreWallet
167 The current contract version ID was not found 当前合约版本id没有找到 X queryContract
168 This subscription does not exist 当前没有订阅此项 unsubscribe
169 Method does not exist API方法不存在 unsubscribe

Part 2. 区块链系统的互操作API

钱包模式

创建账户

方法:createAccountWithWallet
功能:钱包模式创建账户,钱包模式创建的账户不能用账户名密码登录。如果钱包模式已经存在账户,该操作会创建子账户,创建该子账户需要先成为终身会员账户
参数:
account:账户名注册规则,/^[a-z][a-z0-9.-]{4,63}$/,账户名长度为4-63位,由小写字母或数字构成且以字母开头
password:密码

备份钱包

方法:backupDownload
功能:备份钱包,调用该API会生成一个钱包文件,自动下载
参数:
callback:回调函数

加载备份钱包文件

方法:loadWalletFile
功能:对于web来说,file input绑定change事件,读取钱包文件
参数:
file:宿主环境若在web => file input 的 change事件触发返回的事件对象event.target,files[0]

从备份文件恢复钱包

方法:restoreWallet
功能:备份钱包,调用该API会生成一个钱包文件,自动下载。该API调用后,钱包处于锁定状态。
参数:
password:备份文件的钱包密码

导入私钥

方法:importPrivateKey
功能:导入私钥到钱包
参数:
privateKey:明文私钥
password:如果是已经创建钱包或恢复钱包,此时的密码为原来钱包的密码,否则是可以随意填写的临时密码

删除钱包

方法:deleteWallet
功能:删除钱包,使用账户模式时,最好让用户先执行删除钱包
参数:

获取钱包账户列表

方法:getAccounts
功能:获取钱包账户列表
参数:
callback:若有该参数,则内部会自动判断进行链初始化,否则直接返回数据,格式示例:

  {  
		"accounts": ["tom0002"],  
		"currentAccount": {  
			"account_id": "1.2.20",  
			"locked": true,  
			"account_name": "tom0002"  
		}
  }  

切换账户

方法:setCurrentAccount
功能:钱包模式切换当前使用账户
参数:
account:要切换的账户

解锁账户

方法:unlockAccount
功能:导入私钥或钱包模式才可以使用此方法解锁账户
参数:
password:导入私钥时设置的临时密码

锁定账户

方法:lockAccount
功能:锁定账户
参数:
callback:回调函数

账户模式

创建账户

方法:createAccountWithPassword
功能:账户注册。如果账户模式已经有账户登录,该操作会创建子账户,创建该子账户需要操作账户为终身会员账户
参数:
account:账户名注册规则,/^[a-z][a-z0-9.-]{4,63}$/,账户名长度为4-63位,由小写字母或数字构成且以字母开头
password:密码
autoLogin:boolean类型,指定是否自动登录,默认值为false
callback:回调函数

账户登录

方法:passwordLogin
功能:账户登录
参数:
account:账户名 password:密码

私钥登录

方法:privateKeyLogin
功能:之前这个API只是过渡,严格上导入私钥只存在于钱包模式。现在为了兼容,此API还暂时留在这里,依然可用调用
参数:
privateKey:私钥
password:设置的临时密码

退出登录

方法:logout
功能:该方法会清除用户相关缓存,其中包括清除加密后的密文key
参数:
callback:回调函数

修改密码

方法:changePassword
功能:只有账户模式,才能修改密码;修改密码成功后,API将会自动调用退出登录。
参数:
oldPassword:旧密码
newPassword:新密码

获取当前账户信息

方法:getAccountInfo
功能:当账户处于解锁状态,返回数据中将包含账户名name
参数:无

账户操作

公钥+账户名注册账户

方法:createAccountWithPublicKey 功能:通过随机生成的公钥和账户名创建账户。如果账户模式已经有账户登录,该操作会创建子账户,创建该子账户需要操作账户为终身会员账户 参数:
account(string):账户名注册规则,/^[a-z][a-z0-9.-]{4,63}$/,账户名长度为4-63位,由小写字母或数字构成且以字母开头
ownerPubkey(string):账户权限公钥 activePubkey(string):资金权限公钥

升级成为终身会员账户

方法:upgradeAccount
功能:购买终身会员账户后,可以创建子账户,此操作需消耗一定的手续费
参数:
callback:回调函数

导出用户私钥

方法:getPrivateKey
功能:获取用户active_private_key,本秘钥可用于为账户所有花费行为签名,返回的owner_private_key:可修改账户相关的各种设置,包括权限设置
参数:
callback:设置获取私钥成功后的回调函数

查询账户记录

方法:queryAccountOperations
功能:查询用户近期操作记录
参数:
account:账户名
limit:查询记录条数
startId:开始账户记录id,如果查询范围是整个账户记录,则最开始的账户记录则是startId
endId:结束账户记录id,如果查询范围是整个账户记录,则最新的账户记录则是endId

订阅用户操作记录变更

方法:subscribeToAccountOperations
功能:订阅用户操作记录变更
参数:
account:账户名
callback:只要用户操作记录有变化,就调用此callback:回调函数

查询账户信息

方法:queryAccountInfo
功能:账户信息中包含用户id用户名等信息
参数:
account:账户名

代币操作接口

代币资产转移

方法:transferAsset
功能:向目标对象发送代币
参数:
fromAccount:发款方账户名,不是发起提议,
toAccount:收款方账号名
amount:发送的代币数量
assetId:资产ID (如:X.X.X)或 代币符号(如:BTC)
memo:转账备注
isEncryption(boolean):是否加密备注
isPropose(boolean):是否发起提议
callback:设置转账后的回调函数

创建资产

方法:createAsset
功能:创建token
参数:
assetId:资产符号,正则^[.A-Z]+$
precision:精度(小数位数)
maxSupply:最大资产总量
description: 资产描述,可不填
isBitAsset:是否锚定资产
callback:见统一API说明
chargeMarketFee(Object):

		{  
			marketFeePercent:交易手续费率 (%),  
			maxMarketFee: 最大交易手续费 
		}  
bitassetOpts(Object):  
		{  
			feedLifetimeSec(number):喂价有效时间(分钟),
			minimumFeeds(number):最少喂价次数,
			forceSettlementDelaySec(number):强制清算发生前延迟时间(分钟),
			forceSettlementOffsetPercent(number):强制清算价格偏离百分比,
			maximumForceSettlementVolume(number):强制清算最大数量(百分比),
		}  

更新资产

方法:updateAsset
功能:更新token
参数:
assetId:资产符号,正则^[.A-Z]+$
maxSupply:最大资产总量
newIssuer:更新发行人
description:资产描述,可不填
whiteList:是否开启黑白名单
transferRestricted:是否开启限制交易
chargeMarketFee(Object):

		{  
			marketFeePercent:交易手续费率 (%),  
			maxMarketFee: 最大交易手续费 
		}  
bitassetOpts(Object):  
		{  
			feedLifetimeSec(number):喂价有效时间(分钟),
			minimumFeeds(number):最少喂价次数,
			forceSettlementDelaySec(number):强制清算发生前延迟时间(分钟),
			forceSettlementOffsetPercent(number):强制清算价格偏离百分比,
			maximumForceSettlementVolume(number):强制清算最大数量(百分比),
		}  

资产销毁

方法:reserveAsset
功能:销毁代币资产
参数:
assetId:资产符号
amount:销毁数量

资产发行

方法:issueAsset
功能:代币资产token发行
参数:
toAccount:发行对象
amount:发行数量
assetId:资产符号
memo:备注消息,选填

领取资产手续费

方法:assetClaimFees
功能:资产发行人可以在这里领取累积的资产手续费。
参数:
assetId:需要领取的二级资产代币符号
amount:二级资产代币数量

资产受限名单更新

方法:assetUpdateRestricted 功能:注:若是发行人与黑名单中的账户进行交易则不受限制。
参数:
assetId:资产代币符号
isadd:是否添加名单,否则移除
restrictedType:限制类型
restrictedList:限制列表

为gas调整质押物

方法:updateCollateralForGas 功能:为gas调整质押物。
参数:
mortgager:抵押人
beneficiary:受益人
amount:抵押数量
isPropose:是否提议

查询GAS兑换率

方法:queryGas
功能:查询核心资产对GAS兑换率
参数:
amount:核心资产数量

查询资产受限名单

方法:queryAssetRestricted
功能:查询资产受限名单
参数:
assetId:资产符号
restrictedType:限制类型

查询链上发行的资产

方法:queryAsset
功能:代币资产查询
参数:
assetId:资产符号,此参数若为空,则查询链上发行的所有资产

查询账户指定资产余额

方法:queryAccountBalances
功能:获取用户对应的数字资产,如果assetId为空,则返回用户所有代币。
参数:
assetId:资产ID或代币符号,资产ID:数字代币的唯一代币标识ID(如:"X.X.X"),代币符号(如:”BTC”)
account:用户名

查询账户所有资产余额列表

方法:queryAccountAllBalances
功能:查询用户拥有的所有资产列表,列表中包含资产对记账单位的换算值。当账户无任何资产余额将会返回余额为0的核心资产
参数:
unit:记账单位,将会根据手续费汇率或交易市场价格换算等价的该资产,资产ID或代币符号,资产ID:数字代币的唯一代币标识ID(如:"X.X.X"),代币符号(如:”BTC”)
account:用户名

NH资产操作

注册开发者

方法:registerCreator
功能:将当前账户注册成为开发者

创建世界观

方法:creatWorldView
功能:创建支持的NH资产世界观,向区块链系统注册当前账号(通常为游戏的账号)支持的NH资产世界观
参数:
worldView:世界观名称,区分大小写;

创造NH资产

方法:creatNHAsset
功能:创建一个唯一的NH资产,具有唯一性。本接口仅限NH资产制造商(铁匠铺)使用。
参数:
assetId:当前NH资产交易时,适用的资产ID;
worldView:世界观;
baseDescribe:当前NH资产的具体内容描述,由制造者定义;
ownerAccount:指定NH资产拥有者(NH资产归属权账户,默认为NH资产创建者)
NHAssetsCount (Number):创建NH资产的数量,默认值为1,只有type为0即创建同一种NH资产生效
type:创建NH资产方式的类型,默认值为0。值为0时默认创建同一种NH资产,1是创建不同NH资产。
NHAssets(Array)示例:

	[{  
	 "assetId": "X.X.X",  
	 "worldView": "TEST",  
	 "baseDescribe": "{name:\"预言家\"}",  
	 "ownerAccount": "test2"  
	}, {  
	 "assetId": "X.X.X",  
	 "worldView": "TEST",  
	 "baseDescribe": "{name:\"女巫\"}",  
	 "ownerAccount": "test2"  
	}, {  
	 "assetId": "X.X.X",  
	 "worldView": "TEST",  
	 "baseDescribe": "{name:\"猎人\"}",  
	 "ownerAccount": "test2"  
	}]  

删除NH资产

方法:deleteNHAsset
功能:删除整条NH资产数据记录,通常在商品销毁时使用(仅能由用户自己授权处理自己想要销毁的数据)。
参数:
NHAssetIds (Array):NH资产实例的唯一标识ID;示例:[X.X.X, X.X.X]

转移NH资产

方法:transferNHAsset
功能:用户可以将自己的NH资产转移到另外一个用户
参数:
toAccount:转移NH资产的目标用户名
NHAssetIds(Array):多个NH资产id组成的数组,示例:[X.X.X, X.X.X]

提议关联世界观

方法:proposeRelateWorldView
功能:提议关联到某一个世界观,需要该世界观的创建人审批
参数:
worldView:需要关联的世界观名

批准关联世界观的提议

方法:approvalProposal
功能:批准其他用户关联自己的世界观的提议
参数:
proposalId:提议ID

获取当前用户收到的提议

方法:getAccountProposals
功能:获取当前操作用户收到的提议

NH资产买卖接口

创建NH资产出售单

方法:creatNHAssetOrder
功能:卖出NH资产(在交易前可调用queryAccountGameItems函数,列举用户NH资产,以便用户选着卖出)
参数:
otcAccount:OTC交易平台账户,用于收取挂单费用;(OTC平台填写)
orderFee:挂单费用,用户向OTC平台账户支付的挂单费用;(OTC平台填写)
NHAssetId:NH资产实例的唯一标识ID; (用户填写)
price:商品挂单价格;(用户填写)
priceAssetId:商品挂单价格所使用的代币种类;(用户填写)
expiration:挂单时间,如3600(秒),为1小时
memo:挂单备注信息;
callback:设置执行挂单卖出后的回调函数

购买订单NH资产

方法:fillNHAssetOrder
功能:买入NH资产,支付购买游戏装备的代币费用,同时修改用户拥有的商品数据。该操作是一个多步合成的原子操作,在支付费用的同时完成用户账户NH资产数据的更新,如果支付动作或账户商品数据更新动作中某一个动作不被主链区块认可,则整个交易将被回滚,避免异常交易。
参数:
orderId:订单ID

取消NH资产出售单

方法:cancelNHAssetOrder
功能:取消NH资产挂卖订单
参数:
orderId:订单ID

NH资产查询类接口

查询全网用户NH资产售卖订单

方法:queryNHAssetOrders
功能:查询全网用户NH资产的售卖订单
参数:
assetIds(string):资产符号或id筛选条件
worldViews(string):版本名称或版本id筛选条件
baseDescribe(string):基本描述 pageSize:页容量
page:页数

查询指定用户的NH资产售卖订单

方法:queryAccountNHAssetOrders
功能:查询指定用户的NH资产售卖订单
参数:
account:查询账户名或账户Id
pageSize:页容量
page:页数

查询账户下所拥有的道具NH资产

方法:queryAccountNHAssets
功能:读取当前用户账户下所有可在对应游戏中使用的NH资产
参数:
account:账户名或账户id
worldViews (array):世界观名集合
page:页数
pageSize:页容量,每页的数据条数
callback:返回值。示例:
{status:1,data:[],total:0}

查询开发者所关联的世界观

方法:queryNHCreator
功能:查询开发者所关联的世界观
参数:
account:账户名或账户ID

查询开发者创建的NH资产

方法:queryNHCreator
功能:查询开发者所创建的世界观
参数:
account:账户名或账户ID

查询NH资产详细信息

方法:queryNHAssets
功能:查询NH资产详细信息
参数:
NHAssetIds(Array):NH资产id或hash

查询世界观详细信息

方法:lookupWorldViews
功能:查询世界观详细信息
参数:
worldViews (array):世界观名称或id

节点投票

查询节点投票信息数据

方法:queryVotes
功能:查询节点投票信息数据
参数:
queryAccount:查询指定账户的投票信息
type:witnesses表示查询见证人,committee表示查询理事会

用户提交投票信息

方法:publishVotes
功能:用户提交投票信息
参数:
type:见证人账户id集合或理事会账户id集合 ,查询节点投票信息数据中会有每个见证人和理事会成员的账户ID
vote_ids:投票id votes(Number):投票数量

区块链浏览器类接口

查询区块

方法:queryBlock
功能:通过区块高度查询区块信息
参数:
block:区块高度

查询交易

方法:queryTransaction
功能:通过交易id(即交易hash)查询交易信息
参数:
transactionId:交易id

查询信息通过id

方法:queryDataByIds 功能:通过id查询相关数据信息
参数:
ids(Array):id数组集合

订阅区块

方法:subscribeToBlocks
功能:监听实时出块信息
参数:
isReqTrx:订阅的区块是否包含交易信息,默认包含 callback:回调函数

订阅区块链交易

方法:subscribeToChainTranscation
功能:监听区块链全网发生的交易
参数:
callback:回调函数

查看节点出块信息

方法:lookupWitnessesForExplorer
功能:这里重点是参照demo解析节点出块信息数据
参数:
callback:回调函数

查询可领取的解冻资产

方法:queryVestingBalance 功能:参照demo解析数据
参数: account:查询指定账户的可领取的解冻资产
callback:回调函数

领取节点出块奖励

方法:claimVestingBalance
功能:领取节点出块奖励
参数:
id:奖励id,查询节点出块奖励中会有这个id

API服务器节点相关接口

bcx初始化

方法:init
功能:初始化内容包括RPC连接、重新载入Indexedb数据等
参数:
refresh:选填,第一次init后,第二次init会使用缓存信息。只有当refresh为true才会重新载入数据,重新初始化RPC模块
autoReconnect:选填,RPC断开后是否进行重连
subscribeToRpcConnectionStatusCallback:选填,监听RPC连接状态,返回 status=>closed:rpc连接关闭,error:rpc连接错误,realopen:rpc连接成功。此监听有单独的方法提供
callback:选填,回调函数

查看API服务器节点列表

方法:lookupWSNodeList
功能:查看API服务器节点列表信息
参数:
refresh:是否刷新ping,此刷新只能刷新非当前连接节点,若想全刷新则调用init({refresh:true})

连接API服务器节点

方法:switchAPINode
功能:切换节点
参数:
url:API服务器节点地址,此地址必须是API服务器节点列表中的websoket地址

添加新的API服务器节点

方法:addAPINode
功能:添加新节点
参数:
name:新节点名称
url:API服务器节点websoket地址

删除API服务器节点

方法:deleteAPINode
功能:删除节点
参数:
url:API服务器节点websoket地址

监听与API服务器节点的连接状态变化

方法:subscribeToRpcConnectionStatus
功能:监听rpc连接状态变化
参数:
callback:回调会返回状态status,包括下述结果:
closed:rpc连接关闭
error:rpc连接错误
realopen:rpc连接成功

合约

一键生成私钥/公钥(随机生成)

方法:generateKeys
功能:随机生成一对公私钥,创建带有权限的合约会用到,生成的私钥用于API初始化对合约授权,没有回调,直接返回

合约创建

方法:createContract
功能:创建智能合约,如果要对合约设置权限,创建合约时得加入特定的合约权限相关代码,并调用合约函数set_permissions_flag,合约权限相关代码:

function my_change_contract_authority(publickey) 
    assert(chainhelper:is_owner()) 
    chainhelper:change_contract_authority(publickey) 
end 

function set_permissions_flag(flag) 
    assert(chainhelper:is_owner()) 
    chainhelper:set_permissions_flag(flag) 
end

参数:
authority:合约权限(一对公私钥中的公钥publicKey),开发者在使用API初始化的时候,可以配置私钥,配置了该公钥对应的私钥才可以调用合约。
name:合约名称,正则/^[a-z][a-z0-9.-]{4,63}$/,首字母开头+字母或数字或点.或短横线-,长度4至63 data:合约lua代码

合约更新

方法:updateContract
功能:更新合约代码
参数:
nameOrId:合约名称或Id,示例:contract.test02
data:合约lua代码

合约调用

方法:callContractFunction
功能:调用合约函数接口
参数:
nameOrId:合约名称或Id,示例:contract.test02
functionName:合约里的函数名称,my_nht_describe_change (修改道具属性)
valueList(array): 调用合约函数的参数列表,示例:[4.2.0,{"size":"large"}] ,这里的参数若传json字符串,则合约需调用cjson解析,若传对象则无需cjson解析

查询合约信息

方法:queryContract
功能:查询合约信息数据
参数:
nameOrId:合约名字或Id

查询账户合约数据

方法:queryAccountContractData
功能:查询账户合约里产生数据
参数:
account:账户名或Id
contractNameOrId:合约名字或Id

交易市场

代币资产“限价单”交易

方法:createLimitOrder
功能:代币资产“限价单”交易
参数:
transactionPair:交易对,示例"TEST_USDT",(TEST_USDT为买卖USDT交易市场的TEST)
type(number):交易类型type(0:卖单,1:买单)
price:价格price(单位为交易市场顶级资产,如USDT市场,单位为USDT) amount:数量(单位如二级资产TEST)

取消“限价单”委托订单

方法:cancelLimitOrder
功能:取消“限价单”委托订单
参数:
orderId:订单id

查询&订阅市场交易对相关数据

方法:queryTransactionPair
功能:返回的数据有orders(当前买卖盘订单),my_orders(当前账户的委托订单),last_trade_history(近期该交易对的交易记录),my_last_trade_history(当前账户该交易对的交易记录) 参数:
transactionPair:交易对,示例"TEST_USDT",(TEST_USDT为买卖USDT交易市场的TEST)
subscribe(boolean):是否开启订阅 hasMyTradeHistory:是否包含我的交易历史

查询&订阅交易市场行情

方法:queryMarketStats
功能:查询&订阅交易市场行情
参数:
baseAsset:交易市场资产symbol quoteAssets(Array):相关交易对的币种,如[COCOS,TEST]
subscribe(boolean):是否开启订阅
assetCache(boolean):是否缓存资产信息,若缓存,则手续费汇率更新不会影响价格

查询交易对K线数据

方法:queryPriceHistory
功能:查询交易对K线数据
参数:
trxSymbol:交易对trx_symbol(TEST_USDT为买卖USDT交易市场的TEST) step(number):周期(单位秒) page(number):第几页 pageSize(number):返回数据条数

资产喂价提供者更新

方法:assetUpdateFeedProducers 功能:资产喂价提供者更新
参数:
assetId:资产id newFeedProducers(Array):喂价账户数组

资产喂价

方法:assetPublishFeed 功能:资产喂价 参数:
assetId:资产id price(Number):价格 maintenanceCollateralRatio(Number):维持抵押率
maximumShortSqueezeRatio(Number):强制平仓比例上限
coreExchangeRate:{ //手续费汇率 quoteAmount(Number)://基准资产数量 baseAmount(Number)://标价资产数量(COCOS) }

抵押债仓

方法:callOrderUpdate 功能:抵押资产借入锚定资产,如果结算价格没有被清空,则不能进行借贷,要想清空结算价格,需要发布结算价格低"维持抵押率"倍数的价格 参数:
collateralAmount:债务金额(借入金额)
collateralAssetId:债务资产id
debtAmount:抵押资产金额
debtAssetId:抵押资产id

查询债仓

方法:queryDebt 功能:查询债仓
参数:
account:查询账户
debtAssetId:债务资产id
collateralAssetId:抵押资产id

个人资产清算

方法:assetSettle 功能:个人资产清算
参数:
assetId:清算资产符号
amount:清算资产金额

全局资产清算

方法:assetGlobalSettle 功能:全局清算根据当前提供的价格立即清算,个人清算是以资产设定的延迟清算时间到来时的喂价价格执行清算
参数:
assetId:清算资产符号
price:清算资产价格

其他

API参数配置

方法:apiConfig
功能:API参数配置
参数:
API初始化相关参数

取消订阅

方法:unsubscribe
功能:取消订阅
参数:
method(Array):取消指定订阅的方法名,如取消订阅区块和区块链交易['subscribeToBlocks','subscribeToBlocks'],不传该参数则取消所有订阅。该方法不传callback则返回promise。
注:若需指定取消某一用户的订阅,则参数为['subscribeToAccountOperation|account'] callback:回调函数

交易备注解密

方法:decodeMemo
功能:无回调,直接返回结果,结果是一个对象,对象中包含备注文本text。该方法传参是直接传入,非包裹式options对象传参。 示例:bcl.decodeMemo(raw_data.memo) ,其中raw_data为交易原始数据。

获取交易类型基础手续费

方法:queryTransactionBaseFee
功能: 获取交易类型基础手续费
参数:
transactionType:交易类型,示例transfer
feeAssetId:选择支付手续费的代币类型资产符号或ID

transactionType列表

transactionType 对应相关API
transfer transferAsset
account_create createAccountWithPassword
account_update changePassword
account_upgrade upgradeAccount
asset_create createAsset
asset_issue issueAsset
proposal_update submitProposal
vesting_balance_withdraw claimVestingBalance
contract_create createContract
call_contract_function callContractFunction
register_creator registerCreator
creat_world_view creatWorldView
propose_relate_world_view proposeRelateWorldView
creat_nh_asset creatNHAsset
delete_nh_asset delete_nh_asset
transfer_nh_asset transferNHAsset
creat_nh_asset_order creatNHAssetOrder
cancel_nh_asset_order cancelNHAssetOrder
fill_nh_asset_order fillNHAssetOrder
limit_order_create createLimitOrder
limit_order_cancel cancelLimitOrder