mirror of
https://github.com/tubearchivist/tubearchivist.git
synced 2025-01-04 16:00:13 +00:00
various finetuning, RC, #build
Changed: - Added auto tag to download queue item - Add filesystem rescan before stream extract migration - Add channel tags to search results - Fix migration notification logic - Fix filesystem rescan without task
This commit is contained in:
commit
e94e11c456
@ -11,6 +11,7 @@ from django.core.management.base import BaseCommand, CommandError
|
|||||||
from home.src.es.connect import ElasticWrap, IndexPaginate
|
from home.src.es.connect import ElasticWrap, IndexPaginate
|
||||||
from home.src.es.index_setup import ElasitIndexWrap
|
from home.src.es.index_setup import ElasitIndexWrap
|
||||||
from home.src.es.snapshot import ElasticSnapshot
|
from home.src.es.snapshot import ElasticSnapshot
|
||||||
|
from home.src.index.filesystem import Filesystem
|
||||||
from home.src.index.video_streams import MediaStreamExtractor
|
from home.src.index.video_streams import MediaStreamExtractor
|
||||||
from home.src.ta.config import AppConfig, ReleaseVersion
|
from home.src.ta.config import AppConfig, ReleaseVersion
|
||||||
from home.src.ta.helper import clear_dl_cache
|
from home.src.ta.helper import clear_dl_cache
|
||||||
@ -162,6 +163,8 @@ class Command(BaseCommand):
|
|||||||
self.stdout.write(" no videos need updating")
|
self.stdout.write(" no videos need updating")
|
||||||
return
|
return
|
||||||
|
|
||||||
|
self.stdout.write(" start filesystem rescan")
|
||||||
|
Filesystem().process()
|
||||||
total = len(all_missing)
|
total = len(all_missing)
|
||||||
for idx, missing in enumerate(all_missing):
|
for idx, missing in enumerate(all_missing):
|
||||||
media_url = missing["media_url"]
|
media_url = missing["media_url"]
|
||||||
@ -201,17 +204,17 @@ class Command(BaseCommand):
|
|||||||
response, status_code = ElasticWrap(path).post(data=data)
|
response, status_code = ElasticWrap(path).post(data=data)
|
||||||
if status_code == 200:
|
if status_code == 200:
|
||||||
updated = response.get("updated", 0)
|
updated = response.get("updated", 0)
|
||||||
if not updated:
|
if updated:
|
||||||
self.stdout.write(
|
|
||||||
" no videos needed updating in ta_download"
|
|
||||||
)
|
|
||||||
return
|
|
||||||
|
|
||||||
self.stdout.write(
|
self.stdout.write(
|
||||||
self.style.SUCCESS(
|
self.style.SUCCESS(
|
||||||
f" ✓ {updated} videos updated in ta_download"
|
f" ✓ {updated} videos updated in ta_download"
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
else:
|
||||||
|
self.stdout.write(
|
||||||
|
" no videos needed updating in ta_download"
|
||||||
|
)
|
||||||
|
return
|
||||||
|
|
||||||
message = " 🗙 ta_download auto_start update failed"
|
message = " 🗙 ta_download auto_start update failed"
|
||||||
self.stdout.write(self.style.ERROR(message))
|
self.stdout.write(self.style.ERROR(message))
|
||||||
|
@ -391,6 +391,7 @@ class QueryBuilder:
|
|||||||
"channel_name._2gram^2",
|
"channel_name._2gram^2",
|
||||||
"channel_name._3gram^2",
|
"channel_name._3gram^2",
|
||||||
"channel_name.search_as_you_type^2",
|
"channel_name.search_as_you_type^2",
|
||||||
|
"channel_tags",
|
||||||
],
|
],
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -47,13 +47,13 @@ class YoutubeChannel(YouTubeItem):
|
|||||||
if not self.youtube_meta and fallback:
|
if not self.youtube_meta and fallback:
|
||||||
self._video_fallback(fallback)
|
self._video_fallback(fallback)
|
||||||
else:
|
else:
|
||||||
self._process_youtube_meta()
|
self.process_youtube_meta()
|
||||||
self.get_channel_art()
|
self.get_channel_art()
|
||||||
|
|
||||||
if upload:
|
if upload:
|
||||||
self.upload_to_es()
|
self.upload_to_es()
|
||||||
|
|
||||||
def _process_youtube_meta(self):
|
def process_youtube_meta(self):
|
||||||
"""extract relevant fields"""
|
"""extract relevant fields"""
|
||||||
self.youtube_meta["thumbnails"].reverse()
|
self.youtube_meta["thumbnails"].reverse()
|
||||||
channel_subs = self.youtube_meta.get("channel_follower_count") or 0
|
channel_subs = self.youtube_meta.get("channel_follower_count") or 0
|
||||||
|
@ -127,6 +127,7 @@ class Filesystem(ScannerBase):
|
|||||||
|
|
||||||
def process(self):
|
def process(self):
|
||||||
"""entry point"""
|
"""entry point"""
|
||||||
|
if self.task:
|
||||||
self.task.send_progress(["Scanning your archive and index."])
|
self.task.send_progress(["Scanning your archive and index."])
|
||||||
self.scan()
|
self.scan()
|
||||||
self.rename_files()
|
self.rename_files()
|
||||||
@ -140,6 +141,7 @@ class Filesystem(ScannerBase):
|
|||||||
return
|
return
|
||||||
|
|
||||||
total = len(self.to_rename)
|
total = len(self.to_rename)
|
||||||
|
if self.task:
|
||||||
self.task.send_progress([f"Rename {total} media files."])
|
self.task.send_progress([f"Rename {total} media files."])
|
||||||
for bad_filename in self.to_rename:
|
for bad_filename in self.to_rename:
|
||||||
channel, filename, expected_filename = bad_filename
|
channel, filename, expected_filename = bad_filename
|
||||||
@ -154,6 +156,7 @@ class Filesystem(ScannerBase):
|
|||||||
return
|
return
|
||||||
|
|
||||||
total = len(self.mismatch)
|
total = len(self.mismatch)
|
||||||
|
if self.task:
|
||||||
self.task.send_progress([f"Fix media urls for {total} files"])
|
self.task.send_progress([f"Fix media urls for {total} files"])
|
||||||
bulk_list = []
|
bulk_list = []
|
||||||
for video_mismatch in self.mismatch:
|
for video_mismatch in self.mismatch:
|
||||||
@ -174,6 +177,7 @@ class Filesystem(ScannerBase):
|
|||||||
return
|
return
|
||||||
|
|
||||||
total = len(self.to_delete)
|
total = len(self.to_delete)
|
||||||
|
if self.task:
|
||||||
self.task.send_progress([f"Clean up {total} items from index."])
|
self.task.send_progress([f"Clean up {total} items from index."])
|
||||||
for indexed in self.to_delete:
|
for indexed in self.to_delete:
|
||||||
youtube_id = indexed[0]
|
youtube_id = indexed[0]
|
||||||
|
@ -331,23 +331,29 @@ class Reindex(ReindexBase):
|
|||||||
@staticmethod
|
@staticmethod
|
||||||
def _reindex_single_channel(channel_id):
|
def _reindex_single_channel(channel_id):
|
||||||
"""refresh channel data and sync to videos"""
|
"""refresh channel data and sync to videos"""
|
||||||
|
# read current state
|
||||||
channel = YoutubeChannel(channel_id)
|
channel = YoutubeChannel(channel_id)
|
||||||
channel.get_from_es()
|
channel.get_from_es()
|
||||||
subscribed = channel.json_data["channel_subscribed"]
|
es_meta = channel.json_data.copy()
|
||||||
overwrites = channel.json_data.get("channel_overwrites", False)
|
|
||||||
|
# get new
|
||||||
channel.get_from_youtube()
|
channel.get_from_youtube()
|
||||||
if not channel.json_data:
|
if not channel.youtube_meta:
|
||||||
channel.deactivate()
|
channel.deactivate()
|
||||||
channel.get_from_es()
|
channel.get_from_es()
|
||||||
channel.sync_to_videos()
|
channel.sync_to_videos()
|
||||||
return
|
return
|
||||||
|
|
||||||
channel.json_data["channel_subscribed"] = subscribed
|
channel.process_youtube_meta()
|
||||||
|
channel.get_channel_art()
|
||||||
|
|
||||||
|
# add back
|
||||||
|
channel.json_data["channel_subscribed"] = es_meta["channel_subscribed"]
|
||||||
|
overwrites = es_meta.get("channel_overwrites")
|
||||||
if overwrites:
|
if overwrites:
|
||||||
channel.json_data["channel_overwrites"] = overwrites
|
channel.json_data["channel_overwrites"] = overwrites
|
||||||
channel.upload_to_es()
|
|
||||||
channel.sync_to_videos()
|
|
||||||
|
|
||||||
|
channel.upload_to_es()
|
||||||
ChannelFullScan(channel_id).scan()
|
ChannelFullScan(channel_id).scan()
|
||||||
|
|
||||||
def _reindex_single_playlist(self, playlist_id):
|
def _reindex_single_playlist(self, playlist_id):
|
||||||
|
@ -81,6 +81,9 @@
|
|||||||
<span>queued</span>
|
<span>queued</span>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
<span>{{ video.source.vid_type }}</span>
|
<span>{{ video.source.vid_type }}</span>
|
||||||
|
{% if video.source.auto_start %}
|
||||||
|
<span>auto</span>
|
||||||
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -413,7 +413,10 @@ class DownloadView(ArchivistResultsView):
|
|||||||
self.data.update(
|
self.data.update(
|
||||||
{
|
{
|
||||||
"query": {"bool": {"must": must_list}},
|
"query": {"bool": {"must": must_list}},
|
||||||
"sort": [{"timestamp": {"order": "asc"}}],
|
"sort": [
|
||||||
|
{"auto_start": {"order": "desc"}},
|
||||||
|
{"timestamp": {"order": "asc"}},
|
||||||
|
],
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user