1
0

Merge pull request #5416 from matrix-org/babolivier/fix_profile_replication

Add unique index to the profile_replication_status table.
This commit is contained in:
Brendan Abolivier
2019-06-13 18:10:14 +01:00
committed by GitHub
5 changed files with 32 additions and 3 deletions
+1 -1
View File
@@ -1 +1 @@
Adds auth_profile_reqs option to require access_token to GET /profile endpoints on CS API
Adds auth_profile_reqs option to require access_token to GET /profile endpoints on CS API.
+1
View File
@@ -0,0 +1 @@
Add unique index to the profile_replication_status table.
-1
View File
@@ -22,7 +22,6 @@ from synapse.http.servlet import RestServlet, parse_json_object_from_request
from synapse.rest.client.v2_alpha._base import client_patterns
from synapse.types import UserID
logger = logging.getLogger(__name__)
+13 -1
View File
@@ -19,6 +19,7 @@ from twisted.internet import defer
from synapse.api.errors import StoreError
from synapse.storage.roommember import ProfileInfo
from . import background_updates
from ._base import SQLBaseStore
BATCH_SIZE = 100
@@ -165,7 +166,18 @@ class ProfileWorkerStore(SQLBaseStore):
)
class ProfileStore(ProfileWorkerStore):
class ProfileStore(ProfileWorkerStore, background_updates.BackgroundUpdateStore):
def __init__(self, db_conn, hs):
super(ProfileStore, self).__init__(db_conn, hs)
self.register_background_index_update(
"profile_replication_status_host_index",
index_name="profile_replication_status_idx",
table="profile_replication_status",
columns=["host"],
)
def add_remote_profile_cache(self, user_id, displayname, avatar_url):
"""Ensure we are caching the remote user's profiles.
@@ -0,0 +1,17 @@
/* Copyright 2019 New Vector 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.
*/
INSERT INTO background_updates (update_name, progress_json) VALUES
('profile_replication_status_host_index', '{}');