use futures::stream::{StreamExt, TryStreamExt};
#[cfg(feature = "compute")]
#[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::compute::ServerSortKey::AccessIpv4;
let servers: Vec<openstack::compute::Server> = os
.find_servers()
.sort_by(openstack::Sort::Asc(sorting))
.detailed()
.into_stream()
.take(10)
.try_collect()
.await
.expect("Cannot list servers");
println!("First 10 servers:");
for s in &servers {
println!("ID = {}, Name = {}", s.id(), s.name());
}
let active = os
.find_servers()
.sort_by(openstack::Sort::Asc(sorting))
.with_status(openstack::compute::ServerStatus::Active)
.all()
.await
.expect("Cannot list servers");
println!("All active servers:");
for s in &active {
println!("ID = {}, Name = {}", s.id(), s.name());
}
}
#[cfg(not(feature = "compute"))]
fn main() {
panic!("This example cannot run with 'compute' feature disabled");
}