mirror of
https://github.com/scm-manager/scm-manager.git
synced 2025-11-10 07:25:44 +01:00
Map com.fasterxml.jackson.core.JsonParseException to proper response
This commit is contained in:
@@ -4,10 +4,8 @@ import org.slf4j.Logger;
|
|||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.slf4j.MDC;
|
import org.slf4j.MDC;
|
||||||
import sonia.scm.api.v2.resources.ErrorDto;
|
import sonia.scm.api.v2.resources.ErrorDto;
|
||||||
import sonia.scm.api.v2.resources.ExceptionWithContextToErrorDtoMapper;
|
|
||||||
import sonia.scm.web.VndMediaType;
|
import sonia.scm.web.VndMediaType;
|
||||||
|
|
||||||
import javax.inject.Inject;
|
|
||||||
import javax.ws.rs.core.Response;
|
import javax.ws.rs.core.Response;
|
||||||
import javax.ws.rs.ext.ExceptionMapper;
|
import javax.ws.rs.ext.ExceptionMapper;
|
||||||
import javax.ws.rs.ext.Provider;
|
import javax.ws.rs.ext.Provider;
|
||||||
@@ -20,16 +18,9 @@ public class FallbackExceptionMapper implements ExceptionMapper<Exception> {
|
|||||||
|
|
||||||
private static final String ERROR_CODE = "CmR8GCJb31";
|
private static final String ERROR_CODE = "CmR8GCJb31";
|
||||||
|
|
||||||
private final ExceptionWithContextToErrorDtoMapper mapper;
|
|
||||||
|
|
||||||
@Inject
|
|
||||||
public FallbackExceptionMapper(ExceptionWithContextToErrorDtoMapper mapper) {
|
|
||||||
this.mapper = mapper;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Response toResponse(Exception exception) {
|
public Response toResponse(Exception exception) {
|
||||||
logger.debug("map {} to status code 500", exception);
|
logger.warn("mapping unexpected {} to status code 500", exception.getClass().getName(), exception);
|
||||||
ErrorDto errorDto = new ErrorDto();
|
ErrorDto errorDto = new ErrorDto();
|
||||||
errorDto.setMessage("internal server error");
|
errorDto.setMessage("internal server error");
|
||||||
errorDto.setContext(Collections.emptyList());
|
errorDto.setContext(Collections.emptyList());
|
||||||
|
|||||||
@@ -0,0 +1,35 @@
|
|||||||
|
package sonia.scm.api;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.core.JsonParseException;
|
||||||
|
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 JsonParseExceptionMapper implements ExceptionMapper<JsonParseException> {
|
||||||
|
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(JsonParseExceptionMapper.class);
|
||||||
|
|
||||||
|
private static final String ERROR_CODE = "2VRCrvpL71";
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Response toResponse(JsonParseException exception) {
|
||||||
|
logger.trace("got illegal json: {}", exception.getMessage());
|
||||||
|
ErrorDto errorDto = new ErrorDto();
|
||||||
|
errorDto.setMessage("illegal json content: " + exception.getMessage());
|
||||||
|
errorDto.setContext(Collections.emptyList());
|
||||||
|
errorDto.setErrorCode(ERROR_CODE);
|
||||||
|
errorDto.setTransactionId(MDC.get("transaction_id"));
|
||||||
|
return Response.status(Response.Status.BAD_REQUEST)
|
||||||
|
.entity(errorDto)
|
||||||
|
.type(VndMediaType.ERROR_TYPE)
|
||||||
|
.build();
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user