xmpp-rs/src/stream.rs

90 lines
2.9 KiB
Rust
Raw Normal View History

2018-03-01 09:08:30 +00:00
// Copyright (c) 2018 Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
//
// 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 jid::Jid;
2018-08-08 17:47:06 +00:00
generate_element!(
/// The stream opening for client-server communications.
Stream, "stream", STREAM,
attributes: [
/// The JID of the entity opening this stream.
from: Option<Jid> = "from" => optional,
/// The JID of the entity receiving this stream opening.
to: Option<Jid> = "to" => optional,
/// The id of the stream, used for authentication challenges.
id: Option<String> = "id" => optional,
/// The XMPP version used during this stream.
version: Option<String> = "version" => optional,
/// The default human language for all subsequent stanzas, which will
/// be transmitted to other entities for better localisation.
xml_lang: Option<String> = "xml:lang" => optional,
]
);
2018-03-01 09:08:30 +00:00
impl Stream {
2018-08-08 17:47:06 +00:00
/// Creates a simple client→server `<stream:stream>` element.
2018-03-01 09:08:30 +00:00
pub fn new(to: Jid) -> Stream {
Stream {
from: None,
to: Some(to),
id: None,
version: Some(String::from("1.0")),
xml_lang: None,
}
}
2018-08-08 17:47:06 +00:00
/// Sets the [@from](#structfield.from) attribute on this `<stream:stream>`
/// element.
2018-03-01 09:08:30 +00:00
pub fn with_from(mut self, from: Jid) -> Stream {
self.from = Some(from);
self
}
2018-08-08 17:47:06 +00:00
/// Sets the [@id](#structfield.id) attribute on this `<stream:stream>`
/// element.
2018-03-01 09:08:30 +00:00
pub fn with_id(mut self, id: String) -> Stream {
self.id = Some(id);
self
}
2018-08-08 17:47:06 +00:00
/// Sets the [@xml:lang](#structfield.xml_lang) attribute on this
/// `<stream:stream>` element.
2018-03-01 09:08:30 +00:00
pub fn with_lang(mut self, xml_lang: String) -> Stream {
self.xml_lang = Some(xml_lang);
self
}
2018-08-08 17:47:06 +00:00
/// Checks whether the version matches the expected one.
2018-03-01 09:08:30 +00:00
pub fn is_version(&self, version: &str) -> bool {
match self.version {
None => false,
Some(ref self_version) => self_version == &String::from(version),
}
}
}
#[cfg(test)]
mod tests {
use super::*;
use try_from::TryFrom;
use minidom::Element;
2018-03-01 09:08:30 +00:00
#[test]
fn test_simple() {
let elem: Element = "<stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' xml:lang='en' version='1.0' id='abc' from='some-server.example'/>".parse().unwrap();
let stream = Stream::try_from(elem).unwrap();
assert_eq!(stream.from, Some(Jid::domain("some-server.example")));
assert_eq!(stream.to, None);
assert_eq!(stream.id, Some(String::from("abc")));
assert_eq!(stream.version, Some(String::from("1.0")));
assert_eq!(stream.xml_lang, Some(String::from("en")));
}
}