summaryrefslogtreecommitdiffstats
path: root/ipfs-api-examples/examples/get_swarm.rs
diff options
context:
space:
mode:
authorFerris Tseng <ferristseng@fastmail.fm>2021-04-04 20:06:34 -0400
committerGitHub <noreply@github.com>2021-04-04 20:06:34 -0400
commit799f702b22a9b567c0b6b7674210583b02b10d55 (patch)
tree92d7a1c9dcac42599357097c53caccfbdcaa8105 /ipfs-api-examples/examples/get_swarm.rs
parent4c78f5759c60499eefd4527ea34d574c2fb35c14 (diff)
parent168f3a5e68780c37f4070ea9d42ac70bd0158292 (diff)
Merge pull request #72 from ferristseng/ftseng-divide-cratesHEADmaster
Divide backends into separate crates
Diffstat (limited to 'ipfs-api-examples/examples/get_swarm.rs')
-rw-r--r--ipfs-api-examples/examples/get_swarm.rs48
1 files changed, 48 insertions, 0 deletions
diff --git a/ipfs-api-examples/examples/get_swarm.rs b/ipfs-api-examples/examples/get_swarm.rs
new file mode 100644
index 0000000..02ea599
--- /dev/null
+++ b/ipfs-api-examples/examples/get_swarm.rs
@@ -0,0 +1,48 @@
+// 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.
+//
+
+use ipfs_api_examples::ipfs_api::{IpfsApi, IpfsClient};
+
+// Creates an Ipfs client, and gets information about your local address, and
+// connected peers.
+//
+#[ipfs_api_examples::main]
+async fn main() {
+ tracing_subscriber::fmt::init();
+
+ eprintln!("connecting to localhost:5001...");
+
+ let client = IpfsClient::default();
+
+ match client.swarm_addrs_local().await {
+ Ok(local) => {
+ eprintln!("your addrs:");
+ for addr in local.strings {
+ eprintln!(" {}", addr);
+ }
+ eprintln!();
+ }
+ Err(e) => eprintln!("error getting local swarm addresses: {}", e),
+ }
+
+ match client.swarm_peers().await {
+ Ok(connected) => {
+ eprintln!("connected:");
+ for peer in connected.peers {
+ let streams: Vec<&str> = peer.streams.iter().map(|s| &s.protocol[..]).collect();
+ eprintln!(" addr: {}", peer.addr);
+ eprintln!(" peer: {}", peer.peer);
+ eprintln!(" latency: {}", peer.latency);
+ eprintln!(" muxer: {}", peer.muxer);
+ eprintln!(" streams: {}", streams.join(", "));
+ eprintln!();
+ }
+ }
+ Err(e) => eprintln!("error getting swarm peers: {}", e),
+ }
+}