nemubot/modules/ycc/Tinyfier.py

38 lines
1.2 KiB
Python
Raw Normal View History

2012-06-30 02:06:59 +00:00
# coding=utf-8
2012-06-30 14:37:02 +00:00
import http.client
2012-06-30 02:06:59 +00:00
import threading
import re
2012-06-30 02:06:59 +00:00
class Tinyfier(threading.Thread):
def __init__(self, url, msg):
self.url = url
self.msg = msg
threading.Thread.__init__(self)
def run(self):
(status, page) = getPage("ycc.fr", "/redirection/create/" + self.url)
if status == http.client.OK and len(page) < 100:
srv = re.match(".*((ht|f)tps?://|www.)([^/ ]+).*", self.url)
if srv is None:
2012-09-07 13:01:28 +00:00
self.msg.srv.send_response(Response(self.msg.sender, "Mauvaise URL : %s" % (self.url), self.msg.channel), None)
2012-06-30 02:06:59 +00:00
else:
2012-09-07 13:01:28 +00:00
self.msg.srv.send_response(Response(self.msg.sender, "URL pour %s : %s" % (srv.group(3), page.decode()), self.msg.channel), None)
2012-06-30 02:06:59 +00:00
else:
print ("ERROR: ycc.fr seem down?")
2012-09-07 13:01:28 +00:00
self.msg.srv.send_response(Response(self.msg.sender, "La situation est embarassante, il semblerait que YCC soit down :(", self.msg.channel), None)
2012-06-30 02:06:59 +00:00
def getPage(s, p):
2012-07-27 16:18:13 +00:00
conn = http.client.HTTPConnection(s, timeout=10)
2012-06-30 02:06:59 +00:00
try:
conn.request("GET", p)
except socket.gaierror:
print ("[%s] impossible de récupérer la page %s."%(s, p))
return None
res = conn.getresponse()
data = res.read()
conn.close()
return (res.status, data)