diff options
author | Till <2353100+S7evinK@users.noreply.github.com> | 2024-04-25 15:25:31 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-04-25 14:25:31 +0100 |
commit | 47773232b034c0d7b72bb7419a01e772509c8814 (patch) | |
tree | 42efcccf16166d94ba289ecb4edef61b0e0d8fe8 /synapse/handlers | |
parent | MSC4108 implementation (#17056) (diff) | |
download | synapse-47773232b034c0d7b72bb7419a01e772509c8814.tar.xz |
Redact membership events if the user requested erasure upon deactivating (#17076)
Fixes #15355 by redacting all membership events before leaving rooms.
Diffstat (limited to 'synapse/handlers')
-rw-r--r-- | synapse/handlers/deactivate_account.py | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/synapse/handlers/deactivate_account.py b/synapse/handlers/deactivate_account.py index b13c4b6cb9..11ac377680 100644 --- a/synapse/handlers/deactivate_account.py +++ b/synapse/handlers/deactivate_account.py @@ -261,11 +261,22 @@ class DeactivateAccountHandler: user = UserID.from_string(user_id) rooms_for_user = await self.store.get_rooms_for_user(user_id) + requester = create_requester(user, authenticated_entity=self._server_name) + should_erase = await self.store.is_user_erased(user_id) + for room_id in rooms_for_user: logger.info("User parter parting %r from %r", user_id, room_id) try: + # Before parting the user, redact all membership events if requested + if should_erase: + event_ids = await self.store.get_membership_event_ids_for_user( + user_id, room_id + ) + for event_id in event_ids: + await self.store.expire_event(event_id) + await self._room_member_handler.update_membership( - create_requester(user, authenticated_entity=self._server_name), + requester, user, room_id, "leave", |