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}