/** * Copyright (c) 2013-2016, The SeedStack authors <http://seedstack.org> * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ package org.seedstack.seed.rest.internal.exceptionmapper; import org.seedstack.seed.security.AuthorizationException; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import javax.ws.rs.core.Response; import javax.ws.rs.ext.ExceptionMapper; import javax.ws.rs.ext.Provider; /** * Default {@link AuthorizationException} exception mapper which returns an HTTP status 403 (forbidden). */ @Provider public class AuthorizationExceptionMapper implements ExceptionMapper<AuthorizationException> { private static final Logger logger = LoggerFactory.getLogger(AuthorizationExceptionMapper.class); @Override public Response toResponse(AuthorizationException exception) { logger.debug(exception.getMessage(), exception); return Response.status(Response.Status.FORBIDDEN).entity("Forbidden").build(); } }