1
0
Fork 0
ruma/crates/ruma-events/tests/it/encrypted.rs
Kévin Commaille 31bd360db8 events: Prevent hidden _Custom variant types to be deserialized
To prevent users from constructing them.

We also change some methods to access the custom data to work with all
variants, otherwise they might break when new variants are added.
2026-04-25 15:26:46 +02:00

651 lines
26 KiB
Rust

use assert_matches2::{assert_let, assert_matches};
use ruma_common::{
canonical_json::assert_to_canonical_json_eq,
owned_device_id, owned_event_id, owned_mxc_uri,
serde::{Base64, Raw},
};
use ruma_events::{
relation::{Annotation, Reference, Reply, Thread},
room::{
EncryptedFile, EncryptedFileHash, EncryptedFileInfo, V2EncryptedFileInfo,
encrypted::{
EncryptedEventScheme, MegolmV1AesSha2ContentInit, Relation, Replacement,
RoomEncryptedEventContent,
},
},
};
use serde_json::{Value as JsonValue, from_value as from_json_value, json};
fn encrypted_scheme() -> EncryptedEventScheme {
EncryptedEventScheme::MegolmV1AesSha2(
MegolmV1AesSha2ContentInit {
ciphertext: "AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF"
.to_owned(),
sender_key: "aV9BpqYFqJpKYmgERyGv/6QyKMcgLqxM05V0gvzg9Yk".to_owned(),
device_id: owned_device_id!("DEVICE"),
session_id: "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw".to_owned(),
}
.into(),
)
}
#[test]
fn content_no_relation_serialization() {
let content = RoomEncryptedEventContent::new(encrypted_scheme(), None);
assert_to_canonical_json_eq!(
content,
json!({
"algorithm": "m.megolm.v1.aes-sha2",
"sender_key": "aV9BpqYFqJpKYmgERyGv/6QyKMcgLqxM05V0gvzg9Yk",
"ciphertext": "AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF",
"session_id": "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw",
"device_id": "DEVICE",
})
);
}
#[test]
fn content_no_relation_deserialization() {
let json = json!({
"algorithm": "m.megolm.v1.aes-sha2",
"sender_key": "aV9BpqYFqJpKYmgERyGv/6QyKMcgLqxM05V0gvzg9Yk",
"ciphertext": "AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF",
"session_id": "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw",
"device_id": "DEVICE",
});
let content = from_json_value::<RoomEncryptedEventContent>(json).unwrap();
assert_let!(EncryptedEventScheme::MegolmV1AesSha2(encrypted_content) = content.scheme);
assert_eq!(encrypted_content.session_id, "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw");
assert_eq!(
encrypted_content.ciphertext,
"AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF"
);
assert_matches!(content.relates_to, None);
}
#[test]
fn content_no_relation_serialization_roundtrip() {
let content = RoomEncryptedEventContent::new(encrypted_scheme(), None);
let json_content = Raw::new(&content).unwrap();
let deser_content = json_content.deserialize().unwrap();
assert_matches!(deser_content.scheme, EncryptedEventScheme::MegolmV1AesSha2(_));
assert_matches!(deser_content.relates_to, None);
}
#[test]
fn content_reply_serialization() {
let content = RoomEncryptedEventContent::new(
encrypted_scheme(),
Some(Relation::Reply(Reply::with_event_id(owned_event_id!("$replied_to_event")))),
);
assert_to_canonical_json_eq!(
content,
json!({
"algorithm": "m.megolm.v1.aes-sha2",
"sender_key": "aV9BpqYFqJpKYmgERyGv/6QyKMcgLqxM05V0gvzg9Yk",
"ciphertext": "AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF",
"session_id": "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw",
"device_id": "DEVICE",
"m.relates_to": {
"m.in_reply_to": {
"event_id": "$replied_to_event",
},
},
})
);
}
#[test]
fn content_reply_deserialization() {
let json = json!({
"algorithm": "m.megolm.v1.aes-sha2",
"sender_key": "aV9BpqYFqJpKYmgERyGv/6QyKMcgLqxM05V0gvzg9Yk",
"ciphertext": "AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF",
"session_id": "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw",
"device_id": "DEVICE",
"m.relates_to": {
"m.in_reply_to": {
"event_id": "$replied_to_event",
},
},
});
let content = from_json_value::<RoomEncryptedEventContent>(json).unwrap();
assert_let!(EncryptedEventScheme::MegolmV1AesSha2(encrypted_content) = content.scheme);
assert_eq!(encrypted_content.session_id, "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw");
assert_eq!(
encrypted_content.ciphertext,
"AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF"
);
assert_let!(Some(Relation::Reply(reply)) = content.relates_to);
assert_eq!(reply.in_reply_to.event_id, "$replied_to_event");
}
#[test]
fn content_reply_serialization_roundtrip() {
let event_id = owned_event_id!("$replied_to_event");
let content = RoomEncryptedEventContent::new(
encrypted_scheme(),
Some(Relation::Reply(Reply::with_event_id(event_id.clone()))),
);
let json_content = Raw::new(&content).unwrap();
let deser_content = json_content.deserialize().unwrap();
assert_matches!(deser_content.scheme, EncryptedEventScheme::MegolmV1AesSha2(_));
assert_let!(Some(Relation::Reply(reply)) = deser_content.relates_to);
assert_eq!(reply.in_reply_to.event_id, event_id);
}
#[test]
fn content_replacement_serialization() {
let content = RoomEncryptedEventContent::new(
encrypted_scheme(),
Some(Relation::Replacement(Replacement::new(owned_event_id!("$replaced_event")))),
);
assert_to_canonical_json_eq!(
content,
json!({
"algorithm": "m.megolm.v1.aes-sha2",
"sender_key": "aV9BpqYFqJpKYmgERyGv/6QyKMcgLqxM05V0gvzg9Yk",
"ciphertext": "AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF",
"session_id": "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw",
"device_id": "DEVICE",
"m.relates_to": {
"rel_type": "m.replace",
"event_id": "$replaced_event",
},
})
);
}
#[test]
fn content_replacement_deserialization() {
let json = json!({
"algorithm": "m.megolm.v1.aes-sha2",
"sender_key": "aV9BpqYFqJpKYmgERyGv/6QyKMcgLqxM05V0gvzg9Yk",
"ciphertext": "AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF",
"session_id": "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw",
"device_id": "DEVICE",
"m.relates_to": {
"rel_type": "m.replace",
"event_id": "$replaced_event",
},
});
let content = from_json_value::<RoomEncryptedEventContent>(json).unwrap();
assert_let!(EncryptedEventScheme::MegolmV1AesSha2(encrypted_content) = content.scheme);
assert_eq!(encrypted_content.session_id, "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw");
assert_eq!(
encrypted_content.ciphertext,
"AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF"
);
assert_let!(Some(Relation::Replacement(replacement)) = content.relates_to);
assert_eq!(replacement.event_id, "$replaced_event");
}
#[test]
fn content_replacement_serialization_roundtrip() {
let replacement = Replacement::new(owned_event_id!("$replaced_event"));
let content = RoomEncryptedEventContent::new(
encrypted_scheme(),
Some(Relation::Replacement(replacement.clone())),
);
let json_content = Raw::new(&content).unwrap();
let deser_content = json_content.deserialize().unwrap();
assert_matches!(deser_content.scheme, EncryptedEventScheme::MegolmV1AesSha2(_));
assert_let!(Some(Relation::Replacement(deser_replacement)) = deser_content.relates_to);
assert_eq!(deser_replacement.event_id, replacement.event_id);
}
#[test]
fn content_reference_serialization() {
let content = RoomEncryptedEventContent::new(
encrypted_scheme(),
Some(Relation::Reference(Reference::new(owned_event_id!("$referenced_event")))),
);
assert_to_canonical_json_eq!(
content,
json!({
"algorithm": "m.megolm.v1.aes-sha2",
"sender_key": "aV9BpqYFqJpKYmgERyGv/6QyKMcgLqxM05V0gvzg9Yk",
"ciphertext": "AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF",
"session_id": "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw",
"device_id": "DEVICE",
"m.relates_to": {
"rel_type": "m.reference",
"event_id": "$referenced_event",
},
})
);
}
#[test]
fn content_reference_deserialization() {
let json = json!({
"algorithm": "m.megolm.v1.aes-sha2",
"sender_key": "aV9BpqYFqJpKYmgERyGv/6QyKMcgLqxM05V0gvzg9Yk",
"ciphertext": "AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF",
"session_id": "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw",
"device_id": "DEVICE",
"m.relates_to": {
"rel_type": "m.reference",
"event_id": "$referenced_event",
},
});
let content = from_json_value::<RoomEncryptedEventContent>(json).unwrap();
assert_let!(EncryptedEventScheme::MegolmV1AesSha2(encrypted_content) = content.scheme);
assert_eq!(encrypted_content.session_id, "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw");
assert_eq!(
encrypted_content.ciphertext,
"AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF"
);
assert_let!(Some(Relation::Reference(reference)) = content.relates_to);
assert_eq!(reference.event_id, "$referenced_event");
}
#[test]
fn content_reference_serialization_roundtrip() {
let reference = Reference::new(owned_event_id!("$referenced_event"));
let content = RoomEncryptedEventContent::new(
encrypted_scheme(),
Some(Relation::Reference(reference.clone())),
);
let json_content = Raw::new(&content).unwrap();
let deser_content = json_content.deserialize().unwrap();
assert_matches!(deser_content.scheme, EncryptedEventScheme::MegolmV1AesSha2(_));
assert_let!(Some(Relation::Reference(deser_reference)) = deser_content.relates_to);
assert_eq!(deser_reference.event_id, reference.event_id);
}
#[test]
fn content_thread_serialization() {
let content = RoomEncryptedEventContent::new(
encrypted_scheme(),
Some(Relation::Thread(Thread::plain(
owned_event_id!("$thread_root"),
owned_event_id!("$prev_event"),
))),
);
assert_to_canonical_json_eq!(
content,
json!({
"algorithm": "m.megolm.v1.aes-sha2",
"sender_key": "aV9BpqYFqJpKYmgERyGv/6QyKMcgLqxM05V0gvzg9Yk",
"ciphertext": "AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF",
"session_id": "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw",
"device_id": "DEVICE",
"m.relates_to": {
"rel_type": "m.thread",
"event_id": "$thread_root",
"is_falling_back": true,
"m.in_reply_to": {
"event_id": "$prev_event",
},
},
})
);
}
#[test]
fn content_thread_deserialization() {
let json = json!({
"algorithm": "m.megolm.v1.aes-sha2",
"sender_key": "aV9BpqYFqJpKYmgERyGv/6QyKMcgLqxM05V0gvzg9Yk",
"ciphertext": "AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF",
"session_id": "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw",
"device_id": "DEVICE",
"m.relates_to": {
"rel_type": "m.thread",
"event_id": "$thread_root",
"m.in_reply_to": {
"event_id": "$prev_event",
},
},
});
let content = from_json_value::<RoomEncryptedEventContent>(json).unwrap();
assert_let!(EncryptedEventScheme::MegolmV1AesSha2(encrypted_content) = content.scheme);
assert_eq!(encrypted_content.session_id, "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw");
assert_eq!(
encrypted_content.ciphertext,
"AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF"
);
assert_let!(Some(Relation::Thread(thread)) = content.relates_to);
assert_eq!(thread.event_id, "$thread_root");
assert_eq!(thread.in_reply_to.unwrap().event_id, "$prev_event");
assert!(!thread.is_falling_back);
}
#[test]
fn content_thread_serialization_roundtrip() {
let thread = Thread::plain(owned_event_id!("$thread_root"), owned_event_id!("$prev_event"));
let content =
RoomEncryptedEventContent::new(encrypted_scheme(), Some(Relation::Thread(thread.clone())));
let json_content = Raw::new(&content).unwrap();
let deser_content = json_content.deserialize().unwrap();
assert_matches!(deser_content.scheme, EncryptedEventScheme::MegolmV1AesSha2(_));
assert_let!(Some(Relation::Thread(deser_thread)) = deser_content.relates_to);
assert_eq!(deser_thread.event_id, thread.event_id);
assert_eq!(deser_thread.in_reply_to.unwrap().event_id, thread.in_reply_to.unwrap().event_id);
assert_eq!(deser_thread.is_falling_back, thread.is_falling_back);
}
#[test]
fn content_annotation_serialization() {
let content = RoomEncryptedEventContent::new(
encrypted_scheme(),
Some(Relation::Annotation(Annotation::new(
owned_event_id!("$annotated_event"),
"some_key".to_owned(),
))),
);
assert_to_canonical_json_eq!(
content,
json!({
"algorithm": "m.megolm.v1.aes-sha2",
"sender_key": "aV9BpqYFqJpKYmgERyGv/6QyKMcgLqxM05V0gvzg9Yk",
"ciphertext": "AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF",
"session_id": "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw",
"device_id": "DEVICE",
"m.relates_to": {
"rel_type": "m.annotation",
"event_id": "$annotated_event",
"key": "some_key",
},
})
);
}
#[test]
fn content_annotation_deserialization() {
let json = json!({
"algorithm": "m.megolm.v1.aes-sha2",
"sender_key": "aV9BpqYFqJpKYmgERyGv/6QyKMcgLqxM05V0gvzg9Yk",
"ciphertext": "AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF",
"session_id": "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw",
"device_id": "DEVICE",
"m.relates_to": {
"rel_type": "m.annotation",
"event_id": "$annotated_event",
"key": "some_key",
},
});
let content = from_json_value::<RoomEncryptedEventContent>(json).unwrap();
assert_let!(EncryptedEventScheme::MegolmV1AesSha2(encrypted_content) = content.scheme);
assert_eq!(encrypted_content.session_id, "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw");
assert_eq!(
encrypted_content.ciphertext,
"AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF"
);
assert_let!(Some(Relation::Annotation(annotation)) = content.relates_to);
assert_eq!(annotation.event_id, "$annotated_event");
assert_eq!(annotation.key, "some_key");
}
#[test]
fn content_annotation_serialization_roundtrip() {
let annotation = Annotation::new(owned_event_id!("$annotated_event"), "some_key".to_owned());
let content = RoomEncryptedEventContent::new(
encrypted_scheme(),
Some(Relation::Annotation(annotation.clone())),
);
let json_content = Raw::new(&content).unwrap();
let deser_content = json_content.deserialize().unwrap();
assert_matches!(deser_content.scheme, EncryptedEventScheme::MegolmV1AesSha2(_));
assert_let!(Some(Relation::Annotation(deser_annotation)) = deser_content.relates_to);
assert_eq!(deser_annotation.event_id, annotation.event_id);
assert_eq!(deser_annotation.key, annotation.key);
}
#[test]
fn custom_relation_serialization_roundtrip() {
let relation_json = json!({
"rel_type": "io.ruma.custom",
"event_id": "$related_event",
"field": "value",
});
let content_json = json!({
"algorithm": "m.megolm.v1.aes-sha2",
"sender_key": "aV9BpqYFqJpKYmgERyGv/6QyKMcgLqxM05V0gvzg9Yk",
"ciphertext": "AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF",
"session_id": "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw",
"device_id": "DEVICE",
"m.relates_to": relation_json,
});
let content = from_json_value::<RoomEncryptedEventContent>(content_json.clone()).unwrap();
assert_let!(EncryptedEventScheme::MegolmV1AesSha2(encrypted_content) = &content.scheme);
assert_eq!(encrypted_content.session_id, "IkwqWxT2zy3DI1E/zM2Wq+CE8tr3eEpsxsVGjGrMPdw");
assert_eq!(
encrypted_content.ciphertext,
"AwgAEpABjy6BHczo7UZE3alyej6y2YQ5v+L9eB+fBqL7yteCPv8Jig\
FCXKWWuwpbZ4nQpvhUbqW0ZX2474FQf0l1dXGQWDMm0VP5p20elkzSf\
n0uzmHVKGQe+NHUKIczRWsUJ6AbrLBbfFKoIPwfbZ7nQQndjA6F0+PW\
MoMQHqcrtROrCV/TMux6kDKp7h7O77Y6wp6LD4rU1lwTmKnMYkQGnju\
c3+FAMvkow26TuS0/fhJG5m+f0GLlP8FQ3fu0Kjw2YUOLl/BU6gPWdk\
lDl5mzVO3tPnJMKZ0hn+AF"
);
let relation = content.relates_to.as_ref().unwrap();
assert_eq!(relation.rel_type().unwrap().as_str(), "io.ruma.custom");
assert_eq!(JsonValue::Object(relation.data().into_owned()), relation_json);
assert_to_canonical_json_eq!(content, content_json);
}
#[test]
fn encrypted_file_v2_serialization() {
let file = EncryptedFile::new(
owned_mxc_uri!("mxc://notareal.hs/file"),
V2EncryptedFileInfo::new(
Base64::parse("TLlG_OpX807zzQuuwv4QZGJ21_u7weemFGYJFszMn9A").unwrap(),
Base64::parse("S22dq3NAX8wAAAAAAAAAAA").unwrap(),
)
.into(),
std::iter::once(EncryptedFileHash::Sha256(
Base64::parse("aWOHudBnDkJ9IwaR1Nd8XKoI7DOrqDTwt6xDPfVGN6Q").unwrap(),
))
.collect(),
);
assert_to_canonical_json_eq!(
file,
json!({
"url": "mxc://notareal.hs/file",
"key": {
"kty": "oct",
"key_ops": ["decrypt", "encrypt"],
"alg": "A256CTR",
"k": "TLlG_OpX807zzQuuwv4QZGJ21_u7weemFGYJFszMn9A",
"ext": true
},
"iv": "S22dq3NAX8wAAAAAAAAAAA",
"hashes": {
"sha256": "aWOHudBnDkJ9IwaR1Nd8XKoI7DOrqDTwt6xDPfVGN6Q"
},
"v": "v2",
})
);
}
#[test]
fn encrypted_file_v2_deserialization() {
let json = json!({
"url": "mxc://notareal.hs/file",
"key": {
"kty": "oct",
"key_ops": ["decrypt", "encrypt"],
"alg": "A256CTR",
"k": "TLlG_OpX807zzQuuwv4QZGJ21_u7weemFGYJFszMn9A",
"ext": true
},
"iv": "S22dq3NAX8wAAAAAAAAAAA",
"hashes": {
"sha256": "aWOHudBnDkJ9IwaR1Nd8XKoI7DOrqDTwt6xDPfVGN6Q"
},
"v": "v2",
});
let file = from_json_value::<EncryptedFile>(json).unwrap();
assert_eq!(file.url, "mxc://notareal.hs/file");
assert_eq!(file.hashes.len(), 1);
assert_matches!(file.info, EncryptedFileInfo::V2(_));
}
#[test]
fn custom_encrypted_file_serialization_roundtrip() {
let json = json!({
"url": "mxc://notareal.hs/file",
"foo": "bar",
"hashes": {
"sha256": "aWOHudBnDkJ9IwaR1Nd8XKoI7DOrqDTwt6xDPfVGN6Q"
},
"v": "local.dev.custom",
});
let file = from_json_value::<EncryptedFile>(json.clone()).unwrap();
assert_eq!(file.url, "mxc://notareal.hs/file");
assert_eq!(file.hashes.len(), 1);
assert_eq!(file.info.version(), "local.dev.custom");
let data = &*file.info.data();
assert_eq!(data.len(), 1);
assert_let!(Some(JsonValue::String(value)) = data.get("foo"));
assert_eq!(value, "bar");
assert_to_canonical_json_eq!(file, json);
}