From af7db19e1e89e9b4ac4818c47b7f389ad46a7c9b Mon Sep 17 00:00:00 2001 From: David Teller Date: Mon, 30 May 2022 18:24:56 +0200 Subject: Uniformize spam-checker API, part 3: Expand check_event_for_spam with the ability to return additional fields (#12846) Signed-off-by: David Teller --- synapse/handlers/message.py | 15 +++++++++++++++ 1 file changed, 15 insertions(+) (limited to 'synapse/handlers') diff --git a/synapse/handlers/message.py b/synapse/handlers/message.py index 7ca126dbd1..38b71a2c96 100644 --- a/synapse/handlers/message.py +++ b/synapse/handlers/message.py @@ -895,6 +895,21 @@ class EventCreationHandler: spam_check = await self.spam_checker.check_event_for_spam(event) if spam_check is not synapse.spam_checker_api.Allow.ALLOW: + if isinstance(spam_check, tuple): + try: + [code, dict] = spam_check + raise SynapseError( + 403, + "This message had been rejected as probable spam", + code, + dict, + ) + except ValueError: + logger.error( + "Spam-check module returned invalid error value. Expecting [code, dict], got %s", + spam_check, + ) + spam_check = Codes.FORBIDDEN raise SynapseError( 403, "This message had been rejected as probable spam", spam_check ) -- cgit 1.5.1