added svcapi ui and camunda code
[it/otf.git] / otf-service-api / src / main / java / org / oran / otf / common / utility / permissions / UserPermission.java
1 /*  Copyright (c) 2019 AT&T Intellectual Property.                             #\r
2 #                                                                              #\r
3 #   Licensed under the Apache License, Version 2.0 (the "License");            #\r
4 #   you may not use this file except in compliance with the License.           #\r
5 #   You may obtain a copy of the License at                                    #\r
6 #                                                                              #\r
7 #       http://www.apache.org/licenses/LICENSE-2.0                             #\r
8 #                                                                              #\r
9 #   Unless required by applicable law or agreed to in writing, software        #\r
10 #   distributed under the License is distributed on an "AS IS" BASIS,          #\r
11 #   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.   #\r
12 #   See the License for the specific language governing permissions and        #\r
13 #   limitations under the License.                                             #\r
14 ##############################################################################*/\r
15 \r
16 \r
17 package org.oran.otf.common.utility.permissions;\r
18 \r
19 import org.oran.otf.common.model.User;\r
20 \r
21 import java.util.Map;\r
22 import java.util.Set;\r
23 \r
24 public class UserPermission {\r
25     private User user;\r
26     private Map<String,Set<String>> userAccessMap;\r
27 \r
28     public User getUser() {\r
29         return user;\r
30     }\r
31 \r
32     public void setUser(User user) {\r
33         this.user = user;\r
34     }\r
35 \r
36     public Map<String, Set<String>> getUserAccessMap() {\r
37         return userAccessMap;\r
38     }\r
39 \r
40     public void setUserAccessMap(Map<String,Set<String>> userAccessMap) {\r
41         this.userAccessMap = userAccessMap;\r
42     }\r
43 \r
44     public boolean  hasAccessTo(String groupId,String permission) {\r
45         if (userAccessMap.get(groupId) == null) {\r
46             return false;\r
47         }\r
48         Set<String> group = userAccessMap.get(groupId);\r
49         return group.stream().anyMatch(groupPermission->groupPermission.equalsIgnoreCase(permission));\r
50     }\r
51     public class Permission{\r
52         public static final String READ = "READ";\r
53         public static final String WRITE = "WRITE";\r
54         public static final String EXECUTE = "EXECUTE";\r
55         public static final String DELETE = "DELETE";\r
56         public static final String MANAGEMENT ="MANAGEMENT";\r
57     }\r
58 }\r