001/* 002 * The contents of this file are subject to the license and copyright 003 * detailed in the LICENSE and NOTICE files at the root of the source 004 * tree. 005 */ 006package org.fcrepo.http.commons.exceptionhandlers; 007 008import org.slf4j.Logger; 009 010import javax.ws.rs.BadRequestException; 011import javax.ws.rs.core.Response; 012import javax.ws.rs.ext.ExceptionMapper; 013import javax.ws.rs.ext.Provider; 014 015import static javax.ws.rs.core.Response.Status.BAD_REQUEST; 016import static javax.ws.rs.core.Response.status; 017import static org.slf4j.LoggerFactory.getLogger; 018import static org.fcrepo.http.commons.domain.RDFMediaType.TEXT_PLAIN_WITH_CHARSET; 019 020/** 021 * For generic BadRequestExceptions. 022 * 023 * @author md5wz 024 * @since November 18, 2014 025 */ 026@Provider 027public class BadRequestExceptionMapper implements 028 ExceptionMapper<BadRequestException>, ExceptionDebugLogging { 029 030 private static final Logger LOGGER = getLogger(BadRequestExceptionMapper.class); 031 032 @Override 033 public Response toResponse(final BadRequestException e) { 034 LOGGER.error("BadRequestExceptionMapper caught an exception: {}", e.getMessage()); 035 debugException(this, e, LOGGER); 036 return status(BAD_REQUEST).entity(e.getMessage()).type(TEXT_PLAIN_WITH_CHARSET).build(); 037 } 038 039}