X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/93b37d7736dd6853ff1d9fe0c7b511a171994f5b..e866fb958cebc4321b42b7a318c6a156cf4b4b1a:/forum_modules/akismet/startup.py diff --git a/forum_modules/akismet/startup.py b/forum_modules/akismet/startup.py index c1d548c..d587ea1 100644 --- a/forum_modules/akismet/startup.py +++ b/forum_modules/akismet/startup.py @@ -3,24 +3,24 @@ from django.http import HttpResponse, HttpResponseRedirect from django.utils import simplejson from django.utils.encoding import smart_str from django.shortcuts import render_to_response -from forum.modules.decorators import decorate +from forum.modules import decorate from forum import views from lib.akismet import Akismet from forum.settings import APP_URL, OSQA_VERSION -from settings import WORDPRESS_API_KEY, REP_FOR_NO_SPAM_CHECK +from settings import WORDPRESS_API_KEY, REP_FOR_NO_SPAM_CHECK, RECAPTCHA_PUB_KEY, RECAPTCHA_PRIV_KEY from forum.models.user import User +from forum.forms.general import SimpleCaptchaForm import settings def can_bypass_spam_check(user): - return user.is_authenticated() and (user.is_superuser or user.is_staff or cmp(user.reputation, REP_FOR_NO_SPAM_CHECK - ) > 0) + return user.is_authenticated and (user.is_superuser or user.is_staff or cmp(int(user.reputation), REP_FOR_NO_SPAM_CHECK) > 0) def check_spam(param, comment_type): def wrapper(origin, request, *args, **kwargs): - if request.POST and request.POST.get(param, None) and WORDPRESS_API_KEY and (not can_bypass_spam_check( - request.user)): + if request.POST and request.POST.get(param, None) and WORDPRESS_API_KEY and (not can_bypass_spam_check(request.user)): + comment = smart_str(request.POST[param]) data = { @@ -39,6 +39,9 @@ def check_spam(param, comment_type): api = Akismet(settings.WORDPRESS_API_KEY, APP_URL, "OSQA/%s" % OSQA_VERSION) if api.comment_check(comment, data): + post_data = request.POST + captcha_form = SimpleCaptchaForm(request.POST) + if request.is_ajax(): response = { 'success': False, @@ -46,9 +49,18 @@ def check_spam(param, comment_type): } return HttpResponse(simplejson.dumps(response), mimetype="application/json") else: - return render_to_response('modules/akismet/foundspam.html', { - 'action_name': comment_type - }) + captcha_checked = False + + if RECAPTCHA_PUB_KEY and RECAPTCHA_PRIV_KEY: + if captcha_form.is_valid(): + captcha_checked = True + + if not captcha_checked: + return render_to_response('modules/akismet/foundspam.html', { + 'action_name': comment_type, + 'post_data' : post_data, + 'captcha_form' : captcha_form, + }) return origin(request, *args, **kwargs) @@ -58,5 +70,3 @@ def check_spam(param, comment_type): decorate(views.writers.ask)(check_spam('text', _('question'))) decorate(views.writers.answer)(check_spam('text', _('answer'))) decorate(views.commands.comment)(check_spam('comment', _('comment'))) - -