
Desarrollo de una API con Laravel
0%
97 lecciones 10h 14m Nuevas lecciones cada semana
En este curso aprenderemos a desarrollar, con TDD, una API que se adhiera a la especificación JSON:API utilizando Laravel.
Introducción
FREE
03:251. Introducción al curso Desarrollo de una API con Laravel
En este video te doy la bienvenida al curso y hacemos una demostración de la API que vamos a construir y las herramientas que vamos a utilizar.
FREE
11:022. Qué es una API REST
En esta lección repasamos los conceptos que debemos tener en cuenta antes de comenzar a desarrollar la API con Laravel.
FREE
11:183. Qué es la especificación JSON:API
En esta lección revisamos qué es la especificación JSON:API y por qué es buena idea utilizarla al momento de construir tus APIs.
Construyendo la API
PRO
04:374. Cómo crear el esquema de bases de datos en Laravel con Blueprint
En esta lección generamos de forma automática los modelos Article y Category con su respectivas migraciones y factories utilizando el paquete Laravel Blueprint
PRO
08:015. Implementación de la ruta para obtener artículos individuales
En esta lección implementamos gradualmente la ruta que nos devolverá un artículo específico dependiendo de su identificador, y en el proceso aprendemos a utilizar "Resources" en Laravel
PRO
07:046. Implementando la ruta para obtener todos los artículos
En esta lección utilizamos Resource Objects en conjunto con Resource Collections para devolver los recursos siguiendo la especificación JSON:API.
PRO
08:397. Implementando la ruta para crear artículos
En esta lección damos el primer paso en la implementación de la ruta para crear artículos siguiendo la especificación JSON:API
PRO
10:048. Middleware para verificar los headers JSON:API
En esta lección implementamos la verificación de los headers que indica la especificación JSON:API y en el proceso aprendemos a testear middlewares en Laravel.
PRO
05:069. Cómo modificar las peticiones HTTP en los TEST
En esta lección agregamos los headers JSON:API a todas las peticiones que se realicen mediante TESTS automatizados.
PRO
03:0410. Probando errores de validación en formato JSON
En esta lección aprendemos a testear los errores de validación en nuestra API.
PRO
06:4811. Cómo formatear los errores según la especificación JSON:API
En esta lección modificamos la respuesta json que nos provee Laravel cuando suceden errores de validación para que se adhiera al formato sugerido por la especificación JSON:API.
PRO
08:3112. Extendiendo la clase TestResponse utilizando macros
En esta lección aprendemos a utiliza macros para extender las funcionalidades de las clases que vienen con el framework de Laravel
PRO
12:1313. Validando el documento JSON:API
En esta lección creamos y testeamos un middleware que se encargue de verificar que todas las peticiones POST y PATCH contengan un documento JSON:API válido
PRO
03:2914. Cómo modificar los errores de validación en Laravel
En esta lección creamos una respuesta dedicada a formatear automáticamente todos los errores de validación según nos indica la especificación JSON:API
PRO
06:3615. Automatizando la creación del Documento JSON:API
En esta lección modificamos los test helpers para que automáticamente construyan el documento JSON:API enviándo solamente los atributos del recurso.
PRO
09:3216. Actualización de recursos siguiendo la especificación JSON:API
En esta lección modificamos los helpers tests para que nos faciliten las pruebas automatizadas al momento de verificar la actualización de recursos en la API.
PRO
05:0717. Eliminación de recursos siguiendo la especificación JSON:API
En esta lección testeamos e implementamos la ruta para eliminar recursos, y reestructuramos el controlador para evitar duplicaciones de código.
PRO
15:4118. Validación avanzada del slug
En esta lección utilizamos el slug, en lugar del id, como identificador del recurso articles, pero antes vamos a utilizar expresiones regulares para asegurarnos de que el slug tenga el formato correcto.
PRO
06:2619. Cómo ordenar registros con Eloquent
En esta lección ordenamos los registros con Eloquent dependiendo del query string sort que recibamos, tal como lo indica la especificación JSON:API.
PRO
06:1320. Cómo ordenar registros por múltiples parámetros en Laravel
En esta lección modificamos la consulta de Eloquent para permitir ordenar registros recibiendo múltiples parámetros sorts desde la url.
PRO
04:4921. Extendiendo el Query Builder con macros
En esta lección movemos la lógica de ordenar registros a un macro que podamos reutilizar en los demás modelos de Eloquent
PRO
10:4622. Implementando la paginación JSON:API
En esta lección aprendemos a modificar la paginación que viene por defecto en Laravel para que se adhiera a la especificación JSON:API
PRO
06:0123. Reorganizando Macros utilizando Mixins
En esta lección utilizamos mixins para reorganizar los macros que permiten ordenar y paginar registros.
PRO
09:4324. Cómo filtrar recursos siguiendo la especificación JSON:API
En esta lección transformamos los parámetros de la url en modificaciones a la consulta de eloquent del modelo Article.
PRO
08:0325. Utilizando Query Scopes como Filtros
En esta lección reestructuramos la implementación de los filtros para que se puedan extender utilizando Query Scopes de Eloquent.
PRO
08:1826. Cómo solicitar campos específicos de un recurso (Sparse Fieldset)
En esta lección implementamos en nuestra API lo que se conoce como Sparse Fieldset en la especificación JSON:API
PRO
04:3027. Sparse Fieldset en la ruta detalle
En esta lección continuamos con la implementación de Sparse Fieldset para la ruta de artículos individuales, y reestructuramos la implementación para que se pueda reutilizar en cualquier modelo.
PRO
11:1628. Restructurando el Laravel Resource
En esta lección simplificamos el ArticleResource y extraemos toda la lógica de construcción del documento JSON:API para que sea reutilizable en cualquier recurso que creemos a futuro.
PRO
06:0829. Simplificando la verificación de recursos JSON:API
En esta lección extendemos nuevamente el TestResponse agregando 2 nuevos métodos que nos faciliten la verificación de recursos JSON:API
PRO
09:2730. Implementando el recurso para las categorías
En esta lección utilizamos TDD para implementar las rutas index y show del recurso categorías utilizando los métodos personalizados de testing y el trait 'JsonResource' que creamos anteriormente.
PRO
10:4231. Creando un constructor de documentos JSON:API
En esta lección utilizamos TDD para crear una clase que se encargue de crear documentos JSON:API de forma fluida y orientada a objetos.
PRO
06:0032. Cómo utilizar MOCKS dentro de tests unitarios
En esta lección continuamos con el desarrollo de la clase que genera los documentos JSON:API y en el proceso aprendemos a utilizar mocks en Laravel.
PRO
07:3333. Creando un recurso con sus relaciones
En esta lección enviamos el objeto relationships para que se asocie el artículo con una categoría según lo indica la especificación JSON:API
PRO
04:3334. Cómo validar relaciones
En esta lección testeamos y agregamos las reglas de validación de la relación category al momento de crear y actualizar un artículo.
PRO
08:0535. Generando los links de relaciones (Relationship Links)
En esta lección implementamos los links de relación entre el artículo y la categoría según nos indica la especificación JSON:API
PRO
04:3236. Habilitando el query include
En esta lección creamos el primer test que verifique que podemos incluir la categoría asociada de un artículo enviando el query string '?include=category'
PRO
03:4937. Incluir relaciones de múltiples recursos
En esta lección verificamos que la ruta index también acepta el query string include para obtener las categorías asociadas de todos los artículos.
PRO
05:0038. Carga condicional de relaciones
En esta lección evitamos que se ejecuten consultas SQL adicionales (N+1) por cada relación de recurso solicitada.
PRO
03:5139. Validación de includes
En esta lección modificamos la implementación para solo procesar los includes que hayamos definido con anterioridad.
PRO
05:0640. Filtrar recursos por sus relaciones
En esta lección implementamos el filtro categories para filtrar artículos dependiendo de la categoría que le pasemos por la url
PRO
03:2141. Implementando el recurso para los autores
En esta lección testeamos e implementamos las rutas para obtener todos los autores y un autor específico.
PRO
05:0042. Cómo utilizar UUIDs como llave primaria en Eloquent
En esta lección aprendemos a implementar UUIDs en los modelos de Eloquent de una forma sencilla y reutilizable.
PRO
07:1643. Relacionando el artículo con su autor
En esta lección habilitamos la relación del artículo con su autor utilizando el UUID del usuario.
PRO
04:5344. Implementando Include y links del autor
En esta lección implementamos el include del autor en el recurso articles, y agregamos sus respectivos relationship links.
PRO
06:4345. Implementando los links de relaciones
En esta lección hacemos que los links de relaciones de la categoría y el autor, respondan a las peticiones JSON:API de tipo GET
PRO
06:0046. Implementando los links de relaciones - Parte 2
En esta lección implementamos las rutas específicas para modificar las relaciones
PRO
02:4347. Validación de los links de relaciones
En esta lección agregamos tests que verifiquen la existencia de las relaciones en la base de datos
PRO
02:4148. Actualizando la API a Laravel 9
En esta lección actualizamos rápidamente la API a la versión 9 de Laravel y lo hacemos con el respaldo de la suite de test que hemos venido construyendo en el curso.
PRO
03:3349. Cómo interceptar las excepciones HTTP en Laravel
En esta lección modificamos la respuesta de error 404 para que se adhiera a la especificación JSON:API
PRO
02:5250. Custom assertion para verificar errores JSON:API
En esta lección creamos una verificación personalizada que podamos reutilizar para verificar errores en formato JSON:API con Laravel 9
PRO
04:3051. Cómo crear excepciones personalizadas en Laravel
En esta lección creamos una Custom Exception en Laravel 9 para simplificar el método register de la clase Handler.
PRO
06:0252. Interceptando el error 400 en la API
En esta lección formateamos el código de estado HTTP 400 para que se adhiera a los objetos de error según la especificación JSON:API
PRO
09:1053. Qué son y cómo funcionan los tokens en Laravel Sanctum
En esta lección explicamos cómo funcionan los tokens o habilidades de tokens y cómo los vamos a utilizar en nuestra API con Laravel 9.
PRO
06:0254. Cómo generar tokens de acceso con Laravel Sanctum
En esta lección veremos como generar tokens de acceso, para identificar a los usuarios de la API, utilizando Laravel Sanctum.
PRO
05:4555. Validando la generación de tokens de acceso
En esta lección agregamos los tests necesarios para verificar que la generación de tokens funciona correctamente.
PRO
04:5956. Protegiendo las rutas API con Sanctum en Laravel 9
En esta lección utilizamos el middleware Auth con el guard Sanctum para proteger las rutas sensibles de la API.
PRO
02:0557. Interceptando el error de autenticación
En esta lección interceptamos la excepción AuthenticationException para convertirla en una respuesta de error adherida a la especificación JSON:API.
PRO
07:2758. Políticas de acceso para proteger la API
En esta lección utilizamos políticas de acceso para evitar que un usuario pueda editar y eliminar artículos de otros usuarios.
PRO
04:1459. Habilidades de Token dentro de Políticas de Acceso
En esta lección verificamos las habilidades de los tokens de acceso de Sanctum dentro de las políticas de acceso.
PRO
06:4860. Sistema de permisos para la API
En esta lección creamos un simple sistema de permisos en base de datos para aplicar a los usuarios y a los tokens de acceso en nuestra API con Laravel 9.
PRO
03:5761. Permisos de usuario como habilidades de token
En esta lección modificamos el LoginController para que automáticamente se asignen los permisos del usuario como habilidades del token de acceso.
PRO
07:0262. Implementando el logout en la API
En esta lección veremos cómo eliminar los tokens de acceso del usuario actualmente autenticado.
PRO
08:5963. Implementando el registro en la API
En esta lección veremos cómo registrar usuarios y validar la petición utilizando TDD.
PRO
10:2764. Reestructurando los Test Helpers
En esta lección mejoramos los Test Helpers para que sean más dinámicos y reutilizables.
PRO
04:5465. Reestructurando el From Request
En esta lección movemos la lógica de guardar artículos fuera del Form Request dentro del Article Controller.
PRO
07:5666. Json API Request Mixins
En esta lección agregamos varios métodos a la clase Request de Laravel para interactuar con el document JSON:API de forma sencilla.
PRO
07:2167. Laravel Pint y tests en paralelo
En esta lección instalamos y configuramos Pint para dar formato a nuestro código y habilitamos los tests en paralelo.
PRO
07:5168. Implementando el listado de comentarios
En esta lección comenzamos la implementación del recurso comments utilizando TDD.
PRO
09:3869. Implementando la creación de comentarios en la API
En esta lección utilizamos TDD para implementar la habilidad de los usuarios de dejar comentarios en cada artículo.
PRO
05:4470. Validación de comentarios en la API
En esta lección utilizamos TDD para implementar la validación de los comentarios.
PRO
10:2071. Edición de comentarios en la API
En esta lección implementamos con TDD la funcionalidad para editar comentarios y modificar sus relaciones y evitar que se puedan editar los comentarios de otros autores.
PRO
02:4972. Eliminación de comentarios a través de la API
En esta lección utilizamos TDD para implementar la eliminación de usuarios previa autorización utilizando políticas de acceso.
PRO
07:4073. Relación entre comentarios y artículos
En esta lección implementamos las rutas para obtener el identificador y los atributos del artículo relacionado a cada comentario.
PRO
05:3274. Reestructurando el archivo de rutas API
En esta lección modificamos el archivo de rutas API para agrupar las rutas que tienen relación entre sí, de modo que sean más fácil de modificar y leer.
PRO
06:0875. Relaciones entre comentarios y autores
En esta lección implementamos las rutas necesarias para relacionar los comentarios con sus respectivos autores.
PRO
08:0176. Relaciones de uno a muchos siguiendo la especificación JSON:API
En esta lección definimos la url para obtener múltiples identificadores de comentarios asociados a un artículo.
PRO
03:0777. Identificadores de recursos vacíos
En esta lección evitamos que la petición falle cuando intentamos obtener los comentarios de un artículo que no los tiene.
PRO
02:5078. Múltiples recursos relacionados
En esta lección definimos el endpoint para obtener todos los comentarios de un artículo específico.
PRO
07:3379. Actualizar comentarios de un artículo
En esta lección implementamos la ruta que permita, en una sola petición de tipo PATCH, enviar múltiples comentarios para actualizar su artículo asociado.
PRO
01:3580. Validando la relación contra la base de datos
En esta lección agregamos un test que verifique que los comentarios que enviemos para su actualización, existan en la base de datos.
PRO
07:3481. Incluir relaciones de uno a muchos (one to many)
En esta lección implementamos el parámetro `include` que nos permita incluir múltiples comentarios (relación de uno a muchos), al momento de obtener un artículo.
PRO
03:1182. Incluir relaciones de muchos a muchos (many to many)
En esta lección implementamos el parámetro `include` con el valor `comments` en la ruta index de los artículos.
PRO
01:0683. Comment Relationship links
En esta lección implementamos los links de relaciones en la respuesta cuando accedemos a la ruta de los comentarios.
PRO
04:4684. Cómo actualizar Laravel 9 a Laravel 10
En esta lección actualizamos la API (y sus dependencias) paso a paso, hasta llevarla a la versión 10 de Laravel.
PRO
07:2785. Mejora en el formateo de errores
En esta lección personalizamos el mensaje de error 404 dependiendo si existe o no un modelo.
PRO
03:1586. Extendiendo la clase Request de Laravel
En esta lección agregamos 2 nuevos métodos al facade Request para obtener el TYPE y el ID del recurso solicitado.
PRO
03:5087. Error de Laravel por defecto fuera del prefijo 'api'
En esta lección nos aseguramos que los errores JSON:API ocurran únicamente en las peticiones que estén dentro del prefijo 'api'
FREE
09:0988. Capturando todas las excepciones HTTP
En esta lección creamos una excepción genérica que modifique todos los errores HTTP y los convierta en errores JSON:API
FREE
05:0489. Agrupando las clases relacionadas a la especificación JSON:API
En esta lección agrupamos los archivos relevantes de la especificación JSON:API para que sea más fácil de mantener y llevar a otros proyectos.
PRO
05:5090. Comando de Artisan para generar datos de prueba en la API
En esta lección creamos un comando de artisan que nos permita rápidamente crear datos de prueba para utilizar en POSTMAN
FREE
11:5091. Testeando la JSON:API con Postman
En esta lección agregamos las peticiones en POSTMAN y solucionamos algunos errores que tenemos actualmente en nuestra API.
FREE
05:4792. Variables en Postman
En esta lección utilizamos los datos generados por el comando de artisan y las guardamos como variables de entorno en Postman para facilitar su uso.
FREE
08:3393. Probando los filtros de la API con Postman
En esta lección agregamos una petición con ejemplos en Postman para filtrar los artículos por fecha, categorías, autor y demás.
FREE
03:2094. Probando la inclusión de relaciones con Postman
En esta lección agregamos ejemplos de la precarga de la relación con el autor, la categoría y los comentarios en la petición de un artículo.
FREE
03:4295. Probando el parámetro sort en Postman
En esta lección probamos el ordenamiento de artículos por titulo, contenido y fecha utilizando Postman.
PRO
01:5296. Sparse Fieldset en Postman
En esta lección utilizamos el parámetro field para indicarle a la API qué atributos queremos recibir en la respuesta.
FREE
05:4497. Probando la autenticación con Postman
En esta lección agregamos las peticiones para hacer login, logout, registro y también para obtener al usuario "autenticado" en la API.