async def direct_dl_callback(_, update): cb_data = update.data LOGGER.info(cb_data) # youtube_dl extractors send_as, _, __, ___ = cb_data.split("=") ( url, custom_file_name, _, _, ) = get_link(update.message.reply_to_message) if not custom_file_name: custom_file_name = os.path.basename(url) start_download = datetime.now() await update.message.edit_text(text=String.DOWNLOAD_START) tmp_directory_for_each_user = os.path.join( Config.WORK_DIR, str(update.from_user.id) ) if not os.path.isdir(tmp_directory_for_each_user): os.makedirs(tmp_directory_for_each_user) download_directory = os.path.join( mkdtemp(dir=tmp_directory_for_each_user), custom_file_name ) c_time = time.time() try: await direct_downloader( url, download_directory, update.message, c_time, ) except asyncio.TimeoutError: await update.message.edit_text(text=String.SLOW_URL_DECED) return False if os.path.exists(download_directory): end_download = datetime.now() downloaded_in = (end_download - start_download).seconds await update.message.edit_text( text=f"Download took {downloaded_in} seconds.\n" + String.UPLOAD_START ) try: upl = await upload_worker( update, custom_file_name, None, download_directory, downloaded_in ) LOGGER.info(upl) except: return False shutil.rmtree(download_directory, ignore_errors=True) LOGGER.info("Cleared temporary folder") # await update.message.delete() else: await update.message.edit_text( text=String.NO_VOID_FORMAT_FOUND.format("Incorrect Link"), )
async def direct_dl_callback(bot, update): cb_data = update.data LOGGER.info(cb_data) # youtube_dl extractors send_as, _, __, ___ = cb_data.split("=") thumb_image_path = Config.WORK_DIR + "/" + str( update.from_user.id) + ".jpg" ( url, custom_file_name, _, _, ) = get_link(update.message.reply_to_message) if not custom_file_name: custom_file_name = os.path.basename(url) description = String.CUSTOM_CAPTION_UL_FILE start_download = datetime.now() await bot.edit_message_text( text=String.DOWNLOAD_START, chat_id=update.message.chat.id, message_id=update.message.message_id, ) tmp_directory_for_each_user = os.path.join(Config.WORK_DIR, str(update.from_user.id)) if not os.path.isdir(tmp_directory_for_each_user): os.makedirs(tmp_directory_for_each_user) download_directory = os.path.join(tmp_directory_for_each_user, custom_file_name) c_time = time.time() try: await direct_downloader( url, download_directory, update.message, c_time, ) except: return False if os.path.exists(download_directory): end_download = datetime.now() time_taken_for_download = (end_download - start_download).seconds await bot.edit_message_text( text=f"Download took {time_taken_for_download} seconds.\n" + String.UPLOAD_START, chat_id=update.message.chat.id, message_id=update.message.message_id, ) try: upl = await upload_worker(update, custom_file_name, send_as, False, download_directory) LOGGER.info(upl) except: return False try: os.remove(download_directory) os.remove(thumb_image_path) except: pass await update.message.delete() else: await bot.edit_message_text( text=String.NO_VOID_FORMAT_FOUND.format("Incorrect Link"), chat_id=update.message.chat.id, message_id=update.message.message_id, disable_web_page_preview=True, )
async def youtube_dl_call_back(bot, update): cb_data = update.data # youtube_dl extractors tg_send_type, youtube_dl_format, youtube_dl_ext = cb_data.split("|") thumb_image_path = DOWNLOAD_LOCATION + \ "/" + str(update.from_user.id) + ".jpg" save_ytdl_json_path = DOWNLOAD_LOCATION + \ "/" + str(update.from_user.id) + ".json" try: with open(save_ytdl_json_path, "r", encoding="utf8") as f: response_json = json.load(f) except FileNotFoundError: await update.message.delete() return False youtube_dl_url, \ custom_file_name, \ youtube_dl_username, \ youtube_dl_password = get_link( update.message.reply_to_message ) if not custom_file_name: custom_file_name = str(response_json.get("title")) + \ "_" + youtube_dl_format + "." + youtube_dl_ext await update.message.edit_caption(caption=Translation.DOWNLOAD_START) description = Translation.CUSTOM_CAPTION_UL_FILE if "fulltitle" in response_json: description = response_json["fulltitle"][0:1021] # escape Markdown and special characters tmp_directory_for_each_user = os.path.join(DOWNLOAD_LOCATION, str(update.from_user.id)) if not os.path.isdir(tmp_directory_for_each_user): os.makedirs(tmp_directory_for_each_user) download_directory = os.path.join(tmp_directory_for_each_user, custom_file_name) command_to_exec = [] if tg_send_type == "audio": command_to_exec = [ "youtube-dl", "-c", "--max-filesize", str(TG_MAX_FILE_SIZE), "--prefer-ffmpeg", "--extract-audio", "--audio-format", youtube_dl_ext, "--audio-quality", youtube_dl_format, youtube_dl_url, "-o", download_directory ] else: minus_f_format = youtube_dl_format if "youtu" in youtube_dl_url: minus_f_format = youtube_dl_format + "+bestaudio" command_to_exec = [ "youtube-dl", "-c", "--max-filesize", str(TG_MAX_FILE_SIZE), "--embed-subs", "-f", minus_f_format, "--hls-prefer-ffmpeg", youtube_dl_url, "-o", download_directory ] if HTTP_PROXY is not None: command_to_exec.append("--proxy") command_to_exec.append(HTTP_PROXY) if youtube_dl_username is not None: command_to_exec.append("--username") command_to_exec.append(youtube_dl_username) if youtube_dl_password is not None: command_to_exec.append("--password") command_to_exec.append(youtube_dl_password) command_to_exec.append("--no-warnings") # command_to_exec.append("--quiet") command_to_exec.append("--restrict-filenames") LOGGER.info(command_to_exec) start = datetime.now() t_response, e_response = await run_shell_command(command_to_exec) LOGGER.info(e_response) LOGGER.info(t_response) if e_response and Translation.YTDL_ERROR_MESSAGE in e_response: error_message = e_response.replace(Translation.YTDL_ERROR_MESSAGE, "") await update.message.edit_caption(caption=error_message) return False if t_response: # LOGGER.info(t_response) os.remove(save_ytdl_json_path) end_one = datetime.now() time_taken_for_download = (end_one - start).seconds file_size = TG_MAX_FILE_SIZE + 1 download_directory_dirname = os.path.dirname(download_directory) download_directory_contents = os.listdir(download_directory_dirname) for download_directory_c in download_directory_contents: current_file_name = os.path.join(download_directory_dirname, download_directory_c) file_size = os.stat(current_file_name).st_size if file_size > TG_MAX_FILE_SIZE: await update.message.edit_caption( caption=Translation.RCHD_TG_API_LIMIT.format( time_taken_for_download, humanbytes(file_size))) else: is_w_f = False images = await generate_screen_shots( current_file_name, tmp_directory_for_each_user, is_w_f, "", 300, 9) LOGGER.info(images) await update.message.edit_caption( caption=Translation.UPLOAD_START) # get the correct width, height, and duration # for videos greater than 10MB # ref: message from @BotSupport width = 0 height = 0 duration = 0 if tg_send_type != "file": metadata = extractMetadata(createParser(current_file_name)) if metadata is not None: if metadata.has("duration"): duration = metadata.get('duration').seconds # get the correct width, height, and duration # for videos greater than 10MB if os.path.exists(thumb_image_path): # https://stackoverflow.com/a/21669827/4723940 Image.open(thumb_image_path).convert("RGB").save( thumb_image_path) metadata = extractMetadata(createParser(thumb_image_path)) if metadata.has("width"): width = metadata.get("width") if metadata.has("height"): height = metadata.get("height") if tg_send_type == "vm": height = width else: thumb_image_path = None start_time = time.time() # try to upload file if tg_send_type == "audio": await update.message.reply_audio( audio=current_file_name, caption=description, parse_mode="HTML", duration=duration, # performer=response_json["uploader"], # title=response_json["title"], # reply_markup=reply_markup, thumb=thumb_image_path, progress=progress_for_pyrogram, progress_args=(Translation.UPLOAD_START, update.message, start_time)) elif tg_send_type == "file": await update.message.reply_document( document=current_file_name, thumb=thumb_image_path, caption=description, parse_mode="HTML", # reply_markup=reply_markup, progress=progress_for_pyrogram, progress_args=(Translation.UPLOAD_START, update.message, start_time)) elif tg_send_type == "vm": await update.message.reply_video_note( video_note=current_file_name, duration=duration, length=width, thumb=thumb_image_path, progress=progress_for_pyrogram, progress_args=(Translation.UPLOAD_START, update.message, start_time)) elif tg_send_type == "video": await update.message.reply_video( video=current_file_name, caption=description, parse_mode="HTML", duration=duration, width=width, height=height, supports_streaming=True, # reply_markup=reply_markup, thumb=thumb_image_path, progress=progress_for_pyrogram, progress_args=(Translation.UPLOAD_START, update.message, start_time)) else: LOGGER.info("Did this happen? :\\") end_two = datetime.now() time_taken_for_upload = (end_two - end_one).seconds # media_album_p = [] if images is not None: i = 0 caption = "© @KS_AnyDLBot" for image in images: if os.path.exists(image): if i == 0: media_album_p.append( InputMediaPhoto(media=image, caption=caption, parse_mode="html")) else: media_album_p.append( InputMediaPhoto(media=image)) i = i + 1 await update.message.reply_media_group( media=media_album_p, disable_notification=True) # shutil.rmtree(tmp_directory_for_each_user, ignore_errors=True) os.remove(thumb_image_path) await update.message.delete()
async def echo(_, message): LOGGER.info(message.from_user) url, _, youtube_dl_username, youtube_dl_password = get_link(message) info_dict = {} if youtube_dl_username and youtube_dl_password: info_dict.update( { "username": youtube_dl_username, "password": youtube_dl_password, } ) if "hotstar" in url: info_dict.update( { "geo_bypass_country": "IN", } ) try: info = await yt_extract_info( video_url=url, download=False, ytdl_opts=info_dict, ie_key=None, ) except youtube_dl.utils.DownloadError as ytdl_error: await message.reply_text(text=str(ytdl_error), quote=True) return False if info: ikeyboard = InlineKeyboard() thumb_image = info.get("thumbnail", None) thumbnail = thumb_image or Config.DEFAULT_THUMBNAIL extractor_key = info.get("extractor_key", "Generic") duration = info.get("duration", None) if "formats" in info: for formats in info.get("formats"): format_id = formats.get("format_id") format_string = formats.get("format_note", None) if format_string is None: format_string = formats.get("format") # @SpEcHiDe/PublicLeech//helper_funcs/youtube_dl_extractor.py#L100 if "DASH" in format_string.upper(): continue format_ext = formats.get("ext") av_codec = "empty" if formats.get("acodec") == "none" or formats.get("vcodec") == "none": av_codec = "none" approx_file_size = ( humanbytes(formats.get("filesize")) if formats.get("filesize") else "" ) display_str = ( f"{format_string} [{format_ext.upper()}] {approx_file_size}" ) cb_string_video = f"video|{extractor_key}|{format_id}|{av_codec}" # GDrive gets special pass, acodec is not listed here, ie acodec=None if ( extractor_key == "GoogleDrive" and format_id == "source" or extractor_key != "GoogleDrive" and format_string and "audio only" not in format_string ): ikeyboard.row( InlineKeyboardButton(display_str, callback_data=cb_string_video) ) elif extractor_key != "GoogleDrive": # special weird case :\ ikeyboard.row( InlineKeyboardButton( f"Video {approx_file_size}", cb_string_video ), ) if duration: ikeyboard.row( InlineKeyboardButton( "MP3 (64 kbps)", callback_data=f"audio|{extractor_key}|64|mp3" ), InlineKeyboardButton( "MP3 (128 kbps)", callback_data=f"audio|{extractor_key}|128|mp3" ), ) ikeyboard.row( InlineKeyboardButton( "MP3 (320 kbps)", callback_data=f"audio|{extractor_key}|320|mp3" ) ) elif "entries" in info: for entries in info.get("entries"): for formats in entries.get("formats"): format_id = formats.get("format_id") format_ext = formats.get("ext") cb_string_file = f"file|{extractor_key}|{format_id}|{format_ext}" ikeyboard.row( InlineKeyboardButton( f"YTDL Generic File [{format_ext.upper()}]", callback_data=cb_string_file ), ) else: format_id = info.get("format_id") format_ext = info.get("ext") cb_string_file = f"file={extractor_key}={format_id}={format_ext}" ikeyboard.row( InlineKeyboardButton( f"File [{format_ext.upper()}]", callback_data=cb_string_file ), ) save_thumbnail = os.path.join( Config.WORK_DIR, str(message.from_user.id) + ".jpg" ) if not os.path.isdir(Config.WORK_DIR): os.makedirs(Config.WORK_DIR) if os.path.exists(save_thumbnail): thumb_image_path = save_thumbnail else: thumb_image_path = await get_thumbnail(thumbnail, save_thumbnail) await message.reply_photo( photo=thumb_image_path, quote=True, caption=String.FORMAT_SELECTION.format(thumbnail) + "\n" + String.SET_CUSTOM_USERNAME_PASSWORD, reply_markup=ikeyboard, parse_mode="html", ) else: # fallback for nonnumeric port a.k.a seedbox.io ikeyboard = InlineKeyboard() cb_string_file = "file=LFO=NONE=NONE" ikeyboard.row( InlineKeyboardButton("File", callback_data=cb_string_file), ) await message.reply_photo( photo=Config.DEFAULT_THUMBNAIL, quote=True, caption=String.FORMAT_SELECTION.format(""), reply_markup=ikeyboard, parse_mode="html", reply_to_message_id=message.message_id, )
async def echo(bot, update: Message): if update.from_user.id in AUTH_USERS: await update.delete() return # LOGGER.info(update) # await bot.send_chat_action( # chat_id=update.chat.id, # action="typing" # ) LOGGER.info(update.from_user) url, _, youtube_dl_username, youtube_dl_password = get_link(update) if HTTP_PROXY is not None: command_to_exec = [ "youtube-dl", "--no-warnings", "--youtube-skip-dash-manifest", "-j", url, "--proxy", HTTP_PROXY ] else: command_to_exec = [ "youtube-dl", "--no-warnings", "--youtube-skip-dash-manifest", "-j", url ] if youtube_dl_username is not None: command_to_exec.append("--username") command_to_exec.append(youtube_dl_username) if youtube_dl_password is not None: command_to_exec.append("--password") command_to_exec.append(youtube_dl_password) # logger.info(command_to_exec) t_response, e_response = await run_shell_command(command_to_exec) # https://github.com/rg3/youtube-dl/issues/2630#issuecomment-38635239 if e_response and "nonnumeric port" not in e_response: # logger.warn("Status : FAIL", exc.returncode, exc.output) error_message = e_response.replace(Translation.YTDL_ERROR_MESSAGE, "") if Translation.ISOAYD_PREMIUM_VIDEOS in error_message: error_message += Translation.SET_CUSTOM_USERNAME_PASSWORD await update.reply_text(text=Translation.NO_VOID_FORMAT_FOUND.format( str(error_message)), quote=True, parse_mode="html", disable_web_page_preview=True) return False if t_response: # logger.info(t_response) x_reponse = t_response if "\n" in x_reponse: x_reponse, _ = x_reponse.split("\n") response_json = json.loads(x_reponse) save_ytdl_json_path = DOWNLOAD_LOCATION + \ "/" + str(update.from_user.id) + ".json" with open(save_ytdl_json_path, "w", encoding="utf8") as outfile: json.dump(response_json, outfile, ensure_ascii=False) # logger.info(response_json) inline_keyboard = [] duration = None if "duration" in response_json: duration = response_json["duration"] if "formats" in response_json: for formats in response_json["formats"]: format_id = formats.get("format_id") format_string = formats.get("format_note") if format_string is None: format_string = formats.get("format") format_ext = formats.get("ext") approx_file_size = "" if "filesize" in formats: approx_file_size = humanbytes(formats["filesize"]) cb_string_video = "{}|{}|{}".format("video", format_id, format_ext) cb_string_file = "{}|{}|{}".format("file", format_id, format_ext) if format_string and "audio only" not in format_string: ikeyboard = [ InlineKeyboardButton( f"S {format_string} video {format_ext} ", callback_data=(cb_string_video).encode("UTF-8")), InlineKeyboardButton( f"D {format_string} video {approx_file_size} ", callback_data=(cb_string_file).encode("UTF-8")) ] else: # special weird case :\ ikeyboard = [ InlineKeyboardButton( "SVideo [" + "] ( " + approx_file_size + " )", callback_data=(cb_string_video).encode("UTF-8")), InlineKeyboardButton( "DFile [" + "] ( " + approx_file_size + " )", callback_data=(cb_string_file).encode("UTF-8")) ] inline_keyboard.append(ikeyboard) if duration is not None: cb_string_64 = "{}|{}|{}".format("audio", "64k", "mp3") cb_string_128 = "{}|{}|{}".format("audio", "128k", "mp3") cb_string = "{}|{}|{}".format("audio", "320k", "mp3") inline_keyboard.append([ InlineKeyboardButton( "MP3 " + "(" + "64 kbps" + ")", callback_data=cb_string_64.encode("UTF-8")), InlineKeyboardButton( "MP3 " + "(" + "128 kbps" + ")", callback_data=cb_string_128.encode("UTF-8")) ]) inline_keyboard.append([ InlineKeyboardButton( "MP3 " + "(" + "320 kbps" + ")", callback_data=cb_string.encode("UTF-8")) ]) else: format_id = response_json["format_id"] format_ext = response_json["ext"] cb_string_file = "{}|{}|{}".format("file", format_id, format_ext) cb_string_video = "{}|{}|{}".format("video", format_id, format_ext) inline_keyboard.append([ InlineKeyboardButton( "SVideo", callback_data=(cb_string_video).encode("UTF-8")), InlineKeyboardButton( "DFile", callback_data=(cb_string_file).encode("UTF-8")) ]) cb_string_file = "{}={}={}".format("file", format_id, format_ext) cb_string_video = "{}={}={}".format("video", format_id, format_ext) inline_keyboard.append([ InlineKeyboardButton( "video", callback_data=(cb_string_video).encode("UTF-8")), InlineKeyboardButton( "file", callback_data=(cb_string_file).encode("UTF-8")) ]) reply_markup = InlineKeyboardMarkup(inline_keyboard) # logger.info(reply_markup) thumbnail = DEF_THUMB_NAIL_VID_S thumbnail_image = DEF_THUMB_NAIL_VID_S if "thumbnail" in response_json: if response_json["thumbnail"] is not None: thumbnail = response_json["thumbnail"] thumbnail_image = response_json["thumbnail"] thumb_image_path = DownLoadFile( thumbnail_image, DOWNLOAD_LOCATION + "/" + str(update.from_user.id) + ".jpg", 128, None, # bot, Translation.DOWNLOAD_START, update.message_id, update.chat.id) await update.reply_photo( photo=thumb_image_path, quote=True, caption=Translation.FORMAT_SELECTION.format(thumbnail) + "\n" + Translation.SET_CUSTOM_USERNAME_PASSWORD, reply_markup=reply_markup, parse_mode="html") else: # fallback for nonnumeric port a.k.a seedbox.io inline_keyboard = [] cb_string_file = "{}={}={}".format("file", "LFO", "NONE") cb_string_video = "{}={}={}".format("video", "OFL", "ENON") inline_keyboard.append([ InlineKeyboardButton( "SVideo", callback_data=(cb_string_video).encode("UTF-8")), InlineKeyboardButton( "DFile", callback_data=(cb_string_file).encode("UTF-8")) ]) reply_markup = InlineKeyboardMarkup(inline_keyboard) await update.reply_photo( photo=DEF_THUMB_NAIL_VID_S, quote=True, caption=Translation.FORMAT_SELECTION.format(""), reply_markup=reply_markup, parse_mode="html", reply_to_message_id=update.message_id)
async def ddl_call_back(bot, update): LOGGER.info(update) cb_data = update.data # youtube_dl extractors tg_send_type, youtube_dl_format, youtube_dl_ext = cb_data.split("=") thumb_image_path = DOWNLOAD_LOCATION + \ "/" + str(update.from_user.id) + ".jpg" youtube_dl_url, \ custom_file_name, \ youtube_dl_username, \ youtube_dl_password = get_link( update.message.reply_to_message ) if not custom_file_name: custom_file_name = os.path.basename(youtube_dl_url) description = Translation.CUSTOM_CAPTION_UL_FILE start = datetime.now() await bot.edit_message_text(text=Translation.DOWNLOAD_START, chat_id=update.message.chat.id, message_id=update.message.message_id) tmp_directory_for_each_user = os.path.join(DOWNLOAD_LOCATION, str(update.from_user.id)) if not os.path.isdir(tmp_directory_for_each_user): os.makedirs(tmp_directory_for_each_user) download_directory = os.path.join(tmp_directory_for_each_user, custom_file_name) async with aiohttp.ClientSession() as session: c_time = time.time() try: await download_coroutine(bot, session, youtube_dl_url, download_directory, update.message.chat.id, update.message.message_id, c_time) except asyncio.TimeoutError: await bot.edit_message_text(text=Translation.SLOW_URL_DECED, chat_id=update.message.chat.id, message_id=update.message.message_id) return False if os.path.exists(download_directory): end_one = datetime.now() await bot.edit_message_text(text=Translation.UPLOAD_START, chat_id=update.message.chat.id, message_id=update.message.message_id) file_size = TG_MAX_FILE_SIZE + 1 try: file_size = os.stat(download_directory).st_size except FileNotFoundError: await update.message.edit_text(text=Translation.SLOW_URL_DECED) return False if file_size > TG_MAX_FILE_SIZE: await bot.edit_message_text(chat_id=update.message.chat.id, text=Translation.RCHD_TG_API_LIMIT, message_id=update.message.message_id) else: # get the correct width, height, and duration # for videos greater than 10MB # ref: message from @BotSupport width = 0 height = 0 duration = 0 if tg_send_type != "file": metadata = extractMetadata(createParser(download_directory)) if metadata is not None: if metadata.has("duration"): duration = metadata.get('duration').seconds # get the correct width, height, and duration # for videos greater than 10MB if os.path.exists(thumb_image_path): width = 0 height = 0 metadata = extractMetadata(createParser(thumb_image_path)) if metadata.has("width"): width = metadata.get("width") if metadata.has("height"): height = metadata.get("height") if tg_send_type == "vm": height = width # resize image # ref: https://t.me/PyrogramChat/44663 # https://stackoverflow.com/a/21669827/4723940 Image.open(thumb_image_path).convert("RGB").save( thumb_image_path) else: thumb_image_path = None start_time = time.time() # try to upload file if tg_send_type == "audio": await update.message.reply_audio( audio=download_directory, caption=description, duration=duration, # performer=response_json["uploader"], # title=response_json["title"], # reply_markup=reply_markup, thumb=thumb_image_path, progress=progress_for_pyrogram, progress_args=(Translation.UPLOAD_START, update.message, start_time)) elif tg_send_type == "file": await update.message.reply_document( document=download_directory, thumb=thumb_image_path, caption=description, # reply_markup=reply_markup, progress=progress_for_pyrogram, progress_args=(Translation.UPLOAD_START, update.message, start_time)) elif tg_send_type == "vm": await update.message.reply_video_note( video_note=download_directory, duration=duration, length=width, thumb=thumb_image_path, progress=progress_for_pyrogram, progress_args=(Translation.UPLOAD_START, update.message, start_time)) elif tg_send_type == "video": await update.message.reply_video( video=download_directory, caption=description, duration=duration, width=width, height=height, supports_streaming=True, # reply_markup=reply_markup, thumb=thumb_image_path, progress=progress_for_pyrogram, progress_args=(Translation.UPLOAD_START, update.message, start_time)) else: LOGGER.info("Did this happen? :\\") end_two = datetime.now() try: os.remove(download_directory) os.remove(thumb_image_path) except: pass time_taken_for_download = (end_one - start).seconds time_taken_for_upload = (end_two - end_one).seconds await update.message.delete() else: await bot.edit_message_text( text=Translation.NO_VOID_FORMAT_FOUND.format("Incorrect Link"), chat_id=update.message.chat.id, message_id=update.message.message_id, disable_web_page_preview=True)
async def youtube_dl_call_back(_, update): cb_data = update.data LOGGER.info(cb_data) # youtube_dl extractors send_as, extractor_key, format_id, av_codec = cb_data.split("|") thumb_image_path = os.path.join(Config.WORK_DIR, str(update.from_user.id) + ".jpg") ( youtube_dl_url, custom_file_name, youtube_dl_username, youtube_dl_password, ) = get_link(update.message.reply_to_message) if not custom_file_name: custom_file_name = "%(title)s.%(ext)s" await update.message.edit_caption(caption=String.DOWNLOAD_START) # description = Translation.CUSTOM_CAPTION_UL_FILE tmp_directory_for_each_user = os.path.join(Config.WORK_DIR, str(update.from_user.id)) if not os.path.isdir(tmp_directory_for_each_user): os.makedirs(tmp_directory_for_each_user) download_directory = os.path.join(tmp_directory_for_each_user, custom_file_name) ytdl_opts = { "outtmpl": download_directory, "ignoreerrors": True, "nooverwrites": True, "continuedl": True, "noplaylist": True, "restrictfilenames": True, "max_filesize": Config.TG_MAX_FILE_SIZE, } if youtube_dl_username and youtube_dl_password: ytdl_opts.update({ "username": youtube_dl_username, "password": youtube_dl_password, }) if extractor_key == "HotStar": ytdl_opts.update({ "geo_bypass_country": "IN", }) if send_as == "audio": ytdl_opts.update({ "format": "bestaudio/best", "postprocessors": [ { "key": "FFmpegExtractAudio", "preferredcodec": av_codec, "preferredquality": format_id, }, { "key": "FFmpegMetadata" }, ], }) elif send_as == "video": final_format = format_id if extractor_key == "Youtube" and av_codec == "none": final_format = f"{format_id}+bestaudio" ytdl_opts.update({ "format": final_format, "postprocessors": [{ "key": "FFmpegMetadata" }], }) elif send_as == "file": ytdl_opts.update({ "format": format_id, }) start_download = datetime.now() try: info = await yt_extract_info( video_url=youtube_dl_url, download=True, ytdl_opts=ytdl_opts, ie_key=extractor_key, ) except youtube_dl.utils.DownloadError as ytdl_error: await update.message.edit_caption(caption=str(ytdl_error)) return False if info: end_download = datetime.now() time_taken_for_download = (end_download - start_download).seconds await update.message.edit_caption( caption=f"Download took {time_taken_for_download} seconds.\n" + String.UPLOAD_START) upl = await upload_worker(update, info.get("title", ""), send_as, True, download_directory) LOGGER.info(upl) shutil.rmtree(tmp_directory_for_each_user, ignore_errors=True) LOGGER.info("Cleared temporary folder") os.remove(thumb_image_path) await update.message.delete()