From 3893f86815b8fda5d5c7c0705bab9aa3a54529e5 Mon Sep 17 00:00:00 2001 From: Andreas Bielawski Date: Thu, 11 Aug 2016 15:01:18 +0200 Subject: [PATCH] =?UTF-8?q?YouTube-DL=20jetzt=20mit=20globaler=20Qualit?= =?UTF-8?q?=C3=A4tsauswahl?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- otouto/plugins/settings.lua | 77 +++++++++++++++++++++++++++++++---- otouto/plugins/youtube_dl.lua | 11 +++-- 2 files changed, 77 insertions(+), 11 deletions(-) diff --git a/otouto/plugins/settings.lua b/otouto/plugins/settings.lua index b0997dc..f0af030 100644 --- a/otouto/plugins/settings.lua +++ b/otouto/plugins/settings.lua @@ -1,11 +1,19 @@ +-- SWITCH YOUR EDITOR TO UTF-8 (Notepad++ sets this file to ANSI) local settings = {} settings.triggers = { "^(⚙ [Ee]instellungen)$", "^(/settings)$", - "^(💤 [Aa][Ff][Kk]%-[Kk]eyboard einschalten)", - "^(💤 [Aa][Ff][Kk]%-[Kk]eyboard ausschalten)", - "^(❌ [Ee]instellungen verstecken)" + "^(↩️ [Zz]urück)$", + "^(💤 [Aa][Ff][Kk]%-[Kk]eyboard einschalten)$", + "^(💤 [Aa][Ff][Kk]%-[Kk]eyboard ausschalten)$", + "^(❌ [Ee]instellungen verstecken)$", + "^(▶️ [Vv]ideoauflösung für [Yy]ou[Tt]ube%-[Dd][Ll] einstellen)$", + "^(▶️ 144p)$", + "^(▶️ 180p)$", + "^(▶️ 360p [Ww]eb[Mm])$", + "^(▶️ 360p [Mm][Pp]4)$", + "^(▶️ 720p)$" } --[[ @@ -23,12 +31,25 @@ function settings:keyboard(user_id) else afk_button = '{"text":"💤 AFK-Keyboard einschalten"}' end + local youtube_dl_res_button = '{"text":"▶️ Videoauflösung für YouTube-DL einstellen"}' local hide_settings_button = '{"text":"❌ Einstellungen verstecken"}' - local settings_keyboard = '[['..afk_button..','..hide_settings_button..']]' + local settings_keyboard = '[['..afk_button..','..youtube_dl_res_button..'],['..hide_settings_button..']]' return settings_keyboard end +function settings:youtube_dl_keyboard() + local worst = '{"text":"▶️ 144p"}' + local still_worse = '{"text":"▶️ 180p"}' + local better_webm = '{"text":"▶️ 360p WebM"}' + local better_mp4 = '{"text":"▶️ 360p MP4"}' + local best = '{"text":"▶️ 720p"}' + local back = '{"text":"↩️ Zurück"}' + + local youtube_dl_keyboard = '[['..best..','..better_mp4..','..better_webm..'],['..still_worse..','..worst..'],['..back..']]' + return youtube_dl_keyboard +end + function settings:action(msg, config, matches) if msg.chat.type ~= "private" then return @@ -36,10 +57,17 @@ function settings:action(msg, config, matches) local hash = 'user:'..msg.from.id - if matches[1] == '⚙ Einstellungen' or matches[1] == '/settings' then + -- General + if matches[1] == '⚙ Einstellungen' or matches[1] == '/settings' or matches[1] == '↩️ Zurück' then utilities.send_reply(self, msg, 'Was möchtest du einstellen?', false, '{"keyboard":'..settings:keyboard(msg.from.id)..', "one_time_keyboard":true, "selective":true, "resize_keyboard":true}') return - elseif matches[1] == '💤 AFK-Keyboard einschalten' then + elseif matches[1] == '❌ Einstellungen verstecken' then + utilities.send_reply(self, msg, 'Um die Einstellungen wieder einzublenden, führe /settings aus.', true, '{"hide_keyboard":true}') + return + end + + -- AFK keyboard + if matches[1] == '💤 AFK-Keyboard einschalten' then redis:hset(hash, 'afk_keyboard', 'true') utilities.send_reply(self, msg, 'Das AFK-Keyboard wurde erfolgreich *eingeschaltet*.', true, '{"keyboard":'..settings:keyboard(msg.from.id)..', "one_time_keyboard":true, "selective":true, "resize_keyboard":true}') return @@ -47,10 +75,43 @@ function settings:action(msg, config, matches) redis:hset(hash, 'afk_keyboard', 'false') utilities.send_reply(self, msg, 'Das AFK-Keyboard wurde erfolgreich *ausgeschaltet*.', true, '{"keyboard":'..settings:keyboard(msg.from.id)..', "one_time_keyboard":true, "selective":true, "resize_keyboard":true}') return - elseif matches[1] == '❌ Einstellungen verstecken' then - utilities.send_reply(self, msg, 'Um die Einstellungen wieder einzublenden, führe /settings aus.', true, '{"hide_keyboard":true}') + end + + -- YouTube-DL video resolution + -- 144p: 17 + -- 180p: 36 + -- 360p WebM: 43 + -- 360p MP4: 18 + -- 720p: 22 + if matches[1] == '▶️ Videoauflösung für YouTube-DL einstellen' then + utilities.send_reply(self, msg, 'Welche Videoauflösung bevorzugst du?\nHINWEIS: Dies gilt nur für /mp4. Wenn die gewählte Auflösung nicht zur Verfügung steht, wird die nächsthöhere bzw. bei 720p die nächstniedrigere genommen.', 'HTML', '{"keyboard":'..settings:youtube_dl_keyboard()..', "one_time_keyboard":true, "selective":true, "resize_keyboard":true}') + elseif matches[1] == '▶️ 144p' then + local resolution_order = '17/36/43/18/22' + redis:hset(hash, 'yt_dl_res_ordner', resolution_order) + utilities.send_reply(self, msg, 'Die Reihenfolge ist jetzt folgende:\n1) 144p\n2) 180p\n3) 360p WebM\n4) 360p MP4\n5) 720p', true, '{"keyboard":'..settings:keyboard(msg.from.id)..', "one_time_keyboard":true, "selective":true, "resize_keyboard":true}') + return + elseif matches[1] == '▶️ 180p' then + local resolution_order = '36/17/43/18/22' + redis:hset(hash, 'yt_dl_res_ordner', resolution_order) + utilities.send_reply(self, msg, 'Die Reihenfolge ist jetzt folgende:\n1) 180p\n2) 144p\n3) 360p WebM\n4) 360p MP4\n5) 720p', true, '{"keyboard":'..settings:keyboard(msg.from.id)..', "one_time_keyboard":true, "selective":true, "resize_keyboard":true}') + return + elseif matches[1] == '▶️ 360p WebM' then + local resolution_order = '43/18/36/17/22' + redis:hset(hash, 'yt_dl_res_ordner', resolution_order) + utilities.send_reply(self, msg, 'Die Reihenfolge ist jetzt folgende:\n1) 360p WebM\n2) 360p MP4\n3) 180p\n4) 144p\n5) 720p', true, '{"keyboard":'..settings:keyboard(msg.from.id)..', "one_time_keyboard":true, "selective":true, "resize_keyboard":true}') + return + elseif matches[1] == '▶️ 360p MP4' then + local resolution_order = '18/43/36/17/22' + redis:hset(hash, 'yt_dl_res_ordner', resolution_order) + utilities.send_reply(self, msg, 'Die Reihenfolge ist jetzt folgende:\n1) 360p MP4\n2) 360p WebM\n3) 180p\n4) 144p\n5) 720p', true, '{"keyboard":'..settings:keyboard(msg.from.id)..', "one_time_keyboard":true, "selective":true, "resize_keyboard":true}') + return + elseif matches[1] == '▶️ 720p' then + local resolution_order = '22/18/43/36/17' + redis:hset(hash, 'yt_dl_res_ordner', resolution_order) + utilities.send_reply(self, msg, 'Die Reihenfolge ist jetzt folgende:\n1) 720p\n2) 360p MP4\n3) 360p WebM\n4) 180p\n5) 144p', true, '{"keyboard":'..settings:keyboard(msg.from.id)..', "one_time_keyboard":true, "selective":true, "resize_keyboard":true}') return end + end return settings \ No newline at end of file diff --git a/otouto/plugins/youtube_dl.lua b/otouto/plugins/youtube_dl.lua index 46d5dc1..7ceaa15 100644 --- a/otouto/plugins/youtube_dl.lua +++ b/otouto/plugins/youtube_dl.lua @@ -18,8 +18,8 @@ end youtube_dl.command = 'mp3 , /mp4 ' -function youtube_dl:convert_video(id) - local ytdl_json = io.popen('youtube-dl -f 22/43/18/36/17 --max-filesize 49m -j https://www.youtube.com/watch/?v='..id):read('*all') +function youtube_dl:convert_video(id, chosen_res) + local ytdl_json = io.popen('youtube-dl -f '..chosen_res..' --max-filesize 49m -j https://www.youtube.com/watch/?v='..id):read('*all') if not ytdl_json then return end local data = json.decode(ytdl_json) return data @@ -36,11 +36,16 @@ end function youtube_dl:action(msg, config, matches) local id = matches[2] + local hash = 'user:'..msg.from.id + local chosen_res = redis:hget(hash, 'yt_dl_res_ordner') + if not chosen_res then + chosen_res = '22/18/43/36/17' + end if matches[1] == 'mp4' then local first_msg = utilities.send_reply(self, msg, 'Video wird heruntergeladen...', 'HTML') utilities.send_typing(self, msg.chat.id, 'upload_video') - local data = youtube_dl:convert_video(id) + local data = youtube_dl:convert_video(id, chosen_res) if not data then utilities.edit_message(self, msg.chat.id, first_msg.result.message_id, config.errors.results) return