Autenticación y Seguridad en CRUD de Posts en Rails
Clase 24 de 33 • Curso de Creación de APIs con Ruby on Rails
Contenido del curso
- 3

Creación de APIs con Rails: Proyecto Blog API paso a paso
04:37 - 4

Configuración de Gemas para Pruebas en Proyectos Rails
06:26 - 5

Configuración de Gemas en Proyectos Rails: Arspec, Factory Bot y Database Cleaner
07:25 - 6

Implementación de un Health Check Endpoint en API con RSpec
12:28 - 7

Diseño de Casos de Uso y Diagramas de Entidad para Aplicaciones
03:16 - 8

Diagrama de Entidad Relación para Modelos de Aplicación
01:41 - 9

Modelado de Aplicaciones con TDD en Rails
05:59 - 10

Validaciones y Pruebas TDD en Rails: Modelos USR y Post
07:07 - 11

Implementación de Endpoints para Listar y Mostrar Posts con TDD
15:12 - 12

Implementación de Pruebas y Controladores en Rails
10:34 - 13

Creación y Actualización de Posts con Pruebas TDD
10:12 - 14

Implementación de Métodos y Manejo de Excepciones en Rails API
10:23 - 15

Serialización de Modelos en Rails con ActiveModelSerializer
06:03 - 16

Búsqueda y Filtrado de Posts por Título con TDD
05:57 - 17

Implementación de Búsqueda de Posts con Servicios en Rails
06:06 - 18

Problema N+1 en Rails: Detección y Solución Eficaz
04:40 - 19

Identificación y solución del problema N+1 en Rails
06:20 - 20

Flujo de Autenticación en APIs con Tokens y Proveedores
05:29 - 21

Pruebas de Autenticación en API con Test Driven Development
12:17 - 22

Autenticación con Tokens: Implementación en Rails API
05:54 - 23

Autenticación de Usuarios en Controladores Rails
09:20 - 24

Autenticación y Seguridad en CRUD de Posts en Rails
09:17 - 25

Pruebas de Creación y Actualización con Autenticación en Rails
14:21 - 26

Pruebas de API con Postman: Ejecución y Verificación de Respuestas
10:43 - 27

Caching en Aplicaciones Web: Funciones y Niveles
07:15 - 28

Aceleración de Búsquedas en Rails con Caching
08:23 - 29

Background Jobs en Rails: Conceptos y Funcionalidades
05:45 - 30

Procesamiento en Background y Envío de Correos con Rails
09:45 - 31

Envío de Correos en Rails con ActionMailer y Background Jobs
11:06 - 32
Autenticación y Autorización con JWT y Auth0 en Aplicaciones Web
03:48
¿Cómo manejar la autenticación en los métodos de creación, actualización y visualización?
La importancia de la autenticación en aplicaciones web no puede subestimarse, particularmente cuando se trata de operaciones como crear, actualizar o visualizar elementos. En este contexto, aprender a verificar si un usuario está autorizado para realizar estas acciones es crucial. Aquí exploraremos cómo implementar y mejorar las funcionalidades de autenticación para garantizar que solo los usuarios autorizados puedan llevar a cabo estas operaciones en el controlador de publicaciones.
¿Qué consideraciones hay para el método de creación?
-
Asociación directa con el usuario autenticado: Para que una publicación se cree correctamente, debe estar asociada al usuario que está actualmente autenticado. Esto significa que no deberíamos recibir un
user IDarbitrario desde el cliente, sino utilizar elcurrent userya configurado en el métodoautenticate_user. -
Uso del modelo de relación: En el modelo
User, se debe definir que un usuario tiene muchas publicaciones (has_many :posts). Así, puedes utilizar métodos de asociación para crear publicaciones pertenecientes al usuario actual, comocurrent_user.posts.create(params).
¿Cómo se verifica el propietario de una publicación en el método de actualización?
-
Validar la propiedad de la publicación: Al actualizar, es esencial verificar que la publicación pertenece al
current_user. Utilizandocurrent_user.posts.find(params[:id]), nos aseguramos de que solo pueda modificarse si es propiedad del usuario que está autenticado. -
Revisión de parámetros de actualización: Aunque no se menciona un cambio directo en los parámetros, es bueno asegurarse que se están enviando y validando los parámetros correctos para la actualización.
¿Qué lógica implementar en el método de visualización?
-
Verificación de acceso: Aunque no es necesario autenticar al usuario para visualizar una publicación, debemos verificar su estado de publicación. Si el
postes público, entonces se puede renderizar sin más. En caso contrario, se debe:- Comprobar si hay un
current user. - Verificar que la publicación pertenece al
current user.
- Comprobar si hay un
-
Manejo de errores: Si ninguna de las condiciones se cumple, debemos renderizar un estado
404 Not Found, indicando que la publicación no está disponible para el usuario.
¿Cómo solucionar errores comunes en las pruebas?
Al correr pruebas de integración para verificar la funcionalidad, pueden surgir errores que necesitan ser depurados:
-
Diferencia de tipo en identificadores: Asegúrate de que tu prueba no espere un símbolo (
:id) cuando el payload entrega un string ("id"). Utiliza el métodowith_indifferent_accesspara permitir el acceso flexible a valores de hash como símbolos o strings. -
Depuración de métodos no definidos o errores de argumento: Asegúrate de que los métodos sean llamados correctamente y que los argumentos requeridos estén bien estipulados. Por ejemplo, si se espera un método
atributo, pero se invoca comoatributos, seguramente arrojará un error.
¿Qué sigue después de implementar la lógica?
Aunque ya hemos implementado la lógica dentro del controlador para gestionar la autenticación y autorización en create, update, y show, es crucial escribir pruebas para verificar los casos de creación y actualización específicamente. Estas pruebas garantizarán que la lógica implementada funcione según lo esperado, brindando confianza en la robustez y seguridad del sistema. Así que, manos a la obra en la siguiente clase. ¡Sigue creciendo en tu aprendizaje!