New module: YCC, to shorten URLs
This commit is contained in:
parent
4031403c25
commit
441d2de411
81
modules/ycc.py
Normal file
81
modules/ycc.py
Normal file
@ -0,0 +1,81 @@
|
||||
# coding=utf-8
|
||||
|
||||
import http.client
|
||||
import re
|
||||
import sys
|
||||
import threading
|
||||
|
||||
nemubotversion = 3.0
|
||||
|
||||
def help_tiny ():
|
||||
"""Line inserted in the response to the command !help"""
|
||||
return "Gets YCC urls"
|
||||
|
||||
def help_full ():
|
||||
return "TODO"
|
||||
|
||||
|
||||
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:
|
||||
srv = re.match(".*((ht|f)tps?://|www.)([^/]+).*", self.url)
|
||||
if srv is None:
|
||||
self.msg.send_chn("Mauvaise URL : %s" % (self.url))
|
||||
else:
|
||||
self.msg.send_chn("URL pour %s : %s" % (srv.group(3), page.decode()))
|
||||
else:
|
||||
print ("ERROR: ycc.fr seem down?")
|
||||
|
||||
def parseanswer(msg):
|
||||
global LAST_URLS
|
||||
if msg.cmd[0] == "ycc":
|
||||
if len(msg.cmd) == 1:
|
||||
if msg.channel in LAST_URLS and len(LAST_URLS[msg.channel]) > 0:
|
||||
url = LAST_URLS[msg.channel].pop()
|
||||
t = Tinyfier(url, msg)
|
||||
t.start()
|
||||
else:
|
||||
msg.send_chn("%s: je n'ai pas d'autre URL a reduire" % msg.sender)
|
||||
else:
|
||||
if len(msg.cmd) < 6:
|
||||
for url in msg.cmd[1:]:
|
||||
t = Tinyfier(url, msg)
|
||||
t.start()
|
||||
else:
|
||||
msg.send_chn("%s: je ne peux pas reduire autant d'URL d'un seul coup." % msg.sender)
|
||||
return True
|
||||
else:
|
||||
return False
|
||||
|
||||
LAST_URLS = dict()
|
||||
|
||||
def parselisten (msg):
|
||||
global LAST_URLS
|
||||
if re.match(".*(https?://|www\.)[^ ]+.*", msg.content) is not None:
|
||||
res = re.match(".*(((ht|f)tps?://|www\.)[^ ]+).*", msg.content)
|
||||
if msg.channel in LAST_URLS:
|
||||
LAST_URLS[msg.channel].append(res.group(1))
|
||||
else:
|
||||
LAST_URLS[msg.channel] = list(res.group(1))
|
||||
return True
|
||||
return False
|
||||
|
||||
def getPage(s, p):
|
||||
conn = http.client.HTTPConnection(s)
|
||||
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)
|
2
modules/ycc.xml
Normal file
2
modules/ycc.xml
Normal file
@ -0,0 +1,2 @@
|
||||
<?xml version="1.0" ?>
|
||||
<nemubotmodule name="ycc" />
|
Loading…
Reference in New Issue
Block a user