Compare commits
No commits in common. "main" and "add-public-endpoints" have entirely different histories.
main
...
add-public
10 changed files with 20 additions and 127 deletions
|
@ -11,10 +11,5 @@ DATABASE_HOST=movienight-db
|
||||||
DATABASE_NAME=movienight
|
DATABASE_NAME=movienight
|
||||||
DATABASE_USERNAME=admin
|
DATABASE_USERNAME=admin
|
||||||
DATABASE_PASSWORD=super_secret_password
|
DATABASE_PASSWORD=super_secret_password
|
||||||
|
|
||||||
# Django key generator: https://djecrety.ir/
|
|
||||||
SECRET_KEY=your_django_secret_key
|
SECRET_KEY=your_django_secret_key
|
||||||
DJANGO_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
2
.idea/misc.xml
generated
|
@ -5,5 +5,5 @@
|
||||||
<option name="enabledOnSave" value="true" />
|
<option name="enabledOnSave" value="true" />
|
||||||
<option name="sdkName" value="Python 3.13 (api)" />
|
<option name="sdkName" value="Python 3.13 (api)" />
|
||||||
</component>
|
</component>
|
||||||
<component name="ProjectRootManager" version="2" project-jdk-name="Python 3.13 virtualenv at ~/Projects/MovieNight/movie-night-api/.venv" project-jdk-type="Python SDK" />
|
<component name="ProjectRootManager" version="2" project-jdk-name="Python 3.13 (api)" project-jdk-type="Python SDK" />
|
||||||
</project>
|
</project>
|
2
.idea/movie-night-py.iml
generated
2
.idea/movie-night-py.iml
generated
|
@ -17,7 +17,7 @@
|
||||||
<excludeFolder url="file://$MODULE_DIR$/.venv" />
|
<excludeFolder url="file://$MODULE_DIR$/.venv" />
|
||||||
<excludeFolder url="file://$MODULE_DIR$/.venv1" />
|
<excludeFolder url="file://$MODULE_DIR$/.venv1" />
|
||||||
</content>
|
</content>
|
||||||
<orderEntry type="jdk" jdkName="Python 3.13 virtualenv at ~/Projects/MovieNight/movie-night-api/.venv" jdkType="Python SDK" />
|
<orderEntry type="jdk" jdkName="Python 3.13 (api)" jdkType="Python SDK" />
|
||||||
<orderEntry type="sourceFolder" forTests="false" />
|
<orderEntry type="sourceFolder" forTests="false" />
|
||||||
</component>
|
</component>
|
||||||
<component name="PyDocumentationSettings">
|
<component name="PyDocumentationSettings">
|
||||||
|
|
|
@ -35,4 +35,4 @@ USER web
|
||||||
|
|
||||||
EXPOSE 8000
|
EXPOSE 8000
|
||||||
|
|
||||||
CMD ["python", "manage.py", "runserver", "0.0.0.0:8000"]
|
CMD ["gunicorn", "--bind", "0.0.0.0:8000", "--workers", "3", "movienight.wsgi:application"]
|
||||||
|
|
|
@ -1,7 +1,5 @@
|
||||||
import os
|
import os
|
||||||
|
|
||||||
from django.conf import settings
|
|
||||||
|
|
||||||
from movie_db.movie_db import MovieDB
|
from movie_db.movie_db import MovieDB
|
||||||
import requests
|
import requests
|
||||||
|
|
||||||
|
@ -10,7 +8,8 @@ from movie_db.serializers import MovieSerializer, MovieResultSerializer
|
||||||
|
|
||||||
class OMDb(MovieDB):
|
class OMDb(MovieDB):
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.api_key = settings.OMDB_API_KEY
|
api_key = os.getenv("OMDB_API_KEY")
|
||||||
|
self.api_key = f"{api_key}"
|
||||||
self.base_url = "https://www.omdbapi.com/?apikey=" + self.api_key
|
self.base_url = "https://www.omdbapi.com/?apikey=" + self.api_key
|
||||||
super().__init__()
|
super().__init__()
|
||||||
|
|
||||||
|
|
|
@ -9,17 +9,4 @@ def omdb_search(request):
|
||||||
|
|
||||||
search_type = request.GET.get("type")
|
search_type = request.GET.get("type")
|
||||||
omdb = OMDb()
|
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)
|
|
||||||
|
|
|
@ -6,19 +6,19 @@ from movie_manager.models import Movie, MovieList, Schedule, Showing
|
||||||
# Register your models here.
|
# Register your models here.
|
||||||
@admin.register(Movie)
|
@admin.register(Movie)
|
||||||
class MovieAdmin(admin.ModelAdmin):
|
class MovieAdmin(admin.ModelAdmin):
|
||||||
list_display = ["title", "imdb_id", "added_by"]
|
pass
|
||||||
|
|
||||||
|
|
||||||
@admin.register(MovieList)
|
@admin.register(MovieList)
|
||||||
class MovieListAdmin(admin.ModelAdmin):
|
class MovieListAdmin(admin.ModelAdmin):
|
||||||
list_display = ["name", "owner"]
|
pass
|
||||||
|
|
||||||
|
|
||||||
@admin.register(Schedule)
|
@admin.register(Schedule)
|
||||||
class ScheduleAdmin(admin.ModelAdmin):
|
class ScheduleAdmin(admin.ModelAdmin):
|
||||||
list_display = ["name", "owner"]
|
pass
|
||||||
|
|
||||||
|
|
||||||
@admin.register(Showing)
|
@admin.register(Showing)
|
||||||
class ShowingAdmin(admin.ModelAdmin):
|
class ShowingAdmin(admin.ModelAdmin):
|
||||||
list_display = ["showtime", "movie"]
|
pass
|
||||||
|
|
|
@ -5,55 +5,21 @@ from movie_manager.models import Movie, MovieList, Schedule, Showing
|
||||||
|
|
||||||
|
|
||||||
class MovieSerializer(serializers.ModelSerializer):
|
class MovieSerializer(serializers.ModelSerializer):
|
||||||
has_been_scheduled = serializers.SerializerMethodField()
|
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = Movie
|
model = Movie
|
||||||
fields = [
|
fields = "__all__"
|
||||||
"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 MovieListListSerializer(serializers.ModelSerializer):
|
|
||||||
movie_count = serializers.SerializerMethodField()
|
|
||||||
|
|
||||||
class Meta:
|
|
||||||
model = MovieList
|
|
||||||
fields = ["id", "name", "owner", "public", "movie_count"]
|
|
||||||
|
|
||||||
def get_movie_count(self, obj):
|
|
||||||
return obj.movies.count()
|
|
||||||
|
|
||||||
|
|
||||||
class MovieListSerializer(serializers.ModelSerializer):
|
class MovieListSerializer(serializers.ModelSerializer):
|
||||||
|
movie_count = serializers.SerializerMethodField()
|
||||||
movies = MovieSerializer(read_only=True, many=True)
|
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:
|
class Meta:
|
||||||
model = MovieList
|
model = MovieList
|
||||||
fields = ["id", "name", "owner", "public", "movies"]
|
fields = ["id", "name", "owner", "public", "movies", "movie_count"]
|
||||||
|
|
||||||
|
def get_movie_count(self, obj):
|
||||||
|
return len(obj.movies.all())
|
||||||
|
|
||||||
|
|
||||||
class UserSerializer(serializers.Serializer):
|
class UserSerializer(serializers.Serializer):
|
||||||
|
|
|
@ -1,10 +1,9 @@
|
||||||
import datetime
|
import datetime
|
||||||
|
import json
|
||||||
|
|
||||||
from django.db.models import QuerySet
|
|
||||||
from django.http import JsonResponse
|
from django.http import JsonResponse
|
||||||
from django.contrib.auth.models import User
|
from django.contrib.auth.models import User
|
||||||
from django.utils.dateparse import parse_datetime
|
from django.utils.dateparse import parse_datetime
|
||||||
from django.db import models
|
|
||||||
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, api_view
|
from rest_framework.decorators import action, api_view
|
||||||
|
@ -17,7 +16,7 @@ from movie_manager.serializers import (
|
||||||
MovieListSerializer,
|
MovieListSerializer,
|
||||||
MovieSerializer,
|
MovieSerializer,
|
||||||
ScheduleSerializer,
|
ScheduleSerializer,
|
||||||
ShowingSerializer, MovieListListSerializer,
|
ShowingSerializer,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@ -34,62 +33,13 @@ class MovieViewset(viewsets.ModelViewSet):
|
||||||
|
|
||||||
serializer_class = MovieSerializer
|
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):
|
class MovieListViewset(viewsets.ModelViewSet):
|
||||||
queryset = MovieList.objects.all()
|
queryset = MovieList.objects.all().order_by("name")
|
||||||
authentication_classes = [TokenAuthentication]
|
authentication_classes = [TokenAuthentication]
|
||||||
permission_classes = [permissions.IsAuthenticated | ReadOnly]
|
permission_classes = [permissions.IsAuthenticated | ReadOnly]
|
||||||
|
|
||||||
def get_serializer_class(self):
|
serializer_class = MovieListSerializer
|
||||||
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):
|
def create(self, request, *args, **kwargs):
|
||||||
movie_list = MovieList.objects.create(
|
movie_list = MovieList.objects.create(
|
||||||
|
@ -172,9 +122,7 @@ class ScheduleViewset(viewsets.ModelViewSet):
|
||||||
def retrieve(self, request, pk=None, *args, **kwargs):
|
def retrieve(self, request, pk=None, *args, **kwargs):
|
||||||
# Get the schedule instance
|
# Get the schedule instance
|
||||||
instance = self.get_object()
|
instance = self.get_object()
|
||||||
now = datetime.datetime.now()
|
today = datetime.datetime.now()
|
||||||
# get time from start of day
|
|
||||||
today = datetime.datetime(now.year, now.month, now.day)
|
|
||||||
|
|
||||||
upcoming_showings = Showing.objects.filter(
|
upcoming_showings = Showing.objects.filter(
|
||||||
showtime__gte=today, schedule=instance
|
showtime__gte=today, schedule=instance
|
||||||
|
|
|
@ -126,8 +126,6 @@ USE_I18N = True
|
||||||
|
|
||||||
USE_TZ = True
|
USE_TZ = True
|
||||||
|
|
||||||
OMDB_API_KEY = os.environ.get("OMDB_API_KEY")
|
|
||||||
|
|
||||||
# Django Rest Framework
|
# Django Rest Framework
|
||||||
REST_FRAMEWORK = {
|
REST_FRAMEWORK = {
|
||||||
"DEFAULT_AUTHENTICATION_CLASSES": [
|
"DEFAULT_AUTHENTICATION_CLASSES": [
|
||||||
|
|
Loading…
Add table
Reference in a new issue