mirror of
https://git.anonymousland.org/anonymousland/synapse.git
synced 2025-08-01 00:38:42 -04:00
Allow accounts to be re-activated from the admin APIs. (#7847)
This commit is contained in:
parent
f13061d515
commit
8c7d0f163d
5 changed files with 90 additions and 22 deletions
|
@ -14,6 +14,7 @@
|
|||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
import logging
|
||||
from typing import Optional
|
||||
|
||||
from synapse.api.errors import SynapseError
|
||||
from synapse.metrics.background_process_metrics import run_as_background_process
|
||||
|
@ -45,19 +46,20 @@ class DeactivateAccountHandler(BaseHandler):
|
|||
|
||||
self._account_validity_enabled = hs.config.account_validity.enabled
|
||||
|
||||
async def deactivate_account(self, user_id, erase_data, id_server=None):
|
||||
async def deactivate_account(
|
||||
self, user_id: str, erase_data: bool, id_server: Optional[str] = None
|
||||
) -> bool:
|
||||
"""Deactivate a user's account
|
||||
|
||||
Args:
|
||||
user_id (str): ID of user to be deactivated
|
||||
erase_data (bool): whether to GDPR-erase the user's data
|
||||
id_server (str|None): Use the given identity server when unbinding
|
||||
user_id: ID of user to be deactivated
|
||||
erase_data: whether to GDPR-erase the user's data
|
||||
id_server: Use the given identity server when unbinding
|
||||
any threepids. If None then will attempt to unbind using the
|
||||
identity server specified when binding (if known).
|
||||
|
||||
Returns:
|
||||
Deferred[bool]: True if identity server supports removing
|
||||
threepids, otherwise False.
|
||||
True if identity server supports removing threepids, otherwise False.
|
||||
"""
|
||||
# FIXME: Theoretically there is a race here wherein user resets
|
||||
# password using threepid.
|
||||
|
@ -134,11 +136,11 @@ class DeactivateAccountHandler(BaseHandler):
|
|||
|
||||
return identity_server_supports_unbinding
|
||||
|
||||
async def _reject_pending_invites_for_user(self, user_id):
|
||||
async def _reject_pending_invites_for_user(self, user_id: str):
|
||||
"""Reject pending invites addressed to a given user ID.
|
||||
|
||||
Args:
|
||||
user_id (str): The user ID to reject pending invites for.
|
||||
user_id: The user ID to reject pending invites for.
|
||||
"""
|
||||
user = UserID.from_string(user_id)
|
||||
pending_invites = await self.store.get_invited_rooms_for_local_user(user_id)
|
||||
|
@ -166,22 +168,16 @@ class DeactivateAccountHandler(BaseHandler):
|
|||
room.room_id,
|
||||
)
|
||||
|
||||
def _start_user_parting(self):
|
||||
def _start_user_parting(self) -> None:
|
||||
"""
|
||||
Start the process that goes through the table of users
|
||||
pending deactivation, if it isn't already running.
|
||||
|
||||
Returns:
|
||||
None
|
||||
"""
|
||||
if not self._user_parter_running:
|
||||
run_as_background_process("user_parter_loop", self._user_parter_loop)
|
||||
|
||||
async def _user_parter_loop(self):
|
||||
async def _user_parter_loop(self) -> None:
|
||||
"""Loop that parts deactivated users from rooms
|
||||
|
||||
Returns:
|
||||
None
|
||||
"""
|
||||
self._user_parter_running = True
|
||||
logger.info("Starting user parter")
|
||||
|
@ -198,11 +194,8 @@ class DeactivateAccountHandler(BaseHandler):
|
|||
finally:
|
||||
self._user_parter_running = False
|
||||
|
||||
async def _part_user(self, user_id):
|
||||
async def _part_user(self, user_id: str) -> None:
|
||||
"""Causes the given user_id to leave all the rooms they're joined to
|
||||
|
||||
Returns:
|
||||
None
|
||||
"""
|
||||
user = UserID.from_string(user_id)
|
||||
|
||||
|
@ -224,3 +217,18 @@ class DeactivateAccountHandler(BaseHandler):
|
|||
user_id,
|
||||
room_id,
|
||||
)
|
||||
|
||||
async def activate_account(self, user_id: str) -> None:
|
||||
"""
|
||||
Activate an account that was previously deactivated.
|
||||
|
||||
This simply marks the user as activate in the database and does not
|
||||
attempt to rejoin rooms, re-add threepids, etc.
|
||||
|
||||
The user will also need a password hash set to actually login.
|
||||
|
||||
Args:
|
||||
user_id: ID of user to be deactivated
|
||||
"""
|
||||
# Mark the user as activate.
|
||||
await self.store.set_user_deactivated_status(user_id, False)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue