use futures::stream::{StreamExt, TryStreamExt};
#[cfg(feature = "network")]
async fn display_subnet(subnet: &openstack::network::Subnet) {
println!(
"ID = {}, CIDR = {}, Gateway = {:?}, DHCP? {}",
subnet.id(),
subnet.cidr(),
subnet.gateway_ip(),
subnet.dhcp_enabled()
);
let net = subnet.network().await.expect("Cannot fetch network");
println!("* Network: ID = {}, Name = {:?}", net.id(), net.name());
}
#[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::SubnetSortKey::Name;
let subnets: Vec<_> = os
.find_subnets()
.sort_by(openstack::Sort::Asc(sorting))
.into_stream()
.take(10)
.try_collect()
.await
.expect("Cannot list subnets");
println!("First 10 subnets:");
for p in &subnets {
display_subnet(p).await;
}
}
#[cfg(not(feature = "network"))]
fn main() {
panic!("This example cannot run with 'network' feature disabled");
}