solana
is an unofficial Elixir package for interacting with the Solana blockchain.
There’s also solana_spl
, an unofficial Elixir package for interacting with the Solana Program Library.
You can use these packages to build clients for your Solana programs in Elixir, as opposed to using the official JavaScript and Rust SDKs or any of the unofficial SDKs in other languages.
Here’s an article explaining part of the motivation for me building this: Announcing the Solana Elixir SDK. Bringing Elixir to the Solana… | by e^{i} Ventures | Nov, 2021 | Medium
JSON-RPC API Client
At its core, solana
provides a simple interface for interacting with Solana’s JSON-RPC API. Here’s an example of requesting an airdrop to a new Solana account via the requestAirdrop
method:
key = Solana.keypair() |> Solana.pubkey!()
client = Solana.RPC.client(network: "localhost")
{:ok, signature} = Solana.RPC.send(client, Solana.RPC.Request.request_airdrop(key, 1))
Solana.Transaction.check(signature) # {:ok, ^signature}
I haven’t implemented all the API methods yet since I don’t need all of them. All the commonly-used ones are supported.
Using a custom HTTP client
Since this module uses Tesla for its API client, you can use whichever HTTP client you wish, just be sure to include it in your dependencies:
def deps do
[
# Gun, for example
{:gun, "~> 1.3"},
{:idna, "~> 6.0"},
{:castore, "~> 0.1"},
# SSL verification
{:ssl_verify_hostname, "~> 1.0"},
]
end
Then, specify the corresponding Tesla.Adapter when creating your client:
client = Solana.RPC.client(network: "localhost", adapter: {Tesla.Adapter.Gun, certificates_verification: true})
See the Solana.RPC
module for more details about which options are available when creating an API client.
On-chain program interaction
Since solana
's JSON-RPC API client supports sendTransaction
, you can use it to interact with on-chain Solana programs. solana
provides utilities to craft transactions, send them, and confirm them on-chain. It also includes the Solana.SystemProgram
module, which allows you to create SystemProgram
instructions.
Also check out the solana_spl
package documentation to interact with the Solana Program Library.
Writing a custom program client
By providing an interface for the Solana.SystemProgram
, solana
provides guidelines for how to build interfaces to your own programs. For more examples, see the solana_spl
package.
Testing custom programs
Once you’ve built your custom program’s client, you should probably write some tests for it. solana
provides example tests for the Solana.SystemProgram in test/solana/system_program_test.exs
, along with an Elixir-managed Solana Test Validator process to test your program locally. See Solana.TestValidator
for more details about how to set this up.
Future work
I plan on adding additional JSON-RPC API methods and on-chain program interfaces as I need them (and as the Solana JSON-RPC API changes). Contributions are welcome on GitHub.