use std::ops::Deref;
pub use reqwest as request;
use reqwest::Response;
use serde::{Deserialize, Serialize};
#[derive(Deserialize, Debug, Serialize)]
pub struct Multistatus {
#[serde(rename = "response", default)]
pub responses: Vec<DResponse>,
}
impl Multistatus {
#[allow(clippy::should_implement_trait)]
pub fn from_str(s: &str) -> Result<Self, quick_xml::DeError> {
quick_xml::de::from_str(s)
}
pub async fn from_response(res: Response) -> Result<Self, String> {
if res.status().is_success() {
let text = res.text().await.map_err(|err| err.to_string())?;
Self::from_str(&text).map_err(|err| err.to_string())
} else {
Err(res.status().to_string())
}
}
}
#[derive(Debug, Deserialize, Serialize)]
pub struct DResponse {
#[serde(rename = "href")]
pub href: String,
#[serde(default)]
pub propstat: Option<Propstat>,
}
#[derive(Debug, Deserialize, Serialize)]
pub struct Propstat {
prop: Prop,
pub status: String,
}
impl Deref for Propstat {
type Target = Prop;
fn deref(&self) -> &Self::Target {
&self.prop
}
}
#[derive(Debug, Deserialize, Serialize)]
pub struct Prop {
#[serde(rename = "displayname")]
pub display_name: Option<String>,
#[serde(default, rename = "getcontenttype")]
pub content_type: String,
#[serde(default, rename = "getlastmodified")]
pub last_modified: String,
#[serde(rename = "getcontentlength")]
pub content_length: u64,
#[serde(rename = "iscollection")]
pub is_collection: bool,
}