2018-11-02 17:12:49 +01:00
|
|
|
package sonia.scm.api;
|
|
|
|
|
|
|
|
|
|
import org.slf4j.Logger;
|
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
|
import org.slf4j.MDC;
|
|
|
|
|
import sonia.scm.api.v2.resources.ErrorDto;
|
|
|
|
|
import sonia.scm.web.VndMediaType;
|
|
|
|
|
|
|
|
|
|
import javax.ws.rs.core.Response;
|
|
|
|
|
import javax.ws.rs.ext.ExceptionMapper;
|
|
|
|
|
import javax.ws.rs.ext.Provider;
|
|
|
|
|
import java.util.Collections;
|
|
|
|
|
|
|
|
|
|
@Provider
|
|
|
|
|
public class FallbackExceptionMapper implements ExceptionMapper<Exception> {
|
|
|
|
|
|
|
|
|
|
private static final Logger logger = LoggerFactory.getLogger(FallbackExceptionMapper.class);
|
|
|
|
|
|
|
|
|
|
private static final String ERROR_CODE = "CmR8GCJb31";
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public Response toResponse(Exception exception) {
|
2018-12-21 14:05:52 +01:00
|
|
|
logger.warn("mapping unexpected {} to status code 500", exception.getClass().getName(), exception);
|
2018-11-02 17:12:49 +01:00
|
|
|
ErrorDto errorDto = new ErrorDto();
|
|
|
|
|
errorDto.setMessage("internal server error");
|
|
|
|
|
errorDto.setContext(Collections.emptyList());
|
|
|
|
|
errorDto.setErrorCode(ERROR_CODE);
|
|
|
|
|
errorDto.setTransactionId(MDC.get("transaction_id"));
|
|
|
|
|
return Response.status(Response.Status.INTERNAL_SERVER_ERROR)
|
|
|
|
|
.entity(errorDto)
|
|
|
|
|
.type(VndMediaType.ERROR_TYPE)
|
|
|
|
|
.build();
|
|
|
|
|
}
|
|
|
|
|
}
|