View Javadoc

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  }