diff options
author | Erik Johnston <erikj@jki.re> | 2017-03-14 11:34:35 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-03-14 11:34:35 +0000 |
commit | 6a3c5d6891bd815d34dac730f14e3bff3ea925fe (patch) | |
tree | cbb99adcab99e08ed80e9721791aeebdf1c40376 | |
parent | Merge pull request #1993 from matrix-org/luke/delete-devices (diff) | |
parent | Fix current_state_events table to not lie (diff) | |
download | synapse-6a3c5d6891bd815d34dac730f14e3bff3ea925fe.tar.xz |
Merge pull request #1996 from matrix-org/erikj/fix_current_state
Fix current_state_events table to not lie
-rw-r--r-- | synapse/storage/events.py | 31 |
1 files changed, 28 insertions, 3 deletions
diff --git a/synapse/storage/events.py b/synapse/storage/events.py index db01eb6d14..03881ea3dc 100644 --- a/synapse/storage/events.py +++ b/synapse/storage/events.py @@ -433,11 +433,36 @@ class EventsStore(SQLBaseStore): if not new_latest_event_ids: current_state = {} elif was_updated: + # We work out the current state by passing the state sets to the + # state resolution algorithm. It may ask for some events, including + # the events we have yet to persist, so we need a slightly more + # complicated event lookup function than simply looking the events + # up in the db. + events_map = {ev.event_id: ev for ev, _ in events_context} + + @defer.inlineCallbacks + def get_events(ev_ids): + # We get the events by first looking at the list of events we + # are trying to persist, and then fetching the rest from the DB. + db = [] + to_return = {} + for ev_id in ev_ids: + ev = events_map.get(ev_id, None) + if ev: + to_return[ev_id] = ev + else: + db.append(ev_id) + + if db: + evs = yield self.get_events( + ev_ids, get_prev_content=False, check_redacted=False, + ) + to_return.update(evs) + defer.returnValue(to_return) + current_state = yield resolve_events( state_sets, - state_map_factory=lambda ev_ids: self.get_events( - ev_ids, get_prev_content=False, check_redacted=False, - ), + state_map_factory=get_events, ) else: return |