use azure_storage::ConnectionString;
use azure_storage_blobs::prelude::*;
use futures::StreamExt;
use std::num::NonZeroU32;
#[tokio::main]
async fn main() -> azure_core::Result<()> {
let connection_string =
std::env::var("CONNECTION_STRING").expect("Set env variable CONNECTION_STRING first!");
let container_name = std::env::args()
.nth(1)
.expect("please specify container name as command line parameter");
let connection_string = ConnectionString::new(&connection_string)?;
let blob_service = BlobServiceClient::new(
connection_string.account_name.unwrap(),
connection_string.storage_credentials()?,
);
let container_client = blob_service.container_client(&container_name);
let mut stream = blob_service.list_containers().into_stream();
while let Some(result) = stream.next().await {
if !result?
.containers
.iter()
.any(|container| container.name == container_name)
{
panic!("The specified container must not exists!");
}
}
container_client
.create()
.public_access(PublicAccess::None)
.await?;
println!("Container {container_name} created");
for i in 0..10u8 {
container_client
.blob_client(format!("blob{i}.txt"))
.put_block_blob("somedata")
.content_type("text/plain")
.await?;
println!("\tAdded blob {i}");
}
let max_results = NonZeroU32::new(3).unwrap();
let mut stream = container_client
.list_blobs()
.max_results(max_results)
.into_stream();
let mut cnt: i32 = 0;
while let Some(value) = stream.next().await {
let len = value?.blobs.blobs().count();
println!("received {len} blobs");
match cnt {
0..=2 => assert_eq!(len, 3),
3 => assert_eq!(len, 1),
_ => panic!("more than 10 entries??"),
}
cnt += 1;
}
container_client.delete().await?;
println!("Container {container_name} deleted");
Ok(())
}