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

A煤n no tienes acceso a esta clase

Crea una cuenta y contin煤a viendo este curso

Verificar cuenta usando JWT

28/62
Recursos

Aportes 21

Preguntas 2

Ordenar por:

驴Quieres ver m谩s aportes, preguntas y respuestas de la comunidad? Crea una cuenta o inicia sesi贸n.

Pablo es un excelente profesor.

Platzi, me encantar铆a ver un curso completo y avanzado de django con react. Por supuesto, con Pablo como profesor!

Es inc贸modo cuando el profesor escribe el c贸digo en la parte baja de la pantalla, en la 煤ltima l铆nea disponible. Es hace que cuando se pause la clase, los controles del video tapen la 煤ltima l铆nea de c贸digo y no se pueda ver.

Buenas, tengo una duda sobre el metodo validate_token. S茅 que se llama cuando llamamos serializer.is_valid() en la vista AccountVerificationAPIView, pero porque pasa esto? no veo que la clase Serializer tenga una metodo validate_token(). O es que is_valid() llama a todos los metodos que se llamen validate_NOMBRE_DE_CAMPO (en este caso token)

Nadie sabe c贸mo implementar JWT para un login??

Que chimba de clase 馃ぉ. Es intuitivo. Dificil pero muy interesante. As铆 se aprende o se aprende

Me parece que podr铆amos retornar el payload para reemplazar data en siguientes validaciones, una vez se decodifica, ya se verific贸 tanto la firma como la expiraci贸n del token.

con docker, hay alguna manera de enlazar pgadmin4 con el ?

alguien me explica porque se tiene que usar la sercret key en la generaci贸n de token con JWT 鈥 es decir, es espec铆ficamente necesario.? y porqu茅

Serializer AccountVerification, m茅todos para validar token y actualizar usuario verificado

Creaci贸n de vista para verificar JWT

Verificaci贸n

se puede usar el jwtoken para el inicio de sesi贸n?

Que tal quiz谩s le sirva a alguien.
Al hacer el decode en el serializer obtenia un error tenia esto:
payload = jwt.decode(data, .......)y tuve que hacer
payload = jwt.decode(data.get('token'), ...
No estoy seguro del porque a Pablo si le funciona alguien m谩s tuvo este error?

En el ejemplo se utiliz贸 el m茅todo POST y se env铆a el token generado al endpoint en el body de la petici贸n, este par谩metro deber铆a llegar por petici贸n GET al endpoint para que el usuario pueda activar su cuenta al hacer clic no?

todo me sale perfecto hasta cuando hago login, no encuentr el error, valido el token, lo envia al 鈥渇rontend鈥, pero cuando me hago el login con el usuario y password me sale lo siguiente

password=secretpassword -b
HTTP/1.1 400 Bad Request
Allow: POST, OPTIONS
Content-Length: 81
Content-Type: application/json
Date: Wed, 13 May 2020 10:35:35 GMT
Server: WSGIServer/0.2 CPython/3.6.10
Vary: Accept, Cookie
X-Frame-Options: DENY
x-xss-protection: 1; mode=block

{
    "email": [
        "Enter a valid email address."
    ],
    "password": [
        "This field is required."
    ]
}

estoy metiendo en

Tengo una duda conceptual:

  • Siento que en algunas partes se copia el mismo c贸digo en vez de extender las clases, lo que ir铆a contra lo del DRY (don麓t repeat yourself). Hay alguna raz贸n para que las clases no hereden de una gran clase? (algo as铆 como UsersAPIView(APIView)) 鈥

El punto es para saber que recomendar铆an.

Saludos y gracias

Para los que tengan el siguiente error al hacer login:

NotImplementedError:update()must be implemented.

Lo soluciones adicionando a:
class UserLoginSerializer(serializers.Serializer):

`def update(self, instance, data):
   		return instance`

馃憤馃

Serializer AccountVerification m茅todo validate_token

Vista AccountVerificationAPIView

URL verificaci贸n token