Bienvenida

1

Todo lo que aprenderás sobre Django

Cimientos

2

Arquitectura de una aplicación

3

The Twelve-Factor App

4

Codebase: Settings modular

5

Codebase: Dependencias y archivos de docker

6

Codebase: Docker

7

Setups alternativos

Modelos

8

Herencia de modelos

9

Proxy models

10

App de usuarios

11

Organizando modelos en un paquete de Django

12

Creando el modelo de perfil de usuario

13

Solución del reto: arreglando la migración de users a user

14

Aplicación y modelo de círculos

15

Migraciones y admin de círculos

Introducción a Django REST Framework

16

Aprende cómo construir tu propio API con Django Rest Framework

17

Vistas, URLs y Parsers de DRF

18

Serializers

19

Buenas prácticas para el diseño de un API REST

20

Request, response, renderers y parsers

Real DRF

21

Autenticación y tipos de autenticación

22

APIView

23

Creando el token de autorización

24

User sign up

25

Limitar login a usuarios con cuenta verificada

26

Configurar envío de email

27

Instalar PyJWT y generar tokens

28

Verificar cuenta usando JWT

29

Actualizar modelo de circle (membership)

30

Crear CircleViewSet

31

Añadiendo autorización y paginación

32

Creación de circulos

33

Update de círculo, custom permissions y DRF Mixins

34

Migración de vistas de usuarios a ViewSets

35

Detalle de usuario

36

Update profile data

37

List members - Recursos anidado

38

Retrieve destroy member

39

Modelo de invitaciones y manager

40

Obtener invitaciones de un miembro

41

Unirse a grupo

42

Filtrado

43

App de rides y modelos

44

Implementar la publicación de un ride

45

Validación de campos de un serializer

46

Listado de rides

47

Editar un ride

48

Unirse a viaje

49

Terminar viaje

50

Calificar viaje

Tareas asíncronas

51

¿Qué es Celery?

52

Creando tarea asíncrona

53

Creando tarea periódica

Testing

54

Python unittest y Django TestCase

55

DRF APITestCase

Django Admin

56

Admin actions: Modificar datos de un query

57

Admin actions: Regresando una respuesta HTTP

Deployment

58

Instalación de la aplicación

59

Configuración del dominio en Mailgun y del Bucket en Amazon S3

60

Configuración final de Docker Container usando Supervisor

61

Tutorial de despliegue de la aplicación

62

Futuros pasos y cierre del curso

No tienes acceso a esta clase

¡Continúa aprendiendo! Únete y comienza a potenciar tu carrera

Serializers

18/62
Recursos

Los serializers son contenedores que nos permiten tomar tipos de datos complejos, convertirlos en datos nativos de python para después poderlos usar como JSON o XML. Son contenedores que amoldan datos para que cumplan con las condiciones de los serializers y sean llevados a un tipo de estos y después estos puedan ser transformados en otra cosa.

Aportes 14

Preguntas 4

Ordenar por:

¿Quieres ver más aportes, preguntas y respuestas de la comunidad?

o inicia sesión.

Iba a preguntar ¿Por qué Pablo hace

from rest_framework import serializers

en lugar de

from rest_framework.serializers import Serializer

?
Pero caí en cuenta que Pablo usa los Fields dentro de serializers y me di cuenta que muchas veces por eso es importante traer todo el módulo xD

Si uno hace buen uso de los fields en el modelo, no es necesario reescribirlos en el serializer. se puede usar Modelserializer para que los field usados en el serializer sean iguales a los del modelo:

from rest_framework.serializers import ModelSerializer
from profiles.models import Profile


class UserSerializer(ModelSerializer):
    class Meta:
        model = Profile
        fields = ('__all__')

Por lo que entiendo estos archivos son una base donde se realiza toda la configuración general, si es así entonces estos archivos los puedo usar para cualquier otro proyecto??
O sea aún no comienza a realizar las aplicaciones particulares del proyecto, no??

Por lo que entendi aquí esta mostrando toda la configuración base para el proyecto y que puede servir para cualquier proyecto.
Si es así entonces puedo usar todo estos archivos para otro proyecto???
Esto esto así o estoy equivocado??
Saludos

Para que el serializer filtre solo los publicos:

serializer = CircleSerializer(circles.filter(is_public=True), many=True)

me quedaron un par de dudas en el serializer ya que no me queda muy claro la diferencia entre poner el serializer con data Serializer(data=tu_objeto) a pasarlo sin el data Serializer(tu_objeto). cuando se manda data puedo hacer uso de is_valid pero si no lo paso no … como puedo validar cuando no le paso data= ya que si intento serializar una tupla si mando data debe ser un array pero sin data puedo mandarlo sin problema pero no puedo usar la funcion is_valid()

Tengo entendido que uno de los principios de Django y Python en general es DRY, evitar repetirse.

Ahora, veo que agregar validadores a nivel de la vista a través de los Serializers se hace para evitar que la validación llegue al modelo y sea propagada de vuelta a la vista, pero al mismo tiempo estamos duplicando la definición de la validación de los campos.

Entonces, entiendo que para este caso, esta duplicidad implica muy poco riesgo de tener que actualizarla de forma constante, ya que cambiar validaciones de modelos y/o modificar columnas de una tabla no es una acción demasiado frecuente. Entonces por la parte de DRY, creo que es muy aceptable romperlo un poco aquí.

Pero lo que no comprendo aún, es, ¿qué ventajas nos ofrece el que la validación no llegue hasta el modelo? Mi intuición me dice que al hacerlo de esta forma es más fácil trabajar con Django RestFramework.

No estoy muy seguro, ¿ustedes que piensan?

DRF es excelente, que manera de ahorrar tareas tan repetitivas en la creacion de una API

Algun simil a este proyecto pero con MYSQL??

Es hermosooooo DRF. 😍

<h3>Serializers</h3>

In computing, serialization or serialisation is the process of translating a data structure or object state into a format that can be stored or transmitted and reconstructed later.

CreateCircleSerializer code

CircleSerializer code