Merge branch 'ShittyAdvice-master'
This commit is contained in:
commit
77d7d65412
54
plugins/search_youtube.lua
Normal file
54
plugins/search_youtube.lua
Normal file
@ -0,0 +1,54 @@
|
||||
do
|
||||
|
||||
local function get_yt_data (yt_code)
|
||||
local base_url = 'http://gdata.youtube.com/feeds/api/'
|
||||
local url = base_url..'/videos/'..yt_code..'?v=2&alt=jsonc'
|
||||
local res,code = http.request(url)
|
||||
if code ~= 200 then return "HTTP ERROR" end
|
||||
local data = json:decode(res).data
|
||||
return data
|
||||
end
|
||||
|
||||
local function format_youtube_data(data, link)
|
||||
local title = data.title
|
||||
local uploader = data.uploader
|
||||
local text = title..' ('..uploader..')'..'\n\nLink:' .. link
|
||||
return text
|
||||
end
|
||||
|
||||
local function httpRequest(url)
|
||||
local res,code = http.request(url)
|
||||
if code ~= 200 then return nil end
|
||||
return json:decode(res)
|
||||
end
|
||||
|
||||
local function searchYoutubeVideo(text)
|
||||
local base_url = 'http://gdata.youtube.com/feeds/api/'
|
||||
local data = httpRequest(base_url..'videos?max-results=1&alt=json&q='..URL.escape(text))
|
||||
if not data then
|
||||
print("HTTP Error")
|
||||
return nil
|
||||
elseif not data.feed.entry then
|
||||
return "YouTube video not found!"
|
||||
end
|
||||
return data.feed.entry[1].link[1].href
|
||||
end
|
||||
|
||||
local function run(msg, matches)
|
||||
local text = matches[1]
|
||||
local link = searchYoutubeVideo(text)
|
||||
local yt_code = link:match("?v=([_A-Za-z0-9-]+)")
|
||||
local data = get_yt_data(yt_code)
|
||||
return format_youtube_data(data, link)
|
||||
end
|
||||
|
||||
return {
|
||||
description = "Search video on youtube and send it.",
|
||||
usage = "!youtube [term]: Search for a youtube video and send it.",
|
||||
patterns = {
|
||||
"^!youtube (.*)"
|
||||
},
|
||||
run = run
|
||||
}
|
||||
|
||||
end
|
Reference in New Issue
Block a user