2020-02-03 23:37:18 +00:00
|
|
|
from flask import Blueprint, request, jsonify
|
2020-04-30 14:54:05 +01:00
|
|
|
from google.cloud import firestore
|
|
|
|
from werkzeug.security import generate_password_hash
|
2019-08-08 12:25:53 +01:00
|
|
|
|
2019-08-12 00:34:04 +01:00
|
|
|
import os
|
2019-08-08 12:25:53 +01:00
|
|
|
import json
|
2019-08-17 18:30:13 +01:00
|
|
|
import logging
|
2020-02-24 18:15:38 +00:00
|
|
|
from datetime import datetime
|
2019-08-08 12:25:53 +01:00
|
|
|
|
2019-10-19 17:14:11 +01:00
|
|
|
from music.api.decorators import login_required, login_or_basic_auth, admin_required, gae_cron, cloud_task
|
2020-06-30 16:38:06 +01:00
|
|
|
from music.cloud import queue_run_user_playlist, offload_or_run_user_playlist
|
|
|
|
from music.cloud.tasks import update_all_user_playlists, update_playlists
|
2020-06-21 15:30:51 +01:00
|
|
|
from music.tasks.run_user_playlist import run_user_playlist
|
2019-08-10 17:53:50 +01:00
|
|
|
|
2020-04-30 14:54:05 +01:00
|
|
|
from music.model.user import User
|
|
|
|
from music.model.playlist import Playlist
|
|
|
|
|
2019-10-19 17:14:11 +01:00
|
|
|
import music.db.database as database
|
2019-07-31 12:24:10 +01:00
|
|
|
|
2020-06-22 20:21:54 +01:00
|
|
|
from spotframework.net.network import SpotifyNetworkException
|
|
|
|
|
2019-07-29 11:44:10 +01:00
|
|
|
blueprint = Blueprint('api', __name__)
|
|
|
|
db = firestore.Client()
|
2019-08-17 18:30:13 +01:00
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
2019-07-29 11:44:10 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
@blueprint.route('/playlists', methods=['GET'])
|
2019-09-25 19:28:38 +01:00
|
|
|
@login_or_basic_auth
|
2020-05-15 23:25:19 +01:00
|
|
|
def all_playlists_route(user=None):
|
2020-04-30 14:54:05 +01:00
|
|
|
assert user is not None
|
2019-10-23 14:44:17 +01:00
|
|
|
return jsonify({
|
2020-04-30 14:54:05 +01:00
|
|
|
'playlists': [i.to_dict() for i in Playlist.collection.parent(user.key).fetch()]
|
2019-10-23 14:44:17 +01:00
|
|
|
}), 200
|
2019-07-31 20:31:01 +01:00
|
|
|
|
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
@blueprint.route('/playlist', methods=['GET', 'POST', 'PUT', 'DELETE'])
|
2019-09-25 19:28:38 +01:00
|
|
|
@login_or_basic_auth
|
2020-04-30 14:54:05 +01:00
|
|
|
def playlist_route(user=None):
|
2019-07-30 16:25:01 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if request.method == 'GET' or request.method == 'DELETE':
|
|
|
|
playlist_name = request.args.get('name', None)
|
2019-07-30 16:25:01 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if playlist_name:
|
2020-04-30 14:54:05 +01:00
|
|
|
playlist = Playlist.collection.parent(user.key).filter('name', '==', playlist_name).get()
|
2019-07-30 16:25:01 +01:00
|
|
|
|
2020-04-30 14:54:05 +01:00
|
|
|
if playlist is None:
|
|
|
|
return jsonify({'error': f'playlist {playlist_name} not found'}), 404
|
2019-07-30 16:25:01 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if request.method == "GET":
|
2020-04-30 14:54:05 +01:00
|
|
|
return jsonify(playlist.to_dict()), 200
|
2019-09-12 09:59:00 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
elif request.method == 'DELETE':
|
2020-04-30 14:54:05 +01:00
|
|
|
Playlist.collection.parent(user.key).delete(key=playlist.key)
|
2019-09-16 02:22:58 +01:00
|
|
|
return jsonify({"message": 'playlist deleted', "status": "success"}), 200
|
2019-07-31 12:24:10 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
else:
|
|
|
|
return jsonify({"error": 'no name requested'}), 400
|
2019-08-05 18:29:46 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
elif request.method == 'POST' or request.method == 'PUT':
|
2019-07-31 12:24:10 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
request_json = request.get_json()
|
2019-07-31 12:24:10 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if 'name' not in request_json:
|
|
|
|
return jsonify({'error': "no name provided"}), 400
|
2019-07-31 12:24:10 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
playlist_name = request_json['name']
|
2019-07-31 12:24:10 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
playlist_parts = request_json.get('parts', None)
|
2019-08-02 12:54:18 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
playlist_references = []
|
2019-08-03 12:10:24 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if request_json.get('playlist_references', None):
|
|
|
|
if request_json['playlist_references'] != -1:
|
|
|
|
for i in request_json['playlist_references']:
|
2019-10-23 14:44:17 +01:00
|
|
|
|
2020-04-30 14:54:05 +01:00
|
|
|
updating_playlist = Playlist.collection.parent(user.key).filter('name', '==', i).get()
|
2019-10-23 14:44:17 +01:00
|
|
|
if updating_playlist is not None:
|
2020-04-30 14:54:05 +01:00
|
|
|
playlist_references.append(db.document(updating_playlist.key))
|
2019-09-16 02:22:58 +01:00
|
|
|
else:
|
|
|
|
return jsonify({"message": f'managed playlist {i} not found', "status": "error"}), 400
|
2019-08-03 21:35:08 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if len(playlist_references) == 0 and request_json.get('playlist_references', None) != -1:
|
|
|
|
playlist_references = None
|
2019-08-03 12:10:24 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
playlist_uri = request_json.get('uri', None)
|
|
|
|
playlist_shuffle = request_json.get('shuffle', None)
|
|
|
|
playlist_type = request_json.get('type', None)
|
2019-07-31 12:24:10 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
playlist_day_boundary = request_json.get('day_boundary', None)
|
|
|
|
playlist_add_this_month = request_json.get('add_this_month', None)
|
|
|
|
playlist_add_last_month = request_json.get('add_last_month', None)
|
2019-07-31 12:24:10 +01:00
|
|
|
|
2019-11-01 23:46:49 +00:00
|
|
|
playlist_library_tracks = request_json.get('include_library_tracks', None)
|
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
playlist_recommendation = request_json.get('include_recommendations', None)
|
|
|
|
playlist_recommendation_sample = request_json.get('recommendation_sample', None)
|
2019-07-31 12:24:10 +01:00
|
|
|
|
2019-11-01 23:46:49 +00:00
|
|
|
playlist_chart_range = request_json.get('chart_range', None)
|
|
|
|
playlist_chart_limit = request_json.get('chart_limit', None)
|
|
|
|
|
2020-04-30 14:54:05 +01:00
|
|
|
playlist = Playlist.collection.parent(user.key).filter('name', '==', playlist_name).get()
|
2019-07-30 16:25:01 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if request.method == 'PUT':
|
2019-07-31 12:24:10 +01:00
|
|
|
|
2020-04-30 14:54:05 +01:00
|
|
|
if playlist is not None:
|
2019-09-16 02:22:58 +01:00
|
|
|
return jsonify({'error': 'playlist already exists'}), 400
|
2019-07-31 12:24:10 +01:00
|
|
|
|
2020-06-21 15:30:51 +01:00
|
|
|
from music.tasks.create_playlist import create_playlist
|
2019-07-31 12:24:10 +01:00
|
|
|
|
2020-04-30 14:54:05 +01:00
|
|
|
new_db_playlist = Playlist(parent=user.key)
|
|
|
|
|
|
|
|
new_db_playlist.name = playlist_name
|
|
|
|
new_db_playlist.parts = playlist_parts
|
|
|
|
new_db_playlist.playlist_references = playlist_references
|
|
|
|
|
|
|
|
new_db_playlist.include_library_tracks = playlist_library_tracks
|
|
|
|
new_db_playlist.include_recommendations = playlist_recommendation
|
|
|
|
new_db_playlist.recommendation_sample = playlist_recommendation_sample
|
|
|
|
|
|
|
|
new_db_playlist.shuffle = playlist_shuffle
|
|
|
|
|
|
|
|
new_db_playlist.type = playlist_type
|
|
|
|
new_db_playlist.last_updated = datetime.utcnow()
|
|
|
|
new_db_playlist.lastfm_stat_last_refresh = datetime.utcnow()
|
|
|
|
|
|
|
|
new_db_playlist.day_boundary = playlist_day_boundary
|
|
|
|
new_db_playlist.add_this_month = playlist_add_this_month
|
|
|
|
new_db_playlist.add_last_month = playlist_add_last_month
|
|
|
|
|
|
|
|
new_db_playlist.chart_range = playlist_chart_range
|
|
|
|
new_db_playlist.chart_limit = playlist_chart_limit
|
|
|
|
|
|
|
|
if user.spotify_linked:
|
|
|
|
new_playlist = create_playlist(user, playlist_name)
|
|
|
|
new_db_playlist.uri = str(new_playlist.uri)
|
|
|
|
|
|
|
|
new_db_playlist.save()
|
|
|
|
logger.info(f'added {user.username} / {playlist_name}')
|
2019-08-03 12:10:24 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
return jsonify({"message": 'playlist added', "status": "success"}), 201
|
2019-08-17 18:30:13 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
elif request.method == 'POST':
|
2019-08-17 18:30:13 +01:00
|
|
|
|
2020-04-30 14:54:05 +01:00
|
|
|
if playlist is None:
|
2019-09-16 02:22:58 +01:00
|
|
|
return jsonify({'error': "playlist doesn't exist"}), 400
|
2019-08-05 18:29:46 +01:00
|
|
|
|
2020-04-30 14:54:05 +01:00
|
|
|
updating_playlist = Playlist.collection.parent(user.key).filter('name', '==', playlist_name).get()
|
2019-08-05 21:43:09 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if playlist_parts is not None:
|
|
|
|
if playlist_parts == -1:
|
2020-04-30 14:54:05 +01:00
|
|
|
updating_playlist.parts = []
|
2019-09-16 02:22:58 +01:00
|
|
|
else:
|
2020-04-30 14:54:05 +01:00
|
|
|
updating_playlist.parts = playlist_parts
|
2019-07-31 12:24:10 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if playlist_references is not None:
|
|
|
|
if playlist_references == -1:
|
2020-04-30 14:54:05 +01:00
|
|
|
updating_playlist.playlist_references = []
|
2019-09-16 02:22:58 +01:00
|
|
|
else:
|
2020-04-30 14:54:05 +01:00
|
|
|
updating_playlist.playlist_references = playlist_references
|
2019-07-29 11:44:10 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if playlist_uri is not None:
|
2020-04-30 14:54:05 +01:00
|
|
|
updating_playlist.uri = playlist_uri
|
2019-07-29 11:44:10 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if playlist_shuffle is not None:
|
2020-04-30 14:54:05 +01:00
|
|
|
updating_playlist.shuffle = playlist_shuffle
|
2019-07-29 11:44:10 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if playlist_day_boundary is not None:
|
2020-04-30 14:54:05 +01:00
|
|
|
updating_playlist.day_boundary = playlist_day_boundary
|
2019-07-29 11:44:10 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if playlist_add_this_month is not None:
|
2020-04-30 14:54:05 +01:00
|
|
|
updating_playlist.add_this_month = playlist_add_this_month
|
2019-07-29 11:44:10 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if playlist_add_last_month is not None:
|
2020-04-30 14:54:05 +01:00
|
|
|
updating_playlist.add_last_month = playlist_add_last_month
|
2019-07-29 11:44:10 +01:00
|
|
|
|
2019-11-01 23:46:49 +00:00
|
|
|
if playlist_library_tracks is not None:
|
2020-04-30 14:54:05 +01:00
|
|
|
updating_playlist.include_library_tracks = playlist_library_tracks
|
2019-11-01 23:46:49 +00:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if playlist_recommendation is not None:
|
2020-04-30 14:54:05 +01:00
|
|
|
updating_playlist.include_recommendations = playlist_recommendation
|
2019-08-03 21:35:08 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if playlist_recommendation_sample is not None:
|
2020-04-30 14:54:05 +01:00
|
|
|
updating_playlist.recommendation_sample = playlist_recommendation_sample
|
2019-08-03 21:35:08 +01:00
|
|
|
|
2019-11-01 23:46:49 +00:00
|
|
|
if playlist_chart_range is not None:
|
2020-04-30 14:54:05 +01:00
|
|
|
updating_playlist.chart_range = playlist_chart_range
|
2019-11-01 23:46:49 +00:00
|
|
|
|
|
|
|
if playlist_chart_limit is not None:
|
2020-04-30 14:54:05 +01:00
|
|
|
updating_playlist.chart_limit = playlist_chart_limit
|
2019-11-01 23:46:49 +00:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if playlist_type is not None:
|
2020-05-15 23:25:19 +01:00
|
|
|
playlist_type = playlist_type.strip().lower()
|
|
|
|
if playlist_type in ['default', 'recents', 'fmchart']:
|
|
|
|
updating_playlist.type = playlist_type
|
2019-08-03 21:35:08 +01:00
|
|
|
|
2020-04-30 14:54:05 +01:00
|
|
|
updating_playlist.update()
|
|
|
|
logger.info(f'updated {user.username} / {playlist_name}')
|
2019-08-03 21:35:08 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
return jsonify({"message": 'playlist updated', "status": "success"}), 200
|
2019-08-03 21:35:08 +01:00
|
|
|
|
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
@blueprint.route('/user', methods=['GET', 'POST'])
|
2019-09-25 19:28:38 +01:00
|
|
|
@login_or_basic_auth
|
2020-04-30 14:54:05 +01:00
|
|
|
def user_route(user=None):
|
|
|
|
assert user is not None
|
2019-08-03 21:35:08 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if request.method == 'GET':
|
2020-04-30 14:54:05 +01:00
|
|
|
return jsonify(user.to_dict()), 200
|
2019-08-05 21:43:09 +01:00
|
|
|
|
2020-04-30 14:54:05 +01:00
|
|
|
else: # POST
|
2019-09-16 02:22:58 +01:00
|
|
|
request_json = request.get_json()
|
2019-08-03 21:35:08 +01:00
|
|
|
|
2019-10-19 17:57:56 +01:00
|
|
|
if 'username' in request_json:
|
2020-04-30 14:54:05 +01:00
|
|
|
if request_json['username'].strip().lower() != user.username:
|
|
|
|
if user.type != "admin":
|
|
|
|
return jsonify({'status': 'error', 'message': 'unauthorized'}), 401
|
2019-08-03 21:35:08 +01:00
|
|
|
|
2020-04-30 14:54:05 +01:00
|
|
|
user = User.collection.filter('username', '==', request_json['username'].strip().lower()).get()
|
2019-08-03 21:35:08 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if 'locked' in request_json:
|
2020-04-30 14:54:05 +01:00
|
|
|
if user.type == "admin":
|
|
|
|
logger.info(f'updating lock {user.username} / {request_json["locked"]}')
|
|
|
|
user.locked = request_json['locked']
|
2019-08-03 21:35:08 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if 'spotify_linked' in request_json:
|
2020-04-30 14:54:05 +01:00
|
|
|
logger.info(f'deauthing {user.username}')
|
2019-09-16 02:22:58 +01:00
|
|
|
if request_json['spotify_linked'] is False:
|
2020-04-30 14:54:05 +01:00
|
|
|
user.access_token = None
|
|
|
|
user.refresh_token = None
|
|
|
|
user.spotify_linked = False
|
2019-07-29 11:44:10 +01:00
|
|
|
|
2019-10-19 17:57:56 +01:00
|
|
|
if 'lastfm_username' in request_json:
|
2020-04-30 14:54:05 +01:00
|
|
|
logger.info(f'updating lastfm username {user.username} -> {request_json["lastfm_username"]}')
|
|
|
|
user.lastfm_username = request_json['lastfm_username']
|
|
|
|
|
|
|
|
user.update()
|
2019-08-03 21:35:08 +01:00
|
|
|
|
2020-04-30 14:54:05 +01:00
|
|
|
logger.info(f'updated {user.username}')
|
2019-08-03 21:35:08 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
return jsonify({'message': 'account updated', 'status': 'succeeded'}), 200
|
2019-08-03 21:35:08 +01:00
|
|
|
|
2019-07-30 16:25:01 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
@blueprint.route('/users', methods=['GET'])
|
2019-09-30 14:19:00 +01:00
|
|
|
@login_or_basic_auth
|
2019-09-16 02:22:58 +01:00
|
|
|
@admin_required
|
2020-05-15 23:25:19 +01:00
|
|
|
def all_users_route(user=None):
|
2019-10-23 14:44:17 +01:00
|
|
|
return jsonify({
|
2020-04-30 14:54:05 +01:00
|
|
|
'accounts': [i.to_dict() for i in User.collection.fetch()]
|
2019-10-23 14:44:17 +01:00
|
|
|
}), 200
|
2019-07-30 16:25:01 +01:00
|
|
|
|
|
|
|
|
|
|
|
@blueprint.route('/user/password', methods=['POST'])
|
2019-09-16 02:22:58 +01:00
|
|
|
@login_required
|
2020-04-30 14:54:05 +01:00
|
|
|
def change_password(user=None):
|
2019-07-30 16:25:01 +01:00
|
|
|
request_json = request.get_json()
|
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if 'new_password' in request_json and 'current_password' in request_json:
|
2019-07-30 16:25:01 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if len(request_json['new_password']) == 0:
|
|
|
|
return jsonify({"error": 'zero length password'}), 400
|
2019-07-30 16:25:01 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if len(request_json['new_password']) > 30:
|
|
|
|
return jsonify({"error": 'password too long'}), 400
|
2019-07-30 16:25:01 +01:00
|
|
|
|
2020-04-30 14:54:05 +01:00
|
|
|
if user.check_password(request_json['current_password']):
|
|
|
|
user.password = generate_password_hash(request_json['new_password'])
|
|
|
|
user.update()
|
|
|
|
logger.info(f'password udpated {user.username}')
|
2019-07-30 16:25:01 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
return jsonify({"message": 'password changed', "status": "success"}), 200
|
2019-07-30 16:25:01 +01:00
|
|
|
else:
|
2020-04-30 14:54:05 +01:00
|
|
|
logger.warning(f"incorrect password {user.username}")
|
2019-09-16 02:22:58 +01:00
|
|
|
return jsonify({'error': 'wrong password provided'}), 401
|
2019-07-29 11:44:10 +01:00
|
|
|
|
|
|
|
else:
|
2019-09-16 02:22:58 +01:00
|
|
|
return jsonify({'error': 'malformed request, no old_password/new_password'}), 400
|
2019-08-02 12:54:18 +01:00
|
|
|
|
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
@blueprint.route('/playlist/run', methods=['GET'])
|
2019-09-25 19:28:38 +01:00
|
|
|
@login_or_basic_auth
|
2020-04-30 14:54:05 +01:00
|
|
|
def run_playlist(user=None):
|
2019-08-02 12:54:18 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
playlist_name = request.args.get('name', None)
|
2019-08-02 12:54:18 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if playlist_name:
|
2019-08-02 12:54:18 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
if os.environ.get('DEPLOY_DESTINATION', None) == 'PROD':
|
2020-06-30 16:38:06 +01:00
|
|
|
queue_run_user_playlist(user.username, playlist_name) # pass to either cloud tasks or functions
|
2019-08-02 12:54:18 +01:00
|
|
|
else:
|
2020-06-30 16:38:06 +01:00
|
|
|
run_user_playlist(user.username, playlist_name) # update synchronously
|
2019-09-16 02:22:58 +01:00
|
|
|
|
|
|
|
return jsonify({'message': 'execution requested', 'status': 'success'}), 200
|
2019-08-02 12:54:18 +01:00
|
|
|
|
|
|
|
else:
|
2019-09-16 02:22:58 +01:00
|
|
|
logger.warning('no playlist requested')
|
|
|
|
return jsonify({"error": 'no name requested'}), 400
|
2019-08-03 23:36:14 +01:00
|
|
|
|
|
|
|
|
2019-08-08 12:25:53 +01:00
|
|
|
@blueprint.route('/playlist/run/task', methods=['POST'])
|
2019-09-16 02:22:58 +01:00
|
|
|
@cloud_task
|
2020-06-30 16:38:06 +01:00
|
|
|
def run_playlist_task(): # receives cloud tasks request for update
|
2019-08-08 12:25:53 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
payload = request.get_data(as_text=True)
|
|
|
|
if payload:
|
|
|
|
payload = json.loads(payload)
|
2019-08-10 17:53:50 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
logger.info(f'running {payload["username"]} / {payload["name"]}')
|
2019-08-17 18:30:13 +01:00
|
|
|
|
2020-06-30 16:38:06 +01:00
|
|
|
offload_or_run_user_playlist(payload['username'], payload['name']) # check whether offloading to cloud function
|
2019-08-10 17:53:50 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
return jsonify({'message': 'executed playlist', 'status': 'success'}), 200
|
2019-08-08 12:25:53 +01:00
|
|
|
|
2020-06-29 20:11:05 +01:00
|
|
|
logger.critical('no payload provided')
|
|
|
|
|
2019-08-08 12:25:53 +01:00
|
|
|
|
2019-08-03 23:36:14 +01:00
|
|
|
@blueprint.route('/playlist/run/user', methods=['GET'])
|
2019-09-25 19:28:38 +01:00
|
|
|
@login_or_basic_auth
|
2020-04-30 14:54:05 +01:00
|
|
|
def run_user(user=None):
|
2019-08-03 23:36:14 +01:00
|
|
|
|
2020-04-30 14:54:05 +01:00
|
|
|
if user.type == 'admin':
|
|
|
|
user_name = request.args.get('username', user.username)
|
2019-09-16 02:22:58 +01:00
|
|
|
else:
|
2020-04-30 14:54:05 +01:00
|
|
|
user_name = user.username
|
2019-08-03 23:36:14 +01:00
|
|
|
|
2020-05-15 23:25:19 +01:00
|
|
|
update_playlists(user_name)
|
2019-08-03 23:36:14 +01:00
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
return jsonify({'message': 'executed user', 'status': 'success'}), 200
|
2019-08-03 23:36:14 +01:00
|
|
|
|
|
|
|
|
2019-08-08 12:25:53 +01:00
|
|
|
@blueprint.route('/playlist/run/user/task', methods=['POST'])
|
2019-09-16 02:22:58 +01:00
|
|
|
@cloud_task
|
2019-08-08 12:25:53 +01:00
|
|
|
def run_user_task():
|
|
|
|
|
2019-09-16 02:22:58 +01:00
|
|
|
payload = request.get_data(as_text=True)
|
|
|
|
if payload:
|
2020-05-15 23:25:19 +01:00
|
|
|
update_playlists(payload)
|
2019-09-16 02:22:58 +01:00
|
|
|
return jsonify({'message': 'executed user', 'status': 'success'}), 200
|
2019-08-08 12:25:53 +01:00
|
|
|
|
|
|
|
|
2019-08-03 23:36:14 +01:00
|
|
|
@blueprint.route('/playlist/run/users', methods=['GET'])
|
2019-09-30 14:19:00 +01:00
|
|
|
@login_or_basic_auth
|
2019-09-16 02:22:58 +01:00
|
|
|
@admin_required
|
2020-04-30 14:54:05 +01:00
|
|
|
def run_users(user=None):
|
2019-08-03 23:36:14 +01:00
|
|
|
|
2020-05-15 23:25:19 +01:00
|
|
|
update_all_user_playlists()
|
2019-09-16 02:22:58 +01:00
|
|
|
return jsonify({'message': 'executed all users', 'status': 'success'}), 200
|
2019-08-03 23:36:14 +01:00
|
|
|
|
|
|
|
|
|
|
|
@blueprint.route('/playlist/run/users/cron', methods=['GET'])
|
2019-09-16 02:22:58 +01:00
|
|
|
@gae_cron
|
2019-08-03 23:36:14 +01:00
|
|
|
def run_users_cron():
|
|
|
|
|
2020-05-15 23:25:19 +01:00
|
|
|
update_all_user_playlists()
|
2019-09-16 02:22:58 +01:00
|
|
|
return jsonify({'status': 'success'}), 200
|
2020-03-07 21:53:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
@blueprint.route('/playlist/image', methods=['GET'])
|
|
|
|
@login_or_basic_auth
|
2020-04-30 14:54:05 +01:00
|
|
|
def image(user=None):
|
2020-03-07 21:53:52 +00:00
|
|
|
name = request.args.get('name', None)
|
|
|
|
|
|
|
|
if name is None:
|
|
|
|
return jsonify({'error': "no name provided"}), 400
|
|
|
|
|
2020-04-30 14:54:05 +01:00
|
|
|
_playlist = Playlist.collection.parent(user.key).filter('name', '==', name).get()
|
2020-03-07 21:53:52 +00:00
|
|
|
if _playlist is None:
|
|
|
|
return jsonify({'error': "playlist not found"}), 404
|
|
|
|
|
2020-04-30 14:54:05 +01:00
|
|
|
net = database.get_authed_spotify_network(user)
|
2020-03-07 21:53:52 +00:00
|
|
|
|
2020-06-22 20:21:54 +01:00
|
|
|
try:
|
|
|
|
return jsonify({'images': net.get_playlist(uri_string=_playlist.uri).images, 'status': 'success'}), 200
|
|
|
|
except SpotifyNetworkException as e:
|
2020-07-01 11:03:43 +01:00
|
|
|
logger.exception(f'error occured during {_playlist.name} / {user.username} playlist retrieval')
|
2020-06-22 20:21:54 +01:00
|
|
|
return jsonify({'error': f"spotify error occured: {e.http_code}"}), 404
|