Parses a Solana transaction and extracts the swap info, supports multiple AMMs. Please note that parsing methods may not be convetional as there are many various ways to parse a Solana transaction. Feedback and contributions are welcome!
- Extracts swap information from swap transactions
- Parsing methods:
- Pumpfun and Jupiter: parsing the event data
- Raydium, Orca, and Meteora: parsing Transfer and TransferChecked methods of the token program
- Moonshot: parsing the instruction data of the Trade instruction
To install the solanaswap-go package, use the following command:
go get github.com/franco-bianco/solanaswap-go
Here's an improved version of the Usage section of the solanaswap-go
README to make it clearer and more user-friendly:
Begin by importing the solanaswap-go
package into your Go project:
import (
"context"
"encoding/json"
"fmt"
"log"
"github.com/gagliardetto/solana-go/rpc"
solana "github.com/gagliardetto/solana-go"
solanaswapgo "github.com/franco-bianco/solanaswap-go/solanaswap-go"
)
Use the package to fetch and parse a Solana transaction. Here's an example of how to use the solanaswap-go
library to parse swap information from a transaction signature:
func main() {
// Set up RPC client for Solana mainnet
rpcClient := rpc.New(rpc.MainNetBeta.RPC)
// Replace with your actual transaction signature
txSig := solana.MustSignatureFromBase58("2XYu86VrUXiwNNj8WvngcXGytrCsSrpay69Rt3XBz9YZvCQcZJLjvDfh9UWETFtFW47vi4xG2CkiarRJwSe6VekE")
// Specify the maximum transaction version supported
var maxTxVersion uint64 = 0
// Fetch the transaction data using the RPC client
tx, err := rpcClient.GetTransaction(
context.TODO(),
txSig,
&rpc.GetTransactionOpts{
Commitment: rpc.CommitmentConfirmed,
MaxSupportedTransactionVersion: &maxTxVersion,
},
)
if err != nil {
log.Fatalf("Error fetching transaction: %s", err)
}
// Initialize the transaction parser
parser, err := solanaswapgo.NewTransactionParser(tx)
if err != nil {
log.Fatalf("Error initializing transaction parser: %s", err)
}
// Parse the transaction to extract basic data
transactionData, err := parser.ParseTransaction()
if err != nil {
log.Fatalf("Error parsing transaction: %s", err)
}
// Print the parsed transaction data
marshalledData, _ := json.MarshalIndent(transactionData, "", " ")
fmt.Println(string(marshalledData))
// Process and extract swap-specific data from the parsed transaction
swapData, err := parser.ProcessSwapData(transactionData)
if err != nil {
log.Fatalf("Error processing swap data: %s", err)
}
// Print the parsed swap data
marshalledSwapData, _ := json.MarshalIndent(swapData, "", " ")
fmt.Println(string(marshalledSwapData))
}
The above code fetches a Solana transaction, parses its contents, and extracts swap-specific data. The ProcessSwapData
function processes swap data and outputs it in JSON format.
{
"Signers": [
"4k8WHszi2uBzTiypTKUYH1hzYkUBCARPPn6ZjPNMhDoc"
],
"Signatures": [
"2XYu86VrUXiwNNj8WvngcXGytrCsSrpay69Rt3XBz9YZvCQcZJLjvDfh9UWETFtFW47vi4xG2CkiarRJwSe6VekE"
],
"AMMs": [
"Moonshot"
],
"Timestamp": "0001-01-01T00:00:00Z",
"TokenInMint": "CQn88snXCipTxn6DBbwgSA7d9v1sXPmyxzCNNiVNXzFy",
"TokenInAmount": 59948049312246101,
"TokenInDecimals": 9,
"TokenOutMint": "So11111111111111111111111111111111111111112",
"TokenOutAmount": 1711486459,
"TokenOutDecimals":
- Ensure you replace
txSig
with a valid Solana transaction signature. - The parser currently supports specific AMMs (e.g., Raydium, Orca, Pumpfun, etc.). Transactions involving unsupported programs may not be parsed correctly.
- Custom program swap transactions are not yet supported due to the outer instruction check
- Transaction timestamp is not included in
SwapInfo
response (should get this from block) - Improvements could be made for
splTokenInfoMap
andsplDecimalsMap
use-case and logic
- Raydium (V4, Route, CPMM, ConcentratedLiquidity)
- Orca
- Meteora (DLMM and Pools)
- MoonShot
- Pumpfun
- Jupiter
- OKX Dex Router
- BananaGun Bot
- Bloom Bot
- MinTech
- Nova Bot