From 623451a4effbddf07f486965cd76b3b6ecc6480c Mon Sep 17 00:00:00 2001 From: Blondel MONDESIR Date: Fri, 5 Jul 2024 09:13:09 -0400 Subject: [PATCH 1/5] Fix regression due to ValueError in file uploading mechanism --- cps/editbooks.py | 2 -- 1 file changed, 2 deletions(-) diff --git a/cps/editbooks.py b/cps/editbooks.py index 5764be589f..ae8ad698a5 100644 --- a/cps/editbooks.py +++ b/cps/editbooks.py @@ -389,7 +389,6 @@ def move_mediafile(requested_file, current_user_name=None, shelf_id=None): db_book, input_authors, title_dir, - renamed_authors, ) = create_book_on_upload(modify_date, meta) # Comments need book id therefore only possible after flush @@ -406,7 +405,6 @@ def move_mediafile(requested_file, current_user_name=None, shelf_id=None): input_authors[0], meta.file_path, title_dir + meta.extension.lower(), - renamed_author=renamed_authors, ) move_coverfile(meta, db_book) From 991e39d176c086bce2e9df73b1e475f2b41584b3 Mon Sep 17 00:00:00 2001 From: Blondel MONDESIR Date: Fri, 5 Jul 2024 10:33:19 -0400 Subject: [PATCH 2/5] Adjust message for formerly "live" videos --- cps/tasks/download.py | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/cps/tasks/download.py b/cps/tasks/download.py index 50bbd8dfff..340118d649 100644 --- a/cps/tasks/download.py +++ b/cps/tasks/download.py @@ -15,7 +15,7 @@ log = logger.create() class TaskDownload(CalibreTask): - def __init__(self, task_message, media_url, original_url, current_user_name, shelf_id): + def __init__(self, task_message, media_url, original_url, current_user_name, shelf_id, duration, live_status): super(TaskDownload, self).__init__(task_message) self.message = task_message self.media_url = media_url @@ -23,6 +23,8 @@ def __init__(self, task_message, media_url, original_url, current_user_name, she self.original_url = original_url self.current_user_name = current_user_name self.shelf_id = shelf_id + self.duration = datetime.utcfromtimestamp(int(duration)).strftime("%H:%M:%S") if duration else "unknown" + self.live_status = live_status self.start_time = self.end_time = datetime.now() self.stat = STAT_WAITING self.progress = 0 @@ -54,6 +56,9 @@ def run(self, worker_thread): last_progress_time = datetime.now() fragment_stuck_timeout = 30 # seconds + self.message = f"Downloading {self.media_url_link}..." + if self.live_status == "was_live": + self.message += f" (This may take longer than expected due to the video was live for {self.duration})" while p.poll() is None: self.end_time = datetime.now() # Check if there's data available to read @@ -69,7 +74,6 @@ def run(self, worker_thread): elif re.search(pattern_progress, line): percentage = int(re.search(r'\d+', line).group()) if percentage < 100: - self.message = f"Downloading {self.media_url_link}..." self.progress = min(0.99, (complete_progress_cycle + (percentage / 100)) / 4) if percentage == 100: complete_progress_cycle += 1 @@ -77,7 +81,7 @@ def run(self, worker_thread): else: elapsed_time = (datetime.now() - last_progress_time).total_seconds() if elapsed_time >= fragment_stuck_timeout: - self.message = f"Downloading {self.media_url_link}... (This is taking longer than expected)" + self.message += f"
Some fragments are taking longer than expected to download. Please wait..." sleep(0.1) From b820d9ec8f2ff64a739cfd0cfeb0aa51178b746a Mon Sep 17 00:00:00 2001 From: Blondel MONDESIR Date: Fri, 5 Jul 2024 10:43:13 -0400 Subject: [PATCH 3/5] Display list of unavailable "live" videos --- cps/tasks/metadata_extract.py | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/cps/tasks/metadata_extract.py b/cps/tasks/metadata_extract.py index 5582ed4d8e..4a1a749a55 100644 --- a/cps/tasks/metadata_extract.py +++ b/cps/tasks/metadata_extract.py @@ -63,14 +63,14 @@ def _fetch_requested_urls(self, conn): try: cursor = conn.execute("PRAGMA table_info(media)") self.columns = [column[1] for column in cursor.fetchall()] - query = ("SELECT path, duration FROM media WHERE error IS NULL AND path LIKE 'http%'" + query = ("SELECT path, duration, live_status FROM media WHERE error IS NULL AND path LIKE 'http%'" if "error" in self.columns - else "SELECT path, duration FROM media WHERE path LIKE 'http%'") + else "SELECT path, duration, live_status FROM media WHERE path LIKE 'http%'") rows = conn.execute(query).fetchall() requested_urls = {} - for path, duration in rows: + for path, duration, live_status in rows: if duration is not None and duration > 0: - requested_urls[path] = {"duration": duration} + requested_urls[path] = {"duration": duration, "live_status": live_status} else: self.unavailable.append(path) return requested_urls @@ -140,6 +140,13 @@ def _add_download_tasks_to_worker(self, requested_urls): self.message += f"

Shelf Title: {self.shelf_title}" if self.unavailable: self.message += "

Unavailable Video(s):
" + "
".join(f'{url}' for url in self.unavailable) + upcoming_live_urls = [url for url, url_data in requested_urls.items() if url_data["live_status"] == "is_upcoming"] + live_urls = [url for url, url_data in requested_urls.items() if url_data["live_status"] == "is_live"] + if upcoming_live_urls: + self.message += "

Upcoming Live Video(s):
" + "
".join(f'{url}' for url in upcoming_live_urls) + if live_urls: + self.message += "

Live Video(s):
" + "
".join(f'{url}' for url in live_urls) + def run(self, worker_thread): self.worker_thread = worker_thread From 6a108bdc00a44644a0fb62a71c6bf3f9c6fda5cb Mon Sep 17 00:00:00 2001 From: Blondel MONDESIR Date: Fri, 5 Jul 2024 10:46:06 -0400 Subject: [PATCH 4/5] Send duration and live_status to the download task --- cps/tasks/metadata_extract.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/cps/tasks/metadata_extract.py b/cps/tasks/metadata_extract.py index 4a1a749a55..19998b6198 100644 --- a/cps/tasks/metadata_extract.py +++ b/cps/tasks/metadata_extract.py @@ -125,10 +125,10 @@ def _sort_and_limit_requested_urls(self, requested_urls): return dict(sorted(requested_urls.items(), key=lambda item: item[1]["views_per_day"], reverse=True)[:min(MAX_VIDEOS_PER_DOWNLOAD, len(requested_urls))]) def _add_download_tasks_to_worker(self, requested_urls): - for index, requested_url in enumerate(requested_urls.keys()): + for index, (requested_url, url_data) in enumerate(requested_urls.items()): task_download = TaskDownload(_("Downloading %(url)s...", url=requested_url), requested_url, self.original_url, - self.current_user_name, self.shelf_id) + self.current_user_name, self.shelf_id, duration=str(url_data["duration"]), live_status=url_data["live_status"]) WorkerThread.add(self.current_user_name, task_download) num_requested_urls = len(requested_urls) total_duration = sum(url_data["duration"] for url_data in requested_urls.values()) From d56f65b9abb2ed3a21ed5ea34db49205fd6666ff Mon Sep 17 00:00:00 2001 From: Blondel MONDESIR Date: Fri, 5 Jul 2024 12:33:17 -0400 Subject: [PATCH 5/5] Abbreviate message Co-authored-by: A Holt --- cps/tasks/download.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cps/tasks/download.py b/cps/tasks/download.py index 340118d649..1db4d694a3 100644 --- a/cps/tasks/download.py +++ b/cps/tasks/download.py @@ -58,7 +58,7 @@ def run(self, worker_thread): self.message = f"Downloading {self.media_url_link}..." if self.live_status == "was_live": - self.message += f" (This may take longer than expected due to the video was live for {self.duration})" + self.message += f" (formerly live video, length/duration is {self.duration} seconds)" while p.poll() is None: self.end_time = datetime.now() # Check if there's data available to read