Added youtube search plugin
This commit is contained in:
parent
d8343fcd6c
commit
08dfdb746d
|
@ -11,11 +11,9 @@ locale.setlocale(locale.LC_ALL, '')
|
|||
youtube_re = re.compile(r'youtube.*?v=([-_a-z0-9]+)', flags=re.I)
|
||||
url = 'http://gdata.youtube.com/feeds/api/videos/%s?v=2&alt=jsonc'
|
||||
|
||||
#@hook.command(hook=r'(.*)', prefix=False)
|
||||
def youtube(inp):
|
||||
m = youtube_re.search(inp)
|
||||
if m:
|
||||
j = json.load(urllib2.urlopen(url % m.group(1)))
|
||||
def get_video_description(vid):
|
||||
print vid
|
||||
j = json.load(urllib2.urlopen(url % vid))
|
||||
|
||||
if j.get('error'):
|
||||
return
|
||||
|
@ -49,3 +47,10 @@ def youtube(inp):
|
|||
out += ' - \x034NSFW\x02'
|
||||
|
||||
return out
|
||||
|
||||
|
||||
@hook.command(hook=r'(.*)', prefix=False)
|
||||
def youtube(inp):
|
||||
m = youtube_re.search(inp)
|
||||
if m:
|
||||
return get_video_description(m.group(1))
|
||||
|
|
|
@ -0,0 +1,31 @@
|
|||
import json
|
||||
import locale
|
||||
import re
|
||||
import time
|
||||
import urllib2
|
||||
from urllib import quote_plus
|
||||
|
||||
from util import hook
|
||||
from youtube import get_video_description
|
||||
|
||||
locale.setlocale(locale.LC_ALL, '')
|
||||
|
||||
url = "http://gdata.youtube.com/feeds/api/videos?q=%s&max-results=1&alt=json"
|
||||
video_url = "http://youtube.com/watch?v=%s"
|
||||
|
||||
@hook.command
|
||||
@hook.command('y')
|
||||
def youtube(inp):
|
||||
'.youtube <query> -- returns the first YouTube search result for <query>'
|
||||
inp = quote_plus(inp)
|
||||
j = json.load(urllib2.urlopen(url % (inp)))
|
||||
if j.get('error'):
|
||||
return
|
||||
|
||||
try:
|
||||
vid = j['feed']['entry'][0]['id']['$t']
|
||||
#youtube returns a gdata url for this some reason. The videoid has to be stripped out
|
||||
vid = vid[vid.rfind('/')+1:]
|
||||
return get_video_description(vid) + " " + video_url%vid
|
||||
except:
|
||||
return
|
Loading…
Reference in New Issue