diff --git a/core/config.py b/core/config.py index e03babe..76884a4 100755 --- a/core/config.py +++ b/core/config.py @@ -34,6 +34,7 @@ if not os.path.exists('config'): "wolframalpha": "", "lastfm": "", "rottentomatoes": "", + "soundcloud": "", "twitter_consumer_key": "", "twitter_consumer_secret": "", "twitter_access_token": "", diff --git a/plugins/soundc.py b/plugins/soundc.py new file mode 100644 index 0000000..36b6607 --- /dev/null +++ b/plugins/soundc.py @@ -0,0 +1,18 @@ +from util import hook, http, web +import soundcloud +import re + +sc_re = (r'(.*:)//(www.)?(soundcloud.com)(.*)', re.I) + +@hook.regex(*sc_re) +def soundcloud_url(match, bot=None): + api_key = bot.config.get("api_keys", {}).get("soundcloud") + if not api_key: + return "Error: no api key set" + url = match.group(1).split(' ')[-1] + "//" + (match.group(2) if match.group(2) else "") + match.group(3) + match.group(4).split(' ')[0] + client = soundcloud.Client(client_id=api_key) + track = client.get('/resolve', url=url) + try: + return "SoundCloud track: \x02%s\x02 by \x02%s\x02 - \x02%s\x02" % (track.title, track.user['username'], web.isgd(track.permalink_url)) + except: + return "SoundCloud user: \x02%s\x02 - \x02%s\x02" % (track.username, web.isgd(track.permalink_url)) diff --git a/requirements.txt b/requirements.txt index 9cda528..67fd59c 100644 --- a/requirements.txt +++ b/requirements.txt @@ -2,4 +2,5 @@ BeautifulSoup==3.2.1 lxml==3.1beta1 pyenchant==1.6.5 pydns>=2.3.6 -BeautifulSoup4 \ No newline at end of file +BeautifulSoup4 +soundcloud==0.3.6