diff options
author | Travis Ralston <travpc@gmail.com> | 2019-10-31 09:16:14 -0600 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-10-31 09:16:14 -0600 |
commit | 3a74c03ffb5532831c8412b52a2d682bdeb9f322 (patch) | |
tree | 45158c6d80af3cc241aa1f645635b30aec9328ba /synapse/events/spamcheck.py | |
parent | Merge pull request #6307 from matrix-org/erikj/fix_purge_room (diff) | |
download | synapse-3a74c03ffb5532831c8412b52a2d682bdeb9f322.tar.xz |
Expose some homeserver functionality to spam checkers (#6259)
* Offer the homeserver instance to the spam checker * Newsfile * Linting * Expose a Spam Checker API instead of passing the homeserver object * Alter changelog * s/hs/api
Diffstat (limited to 'synapse/events/spamcheck.py')
-rw-r--r-- | synapse/events/spamcheck.py | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/synapse/events/spamcheck.py b/synapse/events/spamcheck.py index 129771f183..5a907718d6 100644 --- a/synapse/events/spamcheck.py +++ b/synapse/events/spamcheck.py @@ -1,5 +1,6 @@ # -*- coding: utf-8 -*- # Copyright 2017 New Vector Ltd +# Copyright 2019 The Matrix.org Foundation C.I.C. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. @@ -13,6 +14,10 @@ # See the License for the specific language governing permissions and # limitations under the License. +import inspect + +from synapse.spam_checker_api import SpamCheckerApi + class SpamChecker(object): def __init__(self, hs): @@ -26,7 +31,14 @@ class SpamChecker(object): pass if module is not None: - self.spam_checker = module(config=config) + # Older spam checkers don't accept the `api` argument, so we + # try and detect support. + spam_args = inspect.getfullargspec(module) + if "api" in spam_args.args: + api = SpamCheckerApi(hs) + self.spam_checker = module(config=config, api=api) + else: + self.spam_checker = module(config=config) def check_event_for_spam(self, event): """Checks if a given event is considered "spammy" by this server. |