diff options
| author | 2025-03-24 12:22:08 +0000 | |
|---|---|---|
| committer | 2025-03-24 12:31:01 +0000 | |
| commit | 54ca5eb3155d1cfcadced7c0a3a405ce1d51ecf6 (patch) | |
| tree | 49a59ebae7bd7b58caaa748a20b745397c37c2e3 /stanza/src/client | |
| parent | 9f0a480bc4c6ee3ac8c707b05d40529afef0d78f (diff) | |
| download | luz-54ca5eb3155d1cfcadced7c0a3a405ce1d51ecf6.tar.gz luz-54ca5eb3155d1cfcadced7c0a3a405ce1d51ecf6.tar.bz2 luz-54ca5eb3155d1cfcadced7c0a3a405ce1d51ecf6.zip | |
feat(stanza): xep-0203
Diffstat (limited to '')
| -rw-r--r-- | stanza/src/client/message.rs | 19 | ||||
| -rw-r--r-- | stanza/src/client/presence.rs | 19 | 
2 files changed, 34 insertions, 4 deletions
| diff --git a/stanza/src/client/message.rs b/stanza/src/client/message.rs index 893e7cf..192390b 100644 --- a/stanza/src/client/message.rs +++ b/stanza/src/client/message.rs @@ -6,6 +6,9 @@ use peanuts::{      DeserializeError, Element, XML_NS,  }; +#[cfg(feature = "xep_0203")] +use crate::xep_0203::Delay; +  use super::XMLNS;  #[derive(Debug, Clone)] @@ -20,6 +23,8 @@ pub struct Message {      pub subject: Option<Subject>,      pub body: Option<Body>,      pub thread: Option<Thread>, +    #[cfg(feature = "xep_0203")] +    pub delay: Option<Delay>,  }  impl FromElement for Message { @@ -37,6 +42,9 @@ impl FromElement for Message {          let body = element.child_opt()?;          let thread = element.child_opt()?; +        #[cfg(feature = "xep_0203")] +        let delay = element.child_opt()?; +          Ok(Message {              from,              id, @@ -46,13 +54,15 @@ impl FromElement for Message {              subject,              body,              thread, +            #[cfg(feature = "xep_0203")] +            delay,          })      }  }  impl IntoElement for Message {      fn builder(&self) -> peanuts::element::ElementBuilder { -        Element::builder("message", Some(XMLNS)) +        let builder = Element::builder("message", Some(XMLNS))              .push_attribute_opt("from", self.from.clone())              .push_attribute_opt("id", self.id.clone())              .push_attribute_opt("to", self.to.clone()) @@ -66,7 +76,12 @@ impl IntoElement for Message {              .push_attribute_opt_namespaced(XML_NS, "lang", self.lang.clone())              .push_child_opt(self.subject.clone())              .push_child_opt(self.body.clone()) -            .push_child_opt(self.thread.clone()) +            .push_child_opt(self.thread.clone()); + +        #[cfg(feature = "xep_0203")] +        let builder = builder.push_child_opt(self.delay.clone()); + +        builder      }  } diff --git a/stanza/src/client/presence.rs b/stanza/src/client/presence.rs index 1603ace..ae38756 100644 --- a/stanza/src/client/presence.rs +++ b/stanza/src/client/presence.rs @@ -6,6 +6,9 @@ use peanuts::{      DeserializeError, Element, XML_NS,  }; +#[cfg(feature = "xep_0203")] +use crate::xep_0203::Delay; +  use super::{error::Error, XMLNS};  #[derive(Debug, Clone)] @@ -19,6 +22,8 @@ pub struct Presence {      pub show: Option<Show>,      pub status: Option<Status>,      pub priority: Option<Priority>, +    #[cfg(feature = "xep_0203")] +    pub delay: Option<Delay>,      // TODO: ##other      // other: Vec<Other>,      pub errors: Vec<Error>, @@ -40,6 +45,9 @@ impl FromElement for Presence {          let priority = element.child_opt()?;          let errors = element.children()?; +        #[cfg(feature = "xep_0203")] +        let delay = element.child_opt()?; +          Ok(Presence {              from,              id, @@ -50,13 +58,15 @@ impl FromElement for Presence {              status,              priority,              errors, +            #[cfg(feature = "xep_0203")] +            delay,          })      }  }  impl IntoElement for Presence {      fn builder(&self) -> peanuts::element::ElementBuilder { -        Element::builder("presence", Some(XMLNS)) +        let builder = Element::builder("presence", Some(XMLNS))              .push_attribute_opt("from", self.from.clone())              .push_attribute_opt("id", self.id.clone())              .push_attribute_opt("to", self.to.clone()) @@ -65,7 +75,12 @@ impl IntoElement for Presence {              .push_child_opt(self.show)              .push_child_opt(self.status.clone())              .push_child_opt(self.priority) -            .push_children(self.errors.clone()) +            .push_children(self.errors.clone()); + +        #[cfg(feature = "xep_0203")] +        let builder = builder.push_child_opt(self.delay.clone()); + +        builder      }  } | 
