use crate::headers::from_headers::*;
use crate::prelude::*;
use crate::ResourceQuota;
use azure_core::headers::session_token_from_headers;
use azure_core::prelude::*;
use azure_core::Response as HttpResponse;
use azure_core::SessionToken;
use time::OffsetDateTime;
operation! {
DeleteAttachment,
client: AttachmentClient,
?if_match_condition: IfMatchCondition,
?consistency_level: ConsistencyLevel
}
impl DeleteAttachmentBuilder {
pub fn into_future(self) -> DeleteAttachment {
Box::pin(async move {
let mut request = self.client.attachment_request(azure_core::Method::Delete);
request.insert_headers(&self.if_match_condition);
if let Some(cl) = &self.consistency_level {
request.insert_headers(cl);
}
crate::cosmos_entity::add_as_partition_key_header_serialized(
self.client.document_client().partition_key_serialized(),
&mut request,
);
let response = self
.client
.pipeline()
.send(
self.context.clone().insert(ResourceType::Attachments),
&mut request,
)
.await?;
DeleteAttachmentResponse::try_from(response).await
})
}
}
#[derive(Debug, Clone, PartialEq)]
pub struct DeleteAttachmentResponse {
pub max_media_storage_usage_mb: u64,
pub media_storage_usage_mb: u64,
pub last_change: OffsetDateTime,
pub resource_quota: Vec<ResourceQuota>,
pub resource_usage: Vec<ResourceQuota>,
pub lsn: u64,
pub alt_content_path: String,
pub content_path: String,
pub quorum_acked_lsn: u64,
pub current_write_quorum: u64,
pub current_replica_set_size: u64,
pub global_committed_lsn: u64,
pub number_of_read_regions: u32,
pub transport_request_id: u64,
pub cosmos_llsn: u64,
pub cosmos_quorum_acked_llsn: u64,
pub session_token: SessionToken,
pub request_charge: f64,
pub service_version: String,
pub activity_id: uuid::Uuid,
pub gateway_version: String,
pub date: OffsetDateTime,
}
impl DeleteAttachmentResponse {
pub async fn try_from(response: HttpResponse) -> azure_core::Result<Self> {
let headers = response.headers();
Ok(Self {
max_media_storage_usage_mb: max_media_storage_usage_mb_from_headers(headers)?,
media_storage_usage_mb: media_storage_usage_mb_from_headers(headers)?,
last_change: last_state_change_from_headers(headers)?,
resource_quota: resource_quota_from_headers(headers)?,
resource_usage: resource_usage_from_headers(headers)?,
lsn: lsn_from_headers(headers)?,
alt_content_path: alt_content_path_from_headers(headers)?,
content_path: content_path_from_headers(headers)?,
quorum_acked_lsn: quorum_acked_lsn_from_headers(headers)?,
current_write_quorum: current_write_quorum_from_headers(headers)?,
current_replica_set_size: current_replica_set_size_from_headers(headers)?,
global_committed_lsn: global_committed_lsn_from_headers(headers)?,
number_of_read_regions: number_of_read_regions_from_headers(headers)?,
transport_request_id: transport_request_id_from_headers(headers)?,
cosmos_llsn: cosmos_llsn_from_headers(headers)?,
cosmos_quorum_acked_llsn: cosmos_quorum_acked_llsn_from_headers(headers)?,
session_token: session_token_from_headers(headers)?,
request_charge: request_charge_from_headers(headers)?,
service_version: service_version_from_headers(headers)?,
activity_id: activity_id_from_headers(headers)?,
gateway_version: gateway_version_from_headers(headers)?,
date: date_from_headers(headers)?,
})
}
}