Skip to content

Commit

Permalink
direct
Browse files Browse the repository at this point in the history
  • Loading branch information
BennyThink committed Dec 4, 2024
1 parent 38ed4c4 commit 5d9a2ef
Show file tree
Hide file tree
Showing 3 changed files with 40 additions and 36 deletions.
11 changes: 6 additions & 5 deletions src/engine/base.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@
import ffmpeg
import filetype
from helper import debounce, sizeof_fmt
from pyrogram import types
from pyrogram import enums, types
from tqdm import tqdm

from config import TG_NORMAL_MAX_SIZE, Types
Expand Down Expand Up @@ -128,14 +128,14 @@ def download_hook(self, d: dict):
eta = self.__remove_bash_color(d.get("_eta_str", d.get("eta")))
text = self.__tqdm_progress("Downloading...", total, downloaded, speed, eta)
# debounce in here
self.__edit_text(self._bot_msg, text)
self.edit_text(self._bot_msg, text)

def upload_hook(self, current, total):
text = self.__tqdm_progress("Uploading...", total, current)
self.__edit_text(self._bot_msg, text)
self.edit_text(self._bot_msg, text)

@debounce(5)
def __edit_text(self, text: str):
def edit_text(self, text: str):
self._bot_msg.edit_text(text)

def get_cache_fileid(self):
Expand All @@ -147,7 +147,7 @@ def _setup_formats(self) -> list | None:
pass

@abstractmethod
def _download(self, formats):
def _download(self, formats) -> list:
# responsible for get format and download it
pass

Expand All @@ -162,6 +162,7 @@ def _methods(self):
}

def send_something(self, *, chat_id, files, _type, caption=None, thumb=None, **kwargs):
self._client.send_chat_action(chat_id, enums.ChatAction.UPLOAD_DOCUMENT)
if len(files) > 1:
inputs = generate_input_media(files, caption)
return self._client.send_media_group(chat_id, inputs)[0]
Expand Down
60 changes: 32 additions & 28 deletions src/engine/direct.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,11 @@
import pathlib
import subprocess
import tempfile
from pathlib import Path
from uuid import uuid4

import filetype
import requests
from base import BaseDownloader
from pyrogram import enums

Expand All @@ -18,25 +21,30 @@

class DirectDownloader(BaseDownloader):

def start(self):
pass

def _setup_formats(self) -> list | None:
# direct download doesn't need to setup formats
pass

def _requests_download(self):
pass
response = requests.get(self._url, stream=True)
response.raise_for_status()
file = Path(self._tempdir).joinpath(uuid4().hex)
ext = filetype.guess_extension(file)
if ext is not None:
file = file.with_suffix(ext)

with open(file, "wb") as f:
for chunk in response.iter_content(chunk_size=8192):
f.write(chunk)
return [file.as_posix()]

def _aria2_download(self):
chat_id = self._bot_msg.chat.id
temp_dir = tempfile.TemporaryDirectory(prefix="ytdl-aria2-", dir=TMPFILE_PATH)
tempdir = temp_dir.name
ua = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/126.0.0.0 Safari/537.36"
response = None
video_paths = None
# Download process using aria2c
try:
self._bot_msg.__edit_text(f"Download Starting...", disable_web_page_preview=True)
self._bot_msg.edit_text(f"Aria2 download starting...")
# Command to engine the link using aria2c
command = [
"aria2c",
Expand All @@ -45,47 +53,43 @@ def _aria2_download(self):
"--max-tries=5",
"--console-log-level=warn",
"-d",
tempdir,
self._tempdir,
self._url,
]
# Run the command using subprocess.Popen
process = subprocess.Popen(command, bufsize=0, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
line = ""
max_iterations = 100 # Set a reasonable maximum number of iterations
iteration = 0

while process.poll() is None and iteration < max_iterations:
line = process.stdout.readline().decode("utf-8")
line: str = process.stdout.readline().decode("utf-8")
if line.startswith("[#"):
line = line.strip()
self._bot_msg.__edit_text(f"Downloading... \n\n`{line}`", disable_web_page_preview=True)
self.edit_text(f"Aria2 downloading... \n\n`{line}`", disable_web_page_preview=True)
break
iteration += 1

if iteration >= max_iterations:
self._bot_msg.__edit_text("Something went wrong. Please try again.", disable_web_page_preview=True)
self.edit_text("Download exceed max iteration. Please try again later.", disable_web_page_preview=True)
except Exception as e:
self._bot_msg.__edit_text(f"Download failed!❌\n\n`{e}`", disable_web_page_preview=True)
self.edit_text(f"Download failed!❌\n\n`{e}`", disable_web_page_preview=True)
return
# Get filename and extension correctly after engine
filepath = list(pathlib.Path(tempdir).glob("*"))
file_path_obj = filepath[0]
path_obj = pathlib.Path(file_path_obj)
filename = path_obj.name
file: Path = next(Path(self._tempdir).glob("*"))
filename = file.name
logging.info("Downloaded file %s", filename)
self._bot_msg.__edit_text(f"Download Complete", disable_web_page_preview=True)
ext = filetype.guess_extension(file_path_obj)
self.edit_text(f"Download Complete", disable_web_page_preview=True)
ext = filetype.guess_extension(file)
# Rename file if it doesn't have extension
if ext is not None and not filename.endswith(ext):
new_filename = f"{tempdir}/{filename}.{ext}"
os.rename(file_path_obj, new_filename)
file.rename(f"{self._tempdir}/{filename}.{ext}")
# Get file path of the downloaded file to upload
video_paths = list(pathlib.Path(tempdir).glob("*"))
self._client.send_chat_action(chat_id, enums.ChatAction.UPLOAD_DOCUMENT)
upload_processor(self._client, self._bot_msg, self._url, video_paths)
self._bot_msg.__edit_text("Download success!✅")
return [file.as_posix()]

def _download(self, formats):
def _download(self, formats=None) -> list:
if ENABLE_ARIA2:
return self._aria2_download()
return self._requests_download()

def start(self):
self._download()
self._upload()
5 changes: 2 additions & 3 deletions src/engine/generic.py
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ def _setup_formats(self) -> list | None:
# Add any remaining buttons as the last row
if temp_row:
markup.append(temp_row)
self._bot_msg.__edit_text("Choose the format", reply_markup=types.InlineKeyboardMarkup(markup))
self._bot_msg.edit_text("Choose the format", reply_markup=types.InlineKeyboardMarkup(markup))
return None
if download == "audio":
# download audio only
Expand All @@ -59,9 +59,8 @@ def _setup_formats(self) -> list | None:
formats.append("worst")
return formats

def _download(self, formats):
def _download(self, formats) -> list:
output = Path(self._tempdir, "%(title).70s.%(ext)s").as_posix()

ydl_opts = {
"progress_hooks": [lambda d: self.download_hook(d)],
"outtmpl": output,
Expand Down

0 comments on commit 5d9a2ef

Please sign in to comment.