From 6cfc1ca75c4e5e4b8755fcba332313606292ae7a Mon Sep 17 00:00:00 2001 From: Garret Wassermann Date: Wed, 2 Jan 2019 19:17:19 -0500 Subject: [PATCH] Fix API changes to python-akismet, #687 --- helpdesk/lib.py | 22 +++++++++++++++------- 1 file changed, 15 insertions(+), 7 deletions(-) diff --git a/helpdesk/lib.py b/helpdesk/lib.py index 54dd1124..bff529a6 100644 --- a/helpdesk/lib.py +++ b/helpdesk/lib.py @@ -175,19 +175,27 @@ def text_is_spam(text, request): except ImproperlyConfigured: site = Site(domain='configure-django-sites.com') - ak = Akismet( - blog_url='http://%s/' % site.domain, - agent='django-helpdesk', - ) - + # see https://akismet.readthedocs.io/en/latest/overview.html#using-akismet + + apikey = None + if hasattr(settings, 'TYPEPAD_ANTISPAM_API_KEY'): - ak.setAPIKey(key=settings.TYPEPAD_ANTISPAM_API_KEY) + apikey = settings.TYPEPAD_ANTISPAM_API_KEY ak.baseurl = 'api.antispam.typepad.com/1.1/' + elif hasattr(settings, 'PYTHON_AKISMET_API_KEY'): + # new env var expected by python-akismet package + apikey = settings.PYTHON_AKISMET_API_KEY elif hasattr(settings, 'AKISMET_API_KEY'): - ak.setAPIKey(key=settings.AKISMET_API_KEY) + # deprecated, but kept for backward compatibility + apikey = settings.AKISMET_API_KEY else: return False + ak = Akismet( + blog_url='http://%s/' % site.domain, + key=apikey, + ) + if ak.verify_key(): ak_data = { 'user_ip': request.META.get('REMOTE_ADDR', '127.0.0.1'),