mirror of
https://git.anonymousland.org/anonymousland/synapse.git
synced 2024-12-27 14:49:24 -05:00
Merge pull request #1963 from matrix-org/erikj/delete_old_device_streams
Clobber old device list stream entries
This commit is contained in:
commit
96d79bb532
@ -33,6 +33,13 @@ class DeviceStore(SQLBaseStore):
|
|||||||
self._prune_old_outbound_device_pokes, 60 * 60 * 1000
|
self._prune_old_outbound_device_pokes, 60 * 60 * 1000
|
||||||
)
|
)
|
||||||
|
|
||||||
|
self.register_background_index_update(
|
||||||
|
"device_lists_stream_idx",
|
||||||
|
index_name="device_lists_stream_user_id",
|
||||||
|
table="device_lists_stream",
|
||||||
|
columns=["user_id", "device_id"],
|
||||||
|
)
|
||||||
|
|
||||||
@defer.inlineCallbacks
|
@defer.inlineCallbacks
|
||||||
def store_device(self, user_id, device_id,
|
def store_device(self, user_id, device_id,
|
||||||
initial_device_display_name):
|
initial_device_display_name):
|
||||||
@ -546,6 +553,16 @@ class DeviceStore(SQLBaseStore):
|
|||||||
host, stream_id,
|
host, stream_id,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
# Delete older entries in the table, as we really only care about
|
||||||
|
# when the latest change happened.
|
||||||
|
txn.executemany(
|
||||||
|
"""
|
||||||
|
DELETE FROM device_lists_stream
|
||||||
|
WHERE user_id = ? AND device_id = ? AND stream_id < ?
|
||||||
|
""",
|
||||||
|
[(user_id, device_id, stream_id) for device_id in device_ids]
|
||||||
|
)
|
||||||
|
|
||||||
self._simple_insert_many_txn(
|
self._simple_insert_many_txn(
|
||||||
txn,
|
txn,
|
||||||
table="device_lists_stream",
|
table="device_lists_stream",
|
||||||
|
17
synapse/storage/schema/delta/41/device_list_stream_idx.sql
Normal file
17
synapse/storage/schema/delta/41/device_list_stream_idx.sql
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
/* Copyright 2017 Vector Creations 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 ('device_lists_stream_idx', '{}');
|
Loading…
Reference in New Issue
Block a user