More config options (tmpl, yt_proxy) + notes

This commit is contained in:
DarkCat09 2024-05-04 10:27:57 +04:00
parent 0cbb9d424e
commit 96be306b2b
Signed by: DarkCat09
GPG key ID: 0A26CD5B3345D6E3
3 changed files with 23 additions and 6 deletions

View file

@ -1,7 +1,10 @@
.PHONY: run test build frontend backend .PHONY: run test build frontend backend
run: run:
HOST=127.0.0.1 PORT=4009 COOKIES_DIR=cookies python3 ./backend/main.py # See backend/config.py for more fields
HOST=127.0.0.1 PORT=4009 \
COOKIES_DIR=cookies \
python3 ./backend/main.py
test: test:
@python3 -m unittest discover -vcs ./backend @python3 -m unittest discover -vcs ./backend

View file

@ -8,9 +8,24 @@ class Config:
self.host = os.getenv('HOST') or '0.0.0.0' self.host = os.getenv('HOST') or '0.0.0.0'
self.port = int(os.getenv('PORT') or 4009) self.port = int(os.getenv('PORT') or 4009)
self.path_length = int(os.getenv('PATH_LENGTH') or 255)
# This directory will be searched for <site>.txt (e.g. yandex.txt)
# Cookies are in Netscape CSV format, see yt-dlp docs
self.cookies_dir = Path(os.getenv('COOKIES_DIR') or 'cookies') self.cookies_dir = Path(os.getenv('COOKIES_DIR') or 'cookies')
# Note: yt-dlp's path trimmer also counts album_path_tmpl, not only filename
# Why 235? 255 is the ext4 limit. 255 - len("/var/lib/musicdlp/") = 237, rounded down to 235
self.path_length = int(os.getenv('PATH_LENGTH') or 235)
self.tmpl = os.path.join(
# `artists.0` instead of `artist`, because the latter can contain "feat. ..."
os.getenv('ALBUM_PATH_TMPL') or 'music/%(artists.0)s/%(album)s',
os.getenv('TRACK_FILE_TMPL') or '%(track)s.%(ext)s',
)
# Proxy URL for yt_proxied downloader (can be used for geo-restricted content)
self.yt_proxy = os.getenv('YT_PROXY') or 'http://127.0.0.1:1080'
_config: Config | None = None _config: Config | None = None

View file

@ -17,7 +17,7 @@ class _CreateYDL:
@staticmethod @staticmethod
def yt_proxied() -> YoutubeDL: def yt_proxied() -> YoutubeDL:
ydl = _CreateYDL.youtube() ydl = _CreateYDL.youtube()
ydl.params['proxy'] = 'http://127.0.0.1:1080' # TODO ydl.params['proxy'] = config.get().yt_proxy
return ydl return ydl
@staticmethod @staticmethod
@ -52,9 +52,8 @@ class Downloaders:
if ydl is None: if ydl is None:
ydl = create_ydl_fn[site]() ydl = create_ydl_fn[site]()
ydl.params['trim_file_name'] = cfg.path_length # NOTE: includes path, not only filename ydl.params['trim_file_name'] = cfg.path_length # Note: not only filename, but path in outtmpl
# artists.0 instead of artist, because it can contain "feat. ..." ydl.params['outtmpl']['default'] = cfg.tmpl
ydl.params['outtmpl']['default'] = 'music/%(artists.0)s/%(album)s/%(track)s.%(ext)s'
ydl.add_post_processor(id3pp.ID3TagsPP(), when='post_process') ydl.add_post_processor(id3pp.ID3TagsPP(), when='post_process')
cookies = cfg.cookies_dir / (site + '.txt') cookies = cfg.cookies_dir / (site + '.txt')