diff options
author | lassulus <lassulus@googlemail.com> | 2014-01-06 00:09:00 +0100 |
---|---|---|
committer | lassulus <lassulus@googlemail.com> | 2014-01-06 00:09:00 +0100 |
commit | f98847bb46197e2872705abf9278fda26895d75d (patch) | |
tree | 86174ba82f38bd4a93e08ae62477b3f71efad784 /ircbot | |
parent | 1cbf273c3b74c070ebd7e65c50223f276daa26ca (diff) |
ircbot: datetime and regex url
Diffstat (limited to 'ircbot')
-rwxr-xr-x | ircbot/rssbot.py | 24 |
1 files changed, 10 insertions, 14 deletions
diff --git a/ircbot/rssbot.py b/ircbot/rssbot.py index 1e1d620d..3c8495f1 100755 --- a/ircbot/rssbot.py +++ b/ircbot/rssbot.py @@ -3,6 +3,8 @@ import irc.bot import feedparser import _thread import math +import re +from datetime import datetime from time import sleep class RssBot(irc.bot.SingleServerIRCBot): @@ -17,6 +19,7 @@ class RssBot(irc.bot.SingleServerIRCBot): self.oldnews = [] self.sendqueue = [] self.loop = True + self.lastpull = datetime.now() def start(self): self.upd_loop = _thread.start_new_thread(self.updateloop, ()) @@ -27,20 +30,7 @@ class RssBot(irc.bot.SingleServerIRCBot): self.disconnect() def updateloop(self): - try: - self.feed = feedparser.parse(self.url) - except: - print(self.name + ': rss timeout occured') - for entry in self.feed.entries: - #try: - # self.sendqueue.append(entry.title + " " + entry.link + " com: " + entry.comments) - #except AttributeError: - self.sendqueue.append(entry.title + " " + entry.link) - - self.oldnews.append(entry.link) - while self.loop: - sleep(self.to) try: self.feed = feedparser.parse(self.url) except: @@ -52,13 +42,19 @@ class RssBot(irc.bot.SingleServerIRCBot): #except AttributeError: self.send(entry.title + " " + entry.link) self.oldnews.append(entry.link) + self.lastpull = datetime.now() + sleep(self.to) def sendall(self): while len(self.sendqueue) > 0: sleep(1) self.send(self.sendqueue.pop()) - def send(self, string=''): + def send(self, string): + urls = re.findall('http[s]?://(?:[a-zA-Z]|[0-9]|[$-_@.&+]|[!*\(\),]|(?:%[0-9a-fA-F][0-9a-fA-F]))+', string) + for url in urls: + shorturl = subprocess.check_output(["curl", "-F", "uri=" + url, "http://127.0.0.1:1337"]) + string = string.replace(url, shorturl) if self.connection.connected: for line in string.split('\n'): if len(line) < 450: |