events: Support m.room.message
events with custom msgtype
s
This commit is contained in:
parent
704e5f89f5
commit
a76d3e24a4
@ -1,5 +1,7 @@
|
||||
//! Types for the *m.room.message* event.
|
||||
|
||||
use std::collections::BTreeMap;
|
||||
|
||||
use js_int::UInt;
|
||||
use ruma_events_macros::MessageEventContent;
|
||||
#[cfg(feature = "unstable-pre-spec")]
|
||||
@ -64,6 +66,10 @@ pub enum MessageEventContent {
|
||||
/// A request to initiate a key verification.
|
||||
#[cfg(feature = "unstable-pre-spec")]
|
||||
VerificationRequest(KeyVerificationRequestEventContent),
|
||||
|
||||
/// A custom message.
|
||||
#[doc(hidden)]
|
||||
_Custom(CustomEventContent),
|
||||
}
|
||||
|
||||
/// Enum modeling the different ways relationships can be expressed in a
|
||||
@ -586,3 +592,15 @@ pub struct KeyVerificationRequestEventContent {
|
||||
/// events that have a m.reference relationship with this event.
|
||||
pub to: UserId,
|
||||
}
|
||||
|
||||
/// The payload for a custom message event.
|
||||
#[doc(hidden)]
|
||||
#[derive(Clone, Debug, Deserialize, Serialize)]
|
||||
pub struct CustomEventContent {
|
||||
/// A custom msgtype
|
||||
pub msgtype: String,
|
||||
|
||||
/// Remaining event content
|
||||
#[serde(flatten)]
|
||||
pub data: BTreeMap<String, JsonValue>,
|
||||
}
|
||||
|
@ -32,7 +32,7 @@ impl<'de> de::Deserialize<'de> for MessageEventContent {
|
||||
"m.video" => Self::Video(from_raw_json_value(&json)?),
|
||||
#[cfg(feature = "unstable-pre-spec")]
|
||||
"m.key.verification.request" => Self::VerificationRequest(from_raw_json_value(&json)?),
|
||||
_ => return Err(de::Error::custom("unknown msgtype")),
|
||||
_ => Self::_Custom(from_raw_json_value(&json)?),
|
||||
})
|
||||
}
|
||||
}
|
||||
|
@ -1,6 +1,7 @@
|
||||
use std::time::{Duration, UNIX_EPOCH};
|
||||
|
||||
use assign::assign;
|
||||
use maplit::btreemap;
|
||||
use matches::assert_matches;
|
||||
#[cfg(feature = "unstable-pre-spec")]
|
||||
use ruma_events::{
|
||||
@ -9,7 +10,8 @@ use ruma_events::{
|
||||
use ruma_events::{
|
||||
room::{
|
||||
message::{
|
||||
AudioMessageEventContent, MessageEventContent, Relation, TextMessageEventContent,
|
||||
AudioMessageEventContent, CustomEventContent, MessageEventContent, Relation,
|
||||
TextMessageEventContent,
|
||||
},
|
||||
relationships::InReplyTo,
|
||||
},
|
||||
@ -73,6 +75,53 @@ fn content_serialization() {
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn custom_content_serialization() {
|
||||
let json_data = btreemap! {
|
||||
"custom_field".into() => json!("baba"),
|
||||
"another_one".into() => json!("abab"),
|
||||
};
|
||||
let custom_event_content = MessageEventContent::_Custom(CustomEventContent {
|
||||
msgtype: "my_custom_msgtype".into(),
|
||||
data: json_data,
|
||||
});
|
||||
|
||||
assert_eq!(
|
||||
to_json_value(&custom_event_content).unwrap(),
|
||||
json!({
|
||||
"msgtype": "my_custom_msgtype",
|
||||
"custom_field": "baba",
|
||||
"another_one": "abab",
|
||||
})
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn custom_content_deserialization() {
|
||||
let json_data = json!({
|
||||
"msgtype": "my_custom_msgtype",
|
||||
"custom_field": "baba",
|
||||
"another_one": "abab",
|
||||
});
|
||||
|
||||
let expected_json_data = btreemap! {
|
||||
"custom_field".into() => json!("baba"),
|
||||
"another_one".into() => json!("abab"),
|
||||
};
|
||||
|
||||
assert_matches!(
|
||||
from_json_value::<Raw<MessageEventContent>>(json_data)
|
||||
.unwrap()
|
||||
.deserialize()
|
||||
.unwrap(),
|
||||
MessageEventContent::_Custom(CustomEventContent {
|
||||
msgtype,
|
||||
data
|
||||
}) if msgtype == "my_custom_msgtype"
|
||||
&& data == expected_json_data
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn formatted_body_serialization() {
|
||||
let message_event_content = MessageEventContent::Text(TextMessageEventContent::html(
|
||||
|
Loading…
x
Reference in New Issue
Block a user