selaz/solana-php-sdk

Solana PHP SDK

dev-main 2023-09-28 11:59 UTC

This package is not auto-updated.

Last update: 2024-09-27 14:34:17 UTC


README

Latest Version on Packagist GitHub Tests Action Status

⚠️ 截至2023年5月,此包再次可供收养! 随意联系 https://github.com/neverything。遗憾的是,我们从未在Verze完成我们想要的事情,所以我们不再从事此项目,因此此包正在寻找新的手来工作。使用风险自担。Verze 不会 为现有此包提供任何支持;请不要给我们发邮件期望得到支持。

简单的Solana PHP SDK。

安装

您可以通过composer安装此包

composer require tightenco/solana-php-sdk

用法

使用Solana简单客户端

您可以使用Connection类方便地访问API方法。其中一些在代码中定义

use Tighten\SolanaPhpSdk\Connection;
use Tighten\SolanaPhpSdk\SolanaRpcClient;

// Using a defined method
$sdk = new Connection(new SolanaRpcClient(SolanaRpcClient::MAINNET_ENDPOINT));
$accountInfo = $sdk->getAccountInfo('4fYNw3dojWmQ4dXtSGE9epjRGy9pFSx62YypT7avPYvA');
var_dump($accountInfo);

有关所有可能的方法,请参阅API文档

直接使用RPC客户端

Connection类只是在RPC客户端之上提供了一个轻量级的便利层。如果您愿意,可以直接使用客户端,这允许您与完整的Response对象一起工作

use Tighten\SolanaPhpSdk\SolanaRpcClient;

$client = new SolanaRpcClient(SolanaRpcClient::MAINNET_ENDPOINT);
$accountInfoResponse = $client->call('getAccountInfo', ['4fYNw3dojWmQ4dXtSGE9epjRGy9pFSx62YypT7avPYvA']);
$accountInfoBody = $accountInfoResponse->json();
$accountInfoStatusCode = $accountInfoResponse->getStatusCode();

交易

以下是将转账指令发送到Solana区块链的示例

$client = new SolanaRpcClient(SolanaRpcClient::DEVNET_ENDPOINT);
$connection = new Connection($client);
$fromPublicKey = KeyPair::fromSecretKey([...]);
$toPublicKey = new PublicKey('J3dxNj7nDRRqRRXuEMynDG57DkZK4jYRuv3Garmb1i99');
$instruction = SystemProgram::transfer(
    $fromPublicKey->getPublicKey(),
    $toPublicKey,
    6
);

$transaction = new Transaction(null, null, $fromPublicKey->getPublicKey());
$transaction->add($instruction);

$txHash = $connection->sendTransaction($transaction, $fromPublicKey);

注意:此项目处于alpha阶段,生成指令的代码仍在开发中 $instruction = SystemProgram::abc()

路线图

  1. Borsh序列化和反序列化。
  2. 改进文档。
  3. 构建更多Connection、SystemProgram、TokenProgram、MetaplexProgram类。
  4. 改善处理二进制数据的相关抽象。
  5. 优化
    1. 利用PHP。
    2. 在发送交易时更好地缓存$recentBlockhash
  6. 建议?打开一个issue或PR :D

测试

composer test

贡献

请参阅CONTRIBUTING以获取详细信息。

安全性

如果您发现任何与安全相关的问题,请通过电子邮件security@verze.app联系,而不是使用issue跟踪器。

致谢

许可证

MIT许可证(MIT)。有关更多信息,请参阅许可证文件