ethers-rs/ethers/examples/get_logs.rs

20 lines
620 B
Rust
Raw Normal View History

2020-05-26 11:00:56 +00:00
use anyhow::Result;
2020-06-02 10:58:48 +00:00
use ethers::prelude::*;
2020-05-25 09:23:50 +00:00
use std::convert::TryFrom;
#[tokio::main]
2020-05-26 11:00:56 +00:00
async fn main() -> Result<()> {
2020-05-25 09:23:50 +00:00
// connect to the network
2020-06-02 10:58:48 +00:00
let provider = Provider::<Http>::try_from("http://localhost:8545")?;
2020-05-25 09:23:50 +00:00
let filter = Filter::new()
.address_str("f817796F60D268A36a57b8D2dF1B97B14C0D0E1d")?
.event("ValueChanged(address,string,string)") // event name
.topic0("9729a6fbefefc8f6005933898b13dc45c3a2c8b7".parse::<Address>()?); // indexed param
2020-05-25 09:23:50 +00:00
let logs = provider.get_logs(&filter).await?;
println!("Got logs: {}", serde_json::to_string(&logs).unwrap());
Ok(())
}