#[cfg(feature = "actix")]
extern crate actix_web;
extern crate futures;
#[cfg(feature = "hyper")]
extern crate hyper;
extern crate ipfs_api;
use futures::{Future, Stream};
use ipfs_api::{response::PingResponse, IpfsClient};
fn main() {
println!("connecting to localhost:5001...");
let client = IpfsClient::default();
println!();
println!("discovering connected peers...");
let req = client
.swarm_peers()
.and_then(move |connected| {
let peer = connected
.peers
.iter()
.next()
.expect("expected at least one peer");
println!();
println!("discovered peer ({})", peer.peer);
println!();
println!("streaming 10 pings...");
let ping_stream = client.ping(&peer.peer[..], Some(10)).for_each(|ping| {
println!("{:?}", ping);
Ok(())
});
let ping_gather = client.ping(&peer.peer[..], Some(15)).collect();
ping_stream.and_then(|_| {
println!();
println!("gathering 15 pings...");
ping_gather
})
})
.map(|pings: Vec<PingResponse>| {
for ping in pings.iter() {
println!("got response ({:?}) at ({})...", ping.text, ping.time);
}
})
.map_err(|e| eprintln!("{}", e));
#[cfg(feature = "hyper")]
hyper::rt::run(req);
#[cfg(feature = "actix")]
actix_web::actix::run(|| {
req.then(|_| {
actix_web::actix::System::current().stop();
Ok(())
})
});
}