events: Add the to-device variant of the m.key.verification.ready event
This commit is contained in:
parent
cb489729b8
commit
166ee8b9d7
@ -107,6 +107,9 @@ event_enum! {
|
|||||||
"m.room_key_request",
|
"m.room_key_request",
|
||||||
"m.forwarded_room_key",
|
"m.forwarded_room_key",
|
||||||
"m.key.verification.request",
|
"m.key.verification.request",
|
||||||
|
#[cfg(feature = "unstable-pre-spec")]
|
||||||
|
#[cfg_attr(docsrs, doc(cfg(feature = "unstable-pre-spec")))]
|
||||||
|
"m.key.verification.ready",
|
||||||
"m.key.verification.start",
|
"m.key.verification.start",
|
||||||
"m.key.verification.cancel",
|
"m.key.verification.cancel",
|
||||||
"m.key.verification.accept",
|
"m.key.verification.accept",
|
||||||
|
@ -56,6 +56,10 @@ pub enum EventType {
|
|||||||
#[ruma_enum(rename = "m.key.verification.mac")]
|
#[ruma_enum(rename = "m.key.verification.mac")]
|
||||||
KeyVerificationMac,
|
KeyVerificationMac,
|
||||||
|
|
||||||
|
/// m.key.verification.ready
|
||||||
|
#[ruma_enum(rename = "m.key.verification.ready")]
|
||||||
|
KeyVerificationReady,
|
||||||
|
|
||||||
/// m.key.verification.request
|
/// m.key.verification.request
|
||||||
#[ruma_enum(rename = "m.key.verification.request")]
|
#[ruma_enum(rename = "m.key.verification.request")]
|
||||||
KeyVerificationRequest,
|
KeyVerificationRequest,
|
||||||
@ -229,6 +233,7 @@ mod tests {
|
|||||||
serde_json_eq(EventType::KeyVerificationCancel, json!("m.key.verification.cancel"));
|
serde_json_eq(EventType::KeyVerificationCancel, json!("m.key.verification.cancel"));
|
||||||
serde_json_eq(EventType::KeyVerificationKey, json!("m.key.verification.key"));
|
serde_json_eq(EventType::KeyVerificationKey, json!("m.key.verification.key"));
|
||||||
serde_json_eq(EventType::KeyVerificationMac, json!("m.key.verification.mac"));
|
serde_json_eq(EventType::KeyVerificationMac, json!("m.key.verification.mac"));
|
||||||
|
serde_json_eq(EventType::KeyVerificationReady, json!("m.key.verification.ready"));
|
||||||
serde_json_eq(EventType::KeyVerificationRequest, json!("m.key.verification.request"));
|
serde_json_eq(EventType::KeyVerificationRequest, json!("m.key.verification.request"));
|
||||||
serde_json_eq(EventType::KeyVerificationStart, json!("m.key.verification.start"));
|
serde_json_eq(EventType::KeyVerificationStart, json!("m.key.verification.start"));
|
||||||
serde_json_eq(EventType::IgnoredUserList, json!("m.ignored_user_list"));
|
serde_json_eq(EventType::IgnoredUserList, json!("m.ignored_user_list"));
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
//! Types for the *m.key.verification.ready* event.
|
//! Types for the *m.key.verification.ready* event.
|
||||||
|
|
||||||
use ruma_events_macros::MessageEventContent;
|
use ruma_events_macros::{EventContent, MessageEventContent};
|
||||||
use ruma_identifiers::DeviceIdBox;
|
use ruma_identifiers::DeviceIdBox;
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
|
|
||||||
@ -10,7 +10,25 @@ use crate::MessageEvent;
|
|||||||
/// Response to a previously sent *m.key.verification.request* message.
|
/// Response to a previously sent *m.key.verification.request* message.
|
||||||
pub type ReadyEvent = MessageEvent<ReadyEventContent>;
|
pub type ReadyEvent = MessageEvent<ReadyEventContent>;
|
||||||
|
|
||||||
/// The payload for `ReadyEvent`.
|
/// The payload for a to-device `m.key.verification.ready` event.
|
||||||
|
#[derive(Clone, Debug, Deserialize, Serialize, EventContent)]
|
||||||
|
#[ruma_event(type = "m.key.verification.ready")]
|
||||||
|
pub struct ReadyToDeviceEventContent {
|
||||||
|
/// The device ID which is initiating the request.
|
||||||
|
pub from_device: DeviceIdBox,
|
||||||
|
|
||||||
|
/// The verification methods supported by the sender.
|
||||||
|
pub methods: Vec<VerificationMethod>,
|
||||||
|
|
||||||
|
/// An opaque identifier for the verification process.
|
||||||
|
///
|
||||||
|
/// Must be unique with respect to the devices involved. Must be the same as the
|
||||||
|
/// `transaction_id` given in the *m.key.verification.request* from a
|
||||||
|
/// request.
|
||||||
|
pub transaction_id: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
/// The payload for an in-room `m.key.verification.ready` event.
|
||||||
#[derive(Clone, Debug, Deserialize, Serialize, MessageEventContent)]
|
#[derive(Clone, Debug, Deserialize, Serialize, MessageEventContent)]
|
||||||
#[ruma_event(type = "m.key.verification.ready")]
|
#[ruma_event(type = "m.key.verification.ready")]
|
||||||
pub struct ReadyEventContent {
|
pub struct ReadyEventContent {
|
||||||
@ -33,7 +51,7 @@ mod tests {
|
|||||||
use ruma_serde::Raw;
|
use ruma_serde::Raw;
|
||||||
use serde_json::{from_value as from_json_value, json, to_value as to_json_value};
|
use serde_json::{from_value as from_json_value, json, to_value as to_json_value};
|
||||||
|
|
||||||
use super::{ReadyEventContent, Relation, VerificationMethod};
|
use super::{ReadyEventContent, ReadyToDeviceEventContent, Relation, VerificationMethod};
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn serialization() {
|
fn serialization() {
|
||||||
@ -50,12 +68,26 @@ mod tests {
|
|||||||
});
|
});
|
||||||
|
|
||||||
let content = ReadyEventContent {
|
let content = ReadyEventContent {
|
||||||
from_device: device,
|
from_device: device.clone(),
|
||||||
relation: Relation { event_id },
|
relation: Relation { event_id },
|
||||||
methods: vec![VerificationMethod::MSasV1],
|
methods: vec![VerificationMethod::MSasV1],
|
||||||
};
|
};
|
||||||
|
|
||||||
assert_eq!(to_json_value(&content).unwrap(), json_data);
|
assert_eq!(to_json_value(&content).unwrap(), json_data);
|
||||||
|
|
||||||
|
let json_data = json!({
|
||||||
|
"from_device": device,
|
||||||
|
"methods": ["m.sas.v1"],
|
||||||
|
"transaction_id": "456",
|
||||||
|
});
|
||||||
|
|
||||||
|
let content = ReadyToDeviceEventContent {
|
||||||
|
from_device: device,
|
||||||
|
transaction_id: "456".to_owned(),
|
||||||
|
methods: vec![VerificationMethod::MSasV1],
|
||||||
|
};
|
||||||
|
|
||||||
|
assert_eq!(to_json_value(&content).unwrap(), json_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
@ -87,5 +119,25 @@ mod tests {
|
|||||||
&& methods == vec![VerificationMethod::MSasV1]
|
&& methods == vec![VerificationMethod::MSasV1]
|
||||||
&& event_id == id
|
&& event_id == id
|
||||||
);
|
);
|
||||||
|
|
||||||
|
let json_data = json!({
|
||||||
|
"from_device": device,
|
||||||
|
"methods": ["m.sas.v1"],
|
||||||
|
"transaction_id": "456",
|
||||||
|
});
|
||||||
|
|
||||||
|
assert_matches!(
|
||||||
|
from_json_value::<Raw<ReadyToDeviceEventContent>>(json_data)
|
||||||
|
.unwrap()
|
||||||
|
.deserialize()
|
||||||
|
.unwrap(),
|
||||||
|
ReadyToDeviceEventContent {
|
||||||
|
from_device,
|
||||||
|
transaction_id,
|
||||||
|
methods,
|
||||||
|
} if from_device == device
|
||||||
|
&& methods == vec![VerificationMethod::MSasV1]
|
||||||
|
&& transaction_id == "456"
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user