summaryrefslogtreecommitdiffstats
path: root/lib/src/reactor/mod.rs
diff options
context:
space:
mode:
Diffstat (limited to 'lib/src/reactor/mod.rs')
-rw-r--r--lib/src/reactor/mod.rs20
1 files changed, 20 insertions, 0 deletions
diff --git a/lib/src/reactor/mod.rs b/lib/src/reactor/mod.rs
index 9e22b1e..c35cecc 100644
--- a/lib/src/reactor/mod.rs
+++ b/lib/src/reactor/mod.rs
@@ -24,6 +24,8 @@ pub enum ReactorRequest<CustomRequest: Debug + Send + Sync> {
/// Quit the reactor
Exit,
+ Connect(ipfs::MultiaddrWithPeerId),
+
Custom(CustomRequest),
}
@@ -32,6 +34,8 @@ pub enum ReactorReply<CustomReply: Debug + Send + Sync> {
Pong,
Exiting,
+ ConnectResult((Result<()>, ipfs::MultiaddrWithPeerId)),
+
Custom(CustomReply),
}
@@ -107,6 +111,22 @@ impl<CustomReactorRequest, CustomReactorReply> Reactor<CustomReactorRequest, Cus
Ok(None)
},
+ (ReactorRequest::Connect(addr), reply_channel) => {
+ match self.profile.read().await.client().connect(addr.clone()).await {
+ Ok(()) => if let Err(_) = reply_channel.send(ReactorReply::ConnectResult((Ok(()), addr.clone()))) {
+ anyhow::bail!("Failed sending ConnectResult({}, Ok(()))", addr)
+ } else {
+ Ok(None)
+ }
+
+ Err(e) => if let Err(_) = reply_channel.send(ReactorReply::ConnectResult((Err(e), addr.clone()))) {
+ anyhow::bail!("Failed sending ConnectResult({}, Err(_))", addr)
+ } else {
+ Ok(None)
+ }
+ }
+ }
+
(ReactorRequest::Custom(c), reply_channel) => {
Ok(Some((c, reply_channel)))
}