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

Aprende todo un fin de semana sin pagar una suscripci贸n 馃敟

Aprende todo un fin de semana sin pagar una suscripci贸n 馃敟

Reg铆strate

Comienza en:

4D
2H
0M
2S

List members - Recursos anidado

37/62
Recursos

Aportes 9

Preguntas 1

Ordenar por:

驴Quieres ver m谩s aportes, preguntas y respuestas de la comunidad?

o inicia sesi贸n.

durante la declaraci贸n de URL, hubo un typo en la expresi贸n regular por lo tanto no va funcionar con slug_name que tengan n煤meros, ac谩 dejo la correci贸n:

router.register(r'circles/(?P<slug_name>[a-zA-Z0-9_-]+)/members',
                membership_views.MembershipViewSet, base_name='membership')```

En el minuto 11:50 no se ve que es lo que esta haciendo, pueden editar esa parte por favor. Gracias.

El hecho de mostrar tanta informacion es bueno? A mi parecer el user deberia de traer el email nada mas, porque no creo que sea relevante, si lo fuera entonces tambien deberiamos mostrar el user en circles.

Es posible hacer lo mismo agregando la l贸gica del dispatch al init de MembershipViewSet ?

Creo que no est谩 el video en donde se crea el ProfileModelSerializers, por lo que al realizar la petici贸n a /circles/platzi-chile/members/ el campo 鈥減rofile鈥 no aparece.

Si te pas贸 lo anterior, como a m铆, realiza los siguientes pasos:

Primero, agrega el campo 鈥減rofile鈥 en par谩metros de fields en la clase Meta del UserModelSerializer. Adem谩s, debes importar 鈥淧rofileModelSerializer鈥 y mencionar que profile corresponde a su serializer:

from cride.users.models import User, Profile

# Serializers
from cride.users.serializers.profiles import ProfileModelSerializer

# Utilities
from datetime import timedelta
import jwt


class UserModelSerializer(serializers.ModelSerializer):
    """User model Serializer."""

    profile = ProfileModelSerializer(read_only=True)

    class Meta:
        model = User
        fields = (
            'username',
            'first_name',
            'last_name',
            'email',
            'phone_number',
            'profile'
        )

Luego, en la carpeta cride.users.serializers crea el archivo 鈥profiles.py鈥 agregando lo siguiente:

"""Profile serializer."""

# Django REST Framework
from rest_framework import serializers

# Models
from cride.users.models import Profile


class ProfileModelSerializer(serializers.ModelSerializer):
    """Profile model serializer."""

    class Meta:
        """Meta class."""

        model = Profile
        fields = (
            'picture',
            'biography',
            'rides_taken',
            'rides_offered',
            'reputation'
        )
        read_only_fields = (
            'rides_taken',
            'rides_offered',
            'reputation'
        )

Serializers relations

Para URLs de varios niveles, es com煤n requerir los objetos del primer nivel en los sucesores, lo cual puede hacerse extendiendo el m茅todo dispatch

Que hermosura !!

馃馃憤