ethers-rs/book/subscriptions/subscriptions.md

61 lines
2.1 KiB
Markdown

## Ethers-rs: Subscriptions
Here we will discuss how to use `ethers-rs` to subscribe and listen to blocks, events, and logs. Subscriptions provide a way to receive real-time updates on various activities on the Ethereum blockchain, allowing you to monitor the network and react to changes as they happen.
## Overview
ethers-rs offers a convenient way to work with subscriptions, enabling you to listen to new blocks, transaction receipts, and logs. The main components you will work with are:
1. Provider: The main struct used to interact with the Ethereum network.
2. SubscriptionStream: A stream of updates you can subscribe to for real-time notifications.
## Getting Started
Before working with subscriptions, make sure you have ethers-rs added to your project's dependencies in Cargo.toml:
```toml
[dependencies]
ethers = { version = "2.0.0", features = ["full"] }
```
Next, import the necessary components from the ethers-rs library:
```rust
use ethers::{prelude::\*,types::H256,};
```
### Subscribing to Events
As we discussed in the previous section on events, you can subscribe to specific events emitted by smart contracts using the EventWatcher struct. To create a SubscriptionStream, call the subscribe method on your EventWatcher:
```rust
let mut stream = watcher.subscribe().await?;
```
Now, you can listen to events as they are emitted by the smart contract:
```rust
while let Some(event) = stream.next().await {
match event {
Ok(log) => {
println!("New event: {:?}", log);
}
Err(e) => {
eprintln!("Error: {:?}", e);
}
}
}
```
By using the subscription features provided by ethers-rs, you can efficiently monitor and react to various activities on the Ethereum network. Subscriptions are a powerful tool for building responsive and dynamic applications that can interact with smart contracts and stay up-to-date with the latest network events.
### Unsubscribing from Subscriptions
In some cases, you may want to stop listening to a subscription. To do this, simply drop the SubscriptionStream:
```rust
drop(stream);
```
This will stop the stream from receiving any further updates.