Mixonomer/music/tasks/run_user_playlist.py

93 lines
3.4 KiB
Python
Raw Normal View History

from google.cloud import firestore
import datetime
import logging
from spotframework.engine.playlistengine import PlaylistEngine, PlaylistSource, RecommendationSource, LibraryTrackSource
from spotframework.engine.processor.shuffle import Shuffle
from spotframework.engine.processor.sort import SortReleaseDate
from spotframework.engine.processor.deduplicate import DeduplicateByID
2019-09-15 15:33:29 +01:00
from spotframework.model.uri import Uri
2019-10-19 17:14:11 +01:00
import music.db.database as database
from music.db.part_generator import PartGenerator
2019-10-23 14:44:17 +01:00
from music.model.playlist import RecentsPlaylist
db = firestore.Client()
logger = logging.getLogger(__name__)
def run_user_playlist(username, playlist_name):
2019-10-23 14:44:17 +01:00
user = database.get_user(username)
logger.info(f'running {username} / {playlist_name}')
2019-10-23 14:44:17 +01:00
if user:
2019-10-23 14:44:17 +01:00
playlist = database.get_playlist(username=username, name=playlist_name)
2019-10-23 14:44:17 +01:00
if playlist is not None:
2019-10-23 14:44:17 +01:00
if playlist.uri is None:
logger.critical(f'no playlist id to populate ({username}/{playlist_name})')
return None
2019-10-23 14:44:17 +01:00
if len(playlist.parts) == 0 and len(playlist.playlist_references) == 0:
logger.critical(f'no playlists to use for creation ({username}/{playlist_name})')
return None
net = database.get_authed_spotify_network(username)
engine = PlaylistEngine(net)
processors = [DeduplicateByID()]
2019-10-23 14:44:17 +01:00
if playlist.shuffle is True:
processors.append(Shuffle())
else:
processors.append(SortReleaseDate(reverse=True))
2019-10-23 14:44:17 +01:00
part_generator = PartGenerator(user=user)
submit_parts = part_generator.get_recursive_parts(playlist.name)
params = [
PlaylistSource.Params(names=submit_parts)
]
2019-10-23 14:44:17 +01:00
if playlist.include_recommendations:
params.append(RecommendationSource.Params(recommendation_limit=playlist.recommendation_sample))
2019-10-23 14:44:17 +01:00
if playlist.include_library_tracks:
params.append(LibraryTrackSource.Params())
2019-10-23 14:44:17 +01:00
if isinstance(playlist, RecentsPlaylist):
2019-09-15 15:33:29 +01:00
boundary_date = datetime.datetime.now(datetime.timezone.utc) - \
2019-10-23 14:44:17 +01:00
datetime.timedelta(days=int(playlist.day_boundary))
tracks = engine.get_recent_playlist(params=params,
processors=processors,
boundary_date=boundary_date,
2019-10-23 14:44:17 +01:00
add_this_month=playlist.add_this_month,
add_last_month=playlist.add_last_month)
else:
tracks = engine.make_playlist(params=params,
processors=processors)
2019-10-23 14:44:17 +01:00
engine.execute_playlist(tracks, Uri(playlist.uri))
2019-10-23 14:44:17 +01:00
overwrite = playlist.description_overwrite
suffix = playlist.description_suffix
engine.change_description(sorted(submit_parts),
2019-10-23 14:44:17 +01:00
uri=Uri(playlist.uri),
overwrite=overwrite,
suffix=suffix)
else:
2019-10-23 14:44:17 +01:00
logger.critical(f'playlist not found ({username}/{playlist_name})')
return None
else:
2019-10-23 14:44:17 +01:00
logger.critical(f'{username} not found')