summaryrefslogtreecommitdiffstats
path: root/ipfs-api-examples/examples/bootstrap_default.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/bootstrap_default.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/bootstrap_default.rs')
-rw-r--r--ipfs-api-examples/examples/bootstrap_default.rs62
1 files changed, 62 insertions, 0 deletions
diff --git a/ipfs-api-examples/examples/bootstrap_default.rs b/ipfs-api-examples/examples/bootstrap_default.rs
new file mode 100644
index 0000000..f4d83fb
--- /dev/null
+++ b/ipfs-api-examples/examples/bootstrap_default.rs
@@ -0,0 +1,62 @@
+// 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};
+
+// Lists clients in bootstrap list, then adds the default list, then removes
+// them, and readds them.
+//
+#[ipfs_api_examples::main]
+async fn main() {
+ tracing_subscriber::fmt::init();
+
+ eprintln!("connecting to localhost:5001...");
+
+ let client = IpfsClient::default();
+
+ match client.bootstrap_list().await {
+ Ok(bootstrap) => {
+ eprintln!("current bootstrap peers:");
+ for peer in bootstrap.peers {
+ eprintln!(" {}", peer);
+ }
+ eprintln!();
+ }
+ Err(e) => {
+ eprintln!("error getting list of bootstrap peers: {}", e);
+ return;
+ }
+ }
+
+ match client.bootstrap_rm_all().await {
+ Ok(drop) => {
+ eprintln!("dropped:");
+ for peer in drop.peers {
+ eprintln!(" {}", peer);
+ }
+ eprintln!();
+ }
+ Err(e) => {
+ eprintln!("error dropping bootstrap peers: {}", e);
+ return;
+ }
+ }
+
+ match client.bootstrap_add_default().await {
+ Ok(add) => {
+ eprintln!("added:");
+ for peer in add.peers {
+ eprintln!(" {}", peer);
+ }
+ eprintln!();
+ }
+ Err(e) => {
+ eprintln!("error adding default peers: {}", e);
+ }
+ }
+}