Diseño de Casos de Uso y Diagramas de Entidad para Aplicaciones
Clase 7 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
¿Cuáles son los casos de uso para los diferentes usuarios en la aplicación?
El diseño de una aplicación requiere una comprensión clara de los casos de uso que respaldan las funcionalidades necesarias para los usuarios. En este proyecto específico, debemos determinar los casos de uso para dos tipos principales de usuarios: el usuario autenticado y el no autenticado.
Casos de uso para usuarios no autenticados
Un usuario no autenticado se encuentra limitado en términos de acceso y acciones dentro de la aplicación. Aquí se listan las funcionalidades principales que deben estar soportadas:
-
Autenticación:
- Login
- Creación de cuenta
-
Contenido:
- Listar posts publicados
-
Búsqueda:
- Filtrar o buscar posts
Estas funcionalidades permiten a los usuarios no autenticados interactuar de manera básica con el contenido de la aplicación, brindándoles una primera impresión del servicio antes de que decidan registrarse.
Casos de uso para usuarios autenticados
Las posibilidades se expanden considerablemente para los usuarios autenticados, ofreciéndoles una experiencia más rica y personalizada:
-
Manejo de cuenta:
- Logout
-
Contenido y creación:
- Creación de posts
- Creación de borradores
- Publicación de borradores
-
Edición:
- Editar un post existente
Los usuarios autenticados no solo tienen acceso a la funcionalidad básica, sino que también pueden contribuir contenido propio, gestionarlo y modificarlo según sea necesario.
¿Cómo definimos las entidades y relaciones para almacenar información?
La estructuración correcta de bases de datos es crucial para mantener y recuperar información de manera eficiente. En este proyecto, un diagrama de entidad-relación será nuestra guía para identificar las tablas necesarias en la base de datos.
Entidades principales
-
Usuarios:
- Almacena la información personal de los usuarios y su estado de autenticación.
-
Posts:
- Guarda los detalles de los artículos o entradas creadas por los usuarios.
-
Borradores:
- Contiene los posts que aún no se han publicado y están en estado de edición.
Cada una de estas entidades será indispensable para el funcionamiento de las diferentes funcionalidades diseñadas en la arquitectura de la aplicación.
Relaciones entre entidades
Los diagramas de entidad-relación nos ayudan a visualizar cómo interactúan las distintas partes de la base de datos:
-
Relación Usuario-Post:
- Un usuario puede crear múltiples posts (relación uno a muchos).
-
Relación Usuario-Borrador:
- Similar al post, un usuario puede mantener varios borradores antes de publicarlos.
Con estos diagramas, aseguramos que tanto los casos de uso como los componentes de la base de datos están alineados, brindando así una estructura sólida para el desarrollo de la aplicación.
Con esta base clara tanto de funcionalidades como de estructuras de datos, puedes comenzar a desarrollar una aplicación robusta y eficiente. ¡Explora, innova y sigue aprendiendo mientras avanzas!