use futures::stream::{StreamExt, TryStreamExt};
#[cfg(feature = "network")]
async fn display_floating_ip(floating_ip: &openstack::network::FloatingIp) {
println!(
"ID = {}, IP = {}, Fixed IP = {:?}, Status = {}",
floating_ip.id(),
floating_ip.floating_ip_address(),
floating_ip.fixed_ip_address(),
floating_ip.status()
);
println!(
"* Network = {}, Name = {:?}",
floating_ip.floating_network_id(),
floating_ip
.floating_network()
.await
.expect("Cannot fetch floating network")
.name()
);
if floating_ip.is_associated() {
println!(
"* Port = {}",
floating_ip.port().await.expect("Cannot fetch port").id()
);
}
}
#[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::FloatingIpSortKey::Status;
let floating_ips: Vec<_> = os
.find_floating_ips()
.sort_by(openstack::Sort::Asc(sorting))
.into_stream()
.take(10)
.try_collect()
.await
.expect("Cannot list floating IPs");
println!("First 10 floating IPs:");
for p in &floating_ips {
display_floating_ip(p).await;
}
let att_floating_ips: Vec<_> = os
.find_floating_ips()
.sort_by(openstack::Sort::Asc(
openstack::network::FloatingIpSortKey::FloatingIpAddress,
))
.with_status(openstack::network::FloatingIpStatus::Active)
.all()
.await
.expect("Cannot list attached floating_ips");
println!("Only active floating IPs:");
for p in &att_floating_ips {
display_floating_ip(p).await;
}
}
#[cfg(not(feature = "network"))]
fn main() {
panic!("This example cannot run with 'network' feature disabled");
}