2026-03-29 12:25:42 -04:00
|
|
|
use std::collections::{BTreeMap, BTreeSet};
|
|
|
|
|
|
2026-04-07 14:40:10 +01:00
|
|
|
use ruma::{
|
2026-04-07 09:59:02 -04:00
|
|
|
CanonicalJsonObject, CanonicalJsonValue, IdParseError, OwnedEventId, OwnedServerName,
|
|
|
|
|
OwnedServerSigningKeyId, RoomVersionId, UserId,
|
|
|
|
|
canonical_json::JsonType,
|
2026-04-07 10:44:05 -04:00
|
|
|
room_version_rules::SignaturesRules,
|
|
|
|
|
signatures::{JsonError, VerificationError, required_server_signatures_to_verify_event},
|
2026-04-07 14:40:10 +01:00
|
|
|
};
|
2026-03-29 12:25:42 -04:00
|
|
|
|
|
|
|
|
/// Extracts the server names and key ids to check signatures for given event.
|
|
|
|
|
pub fn required_keys(
|
|
|
|
|
object: &CanonicalJsonObject,
|
2026-04-07 10:44:05 -04:00
|
|
|
rules: &SignaturesRules,
|
2026-04-07 14:40:10 +01:00
|
|
|
) -> Result<BTreeMap<OwnedServerName, Vec<OwnedServerSigningKeyId>>, VerificationError> {
|
2026-03-29 12:25:42 -04:00
|
|
|
use CanonicalJsonValue::Object;
|
|
|
|
|
let mut map = BTreeMap::<OwnedServerName, Vec<OwnedServerSigningKeyId>>::new();
|
|
|
|
|
let Some(Object(signatures)) = object.get("signatures") else {
|
|
|
|
|
return Ok(map);
|
|
|
|
|
};
|
|
|
|
|
|
2026-04-07 10:44:05 -04:00
|
|
|
for server in required_server_signatures_to_verify_event(object, rules)? {
|
2026-03-29 12:25:42 -04:00
|
|
|
let Some(Object(set)) = signatures.get(server.as_str()) else {
|
|
|
|
|
continue;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
let entry = map.entry(server.clone()).or_default();
|
|
|
|
|
set.iter()
|
|
|
|
|
.map(|(k, _)| k.clone())
|
|
|
|
|
.map(TryInto::try_into)
|
|
|
|
|
.filter_map(Result::ok)
|
|
|
|
|
.for_each(|key_id| entry.push(key_id));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Ok(map)
|
2026-04-07 14:40:10 +01:00
|
|
|
}
|