Refactor: to properly use DRFs view functions
This commit is contained in:
parent
3d7e25e20c
commit
3657b4423f
3 changed files with 47 additions and 66 deletions
|
@ -1,3 +1,4 @@
|
||||||
|
from typing import Any, Dict, List, Optional
|
||||||
from rest_framework import serializers
|
from rest_framework import serializers
|
||||||
|
|
||||||
from django.utils.timezone import localtime
|
from django.utils.timezone import localtime
|
||||||
|
@ -5,21 +6,6 @@ from django.utils.timezone import localtime
|
||||||
from apps.archive.models import PostModel
|
from apps.archive.models import PostModel
|
||||||
|
|
||||||
|
|
||||||
class PostListSerializer(serializers.Serializer):
|
|
||||||
count = serializers.SerializerMethodField()
|
|
||||||
posts = serializers.SerializerMethodField()
|
|
||||||
|
|
||||||
class Meta:
|
|
||||||
model = PostModel
|
|
||||||
fields = ["count", "posts"]
|
|
||||||
|
|
||||||
def get_count(self, obj):
|
|
||||||
return obj.count()
|
|
||||||
|
|
||||||
def get_posts(self, obj):
|
|
||||||
return PostPreviewSerializer(obj.all(), many=True).data
|
|
||||||
|
|
||||||
|
|
||||||
class PostPreviewSerializer(serializers.ModelSerializer):
|
class PostPreviewSerializer(serializers.ModelSerializer):
|
||||||
description = serializers.SerializerMethodField()
|
description = serializers.SerializerMethodField()
|
||||||
date = serializers.SerializerMethodField()
|
date = serializers.SerializerMethodField()
|
||||||
|
@ -44,46 +30,37 @@ class PostPreviewSerializer(serializers.ModelSerializer):
|
||||||
"tags",
|
"tags",
|
||||||
]
|
]
|
||||||
|
|
||||||
def get_description(self, obj):
|
def get_description(self, obj: PostModel) -> Optional[str]:
|
||||||
return obj.description.first().content
|
return obj.description.first().content if obj.description.exists() else None
|
||||||
|
|
||||||
def get_source_site(self, obj):
|
def get_source_site(self, obj: PostModel) -> Dict[str, str]:
|
||||||
return {
|
return {
|
||||||
"slug": obj.source_site.slug,
|
"slug": obj.source_site.slug,
|
||||||
"name": obj.source_site.name,
|
"name": obj.source_site.name,
|
||||||
}
|
}
|
||||||
|
|
||||||
def get_category(self, obj):
|
def get_category(self, obj: PostModel) -> List[Dict[str, str]]:
|
||||||
data = []
|
return [{"slug": i.slug, "name": i.name} for i in obj.category.all()]
|
||||||
for i in obj.category.all():
|
|
||||||
data.append({"slug": i.slug, "name": i.name})
|
|
||||||
return data
|
|
||||||
|
|
||||||
def get_creator(self, obj):
|
|
||||||
avatar_url = None
|
|
||||||
if obj.creator.avatar:
|
|
||||||
avatar_url = obj.creator.avatar.file.url
|
|
||||||
|
|
||||||
|
def get_creator(self, obj: PostModel) -> Dict[str, Optional[str]]:
|
||||||
|
avatar_url = obj.creator.avatar.file.url if obj.creator.avatar else None
|
||||||
return {
|
return {
|
||||||
"slug": obj.creator.slug,
|
"slug": obj.creator.slug,
|
||||||
"name": obj.creator.name,
|
"name": obj.creator.name,
|
||||||
"avatar": avatar_url,
|
"avatar": avatar_url,
|
||||||
}
|
}
|
||||||
|
|
||||||
def get_date(self, obj):
|
def get_date(self, obj: PostModel) -> Dict[str, str]:
|
||||||
return {
|
return {
|
||||||
"created": localtime(obj.date_created).isoformat(),
|
"created": localtime(obj.date_created).isoformat(),
|
||||||
"imported": localtime(obj.date_imported).isoformat(),
|
"imported": localtime(obj.date_imported).isoformat(),
|
||||||
"last_import": localtime(obj.date_last_import).isoformat(),
|
"last_import": localtime(obj.date_last_import).isoformat(),
|
||||||
}
|
}
|
||||||
|
|
||||||
def get_media(self, obj):
|
def get_media(self, obj: PostModel) -> List[Dict[str, str]]:
|
||||||
data = []
|
return [{"type": i.mimetype, "src": i.file.url} for i in obj.files.all()]
|
||||||
for i in obj.files.all():
|
|
||||||
data.append({"type": i.mimetype, "src": i.file.url})
|
|
||||||
return data
|
|
||||||
|
|
||||||
def get_tags(self, obj):
|
def get_tags(self, obj: PostModel) -> List[str]:
|
||||||
return [tag.slug for tag in obj.tags.all()]
|
return [tag.slug for tag in obj.tags.all()]
|
||||||
|
|
||||||
|
|
||||||
|
@ -109,39 +86,35 @@ class PostSerializer(serializers.ModelSerializer):
|
||||||
"tags",
|
"tags",
|
||||||
]
|
]
|
||||||
|
|
||||||
def get_source_site(self, obj):
|
def get_source_site(self, obj) -> Dict[str, str]:
|
||||||
return {
|
return {
|
||||||
"slug": obj.source_site.slug,
|
"slug": obj.source_site.slug,
|
||||||
"name": obj.source_site.name,
|
"name": obj.source_site.name,
|
||||||
}
|
}
|
||||||
|
|
||||||
def get_description(self, obj):
|
def get_description(self, obj) -> Dict[str, str]:
|
||||||
return {
|
return {
|
||||||
"count": obj.description.count(),
|
"count": obj.description.count(),
|
||||||
"content": obj.description.first().content,
|
"content": obj.description.first().content,
|
||||||
}
|
}
|
||||||
|
|
||||||
def get_creator(self, obj):
|
def get_creator(self, obj) -> Dict[str, str]:
|
||||||
return {
|
return {
|
||||||
"slug": obj.creator.slug,
|
"slug": obj.creator.slug,
|
||||||
"name": obj.creator.name,
|
"name": obj.creator.name,
|
||||||
# "source_site": {
|
|
||||||
# "slug": obj.creator.source_site.slug,
|
|
||||||
# "name": obj.creator.source_site.name,
|
|
||||||
# },
|
|
||||||
}
|
}
|
||||||
|
|
||||||
def get_tags(self, obj):
|
def get_tags(self, obj) -> List[str]:
|
||||||
return [tag.slug for tag in obj.tags.all()]
|
return [tag.slug for tag in obj.tags.all()]
|
||||||
|
|
||||||
def get_date(self, obj):
|
def get_date(self, obj) -> Dict[str, str]:
|
||||||
return {
|
return {
|
||||||
"created": localtime(obj.date_created).isoformat(),
|
"created": localtime(obj.date_created).isoformat(),
|
||||||
"imported": localtime(obj.date_imported).isoformat(),
|
"imported": localtime(obj.date_imported).isoformat(),
|
||||||
"last_import": localtime(obj.date_last_import).isoformat(),
|
"last_import": localtime(obj.date_last_import).isoformat(),
|
||||||
}
|
}
|
||||||
|
|
||||||
def get_media(self, obj):
|
def get_media(self, obj) -> List[Dict[str, str]]:
|
||||||
data = []
|
data = []
|
||||||
for i in obj.files.all():
|
for i in obj.files.all():
|
||||||
data.append({"type": i.mimetype, "url": i.file.url})
|
data.append({"type": i.mimetype, "url": i.file.url})
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
from django.urls import path
|
from django.urls import path
|
||||||
|
|
||||||
from api.posts.views import PostView, PostListView
|
from api.posts.views import PostDetailView, PostListView
|
||||||
|
|
||||||
urlpatterns = [
|
urlpatterns = [
|
||||||
path("<str:post_id>/", PostView.as_view(), name="post_details"),
|
path("<str:post_id>/", PostDetailView.as_view(), name="post_detail"),
|
||||||
path("", PostListView.as_view(), name="post_list"),
|
path("", PostListView.as_view(), name="post_list"),
|
||||||
]
|
]
|
||||||
|
|
|
@ -1,34 +1,42 @@
|
||||||
|
from rest_framework import generics
|
||||||
from rest_framework.response import Response
|
from rest_framework.response import Response
|
||||||
from rest_framework.views import APIView
|
from rest_framework.views import APIView
|
||||||
from rest_framework.permissions import IsAuthenticated
|
from rest_framework.permissions import IsAuthenticated
|
||||||
|
|
||||||
from apps.archive.models import PostModel
|
from apps.archive.models import PostModel
|
||||||
|
|
||||||
from .serializers import PostListSerializer, PostSerializer
|
from .serializers import PostPreviewSerializer, PostSerializer
|
||||||
|
|
||||||
|
|
||||||
class PostListView(APIView):
|
class PostListView(generics.ListAPIView):
|
||||||
permission_classes = [IsAuthenticated]
|
permission_classes = [IsAuthenticated]
|
||||||
|
serializer_class = (
|
||||||
|
PostPreviewSerializer # Each post will be serialized using this serializer
|
||||||
|
)
|
||||||
|
|
||||||
def get(self, request):
|
def get_queryset(self):
|
||||||
user = request.user.userprofile
|
user = self.request.user.userprofile
|
||||||
|
|
||||||
if user.show_mature:
|
if user.show_mature:
|
||||||
posts = PostModel.objects.all().order_by("-date_created")
|
queryset = PostModel.objects.all()
|
||||||
else:
|
else:
|
||||||
posts = PostModel.objects.filter(mature=False).order_by("-date_created")
|
queryset = PostModel.objects.filter(mature=False)
|
||||||
serializer = PostListSerializer(posts)
|
return queryset.order_by("-date_created")
|
||||||
return Response(serializer.data)
|
|
||||||
|
def list(self, request, *args, **kwargs):
|
||||||
|
"""
|
||||||
|
Overriding list() allows us to return a custom response structure,
|
||||||
|
for example including a count and a key 'posts' instead of DRF's default 'results'.
|
||||||
|
"""
|
||||||
|
queryset = self.filter_queryset(self.get_queryset())
|
||||||
|
serializer = self.get_serializer(queryset, many=True)
|
||||||
|
data = {"count": queryset.count(), "posts": serializer.data}
|
||||||
|
return Response(data)
|
||||||
|
|
||||||
|
|
||||||
class PostView(APIView):
|
class PostDetailView(generics.RetrieveAPIView):
|
||||||
permission_classes = [IsAuthenticated]
|
permission_classes = [IsAuthenticated]
|
||||||
|
serializer_class = PostSerializer
|
||||||
def get(self, request, post_id):
|
lookup_field = (
|
||||||
try:
|
"post_id" # This tells DRF to use the "post_id" URL kwarg for lookups.
|
||||||
post_instance = PostModel.objects.get(post_id=post_id)
|
)
|
||||||
except PostModel.DoesNotExist:
|
queryset = PostModel.objects.all()
|
||||||
raise NotFound(detail="Post not found.")
|
|
||||||
|
|
||||||
serializer = PostSerializer(post_instance)
|
|
||||||
return Response(serializer.data)
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue