added support for list management
This commit is contained in:
parent
94d8969103
commit
a116f5dd63
5 changed files with 56 additions and 10 deletions
3
.gitignore
vendored
3
.gitignore
vendored
|
@ -26,9 +26,6 @@ share/python-wheels/
|
||||||
*.egg
|
*.egg
|
||||||
MANIFEST
|
MANIFEST
|
||||||
|
|
||||||
# django
|
|
||||||
static
|
|
||||||
|
|
||||||
# PyInstaller
|
# PyInstaller
|
||||||
# Usually these files are written by a python script from a template
|
# Usually these files are written by a python script from a template
|
||||||
# before PyInstaller builds the exe, so as to inject date/other infos into it.
|
# before PyInstaller builds the exe, so as to inject date/other infos into it.
|
||||||
|
|
22
movie_manager/migrations/0003_movie_added_by.py
Normal file
22
movie_manager/migrations/0003_movie_added_by.py
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
# Generated by Django 5.1.4 on 2025-04-08 00:18
|
||||||
|
|
||||||
|
import django.db.models.deletion
|
||||||
|
from django.conf import settings
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('movie_manager', '0002_alter_movie_options_alter_movielist_options_and_more'),
|
||||||
|
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='movie',
|
||||||
|
name='added_by',
|
||||||
|
field=models.ForeignKey(default=1, on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL),
|
||||||
|
preserve_default=False,
|
||||||
|
),
|
||||||
|
]
|
|
@ -3,9 +3,6 @@ from django.contrib.auth.models import User
|
||||||
|
|
||||||
# Create your models here.
|
# Create your models here.
|
||||||
class Movie(models.Model):
|
class Movie(models.Model):
|
||||||
class Meta:
|
|
||||||
ordering = ["title"]
|
|
||||||
|
|
||||||
title = models.CharField(max_length=100)
|
title = models.CharField(max_length=100)
|
||||||
imdb_id = models.CharField(max_length=100)
|
imdb_id = models.CharField(max_length=100)
|
||||||
year = models.IntegerField()
|
year = models.IntegerField()
|
||||||
|
@ -16,18 +13,19 @@ class Movie(models.Model):
|
||||||
plot = models.CharField(max_length=500)
|
plot = models.CharField(max_length=500)
|
||||||
poster = models.CharField(max_length=500)
|
poster = models.CharField(max_length=500)
|
||||||
last_watched = models.DateTimeField()
|
last_watched = models.DateTimeField()
|
||||||
|
added_by = models.ForeignKey(User, on_delete=models.CASCADE)
|
||||||
created_at = models.DateTimeField(auto_now_add=True)
|
created_at = models.DateTimeField(auto_now_add=True)
|
||||||
updated_at = models.DateTimeField(auto_now=True)
|
updated_at = models.DateTimeField(auto_now=True)
|
||||||
deleted_at = models.DateTimeField(null=True, blank=True)
|
deleted_at = models.DateTimeField(null=True, blank=True)
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
ordering = ["title"]
|
||||||
|
|
||||||
def __str__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
|
|
||||||
class MovieList(models.Model):
|
class MovieList(models.Model):
|
||||||
class Meta:
|
|
||||||
ordering = ["name"]
|
|
||||||
|
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
public = models.BooleanField(default=False)
|
public = models.BooleanField(default=False)
|
||||||
owner = models.ForeignKey(User, on_delete=models.CASCADE)
|
owner = models.ForeignKey(User, on_delete=models.CASCADE)
|
||||||
|
@ -36,5 +34,8 @@ class MovieList(models.Model):
|
||||||
updated_at = models.DateTimeField(auto_now=True)
|
updated_at = models.DateTimeField(auto_now=True)
|
||||||
deleted_at = models.DateTimeField(null=True, blank=True)
|
deleted_at = models.DateTimeField(null=True, blank=True)
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
ordering = ["name"]
|
||||||
|
|
||||||
def __str__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
|
@ -11,10 +11,11 @@ class MovieSerializer(serializers.ModelSerializer):
|
||||||
|
|
||||||
class MovieListSerializer(serializers.ModelSerializer):
|
class MovieListSerializer(serializers.ModelSerializer):
|
||||||
movie_count = serializers.SerializerMethodField()
|
movie_count = serializers.SerializerMethodField()
|
||||||
|
movies = MovieSerializer(read_only=True, many=True)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = MovieList
|
model = MovieList
|
||||||
fields = ["id","name","owner","public", "movie_count"]
|
fields = ["id","name","owner","public", "movies", "movie_count"]
|
||||||
|
|
||||||
|
|
||||||
def get_movie_count(self, obj):
|
def get_movie_count(self, obj):
|
||||||
|
|
|
@ -2,6 +2,7 @@ from django.http import HttpResponse, JsonResponse
|
||||||
from django.contrib.auth.models import User
|
from django.contrib.auth.models import User
|
||||||
from rest_framework import permissions, viewsets
|
from rest_framework import permissions, viewsets
|
||||||
from knox.auth import TokenAuthentication
|
from knox.auth import TokenAuthentication
|
||||||
|
from rest_framework.decorators import action
|
||||||
from rest_framework.exceptions import NotFound
|
from rest_framework.exceptions import NotFound
|
||||||
|
|
||||||
from movie_manager.models import Movie, MovieList
|
from movie_manager.models import Movie, MovieList
|
||||||
|
@ -25,6 +26,12 @@ class MovieListViewset(viewsets.ModelViewSet):
|
||||||
|
|
||||||
serializer_class = MovieListSerializer
|
serializer_class = MovieListSerializer
|
||||||
|
|
||||||
|
|
||||||
|
def retrieve(self, request, pk=None, *args, **kwargs):
|
||||||
|
movie_list = MovieList.objects.get(pk=pk)
|
||||||
|
return JsonResponse(MovieListSerializer(movie_list).data)
|
||||||
|
|
||||||
|
|
||||||
def update(self, request, pk=None, *args, **kwargs):
|
def update(self, request, pk=None, *args, **kwargs):
|
||||||
movie_list = MovieList.objects.get(pk=pk)
|
movie_list = MovieList.objects.get(pk=pk)
|
||||||
movie_list.name = request.data.get('name')
|
movie_list.name = request.data.get('name')
|
||||||
|
@ -46,3 +53,21 @@ class MovieListViewset(viewsets.ModelViewSet):
|
||||||
movie_list.save()
|
movie_list.save()
|
||||||
|
|
||||||
return JsonResponse(MovieListSerializer(movie_list).data)
|
return JsonResponse(MovieListSerializer(movie_list).data)
|
||||||
|
|
||||||
|
@action(detail=True, methods=['put', 'delete'], url_path='movie/(?P<movie_id>[0-9]+)')
|
||||||
|
def add_movie(self, request, pk=None, movie_id=None, *args, **kwargs):
|
||||||
|
if request.method == 'DELETE':
|
||||||
|
return self.remove_movie(request, pk, movie_id)
|
||||||
|
|
||||||
|
movie_list = MovieList.objects.get(pk=pk)
|
||||||
|
movie = Movie.objects.get(pk=movie_id)
|
||||||
|
movie_list.movies.add(movie)
|
||||||
|
|
||||||
|
return JsonResponse(MovieListSerializer(movie_list).data)
|
||||||
|
|
||||||
|
def remove_movie(self, request, pk=None, movie_id=None, *args, **kwargs):
|
||||||
|
movie_list = MovieList.objects.get(pk=pk)
|
||||||
|
movie = Movie.objects.get(pk=movie_id)
|
||||||
|
movie_list.movies.remove(movie)
|
||||||
|
|
||||||
|
return JsonResponse(MovieListSerializer(movie_list).data)
|
||||||
|
|
Loading…
Add table
Reference in a new issue