added svcapi ui and camunda code
[it/otf.git] / otf-service-api / src / main / java / org / oran / otf / common / utility / permissions / UserPermission.java
diff --git a/otf-service-api/src/main/java/org/oran/otf/common/utility/permissions/UserPermission.java b/otf-service-api/src/main/java/org/oran/otf/common/utility/permissions/UserPermission.java
new file mode 100644 (file)
index 0000000..1883721
--- /dev/null
@@ -0,0 +1,58 @@
+/*  Copyright (c) 2019 AT&T Intellectual Property.                             #\r
+#                                                                              #\r
+#   Licensed under the Apache License, Version 2.0 (the "License");            #\r
+#   you may not use this file except in compliance with the License.           #\r
+#   You may obtain a copy of the License at                                    #\r
+#                                                                              #\r
+#       http://www.apache.org/licenses/LICENSE-2.0                             #\r
+#                                                                              #\r
+#   Unless required by applicable law or agreed to in writing, software        #\r
+#   distributed under the License is distributed on an "AS IS" BASIS,          #\r
+#   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.   #\r
+#   See the License for the specific language governing permissions and        #\r
+#   limitations under the License.                                             #\r
+##############################################################################*/\r
+\r
+\r
+package org.oran.otf.common.utility.permissions;\r
+\r
+import org.oran.otf.common.model.User;\r
+\r
+import java.util.Map;\r
+import java.util.Set;\r
+\r
+public class UserPermission {\r
+    private User user;\r
+    private Map<String,Set<String>> userAccessMap;\r
+\r
+    public User getUser() {\r
+        return user;\r
+    }\r
+\r
+    public void setUser(User user) {\r
+        this.user = user;\r
+    }\r
+\r
+    public Map<String, Set<String>> getUserAccessMap() {\r
+        return userAccessMap;\r
+    }\r
+\r
+    public void setUserAccessMap(Map<String,Set<String>> userAccessMap) {\r
+        this.userAccessMap = userAccessMap;\r
+    }\r
+\r
+    public boolean  hasAccessTo(String groupId,String permission) {\r
+        if (userAccessMap.get(groupId) == null) {\r
+            return false;\r
+        }\r
+        Set<String> group = userAccessMap.get(groupId);\r
+        return group.stream().anyMatch(groupPermission->groupPermission.equalsIgnoreCase(permission));\r
+    }\r
+    public class Permission{\r
+        public static final String READ = "READ";\r
+        public static final String WRITE = "WRITE";\r
+        public static final String EXECUTE = "EXECUTE";\r
+        public static final String DELETE = "DELETE";\r
+        public static final String MANAGEMENT ="MANAGEMENT";\r
+    }\r
+}\r