1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
|
// This example explicitly creates and uses a single-threaded tokio
// runtime. See streamlisten_mt.rs for an example using tokio macros
// and multiple threads.
//
use futures::StreamExt;
use pcap::{Active, Capture, Device, Error, Packet, PacketCodec, PacketStream};
pub struct SimpleDumpCodec;
impl PacketCodec for SimpleDumpCodec {
type Item = String;
fn decode(&mut self, packet: Packet) -> Self::Item {
format!("{:?}", packet)
}
}
async fn start_new_stream(device: Device) -> PacketStream<Active, SimpleDumpCodec> {
match new_stream(device) {
Ok(stream) => stream,
Err(e) => {
println!("{:?}", e);
std::process::exit(1);
}
}
}
fn new_stream(device: Device) -> Result<PacketStream<Active, SimpleDumpCodec>, Error> {
// get the default Device
println!("Using device {}", device.name);
let cap = Capture::from_device(device)?
.immediate_mode(true)
.open()?
.setnonblock()?;
cap.stream(SimpleDumpCodec {})
}
fn main() {
let rt = tokio::runtime::Builder::new_current_thread()
.enable_io()
.build()
.unwrap();
let device = Device::lookup()
.expect("device lookup failed")
.expect("no device available");
let stream = rt.block_on(start_new_stream(device));
let fut = stream.for_each(move |s| {
println!("{:?}", s);
futures::future::ready(())
});
rt.block_on(fut);
}
|