mirror of
https://github.com/scm-manager/scm-manager.git
synced 2025-11-09 15:05:44 +01:00
Merge roles from multiple repository permissions
This commit is contained in:
@@ -18,6 +18,7 @@ import java.util.Collection;
|
|||||||
import java.util.Enumeration;
|
import java.util.Enumeration;
|
||||||
import java.util.LinkedHashSet;
|
import java.util.LinkedHashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Optional;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
import static java.util.Collections.unmodifiableCollection;
|
import static java.util.Collections.unmodifiableCollection;
|
||||||
@@ -63,7 +64,7 @@ public class RepositoryPermissionProvider {
|
|||||||
|
|
||||||
RepositoryPermissionsRoot repositoryPermissionsRoot = parsePermissionDescriptor(context, descriptorUrl);
|
RepositoryPermissionsRoot repositoryPermissionsRoot = parsePermissionDescriptor(context, descriptorUrl);
|
||||||
availableVerbs.addAll(repositoryPermissionsRoot.verbs.verbs);
|
availableVerbs.addAll(repositoryPermissionsRoot.verbs.verbs);
|
||||||
availableRoles.addAll(repositoryPermissionsRoot.roles.roles);
|
mergeRolesInto(availableRoles, repositoryPermissionsRoot.roles.roles);
|
||||||
}
|
}
|
||||||
} catch (IOException ex) {
|
} catch (IOException ex) {
|
||||||
logger.error("could not read permission descriptors", ex);
|
logger.error("could not read permission descriptors", ex);
|
||||||
@@ -75,7 +76,22 @@ public class RepositoryPermissionProvider {
|
|||||||
return new AvailableRepositoryPermissions(availableVerbs, availableRoles);
|
return new AvailableRepositoryPermissions(availableVerbs, availableRoles);
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
private static void mergeRolesInto(Collection<RoleDescriptor> targetRoles, List<RoleDescriptor> additionalRoles) {
|
||||||
|
additionalRoles.forEach(r -> addOrMergeInto(targetRoles, r));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void addOrMergeInto(Collection<RoleDescriptor> targetRoles, RoleDescriptor additionalRole) {
|
||||||
|
Optional<RoleDescriptor> existingRole = targetRoles
|
||||||
|
.stream()
|
||||||
|
.filter(r -> r.name.equals(additionalRole.name))
|
||||||
|
.findFirst();
|
||||||
|
if (existingRole.isPresent()) {
|
||||||
|
existingRole.get().verbs.verbs.addAll(additionalRole.verbs.verbs);
|
||||||
|
} else {
|
||||||
|
targetRoles.add(additionalRole);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private static RepositoryPermissionsRoot parsePermissionDescriptor(JAXBContext context, URL descriptorUrl) {
|
private static RepositoryPermissionsRoot parsePermissionDescriptor(JAXBContext context, URL descriptorUrl) {
|
||||||
try {
|
try {
|
||||||
RepositoryPermissionsRoot descriptorWrapper =
|
RepositoryPermissionsRoot descriptorWrapper =
|
||||||
|
|||||||
@@ -8,6 +8,7 @@ import sonia.scm.util.ClassLoaders;
|
|||||||
|
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
import java.util.Collection;
|
||||||
|
|
||||||
import static org.assertj.core.api.Assertions.assertThat;
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
import static org.junit.jupiter.api.Assertions.fail;
|
import static org.junit.jupiter.api.Assertions.fail;
|
||||||
@@ -48,6 +49,18 @@ class RepositoryPermissionProviderTest {
|
|||||||
assertThat(repositoryPermissionProvider.availableVerbs()).contains(allVerbsFromRepositoryClass);
|
assertThat(repositoryPermissionProvider.availableVerbs()).contains(allVerbsFromRepositoryClass);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void shouldMergeRepositoryRoles() {
|
||||||
|
Collection<String> verbsInMergedRole = repositoryPermissionProvider
|
||||||
|
.availableRoles()
|
||||||
|
.stream()
|
||||||
|
.filter(r -> "READ".equals(r.getName()))
|
||||||
|
.findFirst()
|
||||||
|
.get()
|
||||||
|
.getVerbs();
|
||||||
|
assertThat(verbsInMergedRole).contains("read", "pull", "test");
|
||||||
|
}
|
||||||
|
|
||||||
private String getString(Field field) {
|
private String getString(Field field) {
|
||||||
try {
|
try {
|
||||||
return (String) field.get(null);
|
return (String) field.get(null);
|
||||||
|
|||||||
@@ -0,0 +1,13 @@
|
|||||||
|
<repository-permissions>
|
||||||
|
<verbs>
|
||||||
|
<verb>test</verb>
|
||||||
|
</verbs>
|
||||||
|
<roles>
|
||||||
|
<role>
|
||||||
|
<name>READ</name>
|
||||||
|
<verbs>
|
||||||
|
<verb>test</verb>
|
||||||
|
</verbs>
|
||||||
|
</role>
|
||||||
|
</roles>
|
||||||
|
</repository-permissions>
|
||||||
Reference in New Issue
Block a user