mirror of
https://git.anonymousland.org/anonymousland/synapse.git
synced 2025-01-13 17:29:30 -05:00
Correctly delete old state groups in purge history API
This commit is contained in:
parent
bb36b93f71
commit
485d999c8a
@ -1578,26 +1578,85 @@ class EventsStore(SQLBaseStore):
|
|||||||
|
|
||||||
# Get all state groups that are only referenced by events that are
|
# Get all state groups that are only referenced by events that are
|
||||||
# to be deleted.
|
# to be deleted.
|
||||||
# txn.execute(
|
txn.execute(
|
||||||
# "SELECT state_group FROM event_to_state_groups"
|
"SELECT state_group FROM event_to_state_groups"
|
||||||
# " INNER JOIN events USING (event_id)"
|
" INNER JOIN events USING (event_id)"
|
||||||
# " WHERE state_group IN ("
|
" WHERE state_group IN ("
|
||||||
# " SELECT DISTINCT state_group FROM events"
|
" SELECT DISTINCT state_group FROM events"
|
||||||
# " INNER JOIN event_to_state_groups USING (event_id)"
|
" INNER JOIN event_to_state_groups USING (event_id)"
|
||||||
# " WHERE room_id = ? AND topological_ordering < ?"
|
" WHERE room_id = ? AND topological_ordering < ?"
|
||||||
# " )"
|
" )"
|
||||||
# " GROUP BY state_group HAVING MAX(topological_ordering) < ?",
|
" GROUP BY state_group HAVING MAX(topological_ordering) < ?",
|
||||||
# (room_id, topological_ordering, topological_ordering)
|
(room_id, topological_ordering, topological_ordering)
|
||||||
# )
|
)
|
||||||
# state_rows = txn.fetchall()
|
|
||||||
# txn.executemany(
|
state_rows = txn.fetchall()
|
||||||
# "DELETE FROM state_groups_state WHERE state_group = ?",
|
state_groups_to_delete = [sg for sg, in state_rows]
|
||||||
# state_rows
|
|
||||||
# )
|
# Now we get all the state groups that rely on these state groups
|
||||||
# txn.executemany(
|
new_state_edges = []
|
||||||
# "DELETE FROM state_groups WHERE id = ?",
|
chunks = [
|
||||||
# state_rows
|
state_groups_to_delete[i:i + 100]
|
||||||
# )
|
for i in xrange(0, len(state_groups_to_delete), 100)
|
||||||
|
]
|
||||||
|
for chunk in chunks:
|
||||||
|
rows = self._simple_select_many_txn(
|
||||||
|
txn,
|
||||||
|
table="state_group_edges",
|
||||||
|
column="prev_state_group",
|
||||||
|
iterable=chunk,
|
||||||
|
retcols=["state_group"],
|
||||||
|
keyvalues={},
|
||||||
|
)
|
||||||
|
new_state_edges.extend(row["state_group"] for row in rows)
|
||||||
|
|
||||||
|
# Now we turn the state groups that reference to-be-deleted state groups
|
||||||
|
# to non delta versions.
|
||||||
|
for new_state_edge in new_state_edges:
|
||||||
|
curr_state = self._get_state_groups_from_groups_txn(
|
||||||
|
txn, [new_state_edge], types=None
|
||||||
|
)
|
||||||
|
curr_state = curr_state.values()[0]
|
||||||
|
|
||||||
|
self._simple_delete_txn(
|
||||||
|
txn,
|
||||||
|
table="state_groups_state",
|
||||||
|
keyvalues={
|
||||||
|
"state_group": new_state_edge,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
self._simple_delete_txn(
|
||||||
|
txn,
|
||||||
|
table="state_group_edges",
|
||||||
|
keyvalues={
|
||||||
|
"state_group": new_state_edge,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
self._simple_insert_many_txn(
|
||||||
|
txn,
|
||||||
|
table="state_groups_state",
|
||||||
|
values=[
|
||||||
|
{
|
||||||
|
"state_group": new_state_edge,
|
||||||
|
"room_id": room_id,
|
||||||
|
"type": key[0],
|
||||||
|
"state_key": key[1],
|
||||||
|
"event_id": state_id,
|
||||||
|
}
|
||||||
|
for key, state_id in curr_state.items()
|
||||||
|
],
|
||||||
|
)
|
||||||
|
|
||||||
|
txn.executemany(
|
||||||
|
"DELETE FROM state_groups_state WHERE state_group = ?",
|
||||||
|
state_rows
|
||||||
|
)
|
||||||
|
txn.executemany(
|
||||||
|
"DELETE FROM state_groups WHERE id = ?",
|
||||||
|
state_rows
|
||||||
|
)
|
||||||
# Delete all non-state
|
# Delete all non-state
|
||||||
txn.executemany(
|
txn.executemany(
|
||||||
"DELETE FROM event_to_state_groups WHERE event_id = ?",
|
"DELETE FROM event_to_state_groups WHERE event_id = ?",
|
||||||
|
@ -19,3 +19,4 @@ CREATE TABLE state_group_edges(
|
|||||||
);
|
);
|
||||||
|
|
||||||
CREATE INDEX state_group_edges_idx ON state_group_edges(state_group);
|
CREATE INDEX state_group_edges_idx ON state_group_edges(state_group);
|
||||||
|
CREATE INDEX state_group_edges_prev_idx ON state_group_edges(prev_state_group);
|
||||||
|
Loading…
Reference in New Issue
Block a user