All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.molgenis.bootstrap.populate.PermissionPopulator Maven / Gradle / Ivy

The newest version!
package org.molgenis.bootstrap.populate;

import static com.google.common.collect.Multimaps.filterEntries;
import static java.util.Objects.requireNonNull;

import com.google.common.collect.Multimap;
import java.util.Collection;
import org.molgenis.data.security.permission.PermissionService;
import org.molgenis.data.security.permission.model.Permission;
import org.molgenis.security.core.PermissionSet;
import org.molgenis.util.Pair;
import org.springframework.context.ApplicationContext;
import org.springframework.security.acls.model.ObjectIdentity;
import org.springframework.security.acls.model.Sid;
import org.springframework.stereotype.Component;
import org.springframework.transaction.annotation.Transactional;

/**
 * Discovers {@link PermissionRegistry application system permission registries} and populates
 * permissions.
 */
@Component
public class PermissionPopulator {
  private final PermissionService permissionService;

  PermissionPopulator(PermissionService permissionService) {
    this.permissionService = requireNonNull(permissionService);
  }

  @Transactional
  public void populate(ApplicationContext applicationContext) {
    Collection registries =
        applicationContext.getBeansOfType(PermissionRegistry.class).values();
    registries.forEach(this::populate);
  }

  private void populate(PermissionRegistry systemPermissionRegistry) {
    Multimap> systemPermissions =
        systemPermissionRegistry.getPermissions();

    Multimap> newSystemPermissions =
        filterEntries(
            systemPermissions,
            entry -> entry != null && isNewPermission(entry.getKey(), entry.getValue()));

    newSystemPermissions.asMap().forEach(this::populate);
  }

  private boolean isNewPermission(
      ObjectIdentity objectIdentity, Pair permission) {
    return !permissionService.exists(objectIdentity, permission.getB());
  }

  private void populate(ObjectIdentity objectIdentity, Collection> pairs) {
    pairs.forEach(
        pair ->
            permissionService.createPermission(
                Permission.create(objectIdentity, pair.getB(), pair.getA())));
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy