
com.yammer.dropwizard.jersey.LoggingExceptionMapper Maven / Gradle / Ivy
package com.yammer.dropwizard.jersey;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import javax.ws.rs.WebApplicationException;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response;
import javax.ws.rs.ext.ExceptionMapper;
import javax.ws.rs.ext.Provider;
import java.util.Random;
// TODO: 10/12/11 -- write tests for LoggingExceptionMapper
// TODO: 10/12/11 -- write docs for LoggingExceptionMapper
@Provider
public class LoggingExceptionMapper implements ExceptionMapper {
private static final Logger LOGGER = LoggerFactory.getLogger(LoggingExceptionMapper.class);
private static final Random RANDOM = new Random();
@Override
public Response toResponse(E exception) {
if (exception instanceof WebApplicationException) {
return ((WebApplicationException) exception).getResponse();
}
final long id = randomId();
logException(id, exception);
return Response.status(Response.Status.INTERNAL_SERVER_ERROR)
.type(MediaType.TEXT_PLAIN_TYPE)
.entity(formatResponseEntity(id, exception))
.build();
}
protected void logException(long id, E exception) {
LOGGER.error(formatLogMessage(id, exception), exception);
}
protected String formatResponseEntity(long id, Throwable exception) {
return String.format("There was an error processing your request. It has been logged (ID %016x).\n", id);
}
protected String formatLogMessage(long id, Throwable exception) {
return String.format("Error handling a request: %016x", id);
}
protected static long randomId() {
return RANDOM.nextLong();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy