правки Микоса...
This commit is contained in:
parent
b063160759
commit
6e54faf605
|
|
@ -1,5 +1,5 @@
|
||||||
from django.shortcuts import render
|
from django.shortcuts import render
|
||||||
from rest_framework.viewsets import ViewSet
|
from rest_framework.viewsets import ViewSet, GenericViewSet
|
||||||
from rest_framework.response import Response
|
from rest_framework.response import Response
|
||||||
from rest_framework.decorators import action
|
from rest_framework.decorators import action
|
||||||
from rest_framework import status
|
from rest_framework import status
|
||||||
|
|
@ -11,34 +11,33 @@ from .schemas import SongSchema, DeleteSongSchema
|
||||||
from .models import Song, FavoriteSong
|
from .models import Song, FavoriteSong
|
||||||
from .serializers import SongSerializer, FavoriteSongSerializer
|
from .serializers import SongSerializer, FavoriteSongSerializer
|
||||||
|
|
||||||
class SongViewSet(ViewSet):
|
class SongViewSet(GenericViewSet):
|
||||||
permission_classes_by_action = {
|
permission_classes_by_action = {
|
||||||
'list': [IsAuthenticated],
|
'list': [IsAuthenticated],
|
||||||
'retrieve': [IsAuthenticated],
|
'retrieve': [IsAuthenticated],
|
||||||
'create_song': [IsAuthenticated]
|
'create_song': [IsAuthenticated]
|
||||||
}
|
}
|
||||||
|
|
||||||
def list(self, request):
|
def list(self, request):
|
||||||
user_pk = request.user.pk
|
songs_pk = FavoriteSong.objects.filter(user=request.user, song__isnull=False).values_list('song_id', flat=True)
|
||||||
songs_pk = [i.song.pk for i in get_list_or_404(FavoriteSong, user=user_pk)]
|
|
||||||
queryset = Song.objects.filter(id__in=songs_pk)
|
queryset = Song.objects.filter(id__in=songs_pk)
|
||||||
serializer = SongSerializer(queryset, many=True)
|
serializer = SongSerializer(queryset, many=True)
|
||||||
return Response(serializer.data)
|
return Response(serializer.data)
|
||||||
|
|
||||||
def retrieve(self, request, pk=None):
|
def retrieve(self, request, pk=None):
|
||||||
user_pk = request.user.pk
|
|
||||||
song_obj = get_object_or_404(Song, azura_id=pk).pk
|
song_obj = get_object_or_404(Song, azura_id=pk).pk
|
||||||
queryset = FavoriteSong.objects.filter(user=user_pk, song=song_obj)
|
queryset = FavoriteSong.objects.get(user=request.user.pk, song=song_obj)
|
||||||
serializer = FavoriteSongSerializer(queryset[0])
|
serializer = FavoriteSongSerializer(queryset)
|
||||||
return Response(serializer.data)
|
return Response(serializer.data)
|
||||||
|
|
||||||
@action(detail=False, methods=['post'], schema=SongSchema())
|
@action(detail=False, methods=['post'], schema=SongSchema())
|
||||||
def create_song(self, request):
|
def create_song(self, request):
|
||||||
song = Song.objects.filter(azura_id = request.data['azura_id'])
|
song = get_object_or_404(Song, azura_id=request.data['azura_id'])
|
||||||
data = None
|
data = None
|
||||||
#Если трек есть в базе
|
#Если трек есть в базе
|
||||||
if song:
|
if song:
|
||||||
data = {
|
data = {
|
||||||
"song": song[0].id,
|
"song": song.pk,
|
||||||
"user": request.user.pk
|
"user": request.user.pk
|
||||||
}
|
}
|
||||||
#Если трека нету в базе
|
#Если трека нету в базе
|
||||||
|
|
@ -56,10 +55,9 @@ class SongViewSet(ViewSet):
|
||||||
if serializer.is_valid():
|
if serializer.is_valid():
|
||||||
serializer.save()
|
serializer.save()
|
||||||
data = {
|
data = {
|
||||||
"song": song[0].id,
|
"song": serializer.data['id'],
|
||||||
"user": request.user.pk
|
"user": request.user.pk
|
||||||
}
|
}
|
||||||
|
|
||||||
serializer = FavoriteSongSerializer(data=data)
|
serializer = FavoriteSongSerializer(data=data)
|
||||||
if serializer.is_valid():
|
if serializer.is_valid():
|
||||||
serializer.save()
|
serializer.save()
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue