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.
651 lines
26 KiB
Rust
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);
|
|
}
|