diff options
author | luxagraf <sng@luxagraf.net> | 2015-11-17 10:03:13 -0500 |
---|---|---|
committer | luxagraf <sng@luxagraf.net> | 2015-11-17 10:03:13 -0500 |
commit | a42dde014b194e38c6604d33b14c90c211b7e868 (patch) | |
tree | f45b754a360fd2d74be9240cfd7cfeae1b6fd816 /app/lib | |
parent | ce2cc9e9fc10021fd8ddb600b5548b3e6d06c5bd (diff) |
Oh just getting ready for some live testing. because, why not?
Diffstat (limited to 'app/lib')
-rw-r--r-- | app/lib/django_comments/akismet.py | 105 |
1 files changed, 105 insertions, 0 deletions
diff --git a/app/lib/django_comments/akismet.py b/app/lib/django_comments/akismet.py new file mode 100644 index 0000000..daa4281 --- /dev/null +++ b/app/lib/django_comments/akismet.py @@ -0,0 +1,105 @@ +#!/usr/bin/python + +__version__ = "0.3" +__date__ = "2005-12-01" +__author__ = "David Lynch (kemayo AT Google's mail service DOT com)" +__copyright__ = "Copyright 2005, David Lynch" +__license__ = "New BSD" +__history__ = """ +0.3 - 20051205 - Cleaned up __post. +0.2 - 20051201 - Added documentation, and tweaked the circumstances where an error + will be thrown. +0.1 - 20051201 - Initial release. Everything pretty much works. Probably. +""" + +import http.client +from urllib.parse import urlencode + +USERAGENT = "" +AKISMET_URL = "rest.akismet.com" +AKISMET_PORT = 80 + + +class AkismetError(Exception): + def __init__(self, response, statuscode): + self.response = response + self.statuscode = statuscode + + def __str__(self): + return repr(self.value) + + +def __post(request, host, path, port=80): + connection = http.client.HTTPConnection(host, port) + connection.request("POST", path, request, { + "User-Agent": "%s | %s/%s" % (USERAGENT, "Akistmet.py", __version__), + "Content-type": "application/x-www-form-urlencoded" + }) + response = connection.getresponse() + return response.read(), response.status + + +def verify_key(key, blog): + """Find out whether a given WordPress.com API key is valid. + Required parameters: + key: A WordPress.com API key. + blog: URL of the front page of the site comments will be submitted to. + Returns True if a valid key, False if invalid. + """ + response, status = __post("key=%s&blog=%s" % (key, blog), AKISMET_URL, "/1.1/verify-key", AKISMET_PORT) + if response == "valid": + return True + elif response == "invalid": + return False + else: + raise AkismetError(response, status) + + +def comment_check(key, blog, user_ip, user_agent, **other): + """Submit a comment to find out whether Akismet thinks that it's spam. + Required parameters: + key: A valid WordPress.com API key, as tested with verify_key(). + blog: URL of the front page of the site the comment will appear on. + user_ip: IP address of the being which submitted the comment. + user_agent: User agent reported by said being. + Suggested "other" keys: "permalink", "referrer", "comment_type", "comment_author", + "comment_author_email", "comment_author_url", "comment_content", and any other HTTP + headers sent from the client. + More detail on what should be submitted is available at: + http://akismet.com/development/api/ + Returns True if spam, False if ham. Throws an AkismetError if the server says + anything unexpected. + """ + request = {'blog': blog, 'user_ip': user_ip, 'user_agent': user_agent} + request.update(other) + response, status = __post(urlencode(request), "%s.%s" % (key, AKISMET_URL), "/1.1/comment-check", AKISMET_PORT) + if response == "true": + return True + elif response == "false": + return False + else: + raise AkismetError(response, status) + + +def submit_spam(key, blog, user_ip, user_agent, **other): + """Report a false negative to Akismet. + Same arguments as comment_check. + Doesn't return anything. Throws an AkismetError if the server says anything. + """ + request = {'blog': blog, 'user_ip': user_ip, 'user_agent': user_agent} + request.update(other) + response, status = __post(urlencode(request), "%s.%s" % (key, AKISMET_URL), "/1.1/submit-spam", AKISMET_PORT) + if status != 200 or response != "": + raise AkismetError(response, status) + + +def submit_ham(key, blog, user_ip, user_agent, **other): + """Report a false positive to Akismet. + Same arguments as comment_check. + Doesn't return anything. Throws an AkismetError if the server says anything. + """ + request = {'blog': blog, 'user_ip': user_ip, 'user_agent': user_agent} + request.update(other) + response, status = __post(urlencode(request), "%s.%s" % (key, AKISMET_URL), "/1.1/submit-ham", AKISMET_PORT) + if status != 200 or response != "": + raise AkismetError(response, status) |