soundcloud download fixed (for now) removed youtube download
This commit is contained in:
parent
13005db51c
commit
c8f5e9c823
@ -1,7 +1,6 @@
|
||||
local discordia=require('discordia')
|
||||
local commands=require('./../commands.lua')
|
||||
discordia.extensions()
|
||||
local io = io
|
||||
|
||||
function split(s,d)
|
||||
local t,c,i={},'',0
|
||||
@ -20,72 +19,46 @@ function split(s,d)
|
||||
end
|
||||
|
||||
function clearTmp()
|
||||
for file in io.popen([[dir "./tmp" /b]]):lines() do if file then os.remove('./tmp/'..file) end end
|
||||
for file in io.popen([[dir "./tmp" /b]]):lines() do
|
||||
if file then
|
||||
os.remove('./tmp/'..file)
|
||||
end
|
||||
end
|
||||
end
|
||||
function isTmpEmpty()
|
||||
local dir = io.popen([[dir "./tmp" /b]]):read()
|
||||
return dir==nil, dir, dir~=nil and split(dir,'\n') or {}
|
||||
end
|
||||
|
||||
commands:Add('yt',{},"wip", function(t)
|
||||
clearTmp()
|
||||
local args = t.args
|
||||
local message = t.message
|
||||
if args[1] then
|
||||
if args[1]:match('?v=([%w-_]+)') or args[1]:match('youtu.be/([%w-_]+)') then
|
||||
local id=args[1]:match('?v=([%w-_]+)') or args[1]:match('youtu.be/([%w-_]+)')
|
||||
message:reply('Attempting to download song ID='..id)
|
||||
local filepath = ''
|
||||
local name
|
||||
local s=io.popen('ytdl.exe -x --audio-format mp3 --output "./tmp/%(title)s - %(uploader)s.%(ext)s" '..id)
|
||||
if s then
|
||||
repeat
|
||||
a = split(io.popen([[dir "./tmp" /b]]):read('*all'),'\n')
|
||||
for _,v in next,a do
|
||||
if v:sub(#v-3)=='.mp3' then
|
||||
print(v)
|
||||
filepath=v
|
||||
break
|
||||
end
|
||||
end
|
||||
until filepath:sub(#filepath-3)=='.mp3'
|
||||
if filepath then
|
||||
message:reply('Found file: '..filepath)
|
||||
message:reply({file='./tmp/'..filepath})
|
||||
os.remove('./tmp/'..filepath)
|
||||
else
|
||||
message:reply('Error downloading song (this is not supposed to happen)')
|
||||
end
|
||||
else
|
||||
message:reply('Error downloading song')
|
||||
end
|
||||
else
|
||||
message:reply('Invalid URL')
|
||||
end
|
||||
else
|
||||
message:reply('No URL provided')
|
||||
end
|
||||
end)
|
||||
commands:Add('sc',{},"wip", function(t)
|
||||
clearTmp()
|
||||
local args = t.args
|
||||
local message = t.message
|
||||
if args[1] then
|
||||
if args[1]:match('https://soundcloud.com/[%w-_]+/[%w-_]+') then
|
||||
clearTmp()
|
||||
local link=args[1]:match('https://soundcloud.com/[%w-_]+/[%w-_]+')
|
||||
message:reply('Attempting to download song from <'..link..'>')
|
||||
local filepath
|
||||
local s=io.popen('ytdl.exe -o "./tmp/%(title)s - %(uploader)s.%(ext)s" '..link)
|
||||
if s then
|
||||
local filepath = ''
|
||||
local s=io.popen('ytdl.exe -o "./tmp/%(fulltitle)s.%(ext)s" '..link)
|
||||
local songName
|
||||
repeat
|
||||
local name = io.popen([[dir "./tmp" /b]]):read('*all')
|
||||
filepath = name:sub(1,name:len()-1)
|
||||
until filepath:sub(#filepath-3)=='.mp3'
|
||||
if filepath then
|
||||
message:reply('Found file: '..filepath)
|
||||
message:reply({file='./tmp/'..filepath})
|
||||
os.remove('./tmp/'..filepath)
|
||||
else
|
||||
message:reply('Error downloading song (this is not supposed to happen)')
|
||||
local str = s:read()
|
||||
local tag = str:match('^%[(.+)%]')
|
||||
if tag=='soundcloud' then
|
||||
local song = str:match('^%[soundcloud%] (.+):')
|
||||
if song:match('%d+')~=song then
|
||||
songName = song:match('.+/(.+)')
|
||||
end
|
||||
end
|
||||
until s:read()==nil
|
||||
s:close()
|
||||
if type(songName)=='string' and songName~='' then
|
||||
message:reply('found song: '..songName)
|
||||
local empty,file = isTmpEmpty()
|
||||
if not empty then
|
||||
message:reply({file='./tmp/'..file})
|
||||
os.remove('./tmp/'..file)
|
||||
end
|
||||
else
|
||||
message:reply('Error downloading song')
|
||||
end
|
||||
else
|
||||
message:reply('Invalid URL')
|
||||
@ -94,3 +67,10 @@ commands:Add('sc',{},"wip", function(t)
|
||||
message:reply('No URL provided')
|
||||
end
|
||||
end)
|
||||
|
||||
commands:Add('ct',{},'',function()
|
||||
clearTmp()
|
||||
end)
|
||||
-- commands:Add('ft',{},'',function()
|
||||
-- filterTmp()
|
||||
-- end)
|
@ -1,42 +1,42 @@
|
||||
local discordia=require('discordia')
|
||||
local API=require('./../strafes_net.lua')
|
||||
discordia.extensions()
|
||||
API.MAPS={}
|
||||
for _,game in next,API.GAMES do
|
||||
if type(tonumber(game)) == 'number' then
|
||||
local maps = {count=0}
|
||||
local res,headers = API:GetMaps(game)
|
||||
local pages = tonumber(headers['Pagination-Count'])
|
||||
maps.count=maps.count+#res
|
||||
for _,v in next,res do
|
||||
maps[v.ID]=v
|
||||
end
|
||||
if pages>1 then
|
||||
for i=2,pages do
|
||||
res,headers = API:GetMaps(game,i)
|
||||
maps.count=maps.count+#res
|
||||
for _,j in next,res do
|
||||
maps[j.ID]=j
|
||||
end
|
||||
end
|
||||
end
|
||||
setmetatable(maps,{__index=function(self,i)
|
||||
if i=='count' then return self.count end
|
||||
if not tonumber(i) then
|
||||
for ix,v in next,self do
|
||||
if type(v)=='table' and v.DisplayName:lower():find(i:lower()) then
|
||||
return v
|
||||
end
|
||||
end
|
||||
elseif tonumber(i) then
|
||||
for ix,v in next,self do
|
||||
if type(v)=='table' and v.ID==i then
|
||||
return v
|
||||
end
|
||||
end
|
||||
end
|
||||
end})
|
||||
API.MAPS[game]=maps
|
||||
print('map init done for game:',API.GAMES[game],'count:',API.MAPS[game].count)
|
||||
end
|
||||
end
|
||||
-- local discordia=require('discordia')
|
||||
-- local API=require('./../strafes_net.lua')
|
||||
-- discordia.extensions()
|
||||
-- API.MAPS={}
|
||||
-- for _,game in next,API.GAMES do
|
||||
-- if type(tonumber(game)) == 'number' then
|
||||
-- local maps = {count=0}
|
||||
-- local res,headers = API:GetMaps(game)
|
||||
-- local pages = tonumber(headers['Pagination-Count'])
|
||||
-- maps.count=maps.count+#res
|
||||
-- for _,v in next,res do
|
||||
-- maps[v.ID]=v
|
||||
-- end
|
||||
-- if pages>1 then
|
||||
-- for i=2,pages do
|
||||
-- res,headers = API:GetMaps(game,i)
|
||||
-- maps.count=maps.count+#res
|
||||
-- for _,j in next,res do
|
||||
-- maps[j.ID]=j
|
||||
-- end
|
||||
-- end
|
||||
-- end
|
||||
-- setmetatable(maps,{__index=function(self,i)
|
||||
-- if i=='count' then return self.count end
|
||||
-- if not tonumber(i) then
|
||||
-- for ix,v in next,self do
|
||||
-- if type(v)=='table' and v.DisplayName:lower():find(i:lower()) then
|
||||
-- return v
|
||||
-- end
|
||||
-- end
|
||||
-- elseif tonumber(i) then
|
||||
-- for ix,v in next,self do
|
||||
-- if type(v)=='table' and v.ID==i then
|
||||
-- return v
|
||||
-- end
|
||||
-- end
|
||||
-- end
|
||||
-- end})
|
||||
-- API.MAPS[game]=maps
|
||||
-- print('map init done for game:',API.GAMES[game],'count:',API.MAPS[game].count)
|
||||
-- end
|
||||
-- end
|
@ -65,8 +65,6 @@ commands:Add('skill',{},'skill <username|mention|"me"> <game> <style>', function
|
||||
for _,time in next,times do
|
||||
points = points+time.Points
|
||||
end
|
||||
local s = (test_a)/(test_b-1)
|
||||
print(s)
|
||||
local msg = 'Average Skill: '..API:FormatSkill(math.clamp(s,0,1))..'\n'..
|
||||
'Points: '..points..'\n'..
|
||||
pad(API,'Map',50)..' | '..pad(API,'Skill',7)..' | '.. pad(API,'Placement',14)..' | Time\n\n'
|
||||
|
@ -27,7 +27,6 @@ local function request(method,url,headers,body,options)
|
||||
local remaining_hour = tonumber(rheaders['X-RateLimit-Remaining-Hour'])
|
||||
local reset = tonumber(rheaders['RateLimit-Reset'])
|
||||
local retry_after = tonumber(rheaders['Retry-After'])
|
||||
print(remaining,remaining_hour)
|
||||
if remaining and reset then
|
||||
local t = remaining==0 and reset or .38
|
||||
if retry_after then t = retry_after end
|
||||
|
@ -188,7 +188,7 @@ function API:GetMapCompletionCount(MAP_ID,STYLE_ID)
|
||||
end
|
||||
return ((pages-1)*200)+#res
|
||||
end
|
||||
--cool doggo
|
||||
--cool doggo, aidan and me
|
||||
function API:CalculatePoint(rank,count)
|
||||
return RANK_CONSTANT_A*(math.exp(RANK_CONSTANT_B)-1)/(1-math.exp(math.max(-700, -RANK_CONSTANT_C*count)))*math.exp(math.max(-700, -RANK_CONSTANT_D*rank))+(1-RANK_CONSTANT_E)*(1+2*(count-rank))/(count*count)
|
||||
end
|
||||
|
Loading…
Reference in New Issue
Block a user