summary refs log tree commit diff
path: root/synapse/handlers
diff options
context:
space:
mode:
Diffstat (limited to 'synapse/handlers')
-rw-r--r--synapse/handlers/auth.py21
-rw-r--r--synapse/handlers/deactivate_account.py11
2 files changed, 32 insertions, 0 deletions
diff --git a/synapse/handlers/auth.py b/synapse/handlers/auth.py

index 0f80dfdc43..231829aff8 100644 --- a/synapse/handlers/auth.py +++ b/synapse/handlers/auth.py
@@ -1371,6 +1371,17 @@ class AuthHandler(BaseHandler): access_token=access_token, ) + + # Inform interested appservices + self.hs.get_application_service_handler().notify_synthetic_event( + "m.user.logout", + user_id, + { + "user_id": user_info.user_id, + "device_id": user_info.device_id, + } + ) + # delete pushers associated with this access token if user_info.token_id is not None: await self.hs.get_pusherpool().remove_pushers_by_access_token( @@ -1408,6 +1419,16 @@ class AuthHandler(BaseHandler): user_id, (token_id for _, token_id, _ in tokens_and_devices) ) + # Inform interested appservices + self.hs.get_application_service_handler().notify_synthetic_event( + "m.user.logout", + user_id, + { + "user_id": user_id, + "device_id": device_id, + } + ) + async def add_threepid( self, user_id: str, medium: str, address: str, validated_at: int ) -> None: diff --git a/synapse/handlers/deactivate_account.py b/synapse/handlers/deactivate_account.py
index 9ae5b7750e..5324d9573c 100644 --- a/synapse/handlers/deactivate_account.py +++ b/synapse/handlers/deactivate_account.py
@@ -38,6 +38,7 @@ class DeactivateAccountHandler(BaseHandler): self._room_member_handler = hs.get_room_member_handler() self._identity_handler = hs.get_identity_handler() self._profile_handler = hs.get_profile_handler() + self._application_service_handler = hs.get_application_service_handler() self.user_directory_handler = hs.get_user_directory_handler() self._server_name = hs.hostname @@ -159,6 +160,16 @@ class DeactivateAccountHandler(BaseHandler): # Mark the user as deactivated. await self.store.set_user_deactivated_status(user_id, True) + + # Inform interested appservices + self._application_service_handler.notify_synthetic_event( + "m.user.deactivated", + user_id, + { + "user_id": user_id, + } + ) + return identity_server_supports_unbinding async def _reject_pending_invites_for_user(self, user_id: str) -> None: