общий рефакторинг
This commit is contained in:
parent
500de25785
commit
177dcd0688
|
|
@ -4,7 +4,7 @@ from .models import Song, FavoriteSong
|
||||||
class SongSerializer(serializers.ModelSerializer):
|
class SongSerializer(serializers.ModelSerializer):
|
||||||
class Meta:
|
class Meta:
|
||||||
model = Song
|
model = Song
|
||||||
fields = ('id', 'unique_id', 'azura_id', 'title', 'artist', 'album', 'genre', 'art')
|
fields = ('id', 'unique_id', 'title', 'artist', 'album', 'genre', 'art')
|
||||||
|
|
||||||
class FavoriteSongSerializer(serializers.ModelSerializer):
|
class FavoriteSongSerializer(serializers.ModelSerializer):
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -13,34 +13,34 @@ from .models import Song, FavoriteSong
|
||||||
from .serializers import SongSerializer, FavoriteSongSerializer
|
from .serializers import SongSerializer, FavoriteSongSerializer
|
||||||
|
|
||||||
class SongViewSet(GenericViewSet):
|
class SongViewSet(GenericViewSet):
|
||||||
|
queryset = Song.objects.all()
|
||||||
serializer_class = SongSerializer
|
serializer_class = SongSerializer
|
||||||
permission_classes = (IsAuthenticated,)
|
permission_classes = (IsAuthenticated,)
|
||||||
queryset = Song.objects.all()
|
|
||||||
|
|
||||||
def list(self, request):
|
def list(self, request):
|
||||||
songs_pk = FavoriteSong.objects.filter(user=request.user, song__isnull=False).values_list('song_id', flat=True)
|
songs_pk = FavoriteSong.objects.filter(user=request.user, song__isnull=False).values_list('song_id', flat=True)
|
||||||
queryset = Song.objects.filter(id__in=songs_pk)
|
songs = Song.objects.filter(id__in=songs_pk)
|
||||||
serializer = SongSerializer(queryset, many=True)
|
serializer = SongSerializer(songs, many=True)
|
||||||
return Response(serializer.data)
|
return Response(serializer.data)
|
||||||
|
|
||||||
def retrieve(self, request, pk=None):
|
def retrieve(self, request, pk=None):
|
||||||
try:
|
try:
|
||||||
song_obj = Song.objects.get(azura_id=pk)
|
song_obj = Song.objects.get(azura_id=pk)
|
||||||
queryset = FavoriteSong.objects.get(user=request.user, song=song_obj)
|
favorite_songs = FavoriteSong.objects.get(user=request.user, song=song_obj)
|
||||||
except ObjectDoesNotExist:
|
except ObjectDoesNotExist:
|
||||||
return Response({"error": 'Объекта не существует'}, status=status.HTTP_404_NOT_FOUND)
|
return Response({"error": 'Объекта не существует'}, status=status.HTTP_404_NOT_FOUND)
|
||||||
serializer = FavoriteSongSerializer(queryset)
|
serializer = FavoriteSongSerializer(favorite_songs)
|
||||||
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 add_favorite(self, request):
|
||||||
song = get_object_or_404(Song, azura_id=request.data['azura_id'])
|
song = get_object_or_404(Song, azura_id=request.data.get('azura_id'))
|
||||||
data = None
|
data = None
|
||||||
#Если трек есть в базе
|
#Если трек есть в базе
|
||||||
if song:
|
if song:
|
||||||
data = {
|
data = {
|
||||||
"song": song.pk,
|
"song": song,
|
||||||
"user": request.user.pk
|
"user": request.user
|
||||||
}
|
}
|
||||||
#Если трека нету в базе
|
#Если трека нету в базе
|
||||||
else:
|
else:
|
||||||
|
|
@ -53,12 +53,12 @@ class SongViewSet(GenericViewSet):
|
||||||
data = request.data
|
data = request.data
|
||||||
file_play = f"http://82.97.242.49:10084/api/station/it-radio/file/{response.json()['unique_id']}/play"
|
file_play = f"http://82.97.242.49:10084/api/station/it-radio/file/{response.json()['unique_id']}/play"
|
||||||
data.update(unique_id=file_play)
|
data.update(unique_id=file_play)
|
||||||
serializer = SongSerializer(data=data)
|
serializer = self.get_serializer_class(data=data)
|
||||||
if serializer.is_valid():
|
if serializer.is_valid():
|
||||||
serializer.save()
|
serializer.save()
|
||||||
data = {
|
data = {
|
||||||
"song": serializer.data['id'],
|
"song": serializer.data['id'],
|
||||||
"user": request.user.pk
|
"user": request.user
|
||||||
}
|
}
|
||||||
serializer = FavoriteSongSerializer(data=data)
|
serializer = FavoriteSongSerializer(data=data)
|
||||||
if serializer.is_valid():
|
if serializer.is_valid():
|
||||||
|
|
@ -69,10 +69,13 @@ class SongViewSet(GenericViewSet):
|
||||||
|
|
||||||
@action(detail=False, methods=['post'], schema=DeleteSongSchema())
|
@action(detail=False, methods=['post'], schema=DeleteSongSchema())
|
||||||
def delete_song(self, request):
|
def delete_song(self, request):
|
||||||
song_id = request.data['song_id']
|
try:
|
||||||
item = get_object_or_404(FavoriteSong, pk=song_id)
|
item = FavoriteSong.objects.get(user=request.user, song=request.data.get('song_id'))
|
||||||
item.delete()
|
item.delete()
|
||||||
return Response(status=status.HTTP_202_ACCEPTED)
|
return Response(status=status.HTTP_202_ACCEPTED)
|
||||||
|
except ObjectDoesNotExist:
|
||||||
|
return Response({"error": 'Объекта не существует'}, status=status.HTTP_404_NOT_FOUND)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Loading…
Reference in New Issue