Add list and detail

This commit is contained in:
Andros Fenollosa
2021-07-12 23:47:31 +02:00
parent 2e3f2029d3
commit e2fb03e48c
6 changed files with 85 additions and 14 deletions

View File

@ -1,3 +0,0 @@
from django.test import TestCase
# Create your tests here.

View File

@ -1,10 +1,11 @@
# app/libros/urls.py
from django.urls import path
from app.libros.views import ping, LibrosList
from app.libros.views import *
urlpatterns = [
path("ping/", ping, name="ping"),
path("api/libros/", LibrosList.as_view()),
]
path("api/libros/<int:pk>/", LibrosDetails.as_view()),
]

View File

@ -1,10 +1,11 @@
# app/libros/views.py
from django.http import JsonResponse
from rest_framework.views import APIView # nuevo
from rest_framework.response import Response # nuevo
from rest_framework import status # nuevo
from .serializers import LibroSerializer # nuevo
from rest_framework.views import APIView
from rest_framework.response import Response
from rest_framework import status
from .serializers import LibroSerializer
from .models import Libros
def ping(request):
@ -14,9 +15,25 @@ def ping(request):
class LibrosList(APIView):
def get(self, request, format=None):
libros = Libros.objects.all().order_by('created_at')
serializer = LibroSerializer(libros, many=True)
return Response(serializer.data, status=status.HTTP_200_OK)
def post(self, request):
serializer = LibroSerializer(data=request.data)
if serializer.is_valid():
serializer.save()
return Response(serializer.data, status=status.HTTP_201_CREATED)
return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST)
return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST)
class LibrosDetails(APIView):
def get(self, request, pk, format=None):
libro = Libros.objects.filter(pk=pk).first()
serializer = LibroSerializer(libro)
if libro:
return Response(serializer.data, status=status.HTTP_200_OK)
return Response(serializer.errors, status=status.HTTP_404_NOT_FOUND)