A lightweight Rust library providing efficient event parsing and subscription capabilities for PumpFun, PumpSwap, Bonk, and Raydium protocols.
δΈζ | English | Website | Telegram | Discord
- π Project Features
- β‘ Installation
- π Migration Guide
- βοΈ Configuration System
- π Usage Examples
- π§ Supported Protocols
- π Event Streaming Services
- ποΈ Architecture Features
- π Project Structure
- β‘ Performance Considerations
- π License
- π Contact
β οΈ Important Notes
- Real-time Event Streaming: Subscribe to live trading events from multiple Solana DEX protocols
- Yellowstone gRPC Support: High-performance event subscription using Yellowstone gRPC
- ShredStream Support: Alternative event streaming using ShredStream protocol
- Unified Event Interface: Consistent event handling across all supported protocols
- PumpFun: Meme coin trading platform events
- PumpSwap: PumpFun's swap protocol events
- Bonk: Token launch platform events (letsbonk.fun)
- Raydium CPMM: Raydium's Concentrated Pool Market Maker events
- Raydium CLMM: Raydium's Concentrated Liquidity Market Maker events
- Raydium AMM V4: Raydium's Automated Market Maker V4 events
- Event Parsing System: Automatic parsing and categorization of protocol-specific events
- Account State Monitoring: Real-time monitoring of protocol account states and configuration changes
- Transaction & Account Event Filtering: Separate filtering for transaction events and account state changes
- Dynamic Subscription Management: Runtime filter updates without reconnection, enabling adaptive monitoring strategies
- Multi-Filter Support: Support for multiple transaction and account filters in a single subscription
- Advanced Account Filtering: Memcmp filters for precise account data matching and monitoring
- Token2022 Support: Enhanced support for SPL Token 2022 with extended state parsing
- High Performance: Optimized for low-latency event processing
- Batch Processing Optimization: Batch processing events to reduce callback overhead
- Performance Monitoring: Built-in performance metrics monitoring, including event processing speed
- Memory Optimization: Object pooling and caching mechanisms to reduce memory allocations
- Flexible Configuration System: Support for custom batch sizes, backpressure strategies, channel sizes
- Preset Configurations: High-throughput and low-latency preset configurations optimized for different use cases
- Backpressure Handling: Supports blocking and dropping backpressure strategies
- Runtime Configuration Updates: Dynamic configuration parameter updates at runtime
- Graceful Shutdown: Support for programmatic stop() method for clean shutdown
Clone this project to your project directory:
cd your_project_root_directory
git clone https://github.com/0xfnzero/solana-streamerAdd the dependency to your Cargo.toml:
# Add to your Cargo.toml
solana-streamer-sdk = { path = "./solana-streamer", version = "1.0.0" }# Add to your Cargo.toml
solana-streamer-sdk = "1.0.0"Version 1.0.0 introduces a major architectural change from trait-based event handling to enum-based events. This provides better type safety, improved performance, and simpler code patterns.
Key Changes:
- Event Type Changed -
Box<dyn UnifiedEvent>βDexEventenum - Callback Signature - Callbacks now receive concrete
DexEventinstead of trait objects - Event Matching - Use standard Rust
matchinstead ofmatch_event!macro - Metadata Access - Event properties now accessed through
.metadata()method
For detailed migration steps and code examples, see MIGRATION.md or MIGRATION_CN.md (Chinese version).
Quick Migration Example:
// Old (v0.5.x)
let callback = |event: Box<dyn UnifiedEvent>| {
println!("Event: {:?}", event.event_type());
};
// New (v1.0.0)
let callback = |event: DexEvent| {
println!("Event: {:?}", event.metadata().event_type);
};You can customize client configuration:
use solana_streamer_sdk::streaming::grpc::ClientConfig;
// Use default configuration
let grpc = YellowstoneGrpc::new(endpoint, token)?;
// Or create custom configuration
let mut config = ClientConfig::default();
config.enable_metrics = true; // Enable performance monitoring
config.connection.connect_timeout = 30; // 30 seconds
config.connection.request_timeout = 120; // 120 seconds
let grpc = YellowstoneGrpc::new_with_config(endpoint, token, config)?;Available Configuration Options:
enable_metrics: Enable/disable performance monitoring (default: false)connection.connect_timeout: Connection timeout in seconds (default: 10)connection.request_timeout: Request timeout in seconds (default: 60)connection.max_decoding_message_size: Maximum message size in bytes (default: 10MB)
| Description | Run Command | Source Path |
|---|---|---|
| Monitor transaction events using Yellowstone gRPC | cargo run --example grpc_example |
examples/grpc_example.rs |
| Monitor transaction events using ShredStream | cargo run --example shred_example |
examples/shred_example.rs |
| Parse Solana mainnet transaction data | cargo run --example parse_tx_events |
examples/parse_tx_events.rs |
| Update filters at runtime | cargo run --example dynamic_subscription |
examples/dynamic_subscription.rs |
| Monitor specific token account balance changes | cargo run --example token_balance_listen_example |
examples/token_balance_listen_example.rs |
| Track nonce account state changes | cargo run --example nonce_listen_example |
examples/nonce_listen_example.rs |
| Monitor PumpSwap pool accounts using memcmp filters | cargo run --example pumpswap_pool_account_listen_example |
examples/pumpswap_pool_account_listen_example.rs |
| Monitor all associated token accounts for specific mints using memcmp filters | cargo run --example mint_all_ata_account_listen_example |
examples/mint_all_ata_account_listen_example.rs |
The library supports flexible event filtering to reduce processing overhead and improve performance:
use solana_streamer_sdk::streaming::event_parser::common::{filter::EventTypeFilter, EventType};
// No filtering - receive all events
let event_type_filter = None;
// Filter specific event types - only receive PumpSwap buy/sell events
let event_type_filter = Some(EventTypeFilter {
include: vec![EventType::PumpSwapBuy, EventType::PumpSwapSell]
});Event filtering can provide significant performance improvements:
- 60-80% reduction in unnecessary event processing
- Lower memory usage by filtering out irrelevant events
- Reduced network bandwidth in distributed setups
- Better focus on events that matter to your application
Trading Bot (Focus on Trade Events)
let event_type_filter = Some(EventTypeFilter {
include: vec![
EventType::PumpSwapBuy,
EventType::PumpSwapSell,
EventType::PumpFunTrade,
EventType::RaydiumCpmmSwap,
EventType::RaydiumClmmSwap,
EventType::RaydiumAmmV4Swap,
......
]
});Pool Monitoring (Focus on Liquidity Events)
let event_type_filter = Some(EventTypeFilter {
include: vec![
EventType::PumpSwapCreatePool,
EventType::PumpSwapDeposit,
EventType::PumpSwapWithdraw,
EventType::RaydiumCpmmInitialize,
EventType::RaydiumCpmmDeposit,
EventType::RaydiumCpmmWithdraw,
EventType::RaydiumClmmCreatePool,
......
]
});Update subscription filters at runtime without reconnecting to the stream.
// Update filters on existing subscription
grpc.update_subscription(
vec![TransactionFilter {
account_include: vec!["new_program_id".to_string()],
account_exclude: vec![],
account_required: vec![],
}],
vec![AccountFilter {
account: vec![],
owner: vec![],
filters: vec![],
}],
).await?;- No Reconnection: Filter changes apply immediately without closing the stream
- Atomic Updates: Both transaction and account filters updated together
- Single Subscription: One active subscription per client instance
- Compatible: Works with both immediate and advanced subscription methods
Note: Multiple subscription attempts on the same client return an error.
- PumpFun: Primary meme coin trading platform
- PumpSwap: PumpFun's swap protocol
- Bonk: Token launch platform (letsbonk.fun)
- Raydium CPMM: Raydium's Concentrated Pool Market Maker protocol
- Raydium CLMM: Raydium's Concentrated Liquidity Market Maker protocol
- Raydium AMM V4: Raydium's Automated Market Maker V4 protocol
- Yellowstone gRPC: High-performance Solana event streaming
- ShredStream: Alternative event streaming protocol
- DexEvent Enum: Type-safe enum containing all protocol events
- Protocol Enum: Easy identification of event sources
- Event Factory: Automatic event parsing and categorization
- Protocol-specific Parsers: Dedicated parsers for each supported protocol
- Event Factory: Centralized event creation and parsing
- Extensible Design: Easy to add new protocols and event types
- Yellowstone gRPC Client: Optimized for Solana event streaming
- ShredStream Client: Alternative streaming implementation
- Async Processing: Non-blocking event handling
src/
βββ common/ # Common functionality and types
βββ protos/ # Protocol buffer definitions
βββ streaming/ # Event streaming system
β βββ event_parser/ # Event parsing system
β β βββ common/ # Common event parsing tools
β β βββ core/ # Core parsing traits and interfaces
β β βββ protocols/# Protocol-specific parsers
β β β βββ bonk/ # Bonk event parsing
β β β βββ pumpfun/ # PumpFun event parsing
β β β βββ pumpswap/ # PumpSwap event parsing
β β β βββ raydium_amm_v4/ # Raydium AMM V4 event parsing
β β β βββ raydium_cpmm/ # Raydium CPMM event parsing
β β β βββ raydium_clmm/ # Raydium CLMM event parsing
β β βββ factory.rs # Parser factory
β βββ shred_stream.rs # ShredStream client
β βββ yellowstone_grpc.rs # Yellowstone gRPC client
β βββ yellowstone_sub_system.rs # Yellowstone subsystem
βββ lib.rs # Main library file
βββ main.rs # Example program
- Connection Management: Properly handle connection lifecycle and reconnection
- Event Filtering: Use protocol filtering to reduce unnecessary event processing
- Memory Management: Implement appropriate cleanup for long-running streams
- Error Handling: Robust error handling for network issues and service interruptions
- Batch Processing Optimization: Use batch processing to reduce callback overhead and improve throughput
- Performance Monitoring: Enable performance monitoring to identify bottlenecks and optimization opportunities
- Graceful Shutdown: Use the stop() method for clean shutdown and implement signal handlers for proper resource cleanup
MIT License
- Website: https://fnzero.dev/
- Project Repository: https://github.com/0xfnzero/solana-streamer
- Telegram Group: https://t.me/fnzero_group
- Discord: https://discord.gg/vuazbGkqQE
- Network Stability: Ensure stable network connection for continuous event streaming
- Rate Limiting: Be aware of rate limits on public gRPC endpoints
- Error Recovery: Implement proper error handling and reconnection logic
- Compliance: Ensure compliance with relevant laws and regulations