All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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 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