1 /* 2 * Copyright 2015 Data Archiving and Networked Services (an institute of 3 * Koninklijke Nederlandse Akademie van Wetenschappen), King's College London, 4 * Georg-August-Universitaet Goettingen Stiftung Oeffentlichen Rechts 5 * 6 * Licensed under the EUPL, Version 1.1 or – as soon they will be approved by 7 * the European Commission - subsequent versions of the EUPL (the "Licence"); 8 * You may not use this work except in compliance with the Licence. 9 * You may obtain a copy of the Licence at: 10 * 11 * https://joinup.ec.europa.eu/software/page/eupl 12 * 13 * Unless required by applicable law or agreed to in writing, software 14 * distributed under the Licence is distributed on an "AS IS" basis, 15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 16 * See the Licence for the specific language governing 17 * permissions and limitations under the Licence. 18 */ 19 20 package eu.ehri.extension.errors.mappers; 21 22 import com.google.common.collect.ImmutableMap; 23 import eu.ehri.extension.errors.WebDeserializationError; 24 import eu.ehri.project.exceptions.PermissionDenied; 25 26 import javax.ws.rs.core.Response; 27 import javax.ws.rs.core.Response.Status; 28 import javax.ws.rs.ext.ExceptionMapper; 29 import javax.ws.rs.ext.Provider; 30 31 /** 32 * Maps the {@link PermissionDenied} exception to the Unauthorized response. 33 */ 34 @Provider 35 public class PermissionDeniedMapper implements ExceptionMapper<PermissionDenied> { 36 @Override 37 public Response toResponse(final PermissionDenied e) { 38 return WebDeserializationError.errorToJson( 39 Status.FORBIDDEN, 40 ImmutableMap.of( 41 "message", e.getMessage(), 42 "accessor", e.getAccessor(), 43 "scope", e.getScope(), 44 "item", e.getEntity() 45 ) 46 ); 47 } 48 }