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/.
|
|
|
|
|
2024-07-09 15:01:42 +00:00
|
|
|
use xso::{AsXml, FromXml};
|
2024-06-23 07:52:41 +00:00
|
|
|
|
2018-12-18 14:27:30 +00:00
|
|
|
use crate::message::MessagePayload;
|
2024-06-23 07:52:41 +00:00
|
|
|
use crate::ns;
|
2017-04-29 02:23:50 +00:00
|
|
|
use jid::Jid;
|
|
|
|
|
2024-06-26 11:13:02 +00:00
|
|
|
/// Gives the identifier a service has stamped on this stanza, often in
|
|
|
|
/// order to identify it inside of [an archive](../mam/index.html).
|
2024-07-09 15:01:42 +00:00
|
|
|
#[derive(FromXml, AsXml, PartialEq, Debug, Clone)]
|
2024-06-26 11:13:02 +00:00
|
|
|
#[xml(namespace = ns::SID, name = "stanza-id")]
|
|
|
|
pub struct StanzaId {
|
|
|
|
/// The id associated to this stanza by another entity.
|
|
|
|
#[xml(attribute)]
|
|
|
|
pub id: String,
|
|
|
|
|
|
|
|
/// The entity who stamped this stanza-id.
|
|
|
|
#[xml(attribute)]
|
|
|
|
pub by: Jid,
|
|
|
|
}
|
2017-10-31 17:58:11 +00:00
|
|
|
|
2018-09-20 18:58:27 +00:00
|
|
|
impl MessagePayload for StanzaId {}
|
|
|
|
|
2024-06-23 07:52:41 +00:00
|
|
|
/// A hack for MUC before version 1.31 to track a message which may have
|
|
|
|
/// its 'id' attribute changed.
|
2024-07-09 15:01:42 +00:00
|
|
|
#[derive(FromXml, AsXml, PartialEq, Debug, Clone)]
|
2024-06-23 07:52:41 +00:00
|
|
|
#[xml(namespace = ns::SID, name = "origin-id")]
|
|
|
|
pub struct OriginId {
|
|
|
|
/// The id this client set for this stanza.
|
|
|
|
#[xml(attribute)]
|
|
|
|
pub id: String,
|
|
|
|
}
|
2017-04-29 02:23:50 +00:00
|
|
|
|
2018-09-20 18:58:27 +00:00
|
|
|
impl MessagePayload for OriginId {}
|
|
|
|
|
2017-04-29 02:23:50 +00:00
|
|
|
#[cfg(test)]
|
|
|
|
mod tests {
|
2017-05-06 19:10:35 +00:00
|
|
|
use super::*;
|
2019-09-25 08:28:44 +00:00
|
|
|
use crate::Element;
|
2020-12-10 19:45:30 +00:00
|
|
|
use jid::BareJid;
|
2024-06-21 14:27:43 +00:00
|
|
|
use xso::error::{Error, FromElementError};
|
2017-04-29 02:23:50 +00:00
|
|
|
|
2018-10-28 12:10:48 +00:00
|
|
|
#[cfg(target_pointer_width = "32")]
|
|
|
|
#[test]
|
|
|
|
fn test_size() {
|
2024-07-01 17:38:20 +00:00
|
|
|
assert_size!(StanzaId, 28);
|
2018-10-28 12:10:48 +00:00
|
|
|
assert_size!(OriginId, 12);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(target_pointer_width = "64")]
|
2018-10-26 12:26:16 +00:00
|
|
|
#[test]
|
|
|
|
fn test_size() {
|
2024-04-15 15:03:57 +00:00
|
|
|
assert_size!(StanzaId, 56);
|
2018-10-26 12:26:16 +00:00
|
|
|
assert_size!(OriginId, 24);
|
|
|
|
}
|
|
|
|
|
2017-04-29 02:23:50 +00:00
|
|
|
#[test]
|
|
|
|
fn test_simple() {
|
2018-12-18 14:32:05 +00:00
|
|
|
let elem: Element = "<stanza-id xmlns='urn:xmpp:sid:0' id='coucou' by='coucou@coucou'/>"
|
|
|
|
.parse()
|
|
|
|
.unwrap();
|
2017-05-23 22:31:33 +00:00
|
|
|
let stanza_id = StanzaId::try_from(elem).unwrap();
|
2017-07-29 02:51:41 +00:00
|
|
|
assert_eq!(stanza_id.id, String::from("coucou"));
|
2023-06-20 12:07:50 +00:00
|
|
|
assert_eq!(stanza_id.by, BareJid::new("coucou@coucou").unwrap());
|
2017-04-29 02:23:50 +00:00
|
|
|
|
2018-12-18 14:32:05 +00:00
|
|
|
let elem: Element = "<origin-id xmlns='urn:xmpp:sid:0' id='coucou'/>"
|
|
|
|
.parse()
|
|
|
|
.unwrap();
|
2017-07-29 02:51:41 +00:00
|
|
|
let origin_id = OriginId::try_from(elem).unwrap();
|
|
|
|
assert_eq!(origin_id.id, String::from("coucou"));
|
2017-04-29 02:23:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_invalid_child() {
|
2024-06-26 11:13:02 +00:00
|
|
|
let elem: Element =
|
|
|
|
"<stanza-id xmlns='urn:xmpp:sid:0' by='a@b' id='x'><coucou/></stanza-id>"
|
|
|
|
.parse()
|
|
|
|
.unwrap();
|
2017-05-23 22:31:33 +00:00
|
|
|
let error = StanzaId::try_from(elem).unwrap_err();
|
2017-04-29 02:23:50 +00:00
|
|
|
let message = match error {
|
2024-06-21 14:27:43 +00:00
|
|
|
FromElementError::Invalid(Error::Other(string)) => string,
|
2017-04-29 02:23:50 +00:00
|
|
|
_ => panic!(),
|
|
|
|
};
|
2024-06-26 11:13:02 +00:00
|
|
|
assert_eq!(message, "Unknown child in StanzaId element.");
|
2017-04-29 02:23:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_invalid_id() {
|
|
|
|
let elem: Element = "<stanza-id xmlns='urn:xmpp:sid:0'/>".parse().unwrap();
|
2017-05-23 22:31:33 +00:00
|
|
|
let error = StanzaId::try_from(elem).unwrap_err();
|
2017-04-29 02:23:50 +00:00
|
|
|
let message = match error {
|
2024-06-21 14:27:43 +00:00
|
|
|
FromElementError::Invalid(Error::Other(string)) => string,
|
2017-04-29 02:23:50 +00:00
|
|
|
_ => panic!(),
|
|
|
|
};
|
2024-06-26 11:13:02 +00:00
|
|
|
assert_eq!(
|
|
|
|
message,
|
|
|
|
"Required attribute field 'id' on StanzaId element missing."
|
|
|
|
);
|
2017-04-29 02:23:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_invalid_by() {
|
2018-12-18 14:32:05 +00:00
|
|
|
let elem: Element = "<stanza-id xmlns='urn:xmpp:sid:0' id='coucou'/>"
|
|
|
|
.parse()
|
|
|
|
.unwrap();
|
2017-05-23 22:31:33 +00:00
|
|
|
let error = StanzaId::try_from(elem).unwrap_err();
|
2017-04-29 02:23:50 +00:00
|
|
|
let message = match error {
|
2024-06-21 14:27:43 +00:00
|
|
|
FromElementError::Invalid(Error::Other(string)) => string,
|
2017-04-29 02:23:50 +00:00
|
|
|
_ => panic!(),
|
|
|
|
};
|
2024-06-26 11:13:02 +00:00
|
|
|
assert_eq!(
|
|
|
|
message,
|
|
|
|
"Required attribute field 'by' on StanzaId element missing."
|
|
|
|
);
|
2017-04-29 02:23:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_serialise() {
|
2018-12-18 14:32:05 +00:00
|
|
|
let elem: Element = "<stanza-id xmlns='urn:xmpp:sid:0' id='coucou' by='coucou@coucou'/>"
|
|
|
|
.parse()
|
|
|
|
.unwrap();
|
|
|
|
let stanza_id = StanzaId {
|
|
|
|
id: String::from("coucou"),
|
2023-06-20 12:07:50 +00:00
|
|
|
by: Jid::new("coucou@coucou").unwrap(),
|
2018-12-18 14:32:05 +00:00
|
|
|
};
|
2017-05-23 22:31:33 +00:00
|
|
|
let elem2 = stanza_id.into();
|
2017-04-29 02:23:50 +00:00
|
|
|
assert_eq!(elem, elem2);
|
|
|
|
}
|
|
|
|
}
|