// Copyright (c) 2018 Emmanuel Gil Peyrot // // This Source Code Form is subject to the terms of the Mozilla Public // License, v. 2.0. If a copy of the MPL was not distributed with this // file, You can obtain one at http://mozilla.org/MPL/2.0/. use crate::stanza_error::DefinedCondition; generate_element!( /// Acknowledgement of the currently received stanzas. A, "a", SM, attributes: [ /// The last handled stanza. h: u32 = "h" => required, ] ); impl A { /// Generates a new `` element. pub fn new(h: u32) -> A { A { h } } } generate_attribute!( /// Whether to allow resumption of a previous stream. ResumeAttr, "resume", bool ); generate_element!( /// Client request for enabling stream management. Enable, "enable", SM, attributes: [ /// The preferred resumption time in seconds by the client. // TODO: should be the infinite integer set ≥ 1. max: Option = "max" => optional, /// Whether the client wants to be allowed to resume the stream. resume: ResumeAttr = "resume" => default, ] ); impl Enable { /// Generates a new `` element. pub fn new() -> Self { Enable { max: None, resume: ResumeAttr::False, } } /// Sets the preferred resumption time in seconds. pub fn with_max(mut self, max: u32) -> Self { self.max = Some(max); self } /// Asks for resumption to be possible. pub fn with_resume(mut self) -> Self { self.resume = ResumeAttr::True; self } } generate_id!( /// A random identifier used for stream resumption. StreamId ); generate_element!( /// Server response once stream management is enabled. Enabled, "enabled", SM, attributes: [ /// A random identifier used for stream resumption. id: Option = "id" => optional, /// The preferred IP, domain, IP:port or domain:port location for /// resumption. location: Option = "location" => optional, /// The preferred resumption time in seconds by the server. // TODO: should be the infinite integer set ≥ 1. max: Option = "max" => optional, /// Whether stream resumption is allowed. resume: ResumeAttr = "resume" => default, ] ); generate_element!( /// A stream management error happened. Failed, "failed", SM, attributes: [ /// The last handled stanza. h: Option = "h" => optional, ], children: [ /// The error returned. // XXX: implement the * handling. error: Option = ("*", XMPP_STANZAS) => DefinedCondition ] ); generate_empty_element!( /// Requests the currently received stanzas by the other party. R, "r", SM ); generate_element!( /// Requests a stream resumption. Resume, "resume", SM, attributes: [ /// The last handled stanza. h: u32 = "h" => required, /// The previous id given by the server on /// [enabled](struct.Enabled.html). previd: StreamId = "previd" => required, ] ); generate_element!( /// The response by the server for a successfully resumed stream. Resumed, "resumed", SM, attributes: [ /// The last handled stanza. h: u32 = "h" => required, /// The previous id given by the server on /// [enabled](struct.Enabled.html). previd: StreamId = "previd" => required, ] ); // TODO: add support for optional and required. generate_empty_element!( /// Represents availability of Stream Management in ``. StreamManagement, "sm", SM ); #[cfg(test)] mod tests { use super::*; use minidom::Element; use try_from::TryFrom; #[cfg(target_pointer_width = "32")] #[test] fn test_size() { assert_size!(A, 4); assert_size!(ResumeAttr, 1); assert_size!(Enable, 12); assert_size!(StreamId, 12); assert_size!(Enabled, 36); assert_size!(Failed, 12); assert_size!(R, 0); assert_size!(Resume, 16); assert_size!(Resumed, 16); assert_size!(StreamManagement, 0); } #[cfg(target_pointer_width = "64")] #[test] fn test_size() { assert_size!(A, 4); assert_size!(ResumeAttr, 1); assert_size!(Enable, 12); assert_size!(StreamId, 24); assert_size!(Enabled, 64); assert_size!(Failed, 12); assert_size!(R, 0); assert_size!(Resume, 32); assert_size!(Resumed, 32); assert_size!(StreamManagement, 0); } #[test] fn a() { let elem: Element = "