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:  | 
