use futures::stream::{StreamExt, TryStreamExt};
#[cfg(feature = "network")]
#[tokio::main(flavor = "current_thread")]
async fn main() {
env_logger::init();
let os = openstack::Cloud::from_env()
.await
.expect("Failed to create an identity provider from the environment");
let sorting = openstack::network::RouterSortKey::Name;
let routers: Vec<openstack::network::Router> = os
.find_routers()
.sort_by(openstack::Sort::Asc(sorting))
.with_limit(0)
.into_stream()
.take(10)
.try_collect()
.await
.expect("Cannot list routers");
println!("First 10 routers:");
for s in &routers {
println!(
"ID = {}, Name = {:?}, UP = {}",
s.id(),
s.name(),
s.admin_state_up()
);
}
}
#[cfg(not(feature = "network"))]
fn main() {
panic!("This example cannot run with 'network' feature disabled");
}