use azure_data_cosmos::prelude::*; use clap::Parser; use futures::stream::StreamExt; use serde_json::Value; #[derive(Debug, Parser)] struct Args { /// Cosmos primary key name #[clap(env = "COSMOS_PRIMARY_KEY")] primary_key: String, /// The cosmos account your're using #[clap(env = "COSMOS_ACCOUNT")] account: String, /// The name of the database database_name: String, /// The name of the collection collection_name: String, /// The name of the partition key partition_key_name: String, } // This example expects you to have created a collection // with partitionKey on "id". #[tokio::main] async fn main() -> azure_core::Result<()> { let args = Args::parse(); let authorization_token = AuthorizationToken::primary_key(args.primary_key)?; // Next we will create a Cosmos client. let client = CosmosClient::new(args.account, authorization_token); let collection = client .database_client(args.database_name) .collection_client(args.collection_name); let mut documents = Vec::new(); let stream = collection.list_documents(); let mut stream = stream.into_stream::(); while let Some(res) = stream.next().await { for doc in res?.documents { documents.push(doc); } } for document in documents { // find id and partition key from document json let doc_as_obj = match document.document { Value::Object(map) => map, _ => panic!("expected one object"), }; let id = match &doc_as_obj["id"] { Value::String(id) => id, _ => panic!("cannot find id field as string"), }; let partition_key: String = match &doc_as_obj[&args.partition_key_name] { Value::String(id) => id.to_owned(), Value::Number(num) => { format!( "{}", num.as_i64().expect("only numbers up to i64 are supported") ) } _ => panic!("cannot find supplied partition key as string"), }; println!("deleting id =={id:#?}, partition key == {partition_key:#?}"); collection .document_client(id.clone(), &partition_key)? .delete_document() .await?; } Ok(()) }