Solana Provider
The Tomo Telegram SDK provides a Solana Provider for querying and sending SOL and SPL tokens.
// get provider
const sol = window.tomo_sol;Connect with the Wallet
Before using the provider, the user needs to log in to the wallet through the modal by following the method:
// connect wallet
await sol?.connectWallet();Query Methods
Solana providers support two query methods:
getAddressgetBalance
const address = sol.getAddress();
const balance = await sol.getBalance(address);Signing Methods
In Solana providers, we provide four signing methods:
signMessagesignTransactionsignTransactionssignTokenTransaction
Sign message
signMessage the method will create an offchain signature for one message and return the signed transaction in hex.
const response = await sol.signMessage(signMsg);To verify the signature, you need to add the header "\xffsolana offchain" before the `signMsg`
SOL transfer transaction
signTransaction is typically used to send SOL to another address and return the signed transaction. You can also use signTransactions it to pass an array of transactions for signing.
const response = await sol.signTransaction({
from: 8y9wmwVhban5Mrp8j68fQv1Kceeifeowt5Yw1DjwXoxk,
to: 646rZ228LDcYecNvoBGNysJ9pGLc7gBeTrnSgZ476rBp,
value: 0.01,
});SPL token transaction
and signTokenTransaction supports signing transactions for sending SPL tokens. You need to provide a mint address for this transaction.
const response = await sol.signTokenTransaction({
from: '8y9wmwVhban5Mrp8j68fQv1Kceeifeowt5Yw1DjwXoxk',
to: '646rZ228LDcYecNvoBGNysJ9pGLc7gBeTrnSgZ476rBp',
value: val,
chainId: 501,
contract: 'Es9vMFrzaCERmJfrF4H2FYD4KCoNkY11McCe8BenwNYB',
});Sending Methods
After signing transactions, you can use sendTransaction it to send the transaction. The return value is the transaction hash:
const res = await sol.sendTransaction(response);Last updated