-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathcolmeia-hyperswarm-mdns.rs
98 lines (88 loc) · 3.16 KB
/
colmeia-hyperswarm-mdns.rs
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
92
93
94
95
96
97
98
use async_std::{prelude::FutureExt, prelude::StreamExt, sync::RwLock, task};
use colmeia_hyperstack::utils::PublicKeyExt;
use colmeia_hyperswarm_mdns::MdnsDiscovery;
use std::{env, sync::Arc, time::Duration};
// 7e5998407b3d9dbb94db21ff50ad6f1b1d2c79e476fbaf9856c342eb4382e7f5
// pra
// b62ef6792a0e2f2c5be328593532415d80c0f52c // 32 bytes
// Derivacao igual ao dat1
fn main() {
log::debug!("Starting up");
let hyper_hash = env::args()
.nth(1)
.expect("provide a hyper hash as argument");
let port = env::args()
.nth(2)
.expect("requires a port as second argument")
.parse::<u16>()
.expect("Could not parse port as number");
let duration = env::args()
.nth(3)
.unwrap_or_else(|| "10".into())
.parse::<u64>()
.expect("Could not parse duration into a number");
env_logger::init();
let key = hyper_hash.parse_from_hash().expect("could not parse hash");
task::block_on(async move {
let mdns = Arc::new(RwLock::new(MdnsDiscovery::new()));
let topic = hypercore_protocol::discovery_key(key.as_bytes());
mdns.write()
.await
.with_announcer(port)
.with_locator(Duration::from_secs(duration));
// Spawn a task to print a topic
{
let mdns = mdns.clone();
task::spawn(async move {
loop {
log::debug!("trying to find a peer");
let discovery_attempt = {
let mut write_lock = mdns.write().await;
write_lock.next().timeout(Duration::from_secs(1)).await
};
match discovery_attempt {
Ok(Some((discovery_key, peer))) => {
println!(
"Found peer {:?} serving {}",
peer,
hex::encode(discovery_key)
);
}
Err(_) => {
task::yield_now().await;
}
Ok(None) => {
break;
}
}
}
});
}
// Spawn a task to add a topic
{
let mdns = mdns.clone();
let topic = topic.clone();
task::spawn(async move {
log::debug!("registering topic");
mdns.write()
.await
.add_topic(topic)
.await
.expect("could not write topic");
log::debug!("topic registered");
});
}
// Spawn a task to remove a topic after 30 secs, then finish the program
task::spawn(async move {
task::sleep(Duration::from_secs(30)).await;
log::debug!("sopping cli");
mdns.write()
.await
.remove_topic(topic)
.await
.expect("failed to remove topic");
log::debug!("stoped cli");
})
.await;
});
}