summary refs log tree commit diff
path: root/synapse/replication
diff options
context:
space:
mode:
authorErik Johnston <erik@matrix.org>2016-07-21 17:37:44 +0100
committerErik Johnston <erik@matrix.org>2016-07-21 17:37:44 +0100
commitaede7248ab04118b83d7787547b9cf3fd615e7ad (patch)
treed9b54d82904e12cc5554730201347c12f610314c /synapse/replication
parentMerge pull request #943 from matrix-org/rav/get_device_api (diff)
downloadsynapse-aede7248ab04118b83d7787547b9cf3fd615e7ad.tar.xz
Split out a FederationReader process
Diffstat (limited to 'synapse/replication')
-rw-r--r--synapse/replication/slave/storage/events.py5
-rw-r--r--synapse/replication/slave/storage/keys.py29
2 files changed, 34 insertions, 0 deletions
diff --git a/synapse/replication/slave/storage/events.py b/synapse/replication/slave/storage/events.py
index 369d839464..2ba1e6b803 100644
--- a/synapse/replication/slave/storage/events.py
+++ b/synapse/replication/slave/storage/events.py
@@ -142,6 +142,11 @@ class SlavedEventStore(BaseSlavedStore):
     _get_events_around_txn = DataStore._get_events_around_txn.__func__
     _get_some_state_from_cache = DataStore._get_some_state_from_cache.__func__
 
+    get_backfill_events = DataStore.get_backfill_events.__func__
+    _get_backfill_events = DataStore._get_backfill_events.__func__
+    get_missing_events = DataStore.get_missing_events.__func__
+    _get_missing_events = DataStore._get_missing_events.__func__
+
     def stream_positions(self):
         result = super(SlavedEventStore, self).stream_positions()
         result["events"] = self._stream_id_gen.get_current_token()
diff --git a/synapse/replication/slave/storage/keys.py b/synapse/replication/slave/storage/keys.py
new file mode 100644
index 0000000000..c1c895439d
--- /dev/null
+++ b/synapse/replication/slave/storage/keys.py
@@ -0,0 +1,29 @@
+# -*- coding: utf-8 -*-
+# Copyright 2015, 2016 OpenMarket Ltd
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+#     http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+from twisted.internet import defer
+
+from ._base import BaseSlavedStore
+from synapse.storage import DataStore
+from synapse.storage.keys import KeyStore
+
+
+class SlavedKeyStore(BaseSlavedStore):
+    # TODO: use the cached version and invalidate deleted tokens
+    get_all_server_verify_keys = defer.inlineCallbacks(KeyStore.__dict__[
+        "get_all_server_verify_keys"
+    ].orig)
+
+    get_server_verify_keys = DataStore.get_server_verify_keys.__func__