xmpp-rs-mirror/src/eme.rs

95 lines
3.2 KiB
Rust
Raw Normal View History

2017-04-29 21:14:34 +00:00
// Copyright (c) 2017 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 try_from::TryFrom;
2017-05-06 20:03:42 +00:00
use minidom::Element;
use error::Error;
use ns;
#[derive(Debug, Clone)]
pub struct ExplicitMessageEncryption {
pub namespace: String,
pub name: Option<String>,
}
impl TryFrom<Element> for ExplicitMessageEncryption {
type Err = Error;
2017-05-06 20:03:42 +00:00
fn try_from(elem: Element) -> Result<ExplicitMessageEncryption, Error> {
2017-05-06 20:03:42 +00:00
if !elem.is("encryption", ns::EME) {
return Err(Error::ParseError("This is not an encryption element."));
}
for _ in elem.children() {
return Err(Error::ParseError("Unknown child in encryption element."));
}
Ok(ExplicitMessageEncryption {
2017-05-24 23:30:00 +00:00
namespace: get_attr!(elem, "namespace", required),
name: get_attr!(elem, "name", optional),
2017-05-06 20:03:42 +00:00
})
}
}
impl From<ExplicitMessageEncryption> for Element {
fn from(eme: ExplicitMessageEncryption) -> Element {
2017-05-06 20:03:42 +00:00
Element::builder("encryption")
.ns(ns::EME)
.attr("namespace", eme.namespace)
.attr("name", eme.name)
2017-05-06 20:03:42 +00:00
.build()
}
2017-04-23 02:22:02 +00:00
}
#[cfg(test)]
mod tests {
2017-05-06 20:03:42 +00:00
use super::*;
#[test]
fn test_simple() {
let elem: Element = "<encryption xmlns='urn:xmpp:eme:0' namespace='urn:xmpp:otr:0'/>".parse().unwrap();
let encryption = ExplicitMessageEncryption::try_from(elem).unwrap();
assert_eq!(encryption.namespace, "urn:xmpp:otr:0");
assert_eq!(encryption.name, None);
let elem: Element = "<encryption xmlns='urn:xmpp:eme:0' namespace='some.unknown.mechanism' name='SuperMechanism'/>".parse().unwrap();
let encryption = ExplicitMessageEncryption::try_from(elem).unwrap();
assert_eq!(encryption.namespace, "some.unknown.mechanism");
assert_eq!(encryption.name, Some(String::from("SuperMechanism")));
}
#[test]
fn test_unknown() {
let elem: Element = "<replace xmlns='urn:xmpp:message-correct:0'/>".parse().unwrap();
let error = ExplicitMessageEncryption::try_from(elem).unwrap_err();
let message = match error {
Error::ParseError(string) => string,
_ => panic!(),
};
assert_eq!(message, "This is not an encryption element.");
}
#[test]
fn test_invalid_child() {
let elem: Element = "<encryption xmlns='urn:xmpp:eme:0'><coucou/></encryption>".parse().unwrap();
let error = ExplicitMessageEncryption::try_from(elem).unwrap_err();
let message = match error {
Error::ParseError(string) => string,
_ => panic!(),
};
assert_eq!(message, "Unknown child in encryption element.");
}
2017-04-23 02:22:02 +00:00
#[test]
fn test_serialise() {
let elem: Element = "<encryption xmlns='urn:xmpp:eme:0' namespace='coucou'/>".parse().unwrap();
2017-05-06 20:03:42 +00:00
let eme = ExplicitMessageEncryption { namespace: String::from("coucou"), name: None };
let elem2 = eme.into();
2017-04-23 02:22:02 +00:00
assert_eq!(elem, elem2);
}
}