improvement: faster way to load required state

This commit is contained in:
Timo Kösters 2022-01-05 20:31:20 +01:00
parent 0398e82470
commit 2bdc44751a
No known key found for this signature in database
GPG key ID: 356E705610F626D5

View file

@ -376,24 +376,29 @@ async fn sync_helper(
let mut state_events = Vec::new(); let mut state_events = Vec::new();
let mut lazy_loaded = Vec::new(); let mut lazy_loaded = Vec::new();
for (_, id) in current_state_ids { for (shortstatekey, id) in current_state_ids {
let pdu = match db.rooms.get_pdu(&id)? { let (event_type, state_key) = db.rooms.get_statekey_from_short(shortstatekey)?;
Some(pdu) => pdu,
None => { if event_type != EventType::RoomMember {
error!("Pdu in state not found: {}", id); let pdu = match db.rooms.get_pdu(&id)? {
continue; Some(pdu) => pdu,
} None => {
}; error!("Pdu in state not found: {}", id);
let state_key = pdu continue;
.state_key }
.as_ref() };
.expect("state events have state keys");
if pdu.kind != EventType::RoomMember {
state_events.push(pdu); state_events.push(pdu);
} else if !lazy_load_enabled } else if !lazy_load_enabled
|| body.full_state || body.full_state
|| timeline_users.contains(state_key) || timeline_users.contains(&state_key)
{ {
let pdu = match db.rooms.get_pdu(&id)? {
Some(pdu) => pdu,
None => {
error!("Pdu in state not found: {}", id);
continue;
}
};
lazy_loaded.push( lazy_loaded.push(
UserId::parse(state_key.as_ref()) UserId::parse(state_key.as_ref())
.expect("they are in timeline_users, so they should be correct"), .expect("they are in timeline_users, so they should be correct"),