tightenco/solana-php-sdk

此包已废弃,不再维护。未建议替代包。

Solana PHP SDK

v0.3.2 2022-03-04 21:44 UTC

README

Latest Version on Packagist GitHub Tests Action Status

ℹ️ 截至2024年5月,我们已归档此仓库。 请查看基于分支的替代方案(https://github.com/Attestto-com/solana-php-sdk)。

⚠️ 截至2023年5月,此包再次开放接纳! 欢迎联系 https://github.com/neverything。遗憾的是,我们在Verze从未完成我们想要的工作,因此我们不再从事该项目,因此此包正在寻找新的合作伙伴。自行承担风险。Verze将 不会 为此包提供任何支持;请不要发送任何期望得到支持的电子邮件。

Simple PHP SDK for Solana.

安装

您可以通过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. 有建议?请提交问题或PR :D

测试

composer test

贡献

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

安全

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

致谢

许可

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