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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
|
// Copyright 2017 rust-ipfs-api Developers
//
// Licensed under the Apache License, Version 2.0, <LICENSE-APACHE or
// http://apache.org/licenses/LICENSE-2.0> or the MIT license <LICENSE-MIT or
// http://opensource.org/licenses/MIT>, at your option. This file may not be
// copied, modified, or distributed except according to those terms.
//
#[cfg(feature = "actix")]
extern crate actix_web;
extern crate futures;
#[cfg(feature = "hyper")]
extern crate hyper;
extern crate ipfs_api;
extern crate tokio_timer;
use futures::{Future, Stream};
use ipfs_api::IpfsClient;
use std::{
thread,
time::{Duration, Instant},
};
use tokio_timer::Interval;
static TOPIC: &'static str = "test";
fn get_client() -> IpfsClient {
println!("connecting to localhost:5001...");
IpfsClient::default()
}
// Creates an Ipfs client, and simultaneously publishes and reads from a pubsub
// topic.
//
fn main() {
// This block will execute a repeating function that sends
// a message to the "test" topic.
//
thread::spawn(move || {
let client = get_client();
let publish = Interval::new(Instant::now(), Duration::from_secs(1))
.map_err(|e| eprintln!("{}", e))
.for_each(move |_| {
println!();
println!("publishing message...");
client
.pubsub_pub(TOPIC, "Hello World!")
.map_err(|e| eprintln!("{}", e))
});
println!();
println!("starting task to publish messages to ({})...", TOPIC);
#[cfg(feature = "hyper")]
hyper::rt::run(publish);
#[cfg(feature = "actix")]
actix_web::actix::spawn(publish);
});
// This block will execute a future that suscribes to a topic,
// and reads any incoming messages.
//
{
let client = get_client();
let req = client.pubsub_sub(TOPIC, false);
println!();
println!("waiting for messages on ({})...", TOPIC);
let fut = req
.take(5)
.for_each(|msg| {
println!();
println!("received ({:?})", msg);
Ok(())
})
.map_err(|e| eprintln!("{}", e));
#[cfg(feature = "hyper")]
hyper::rt::run(fut);
#[cfg(feature = "actix")]
actix_web::actix::run(|| {
fut.then(|_| {
actix_web::actix::System::current().stop();
Ok(())
})
});
}
}
|