diff options
author | Erik Johnston <erikj@jki.re> | 2019-04-04 14:15:41 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-04-04 14:15:41 +0100 |
commit | 616e6a10bd763c7994e753458102db799adae1c6 (patch) | |
tree | 0637b25a2b54503b1e3eb2734956851d4036b4e9 /synapse/storage/group_server.py | |
parent | Prevent kicking users who aren't in the room (#4999) (diff) | |
parent | Newsfile (diff) | |
download | synapse-616e6a10bd763c7994e753458102db799adae1c6.tar.xz |
Merge pull request #5002 from matrix-org/erikj/delete_group
Add delete group admin API
Diffstat (limited to 'synapse/storage/group_server.py')
-rw-r--r-- | synapse/storage/group_server.py | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/synapse/storage/group_server.py b/synapse/storage/group_server.py index 80102b02e0..dce6a43ac1 100644 --- a/synapse/storage/group_server.py +++ b/synapse/storage/group_server.py @@ -1150,3 +1150,40 @@ class GroupServerStore(SQLBaseStore): def get_group_stream_token(self): return self._group_updates_id_gen.get_current_token() + + def delete_group(self, group_id): + """Deletes a group fully from the database. + + Args: + group_id (str) + + Returns: + Deferred + """ + + def _delete_group_txn(txn): + tables = [ + "groups", + "group_users", + "group_invites", + "group_rooms", + "group_summary_rooms", + "group_summary_room_categories", + "group_room_categories", + "group_summary_users", + "group_summary_roles", + "group_roles", + "group_attestations_renewals", + "group_attestations_remote", + ] + + for table in tables: + self._simple_delete_txn( + txn, + table=table, + keyvalues={"group_id": group_id}, + ) + + return self.runInteraction( + "delete_group", _delete_group_txn + ) |