Artists of recordings

This commit is contained in:
Daniel Cortes
2020-06-12 00:18:41 -04:00
parent df83c17c39
commit 8951541a7a
4 changed files with 31 additions and 20 deletions

View File

@@ -28,7 +28,7 @@ import json
import django_rq
from fetcher import musicbrainz as mb
from utils import get_redis_connection, parse_date, pretty_print_json
from utils import get_redis_connection, parse_date
_log = logging.getLogger('fetcher_jobs')
_log.addHandler(logging.NullHandler())
@@ -84,7 +84,6 @@ def load_entities_of_recording(recording):
releases = mb.browse_releases({'recording': mbid},
includes=['recordings', 'artist-credits'],
limit=100, offset=offset)
pretty_print_json(releases)
# lo unico que sirve hacer aqui es almacenar en cuantas releases se encuentra la
# grabacion
@@ -177,7 +176,7 @@ def load_entities_of_release_group(release_group):
# Cargo todas las releases posibles la primera vez, si no lo hiciera y necesitara pedir
# mas datos, usuaria una request en vano
releases = mb.browse_releases({'release-group': mbid},
includes=['artist-credits'],
includes=['recordings', 'artist-credits'],
limit=100, offset=offset)
count = releases.get('release_count')
if f'release_group:{mbid}:releases' in redis:

View File

@@ -534,17 +534,36 @@ def get_release_of_recording(mbid, limit, page):
}
def get_artist_of_recording(mbid, limit, page):
def get_artist_of_recording(mbid):
"""Obtiene el artista de una grabacion"""
mb_artists = mb.browse_artists(params={'recording': mbid}, limit=limit,
offset=limit * (page - 1))
_log.info('Obteniendo el artista de la recording %s', mbid)
if 'error' in mb_artists:
return mb_artists
artist = None
with get_redis_connection() as redis:
_log.debug('Intentando obtener el artista de la recording %s desde redis', mbid)
artist_key = f'recording:{mbid}:artist'
if artist_key in redis:
_log.debug('Se encontro el artista de la recording %s en redis', mbid)
artist = get_artist(redis.get(artist_key))
else:
_log.debug('El artista de la recording %s no estaba en redis', mbid)
if artist is None:
_log.debug('Obteniendo el artista de la recording %s desde musicbrainz', mbid)
mb_artist_browse = mb.browse_artists(params={'recording': mbid},
includes=['tags'],
limit=1, offset=0)
if 'error' in mb_artist_browse:
_log.debug('Erro al obtener artista %s', mb_artist_browse)
return mb_artist_browse
artist = mb_artist_browse.get('artists')[0]
jobs.load_artist_on_cache.delay(artist.get('id'))
return {
'paginate': paginate(mb_artists.get('artist_count', 0), limit, page),
'artists': [map_artist(artist) for artist in mb_artists['artists']]
'artist': artist
}

View File

@@ -23,7 +23,7 @@ urlpatterns = [
path('recording/', views.search_recording),
path('recording/<mbid>/', views.get_recording),
path('recording/<mbid>/artist/', views.get_release_of_recording),
path('recording/<mbid>/release/', views.get_release_of_recording),
path('recording/<mbid>/artist/', views.get_artist_of_recording),
path('recording/<mbid>/coverart/', views.get_cover_art_of_recording),
]

View File

@@ -171,15 +171,8 @@ def get_release_of_recording(request, mbid):
@api_view(['GET'])
def get_artist_of_recording(request, mbid):
""" Obtiene el artista de una grabación dada su mbid
Como los datos son paginables la query puede contener per_page y page para definir cuantos
elementos mostrar por pagina y que pagina mostrar.
"""
limit = int(request.GET.get('per_page', 10))
page = int(request.GET.get('page', 1))
return Response(medium.get_artist_of_recording(mbid, limit, page))
""" Obtiene el artista de una grabación dada su mbid"""
return Response(medium.get_artist_of_recording(mbid))
@api_view(['GET'])