com.cleverpine.viravaspringhelper.config.RoleConfig Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of cp-virava-spring-helper Show documentation
Show all versions of cp-virava-spring-helper Show documentation
Library for Spring Framework projects using Virava
package com.cleverpine.viravaspringhelper.config;
import com.cleverpine.viravaspringhelper.core.BaseResource;
import com.cleverpine.viravaspringhelper.core.BaseRole;
import com.cleverpine.viravaspringhelper.dto.Permission;
import com.cleverpine.viravaspringhelper.dto.PermissionBuilder;
import com.cleverpine.viravaspringhelper.dto.ScopeType;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.function.Function;
import java.util.stream.Collectors;
import java.util.stream.Stream;
public class RoleConfig {
private final Map>> permissionMap;
private final List resourceList;
public RoleConfig(R[] roleArray, RE[] resourceArray) {
if (roleArray == null || roleArray.length == 0) {
throw new AssertionError("Role array cannot be null or empty!");
}
if (resourceArray == null || resourceArray.length == 0) {
throw new AssertionError("Resource array cannot be null or empty!");
}
this.permissionMap = getPermissionMap(List.of(roleArray));
this.resourceList = List.of(resourceArray);
}
public RoleConfig(List roleList, List resourceList) {
if (roleList == null || roleList.isEmpty()) {
throw new AssertionError("Role list cannot be null or empty!");
}
if (resourceList == null || resourceList.isEmpty()) {
throw new AssertionError("Resource list cannot be null or empty!");
}
this.permissionMap = getPermissionMap(roleList);
this.resourceList = Collections.unmodifiableList(resourceList);
}
private Map>> getPermissionMap(List roleList) {
return roleList.stream().collect(Collectors.toUnmodifiableMap(
R::getRoleName, r -> getResourceScopeMap(r.getPermissionList())));
}
private Map> getResourceScopeMap(List permissionList) {
return permissionList.stream().collect(Collectors.toMap(Permission::getResource, Permission::getScopeTypes));
}
private Map getDefaultPermissionList() {
return resourceList.stream().collect(Collectors.toMap(Function.identity(), PermissionBuilder::new));
}
public List getRolePermissionList(List roleList) {
if (roleList == null) {
return null;
}
var builderMap = getDefaultPermissionList();
for(String role : roleList) {
var resourceScopes = permissionMap.get(role);
if (resourceScopes == null) {
continue;
}
for (Map.Entry> entry : resourceScopes.entrySet()) {
var builder = builderMap.get(entry.getKey());
if (builder == null) {
throw new AssertionError(String.format(
"Improperly configured RoleConfig! "
+ "It has to be supplied with the full list of Resources."
+ "Resource [%s] is missing.", entry.getKey().resource()));
}
builder.addScope(entry.getValue());
}
}
return builderMap.values().stream().map(Permission::of).collect(Collectors.toList());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy