summary refs log tree commit diff
diff options
context:
space:
mode:
authorErik Johnston <erik@matrix.org>2017-06-29 15:38:48 +0100
committerErik Johnston <erik@matrix.org>2017-06-29 15:38:48 +0100
commit5946aa0877b043ad912d72fa6038adb8abbb7690 (patch)
treeb8c96858ac5747c7bac6186b2d08e854ee4b03f7
parentMerge pull request #2320 from matrix-org/erikj/cache_macaroon_parse (diff)
downloadsynapse-5946aa0877b043ad912d72fa6038adb8abbb7690.tar.xz
Prefill forward extrems and event to state groups
-rw-r--r--synapse/storage/events.py5
-rw-r--r--synapse/storage/state.py10
2 files changed, 13 insertions, 2 deletions
diff --git a/synapse/storage/events.py b/synapse/storage/events.py

index 2b7340c1d9..274426950a 100644 --- a/synapse/storage/events.py +++ b/synapse/storage/events.py
@@ -403,6 +403,11 @@ class EventsStore(SQLBaseStore): (room_id, ), new_state ) + for room_id, latest_event_ids in new_forward_extremeties.iteritems(): + self.get_latest_event_ids_in_room.prefill( + (room_id,), latest_event_ids + ) + @defer.inlineCallbacks def _calculate_new_extremeties(self, room_id, event_contexts, latest_event_ids): """Calculates the new forward extremeties for a room given events to diff --git a/synapse/storage/state.py b/synapse/storage/state.py
index d1e679719b..5673e4aa96 100644 --- a/synapse/storage/state.py +++ b/synapse/storage/state.py
@@ -315,6 +315,12 @@ class StateStore(SQLBaseStore): ], ) + for event_id, state_group_id in state_groups.iteritems(): + txn.call_after( + self._get_state_group_for_event.prefill, + (event_id,), state_group_id + ) + def _count_state_group_hops_txn(self, txn, state_group): """Given a state group, count how many hops there are in the tree. @@ -584,8 +590,8 @@ class StateStore(SQLBaseStore): state_map = yield self.get_state_ids_for_events([event_id], types) defer.returnValue(state_map[event_id]) - @cached(num_args=2, max_entries=50000) - def _get_state_group_for_event(self, room_id, event_id): + @cached(max_entries=50000) + def _get_state_group_for_event(self, event_id): return self._simple_select_one_onecol( table="event_to_state_groups", keyvalues={