com.oath.micro.server.general.exception.mapper.GeneralExceptionMapper Maven / Gradle / Ivy
package com.oath.micro.server.general.exception.mapper;
import java.util.Map;
import java.util.Optional;
import java.util.UUID;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response;
import javax.ws.rs.core.Response.Status;
import javax.ws.rs.ext.ExceptionMapper;
import javax.ws.rs.ext.Provider;
import cyclops.data.tuple.Tuple2;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;
import static cyclops.data.tuple.Tuple.tuple;
@Service
@Provider
public class GeneralExceptionMapper implements ExceptionMapper {
final Logger logger;
private Boolean showDetails;
GeneralExceptionMapper(Logger logger, boolean showDetails){
this.logger = logger;
this.showDetails = showDetails;
}
@Autowired
GeneralExceptionMapper(@Value("${micro.general.exception.mapper.details:true}") Boolean showDetails){
this(LoggerFactory.getLogger(GeneralExceptionMapper.class), showDetails);
}
Map, Tuple2> mapOfExceptionsToErrorCodes = MapOfExceptionsToErrorCodes.getMergedMappings();
private Optional> find(Class extends Exception> c) {
for (Map.Entry, Tuple2> entry : this.mapOfExceptionsToErrorCodes.entrySet()) {
if (entry.getKey().isAssignableFrom(c)) {
return Optional.ofNullable(entry.getValue());
}
}
return Optional.empty();
}
@Override
public Response toResponse(final Exception ex) {
final String errorTrackingId = UUID.randomUUID().toString();
Tuple2 error = new Tuple2<>(MapOfExceptionsToErrorCodes.INTERNAL_SERVER_ERROR, Status.INTERNAL_SERVER_ERROR);
Optional> errorFromLookup = find(ex.getClass());
if (errorFromLookup.isPresent()) {
error = errorFromLookup.get();
} else {
if(ex instanceof javax.ws.rs.WebApplicationException){
javax.ws.rs.WebApplicationException rsEx = ((javax.ws.rs.WebApplicationException)ex);
error = tuple(rsEx.getResponse().getStatusInfo().getReasonPhrase(),Status.fromStatusCode(rsEx.getResponse().getStatus()));
}
}
logger.error(String.format("%s Error id: %s, %s", error._1(), errorTrackingId, ex.getMessage()), ex);
Response.ResponseBuilder responseBuilder = Response.status(error._2()).type(MediaType.APPLICATION_JSON_TYPE);
if (showDetails) {
responseBuilder.entity(new ExceptionWrapper(error._1(), String.format("Error id: %s %s", errorTrackingId, ex.getMessage())));
} else {
responseBuilder.entity(new ExceptionWrapper(MapOfExceptionsToErrorCodes.INTERNAL_SERVER_ERROR, errorTrackingId));
}
return responseBuilder.build();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy