Add support for MIME types

This commit is contained in:
Quentin 2022-07-05 17:48:10 +02:00
parent cc86653ed8
commit 2f51128467
Signed by: quentin
GPG key ID: E9602264D639FF68

View file

@ -561,12 +561,29 @@ fn build_imap_email_struct<'a>(
MessagePart::Message(_) => todo!(), MessagePart::Message(_) => todo!(),
} }
} }
MessageStructure::List(l) => todo!(), MessageStructure::List(lp) => {
/*BodyStructure::Multi { let subtype = IString::try_from(
bodies: l.map(|inner_node| build_email_struct(msg, inner_node)), msg.get_content_type()
subtype: "", .ok_or(anyhow!("Content-Type is missing but required here."))?
.c_subtype
.as_ref()
.ok_or(anyhow!("Content-Type invalid, missing subtype"))?
.to_string(),
)
.map_err(|_| {
anyhow!("Unable to build IString from given Content-Type subtype given")
})?;
// @NOTE we should use try_collect() but it is unstable as of 2022-07-05
Ok(BodyStructure::Multi {
bodies: lp
.iter()
.map(|inner_node| build_imap_email_struct(msg, inner_node))
.fold(Ok(vec![]), try_collect_shime)?,
subtype,
extension_data: None, extension_data: None,
},*/ })
}
MessageStructure::MultiPart((id, l)) => { MessageStructure::MultiPart((id, l)) => {
todo!() todo!()
/*let part = msg.parts.get(id)?; /*let part = msg.parts.get(id)?;
@ -592,6 +609,16 @@ fn build_imap_email_struct<'a>(
} }
} }
fn try_collect_shime<T>(acc: Result<Vec<T>>, elem: Result<T>) -> Result<Vec<T>> {
match (acc, elem) {
(Err(e), _) | (_, Err(e)) => Err(e),
(Ok(mut ac), Ok(el)) => {
ac.push(el);
Ok(ac)
}
}
}
/// s is set to static to ensure that only compile time values /// s is set to static to ensure that only compile time values
/// checked by developpers are passed. /// checked by developpers are passed.
fn unchecked_istring(s: &'static str) -> IString { fn unchecked_istring(s: &'static str) -> IString {
@ -608,12 +635,15 @@ struct SpecialAttrs<'a> {
/// identify some specific attributes (charset and boundary). /// identify some specific attributes (charset and boundary).
fn attrs_to_params<'a>(bp: &impl MimeHeaders<'a>) -> (SpecialAttrs, Vec<(IString, IString)>) { fn attrs_to_params<'a>(bp: &impl MimeHeaders<'a>) -> (SpecialAttrs, Vec<(IString, IString)>) {
// Try to extract Content-Type attributes from headers // Try to extract Content-Type attributes from headers
let attrs = match bp.get_content_type().map(|c| c.attributes.as_ref()).flatten() { let attrs = match bp
.get_content_type()
.map(|c| c.attributes.as_ref())
.flatten()
{
Some(v) => v, Some(v) => v,
_ => return (SpecialAttrs::default(), vec![]) _ => return (SpecialAttrs::default(), vec![]),
}; };
// Transform the Content-Type attributes into IMAP's parameter list // Transform the Content-Type attributes into IMAP's parameter list
// Also collect some special attributes that might be used elsewhere // Also collect some special attributes that might be used elsewhere
attrs.iter().fold( attrs.iter().fold(
@ -691,8 +721,15 @@ mod tests {
/// Keep in mind that special cases must still be tested manually! /// Keep in mind that special cases must still be tested manually!
#[test] #[test]
fn fetch_body() -> Result<()> { fn fetch_body() -> Result<()> {
let txt = fs::read("tests/emails/dxflrs/0001_simple.eml")?; let prefixes = [
let exp = fs::read("tests/emails/dxflrs/0001_simple.body")?; "tests/emails/dxflrs/0001_simple",
"tests/emails/dxflrs/0002_mime",
];
for pref in prefixes.iter() {
println!("{}", pref);
let txt = fs::read(format!("{}.eml", pref))?;
let exp = fs::read(format!("{}.body", pref))?;
let message = Message::parse(&txt).unwrap(); let message = Message::parse(&txt).unwrap();
let mut resp = Vec::new(); let mut resp = Vec::new();
@ -704,8 +741,9 @@ mod tests {
let exp_no_parenthesis = &exp[1..exp.len() - 1]; let exp_no_parenthesis = &exp[1..exp.len() - 1];
let exp_str = String::from_utf8_lossy(exp_no_parenthesis).to_lowercase(); let exp_str = String::from_utf8_lossy(exp_no_parenthesis).to_lowercase();
println!("mine: {}\nexpected: {}", resp_str, exp_str); println!("aerogramme: {}\ndovecot: {}", resp_str, exp_str);
assert_eq!(resp_str, exp_str); assert_eq!(resp_str, exp_str);
}
Ok(()) Ok(())
} }