updated music listing

This commit is contained in:
Alexander Karpov 2024-08-28 20:29:39 +03:00
parent b63beb8da8
commit 1fa8f1b9e3

View File

@ -31,16 +31,49 @@
@shared_task(soft_time_limit=60 * 60, time_limit=60 * 120) @shared_task(soft_time_limit=60 * 60, time_limit=60 * 120)
def list_tracks(url, user_id): def list_tracks(url, user_id):
if "music.youtube.com" in url or "youtu.be" in url: url = normalize_url(url)
url = url.replace("music.youtube.com", "youtube.com")
url = url.replace("youtu.be", "youtube.com") handlers = {
if "spotify.com" in url: "spotify.com": handle_spotify,
"music.yandex.ru": handle_yandex,
"youtube.com": handle_youtube,
}
for domain, handler in handlers.items():
if domain in url:
return handler(url, user_id)
print("failed to find handler, falling back to search")
return fallback_search(url, user_id)
def normalize_url(url):
return url.replace("music.youtube.com", "youtube.com").replace(
"youtu.be", "youtube.com"
)
def handle_spotify(url, user_id):
spotify.download_url(url, user_id) spotify.download_url(url, user_id)
elif "music.yandex.ru" in url: return url
def handle_yandex(url, user_id):
yandex.load_url(url, user_id) yandex.load_url(url, user_id)
if "youtube.com" in url: return url
def handle_youtube(url, user_id):
if "channel" in url or "/c/" in url: if "channel" in url or "/c/" in url:
ytmusic = ytmusicapi.YTMusic() return handle_youtube_channel(url, user_id)
elif "playlist" in url or "&list=" in url:
return handle_youtube_playlist(url, user_id)
else:
process_yb.apply_async(kwargs={"url": url, "user_id": user_id})
return url
def handle_youtube_channel(url, user_id):
ytmusic = YTMusic()
channel_id = url.split("/")[-1] channel_id = url.split("/")[-1]
channel_songs = ytmusic.get_artist(channel_id)["songs"]["results"] channel_songs = ytmusic.get_artist(channel_id)["songs"]["results"]
@ -51,22 +84,20 @@ def list_tracks(url, user_id):
"user_id": user_id, "user_id": user_id,
} }
) )
return url
elif "playlist" in url or "&list=" in url:
ytmusic = ytmusicapi.YTMusic()
# Parse the URL and the query string def handle_youtube_playlist(url, user_id):
ytmusic = YTMusic()
parsed_url = urlparse(url) parsed_url = urlparse(url)
parsed_qs = parse_qs(parsed_url.query) parsed_qs = parse_qs(parsed_url.query)
# Get the playlist ID from the parsed query string
playlist_id = parsed_qs.get("list", [None])[0] playlist_id = parsed_qs.get("list", [None])[0]
if playlist_id: if not playlist_id:
raise ValueError("No playlist ID found in the URL.")
playlist_songs = ytmusic.get_playlist(playlist_id)["tracks"] playlist_songs = ytmusic.get_playlist(playlist_id)["tracks"]
else:
raise ValueError("No playlist ID found in the URL.")
for song in playlist_songs: for song in playlist_songs:
process_yb.apply_async( process_yb.apply_async(
kwargs={ kwargs={
@ -74,9 +105,10 @@ def list_tracks(url, user_id):
"user_id": user_id, "user_id": user_id,
} }
) )
else: return url
process_yb.apply_async(kwargs={"url": url, "user_id": user_id})
else:
def fallback_search(url, user_id):
spotify_manager = SpotifyClientCredentials( spotify_manager = SpotifyClientCredentials(
client_id=settings.MUSIC_SPOTIFY_ID, client_id=settings.MUSIC_SPOTIFY_ID,
client_secret=settings.MUSIC_SPOTIFY_SECRET, client_secret=settings.MUSIC_SPOTIFY_SECRET,
@ -84,13 +116,12 @@ def list_tracks(url, user_id):
spotify_search = spotipy.Spotify(client_credentials_manager=spotify_manager) spotify_search = spotipy.Spotify(client_credentials_manager=spotify_manager)
results = spotify_search.search(q=url, type="track", limit=1) results = spotify_search.search(q=url, type="track", limit=1)
top_track = ( top_track = results["tracks"]["items"][0] if results["tracks"]["items"] else None
results["tracks"]["items"][0] if results["tracks"]["items"] else None
)
if top_track: if top_track:
spotify.download_url(top_track["external_urls"]["spotify"], user_id) spotify_url = top_track["external_urls"]["spotify"]
url = top_track["external_urls"]["spotify"] spotify.download_url(spotify_url, user_id)
return spotify_url
return url return url