Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Para este proyecto se ocupo la libreria ffss-core-chassis para hacer uso de los modelos de error DTO, las excepciones personalizadas, controller :

  • Modelos de error (DTOs)

  • Excepciones personalizadas

  • Controller advice y handlers

...

Por lo cual los componentes mencionados a continuación que se mencionaran en esta documentación se encontrarán en dicha librería, principalmente en los módulos common y starter.

Modelo de error

Cuando se propaguen excepciones por REST o gRPC estas se devolverán bajo el siguiente modelo:

...

A continuación se describe cada campo:

message Mensaje personalizado de la excepción.

code (Obligatorio) - Nombre del Enum que represente el error. Este enum se debe de agregar en la clase com.femsa.digital.ffss.common.domain.FFSSErrorCode que se encuentra en ffss-core-chassis, módulo fss-common

description (Obligatorio) - Valor del Enum que represente el error. Este enum es el mismo descrito en el campo anterior de code.

message Mensaje personalizado de la excepción.

args args - Arreglo de errores. Cada error tiene la propiedad arg y value (llave y valor) respectivamente.

status (Obligatorio) - HttpStatus el cual debe estar formado con el valor (primeros 3 caracteres) y el nombre

¿Como propagar una excepción?

Existen dos formas de llevar a cabo la propagación de excepciones.

...

Para esta forma se tiene que llenar un objeto de tipo ErrorResponseDTO:

...

¿Que handlers cachan las excepciones para Apis

...

REST y gRPC?

Para peticiones de tipo REST la clase BaseControllerAdvice.java procesará los excepciones de tipo AbstractException, Exception, StatusRuntimeException, MethodArgumentNotValidException, etc.

...

Para poder visualizar las excepciones por gRPC se recomienda usar Postman ya que en la pestaña Response se nos mostrará de la siguiente manera:

...

Ejemplos de excepciones Api

...

REST

400 - BAD REQUEST

Los errores en los campos de entrada se concatenan en una sola cadena separados por pipes.

...

500 - INTERNAL SERVER ERROR

...

401 - UNAUTHORIZED

...

Ejemplos de excepciones por gRPC

3 - INVALID ARGUMENT

Para los errores gRPC , el campo args tendrá como valor una cadena json para almacenar el arreglo de errores.

...