diff options
author | Eli W. Hunter <42009212+elihunter173@users.noreply.github.com> | 2020-07-23 23:54:12 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-07-23 23:54:12 -0400 |
commit | 6cd1d7f93bd6f150341582a1b54087cefffdbf87 (patch) | |
tree | 88c109ec79e679d5aa041b20f074cf7b57d97cda /examples/networkdisconnect.rs | |
parent | a4cd2185976ad56b880d5a10374c4dee6d116e6a (diff) |
Async/Await Support (continuation of #191) (#229)
* it builds!
* remove unused dependencies
* bump dependencies
* reimplement 'exec' endpoint
* update a few more examples
* update remaining examples
* fix doc tests, remove unused 'read' module
* remove feature-gated async closures
* split futures dependency to just 'futures-util'
* update version and readme
* make functions accepting Body generic over Into<Body> again
* update changelog
* reinstate 'unix-socket' feature
* reinstate 'attach' endpoint
* fix clippy lints
* fix documentation typo
* fix container copyfrom/into implementations
* add convenience methods for TtyChunk struct
* remove 'main' from code example to silence clippy lint
* Update hyper to 0.13.1
* Add Send bounds to TtyWriter
* Appease clippy
* Fix examples
* Update issue in changelog
Co-authored-by: Daniel Eades <danieleades@hotmail.com>
Co-authored-by: Marc Schreiber <marc.schreiber@aixigo.de>
Diffstat (limited to 'examples/networkdisconnect.rs')
-rw-r--r-- | examples/networkdisconnect.rs | 25 |
1 files changed, 17 insertions, 8 deletions
diff --git a/examples/networkdisconnect.rs b/examples/networkdisconnect.rs index 9588ecc..8d58b35 100644 --- a/examples/networkdisconnect.rs +++ b/examples/networkdisconnect.rs @@ -1,18 +1,27 @@ use shiplift::{ContainerConnectionOptions, Docker}; use std::env; -use tokio::prelude::Future; -fn main() { +async fn network_disconnect( + container_id: &str, + network_id: &str, +) { let docker = Docker::new(); let networks = docker.networks(); + + if let Err(e) = networks + .get(network_id) + .disconnect(&ContainerConnectionOptions::builder(container_id).build()) + .await + { + eprintln!("Error: {}", e) + } +} + +#[tokio::main] +async fn main() { match (env::args().nth(1), env::args().nth(2)) { (Some(container_id), Some(network_id)) => { - let fut = networks - .get(&network_id) - .disconnect(&ContainerConnectionOptions::builder(&container_id).build()) - .map(|v| println!("{:?}", v)) - .map_err(|e| eprintln!("Error: {}", e)); - tokio::run(fut); + network_disconnect(&container_id, &network_id).await; } _ => eprintln!("please provide a container_id and network_id"), } |