GlobalExceptionHandler.java
package com.medilabo.solutions.assessment.exception;
import java.time.LocalDateTime;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.RestControllerAdvice;
import com.fasterxml.jackson.annotation.JsonFormat;
import feign.FeignException;
import lombok.Data;
@RestControllerAdvice
public class GlobalExceptionHandler {
private static final Logger logger = LoggerFactory.getLogger(GlobalExceptionHandler.class);
@ExceptionHandler(ResourceNotFoundException.class)
public ResponseEntity<ErrorResponse> handleResourceNotFoundException(ResourceNotFoundException ex) {
logger.error("Resource not found: {}", ex.getMessage());
ErrorResponse errorResponse = new ErrorResponse(
HttpStatus.NOT_FOUND.value(),
"Resource Not Found",
ex.getMessage());
return ResponseEntity.status(HttpStatus.NOT_FOUND).body(errorResponse);
}
@ExceptionHandler(FeignException.class)
public ResponseEntity<ErrorResponse> handleFeignException(FeignException ex) {
logger.error("Feign client error: {} - {}", ex.status(), ex.getMessage());
String message = "Error communicating with external service";
if (ex.status() == 404) {
message = "Requested resource not found in external service";
}
ErrorResponse errorResponse = new ErrorResponse(
ex.status(),
"External Service Error",
message);
return ResponseEntity.status(ex.status()).body(errorResponse);
}
@ExceptionHandler(Exception.class)
public ResponseEntity<ErrorResponse> handleGenericException(Exception ex) {
logger.error("Unexpected error: {}", ex.getMessage(), ex);
ErrorResponse errorResponse = new ErrorResponse(
HttpStatus.BAD_REQUEST.value(),
"Internal Server Error",
"An unexpected error occurred");
return ResponseEntity.status(HttpStatus.BAD_REQUEST).body(errorResponse);
}
@Data
public static class ErrorResponse {
private int status;
private String error;
private String message;
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private LocalDateTime timestamp;
public ErrorResponse(int status, String error, String message) {
this.status = status;
this.error = error;
this.message = message;
this.timestamp = LocalDateTime.now();
}
}
}