Compare commits

...
Sign in to create a new pull request.

23 commits

Author SHA1 Message Date
a20b3211da Merge pull request 'updated permissions for list' (#11) from list-permission-handling into main
Reviewed-on: #11
2025-06-30 23:17:34 +00:00
8f4a155c06 updated permissions for list 2025-06-30 18:15:56 -05:00
5c83230185 Merge pull request 'added new lighter serializer for list of movielists' (#10) from movielist-improvements into main
Reviewed-on: #10
2025-06-30 22:31:06 +00:00
54cdeb56af added new lighter serializer for list of movielists 2025-06-30 17:30:41 -05:00
548cc478b9 Merge pull request 'updated db queries for performance improvement' (#9) from performance-improvements into main
Reviewed-on: #9
2025-06-30 22:09:10 +00:00
6651be3458 updated db queries for performance improvement 2025-06-30 17:08:47 -05:00
8602784c0d Merge pull request 'improve-search-error-handling' (#8) from improve-search-error-handling into main
Reviewed-on: #8
2025-06-30 20:38:39 +00:00
f8b4fa4a0e removed debug print 2025-06-30 15:37:37 -05:00
9dce0f1ec4 added better error handling to movie search 2025-06-30 15:35:39 -05:00
b25f5c66e1 added fields to admin pages 2025-06-03 00:11:30 -05:00
2b073c5705 updated docker to use development server for live reloading 2025-06-03 00:10:32 -05:00
b326440964 Merge pull request 'fixed hide schedule bug' (#7) from fix-hide-scheduled into main
Reviewed-on: #7
2025-05-29 18:58:30 +00:00
e17e95df04 fixed hide schedule bug 2025-05-29 13:58:00 -05:00
8184b72640 Merge pull request 'fix-missing-current-date-on-schedule' (#6) from fix-missing-current-date-on-schedule into main
Reviewed-on: #6
2025-05-29 18:22:28 +00:00
c45b3e2e18 fixed schedule bug 2025-05-29 13:21:42 -05:00
3085be7fd1 .idea updates 2025-05-29 13:21:28 -05:00
65274b5de6 updated .env example 2025-05-08 18:03:38 -05:00
69dd381e82 .idea updates 2025-05-08 18:03:28 -05:00
4c43266c97 updated .env example 2025-04-27 00:44:03 -05:00
745afd9dbd moved omdb key to settings file 2025-04-23 16:06:58 -05:00
56c8d74f99 Merge pull request 'added support for refreshing movie data' (#5) from add-movie-refresher into main
Reviewed-on: #5
2025-04-23 20:43:50 +00:00
ba590d885d added support for refreshing movie data 2025-04-23 15:37:03 -05:00
9a7f305f90 Merge pull request 'added readonly to movielists and schedules' (#4) from add-public-endpoints into main
Reviewed-on: #4
2025-04-22 22:47:52 +00:00
10 changed files with 127 additions and 20 deletions

View file

@ -11,5 +11,10 @@ DATABASE_HOST=movienight-db
DATABASE_NAME=movienight
DATABASE_USERNAME=admin
DATABASE_PASSWORD=super_secret_password
# Django key generator: https://djecrety.ir/
SECRET_KEY=your_django_secret_key
DJANGO_SECRET_KEY=your_django_secret_key
# You can get a free key here: https://www.omdbapi.com/apikey.aspx
OMDB_API_KEY=your_omdb_api_key

2
.idea/misc.xml generated
View file

@ -5,5 +5,5 @@
<option name="enabledOnSave" value="true" />
<option name="sdkName" value="Python 3.13 (api)" />
</component>
<component name="ProjectRootManager" version="2" project-jdk-name="Python 3.13 (api)" project-jdk-type="Python SDK" />
<component name="ProjectRootManager" version="2" project-jdk-name="Python 3.13 virtualenv at ~/Projects/MovieNight/movie-night-api/.venv" project-jdk-type="Python SDK" />
</project>

View file

@ -17,7 +17,7 @@
<excludeFolder url="file://$MODULE_DIR$/.venv" />
<excludeFolder url="file://$MODULE_DIR$/.venv1" />
</content>
<orderEntry type="jdk" jdkName="Python 3.13 (api)" jdkType="Python SDK" />
<orderEntry type="jdk" jdkName="Python 3.13 virtualenv at ~/Projects/MovieNight/movie-night-api/.venv" jdkType="Python SDK" />
<orderEntry type="sourceFolder" forTests="false" />
</component>
<component name="PyDocumentationSettings">

View file

@ -35,4 +35,4 @@ USER web
EXPOSE 8000
CMD ["gunicorn", "--bind", "0.0.0.0:8000", "--workers", "3", "movienight.wsgi:application"]
CMD ["python", "manage.py", "runserver", "0.0.0.0:8000"]

View file

@ -1,5 +1,7 @@
import os
from django.conf import settings
from movie_db.movie_db import MovieDB
import requests
@ -8,8 +10,7 @@ from movie_db.serializers import MovieSerializer, MovieResultSerializer
class OMDb(MovieDB):
def __init__(self):
api_key = os.getenv("OMDB_API_KEY")
self.api_key = f"{api_key}"
self.api_key = settings.OMDB_API_KEY
self.base_url = "https://www.omdbapi.com/?apikey=" + self.api_key
super().__init__()

View file

@ -9,4 +9,17 @@ def omdb_search(request):
search_type = request.GET.get("type")
omdb = OMDb()
return JsonResponse(omdb.search(query, {"type": search_type}), safe=False)
results = omdb.search(query, {"type": search_type})
if "error" in results:
return parse_error(results)
return JsonResponse(results, safe=False)
def parse_error(results):
error_json = results["error"]
if "Error" in error_json and error_json["Error"] == "Movie not found!":
return JsonResponse({}, status=404)
else:
return JsonResponse("Error while searching for movie.", status=500)

View file

@ -6,19 +6,19 @@ from movie_manager.models import Movie, MovieList, Schedule, Showing
# Register your models here.
@admin.register(Movie)
class MovieAdmin(admin.ModelAdmin):
pass
list_display = ["title", "imdb_id", "added_by"]
@admin.register(MovieList)
class MovieListAdmin(admin.ModelAdmin):
pass
list_display = ["name", "owner"]
@admin.register(Schedule)
class ScheduleAdmin(admin.ModelAdmin):
pass
list_display = ["name", "owner"]
@admin.register(Showing)
class ShowingAdmin(admin.ModelAdmin):
pass
list_display = ["showtime", "movie"]

View file

@ -5,21 +5,55 @@ from movie_manager.models import Movie, MovieList, Schedule, Showing
class MovieSerializer(serializers.ModelSerializer):
has_been_scheduled = serializers.SerializerMethodField()
class Meta:
model = Movie
fields = "__all__"
fields = [
"id",
"title",
"imdb_id",
"year",
"director",
"actors",
"plot",
"genre",
"mpaa_rating",
"critic_scores",
"poster",
"added_by_id",
"has_been_scheduled",
]
def get_has_been_scheduled(self, obj):
return Showing.objects.filter(movie_id=obj.id).exists()
class MovieListSerializer(serializers.ModelSerializer):
class MovieListListSerializer(serializers.ModelSerializer):
movie_count = serializers.SerializerMethodField()
movies = MovieSerializer(read_only=True, many=True)
class Meta:
model = MovieList
fields = ["id", "name", "owner", "public", "movies", "movie_count"]
fields = ["id", "name", "owner", "public", "movie_count"]
def get_movie_count(self, obj):
return len(obj.movies.all())
return obj.movies.count()
class MovieListSerializer(serializers.ModelSerializer):
movies = MovieSerializer(read_only=True, many=True)
serializer_class = MovieSerializer
owner = serializers.PrimaryKeyRelatedField(read_only=True)
def get_queryset(self):
return MovieList.objects.prefetch_related(
"movies",
"movies__showing_set"
)
class Meta:
model = MovieList
fields = ["id", "name", "owner", "public", "movies"]
class UserSerializer(serializers.Serializer):

View file

@ -1,9 +1,10 @@
import datetime
import json
from django.db.models import QuerySet
from django.http import JsonResponse
from django.contrib.auth.models import User
from django.utils.dateparse import parse_datetime
from django.db import models
from rest_framework import permissions, viewsets
from knox.auth import TokenAuthentication
from rest_framework.decorators import action, api_view
@ -16,7 +17,7 @@ from movie_manager.serializers import (
MovieListSerializer,
MovieSerializer,
ScheduleSerializer,
ShowingSerializer,
ShowingSerializer, MovieListListSerializer,
)
@ -33,13 +34,62 @@ class MovieViewset(viewsets.ModelViewSet):
serializer_class = MovieSerializer
def update(self, request, pk=None, *args, **kwargs):
omdb = OMDb()
updated_movie = omdb.search(request.data.get("imdb_id"), {"type": "imdb_id"})
movie = Movie.objects.get(pk=pk)
movie.title = updated_movie["title"]
movie.actors = updated_movie["actors"]
movie.year = updated_movie["year"]
movie.critic_scores = updated_movie["critic_scores"]
movie.mpaa_rating = updated_movie["mpaa_rating"]
movie.director = updated_movie["director"]
movie.poster = updated_movie["poster"]
movie.plot = updated_movie["plot"]
movie.genre = updated_movie["genre"]
movie.save()
return JsonResponse(MovieSerializer(movie).data)
class MovieListViewset(viewsets.ModelViewSet):
queryset = MovieList.objects.all().order_by("name")
queryset = MovieList.objects.all()
authentication_classes = [TokenAuthentication]
permission_classes = [permissions.IsAuthenticated | ReadOnly]
serializer_class = MovieListSerializer
def get_serializer_class(self):
if self.action == "list":
return MovieListListSerializer
else:
return MovieListSerializer
def get_queryset(self):
base_qs = MovieList.objects.all()
if self.action == "list":
if self.request.user.is_authenticated:
return base_qs.filter(
models.Q(public=True) |
models.Q(owner=self.request.user)
).order_by("name")
return base_qs.filter(public=True).order_by("name")
else:
return MovieList.objects.prefetch_related(
"movies",
"movies__showing_set"
).order_by("name")
def perform_create(self, serializer):
serializer.save(owner=self.request.user)
def get_permissions(self):
if self.action in ['update', 'partial_update', 'destroy']:
self.permission_classes = [permissions.IsAuthenticated]
return super().get_permissions()
def create(self, request, *args, **kwargs):
movie_list = MovieList.objects.create(
@ -122,7 +172,9 @@ class ScheduleViewset(viewsets.ModelViewSet):
def retrieve(self, request, pk=None, *args, **kwargs):
# Get the schedule instance
instance = self.get_object()
today = datetime.datetime.now()
now = datetime.datetime.now()
# get time from start of day
today = datetime.datetime(now.year, now.month, now.day)
upcoming_showings = Showing.objects.filter(
showtime__gte=today, schedule=instance

View file

@ -126,6 +126,8 @@ USE_I18N = True
USE_TZ = True
OMDB_API_KEY = os.environ.get("OMDB_API_KEY")
# Django Rest Framework
REST_FRAMEWORK = {
"DEFAULT_AUTHENTICATION_CLASSES": [