Esta clase es magistral. Cada vez me doy cuenta de que no conozco nada jajaja
Introducción al proyecto del curso y su arquitectura
Arquitectura de un backend complejo
Estructuras de datos para nuestro proyecto
Creando la estructura principal
Estructura inicial del proyecto: API y rutas
Aislar el código de la base de datos
Rutas para usuarios
Documentación de nuestra API
Autenticación basada en tokens
JWT: Gestión de acceso
Autenticación: registro
Autenticación: login
Autenticación: cifrar contraseñas para evitar problemas de seguridad
Autenticación: gestión de permisos
Comprobar verificación con token
Gestión avanzada de errores: Throw
Almacenando datos: MySql
Base de datos real: MySQL
Completando la base de datos
Relacionando entidades: follow
Posts y likes
Microservicios en Node
Microservicios: pros y contras
Separando la base de datos a un microservicio
Conectando con nuestro microservicio de datos
Separando los posts a un microservicio
Gestión de microservicios con PM2
Puesta en producción serverless
Microservicios en Zeit Now, serverless y seguridad
Variables de entorno en Now y despliegue local
Cacheando nuestra aplicación
Caché como un microservicio. Redis
Conectando el microservicio a Redis
Conectar la API al caché
Puesta en producción en virtual machine
Desplegando los servicios de Node
Nginx como proxy inverso
No tienes acceso a esta clase
¡Continúa aprendiendo! Únete y comienza a potenciar tu carrera
Convierte tus certificados en títulos universitarios en USA
Antes: $249
Paga en 4 cuotas sin intereses
Termina en:
Carlos Hernández
Aportes 24
Preguntas 4
Esta clase es magistral. Cada vez me doy cuenta de que no conozco nada jajaja
les comparto mi implementación del middleware de error
const Sentry = require('@sentry/node');
const debug = require('debug')('api:error');
const config = require('./../config');
const response = require('./../network/response');
const sentryUrl = `https://${config.sentry.dns}@sentry.io/${config.sentry.id}`;
Sentry.init({ dsn: sentryUrl });
function withErrorStack(err, stack) {
if (config.dev) {
return { ...err, stack }
}
}
function logErrors(err, req, res, next) {
Sentry.captureException(err);
debug(err.stack);
next(err);
}
function errorHandler(err, req, res, next) {
const { statusCode } = err;
response.error(req, res, withErrorStack(err, err.stack), statusCode);
}
module.exports = {
logErrors,
errorHandler,
}
en el curso de backend con node y el de passport js, se trabaja con un libreria @hapi, la cual tiene un modulo para el manejo de errores que es @hapi/boom y @hapi/joi para validaciones, con unas simples lineas se le da manejo al error, es muy practico, lo mismo con las validaciones.
La clase es buena aunque se agradecería que no repita nombres de archivos ya que eso genera mucha confusión. En utils tenemos error.js y en network tenemos errors.js
Por si alguien mas le da el mismo error que a mi, “app use requires a middleware” La solucion es la darle require se le coloca llaves:
const {errors} = require('../network/errors');
Usando custom error en lugar de throw new Error()
creando la fucnion error en la carpeta util, ya no haria falta el error.js de la carpeta network?
Fantástico ahora mi código está mucho más organizado con los cursos de carlos, que fácil es aprender Node con él.
Entiendo el uso del helper lo que no entiendo es porqué repetimos en network/response la misma logica del status code y status msg.
Ahora tenemos todos los errores centralizados dentro de utils/error, con lo cual no deberiamos llamar a network error sino llamar a utils/error y es este error catcheado por network error.
Podemos modificar entonces network/response la function error
exports.error = (req, res, message, status) => {
res.status(status).send({
error: true,
status,
body: message
});
};
¿como funciona el next?
Definitivamente, muy buena clase
Fijesé que igual le devuelve un error:false cuando debería ser true, supongo que se solucionara en adelante.
Estoy super confundido con el archivo “secure” en users, hay una función “checkAuth” que recibe el parametro “action” y adentro “middleware” con los argumentos “req, res, next”. Si mal no entiendo, middleware se ejecuta cuando se devuelve al invocar checkAuth desde router.put, pero el único argumento es lo que afecta al switch, ¿los parámetros req, res y next cómo le llegan al middleware?
Aqui un poco mas de infromación. Acerca de este trucaso para el manejo de errores.
sacando brillo a el mundo magico de nodejs
Fantástico ahora mi código está mucho más organizado con los cursos de carlos, que fácil es aprender Node con él.
Excelente clase!
Para las personas que tengan dudas con los middlewares les dejo la documentación donde vienen explicadas algunas cosas así como el uso e implementación de ellos.
Me agrada como explica Carlos, pero marea un montón tantos archivos con el mismo nombre, el naming de archivos acá es más complicado que el código
Genial esta clase, el orden para realizar el proyecto me parece genial, aunque a veces al repetir algunos nombres en carpetas me he confundido, ese orden hace que el código en general sea más fácil de entender
Justo ese error, estaba pensando como solucionarlo
✌
el middleware de errors que le pasamos a la app de express manejara todos los errores y excepciones no manejadas?
¿Quieres ver más aportes, preguntas y respuestas de la comunidad?