This project is a Rust application that listens for new blocks on the Solana blockchain, fetches block details, and prints transaction information to the console. It connects to the Solana devnet RPC endpoint and periodically polls for new blocks, printing relevant transaction details.
- Creates a gossip node using the
solana_gossip::gossip_service::make_gossip_node
function - Pulls gossip transactions from the cluster using a cursor from
solana_gossip::crds::Cursor
- Prints transaction signatures, recent blockhashes, and instructions
- Connects to the Solana devnet RPC endpoint.
- Periodically polls for new blocks within a specified slot range.
- Fetches detailed transaction information for each block.
- Prints transaction signatures, recent blockhashes, and instructions.
The project also includes an example file websocket.rs that demonstrates how to subscribe to incoming blocks using the PubsubClient from the solana_client. Note that this requires the Solana node to be running with the flag --rpc-pubsub-enable-block-subscription.
- Rust programming language (version 1.50.0 or later)
In the Cargo.toml
file, you'll find the following dependencies:
[dependencies]
solana-client = "1.18.12"
solana-sdk = "1.18.12"
solana-transaction-status = "1.18.12"
tokio = "1.37.0"
solana-gossip = "1.11.11"
solana-streamer = "1.18.16"
solana-gossip
: The Solana Gossip service that allows us to listen on the gossip layer and push/pull datasolana-streamer
: The library used to create aSocketAddrSpace
that is used to create a gossip nodesolana-client
: The Solana RPC client library providing the necessary functions to interact with Solana RPC endpoints.solana-sdk
: The Solana SDK library that provides the necessary functions to interact with the HTTP or Websocket client.solana-transaction-status
: The library including essential types and utilities that we will use for message encoding/decoding and to handle instructions in each transaction.serde_json
: JSON serialization/deserialization librarytokio
: The asynchronous runtime that is used in this case to handle WebSocket communication and timers.
-
Ensure you have Rust installed. If not, you can get it from rust-lang.org.
-
Clone this repository:
git clone [email protected]:JoshuaSum/solana-txn.git cd solana-block-listener
-
Build the project:
cargo build --release
Start the block listener by running the following command
cargo run --release