code improvement
This commit is contained in:
parent
6fd4285b3b
commit
d384efb138
32
main.py
32
main.py
@ -1,63 +1,47 @@
|
||||
import logging
|
||||
from time import sleep
|
||||
|
||||
from telegram import InlineKeyboardMarkup
|
||||
from telegram.ext import Updater, CallbackQueryHandler, MessageHandler, Filters
|
||||
|
||||
from vid_utils import Video, VideoQueue, BadLink
|
||||
from vid_utils import Video, BadLink
|
||||
|
||||
logging.basicConfig(format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
|
||||
level=logging.INFO)
|
||||
logging.basicConfig(format='%(asctime)s - %(name)s - %(levelname)s - %(message)s', level=logging.INFO)
|
||||
logger = logging.getLogger(__name__)
|
||||
|
||||
VIDEOS = VideoQueue()
|
||||
|
||||
def get_format(bot, update):
|
||||
logger.info("from {}: {}".format(update.message.chat_id, update.message.text)) # "history"
|
||||
|
||||
try:
|
||||
video = Video(update.message.text, update.message.chat_id)
|
||||
video = Video(update.message.text, init_keyboard=True)
|
||||
except BadLink:
|
||||
update.message.reply_text("Bad link")
|
||||
else:
|
||||
for i, v in enumerate(VIDEOS):
|
||||
if v.chat_id == video.chat_id:
|
||||
VIDEOS[i] = video # remove old video not downloaded...
|
||||
break
|
||||
else:
|
||||
VIDEOS.append(video)
|
||||
|
||||
reply_markup = InlineKeyboardMarkup(video.keyboard)
|
||||
update.message.reply_text('Choose format:', reply_markup=reply_markup)
|
||||
|
||||
|
||||
def download_choosen_format(bot, update):
|
||||
query = update.callback_query
|
||||
resolution_code, link = query.data.split(' ', 1)
|
||||
|
||||
bot.edit_message_text(text="Downloading...",
|
||||
chat_id=query.message.chat_id,
|
||||
message_id=query.message.message_id)
|
||||
|
||||
while VIDEOS.lock: sleep(1) # finish old download
|
||||
|
||||
VIDEOS.lock = True # maybe we can use a contextmanager?
|
||||
|
||||
for i, video in enumerate(VIDEOS):
|
||||
if video.chat_id == query.message.chat_id:
|
||||
VIDEOS.pop(i)
|
||||
video.download(query.data)
|
||||
video = Video(link)
|
||||
video.download(resolution_code)
|
||||
|
||||
with video.send() as files:
|
||||
for f in files:
|
||||
bot.send_document(chat_id=query.message.chat_id, document=open(f, 'rb'))
|
||||
|
||||
VIDEOS.lock = False
|
||||
|
||||
|
||||
updater = Updater(token=YOUR_TOKEN)
|
||||
|
||||
updater.dispatcher.add_handler(MessageHandler(Filters.text, get_format))
|
||||
updater.dispatcher.add_handler(CallbackQueryHandler(download_choosen_format))
|
||||
|
||||
# Start the Bot
|
||||
|
||||
updater.start_polling()
|
||||
updater.idle()
|
||||
|
Loading…
Reference in New Issue
Block a user