Le kit de développement OmniTool convient pour ajouter rapidement la prise en charge des actifs numériques Omni Layer/USDT aux applications PHP. Il prend en charge les scénarios d'application utilisant ses propres nœuds Omni Layer et ceux tiers légers. scénarios de déploiement pour les services API et les transactions nues hors ligne.
1. Introduction au kit de développement OmniTool
Le kit de développement OmniTool comprend principalement les fonctionnalités suivantes :
Le package RPC complet du nœud Omni Layer prend en charge l'utilisation de ses propres nœuds ou services tiers pour obtenir spécifié La collection d'adresses utxo prend en charge la génération hors ligne de transferts de jetons omni. Les transactions nues prennent en charge la diffusion de transactions nues à l'aide de leurs propres nœuds ou de services tiers
OmniTool prend en charge les nœuds Omnicored déployés localement et prend également en charge la blockchain. .info, btc.com, etc. Il est également très simple d'ajouter le support d'autres services tiers. Il vous suffit de vous référer au code pour implémenter l'interface suivante :
UtxoCollectorInterface : utxo collector UtxoSelectorInterface : filtre utxo BroadcasterInterface : diffuseur de transactions nues ExplorerInterface : interface de requête de données
Le progiciel OmniTool fonctionne dans l'environnement **Php 7.1+**, la version actuelle est 1.0.0, les principales classes/interfaces et relations sont affichées dans la figure ci-dessous :
2. Instructions d'utilisation de la classe RpcClient
La classe RpcClient encapsule le protocole d'interface RPC d'Omni Layer. Lors de la création d'un objet RpcClient, vous devez transmettre l'URL RPC du nœud contenant des informations d'identité valides. Par exemple, supposons que le logiciel de nœud omnicored installé sur la machine locale est configuré comme suit :
rpcuser : userrpcpassword : 123456rpcport : 8332
Vous pouvez ensuite utiliser le code suivant pour instancier RpcClient :
use \OmniTool\RpcClient; $client = new RpcClient( 'http://user:123456@localhost:8332' /*节点RPC接口的URL*/ );
Le nœud Omni Core a étendu des interfaces supplémentaires en plus de l'interface RPC d'origine de Bitcoin pour exploiter les données de la couche Omni. Ces interfaces RPC étendues utilisent le préfixe omni_ pour les distinguer de l'interface RPC d'origine de Bitcoin. Afin de faciliter la séparation des appels RPC au niveau de ces deux couches, RpcClient introduit le concept de sous-module de protocole et connecte respectivement l'interface RPC originale de Bitcoin et l'interface RPC étendue d'Omni au sous-module BTC et au sous-module Omni.
Par exemple, pour obtenir le solde du token USDT d'une certaine adresse, vous devez utiliser l'appel omni_getbalance de la couche Omni. Cet appel RPC correspond à la méthode getBalance() du sous-module omni de l'instance RpcClient. . Le code suivant obtient le solde USDT (asset ID : 31) de l'adresse 1EXoDusjGwvnjZUyKkxZ4UHEf77z6A5S4P :
$ret = $client->omni->getBalance( '1EXoDusjGwvnjZUyKkxZ4UHEf77z6A5S4P', /*地址*/ 31 /*资产ID:USDT*/ );
De même, vous pouvez utiliser l'appel omni_send pour effectuer un simple transfert USDT. Cet appel correspond au send( de l'omni. sous-module de l'instance RpcClient) ). Le code suivant transfère des jetons 100,0 USDT de l'adresse 3M9QVHKTGARHQCMTM5CRT9VAIDJ5PSFQGY à l'adresse 37fakponf7zqomlujeiko25pdiuvh5ylea:
$ret = $client->omni->send( '3M9qvHKtgARhqcMtM5cRT9VaiDJ5PSfQGY', /*代币转出地址*/ '37FaKponF7zqoMLUjEiko25pDiuVH5YLEa', /*代币转入地址*/ 31, /*代币ID:USDT*/ "100.00" /*转移的代币数量*/ );
L'interface RPC de RPC de RPCL. Par exemple, utilisez l'appel listunspent pour obtenir l'utxo de l'adresse spécifiée dans le nœud local :
$ret = $client->btc->listUnspent( 6, /*最小确认数*/ 999999, /*最大确认数*/ ['mgnucj8nYqdrPFh2JfZSB1NmUThUGnmsqe'] /*地址清单*/ );
L'exemple de code demo/rpc-demo.php dans le package de développement utilise la classe RpcClient pour démontrer complètement le jeton. émission et transfert au niveau de la couche Omni Function, si vous envisagez de créer votre propre nœud Omni Core, je pense que cet exemple sera d'une grande aide.
3. Instructions d'utilisation de la classe Wallet
Si vous ne souhaitez pas créer votre propre nœud Omni Core, mais souhaitez ajouter la prise en charge d'Omni Layer/USDT à votre application PHP basée sur un API tierce, puis la méthode la plus simple consiste à utiliser la classe d'entrée Wallet pour les transactions hors ligne.
La fonction principale de la classe Wallet est de créer et de diffuser des transactions nues de transfert de jetons Omni ou des transactions nues de transfert Bitcoin. Ses étapes d'utilisation de base sont les suivantes :
使用Wallet::cloud()静态方法创建一个支持云端API服务的Wallet实例使用addKey()方法将必要的私钥加入该Wallet实例,例如转出地址的私钥,因为Wallet需要利用私钥对裸交易进行签名使用omniSendTx()方法生成Omni代币转账裸交易,或者使用btcSendTx()方法比特币转账裸交易使用broadcast()方法广播裸交易
3.1 Omni代币转账
使用Wallet实现的Omni代币转账示例代码如下,说明见注释:
<?phprequire('../vendor/autoload.php');use OmniTool\Wallet; /*引入开发包*/$wallet = Wallet::cloud( './demo.wallet', /*钱包文件地址,自动创建*/ 'testnet' /*网络ID*/ ); $prvKey = '4aec8e45106....00d5c5af494a4e05b'; /*私钥:16进制字符串*/ $wallet->addKey($prvKey); /*将私钥加入钱包,只需加入一次*/$addressList = $wallet->getAddressList(); /*返回钱包管理的所有地址,数组*/$rawtx = $wallet->omniSendTx( $addressList[0], /*发送方地址,私钥必须已经加入钱包*/ 'mgYPLmNuZymK...e2XUNF6VFnT', /*接收方地址*/ 2, /*转账OMNI代币ID,2:TOMN*/ '0.000001' /*转账OMNI代币数量*/ ); $ret = $wallet->broadcast($rawtx); /*广播OMNI裸交易*/var_dump($ret);
注意:
Wallet实例利用钱包中的私钥生成地址列表,并利用这些地址从第三方服务获取utxo信息。 因此需要钱包中 的私钥对应地址在链上有utxo存在,Wallet对象才能够成功构造裸交易。转账目标地址应当与创建Wallet对象时指定的链ID一致,例如mainnet的p2pkh地址,前缀应当为1
3.2 指定Omni交易的手续费支付地址
在Omni协议层不需要支付交易手续费,但是Omni交易所嵌入的比特币交易依然需要支付手续费。默认情况下omniSendTx()方法使用发送方地址支付比特币交易手续费,但可以传入额外的参数来指定其他地址支付交易手续费,当你的PHP应用需要实现多账户归集功能时,使用统一的手续费支付地址会更容易管理一些。
例如,下面的代码使用地址mnRo8JyTHDd5NxRb3UvGbAhCBPQTQ4UZ8W支付omni交易的手续费:
$rawtx = $wallet->omniSendTx( $addressList[0], /*发送方地址,私钥必须已经加入钱包*/ 'mgYPLmNuZymK...e2XUNF6VFnT', /*接收方地址*/ 2, /*转账OMNI代币ID,2:TOMN*/ '0.000001', /*转账OMNI代币数量*/ 'mnRo8JyTHDd5...CBPQTQ4UZ8W' /*交易手续费支付地址*/ );
注意:
即使指定了余额充足的手续费支付地址,Omni交易的发送方依然必须有微量的比特币 余额(546 SATOSHI),因为Omni协议需要交易发送方至少有一个可用UTXO。手续费支付地址同时也是找零地址,多余的比特币将返回至该地址
3.3 指定Omni交易的比特币转账数量
由于Omni交易要求发送方必须有可用的UTXO,因此为了便于接收Omni代币的地址可以继续流通所持有的Omni代币,omniSendTx()方法在默认情况下将向接收方地址转入微量的比特币(546 SATOSHI),可以在调用该方法时修改这个默认数值。
例如,下面的代码转入接收方1000个SATOSHI:
$rawtx = $wallet->omniSendTx( $addressList[0], /*发送方地址,私钥必须已经加入钱包*/ 'mgYPLmNuZymK...e2XUNF6VFnT', /*接收方地址 2, /*转账OMNI代币ID,2:TOMN*/ '0.000001', /*转账OMNI代币数量*/ 'mnRo8JyTHDd5...CBPQTQ4UZ8W', /*交易手续费支付地址*/ 1000 /*转账比特币数量,单位:SATOSHI*/ );
3.4 比特币转账
OmniTool也支持比特币转账裸交易的生成与广播。
例如,下面的代码从钱包的第一个地址向指定接受地址转入1000个SATOSHI:
<?phprequire('../vendor/autoload.php');use OmniTool\Wallet; $wallet = Wallet::cloud('./demo.wallet','testnet'); $addressList = $wallet->getAddressList(); $rawtx = $wallet->btcSendTx( $addressList[0], /*发送方地址*/ 'moneyqMan7u...8qVrc9ikLP', /*接收方地址*/ 1000, /*转账比特币数量,单位:SATOSHI*/ 500 /*手续费,单位:SATOSHI*/ ); echo 'btc rawtx => ' . $rawtx . PHP_EOL; $ret = $wallet->broadcast($rawtx); /*广播裸交易*/
默认情况下,btcSendTx()使用发送方地址作为找零地址,也可以在调用时指定其他地址作为找零地址,例如,下面的代码创建一个新地址接收找零:
$changeAddress = $wallet->getNewAddress(); /*创建新地址*/$rawtx = $wallet->btcSendTx( $addressList[0], /*发送方地址*/ 'moneyqMan7u...8qVrc9ikLP', /*接收方地址*/ 1000, /*转账比特币数量,单位:SATOSHI*/ 500, /*手续费,单位:SATOSHI*/ $changeAddress /*找零地址*/ );
4、UTXO收集器
OmniTool使用接口UtxoCollectorInterface来约定UTXO的收集功能。该接口的实现需要支持获取指定地址的候选UTXO集合,可指定多个地址。
接口方法:
collect($addressList):提取并返回候选UTXO集合
参数$addressList用来声明要收集UTXO的地址清单,类型为数组。
当前实现类:
CloudUtxoCollector:基于blockchain.com的开放API实现的Utxo收集器LocalUtxoCollector:基于omnicored节点RPC API实现的Utxo收集器
例如,下面的代码使用CloudUtxoCollector获取地址mi8BvbK73nDQfaN3acpaFGYQKhfQ5ysKRn的UTXO:
use OmniTool\CloudUtxoCollector; $collector = new CloudUtxoCollector( 'testnet' /*测试网*/ ); $candidateBag = $collector->collect( ['mi8BvbK73nDQ...KhfQ5ysKRn'] /*地址清单*/ );
5、UTXO筛选器
OmniTool使用UtxoSelectorInterface来约定UTXO筛选功能。该接口的实现需要根据目标金额从候选UTXO中选择可用UTXO,并返回新的UtxoBag实例。
接口方法:
select($target,$candidates):选择可消费UTXO,返回UtxoBag对象
参数$target声明要达成的最低金额目标,单位:wei。
参数$candidates是候选的utxo集合,通常是UtxoCollectorInterface实现对象的collect()调用返回的UtxoBag对象。
当前实现类:
DefaultUtxoSelector
例如下面的代码使用DefaultUtxoSelector实例从候选UTXO中删选出至少100000 wei 的UTXO:
use OmniTool\DefaultUtxoSelector; $selector = new DefaultUtxoSelector(); $selectedBag = $selector->select( 100000, /*最低目标金额*/ $candidateBag /*候选UTXO集合*/ );
考虑到UTXO的不可分割性,筛选出的若干UTXO的总和,有可能超过目标金额。可以使用UtxoBag实例的getTotal()方法查看集合中的UTXO总额:
echo 'total wei in bag => ' . $selectedBag->getTotal() . PHP_EOL;
6、裸交易广播器
OmniTool使用BroadcasterInterface来约定裸交易广播的功能。该接口的实现应当将裸交易广播到Omni网络中。
接口方法:
broadcast($rawtx):广播裸交易
参数$rawtx用来声明要广播的裸交易,类型为16进制字符串。
当前实现类:
CloudBroadcasterLocalBroadcaster
例如,下面的代码使用CloudBroadcaster将裸交易码流广播到Omni网络中:
use OmniTool\CloudBroadcaster; $broadcaster = new CloudBroadcaster( 'testnet' /*测试网*/ ); $ret = $broadcaster->broadcast( '01000000011da9283b4...59f58488ac00000000' /*裸交易*/ );
7、数据查询接口
OmniTool使用ExplorerInterface来约定Omni数据查询功能。
接口方法:
getBtcBalance($address):查询指定地址的比特币余额getOmniBalance($address,$propertyId):查询指定地址的Omni代币余额
当前实现类:
CloudBroadcasterLocalBroadcaster
例如,下面的代码使用CloudExplorer查询地址1Jekm8ZswQmDhLFMp9cuYb1Kcq26riFp6m的比特币余额与USDT代币余额:
use OmniTool\CloudExplorer; $explorer = new CloudExplorer('mainnet'); $address = '1Jekm8ZswQmDhLFMp9cuYb1Kcq26riFp6m'; $balance = $explorer->getBtcBalance($address);echo 'btc balance => ' . PHP_EOL; $balance = $explorer->getOmniBalance($address,31);echo 'usdt balance => ' . $balance['balance']. PHP_EOL;
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!