diff options
author | Erik Johnston <erikj@jki.re> | 2017-02-13 16:59:19 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-02-13 16:59:19 +0100 |
commit | d7457c7661fa3b28427b21f44252c3abbee45ef8 (patch) | |
tree | 791531c7181bf2383b06cfbf1c0f62340d26a943 /synapse/storage/presence.py | |
parent | Merge pull request #1913 from matrix-org/kegan/dont-cache-errors (diff) | |
parent | Cache get_presence storage (diff) | |
download | synapse-d7457c7661fa3b28427b21f44252c3abbee45ef8.tar.xz |
Merge pull request #1914 from matrix-org/erikj/cache_presence
Cache get_presence storage
Diffstat (limited to 'synapse/storage/presence.py')
-rw-r--r-- | synapse/storage/presence.py | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/synapse/storage/presence.py b/synapse/storage/presence.py index 7460f98a1f..4d1590d2b4 100644 --- a/synapse/storage/presence.py +++ b/synapse/storage/presence.py @@ -15,7 +15,7 @@ from ._base import SQLBaseStore from synapse.api.constants import PresenceState -from synapse.util.caches.descriptors import cached, cachedInlineCallbacks +from synapse.util.caches.descriptors import cached, cachedInlineCallbacks, cachedList from collections import namedtuple from twisted.internet import defer @@ -85,6 +85,9 @@ class PresenceStore(SQLBaseStore): self.presence_stream_cache.entity_has_changed, state.user_id, stream_id, ) + self._invalidate_cache_and_stream( + txn, self._get_presence_for_user, (state.user_id,) + ) # Actually insert new rows self._simple_insert_many_txn( @@ -143,7 +146,12 @@ class PresenceStore(SQLBaseStore): "get_all_presence_updates", get_all_presence_updates_txn ) - @defer.inlineCallbacks + @cached() + def _get_presence_for_user(self, user_id): + raise NotImplementedError() + + @cachedList(cached_method_name="_get_presence_for_user", list_name="user_ids", + num_args=1, inlineCallbacks=True) def get_presence_for_users(self, user_ids): rows = yield self._simple_select_many_batch( table="presence_stream", @@ -165,7 +173,7 @@ class PresenceStore(SQLBaseStore): for row in rows: row["currently_active"] = bool(row["currently_active"]) - defer.returnValue([UserPresenceState(**row) for row in rows]) + defer.returnValue({row["user_id"]: UserPresenceState(**row) for row in rows}) def get_current_presence_token(self): return self._presence_id_gen.get_current_token() |