Twitch.tv url parser

This commit is contained in:
blha303 2013-06-18 08:26:17 +00:00
parent 88c179f568
commit 7603bb7b6a

29
plugins/twitch.py Normal file
View file

@ -0,0 +1,29 @@
import re
from util import hook, http
twitch_re = (r'(.*:)//(twitch.tv|www.twitch.tv)(:[0-9]+)?(.*)', re.I)
valid = set('ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_/')
def test(s):
return set(s) <= valid
@hook.regex(*twitch_re)
def twitch_url(match):
location = "/".join(match.group(4).split("/")[1:])
if not test(match.group(4).split("/")[1]):
return "Not a valid username"
soup = http.get_soup("http://twitch.tv/" + location)
title = soup.findAll('span', {'class': 'real_title js-title'})[0].text
try:
name = soup.findAll('a', {'class': 'channel_name'})[0].text
except IndexError:
name = soup.findAll('a', {'class': 'channelname'})[0].text
playing = soup.findAll('a', {'class': 'game js-game'})[0].text
if playing == "/directory/game/":
np = False
else:
np = True
if np:
return "%s: %s playing %s" % (title, name, playing)
else:
return "%s: %s" % (title, name)