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

com.aeontronix.enhancedmule.tools.anypoint.provisioning.RoleDescriptor Maven / Gradle / Ivy

/*
 * Copyright (c) Aeontronix 2020
 */

package com.aeontronix.enhancedmule.tools.anypoint.provisioning;

import com.aeontronix.enhancedmule.tools.anypoint.Environment;
import com.aeontronix.enhancedmule.tools.anypoint.NotFoundException;
import com.aeontronix.enhancedmule.tools.anypoint.Organization;
import com.aeontronix.enhancedmule.tools.role.Role;
import com.aeontronix.enhancedmule.tools.role.RoleAssignmentAddition;
import com.aeontronix.enhancedmule.tools.role.RoleGroup;
import com.aeontronix.enhancedmule.tools.util.HttpException;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.aeontronix.commons.StringUtils;
import com.aeontronix.commons.ThreadUtils;
import org.jetbrains.annotations.NotNull;
import org.slf4j.Logger;

import java.io.IOException;
import java.io.Writer;
import java.util.*;
import java.util.stream.Collectors;

import static com.aeontronix.enhancedmule.tools.util.MarkdownHelper.writeHeader;
import static com.aeontronix.enhancedmule.tools.util.MarkdownHelper.writeParagraph;
import static org.slf4j.LoggerFactory.getLogger;

public class RoleDescriptor {
    private static final Logger logger = getLogger(RoleDescriptor.class);
    private String id;
    private String name;
    private String description;
    private Set externalNames;
    private List permissions;

    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    @JsonProperty(required = false)
    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getDescription() {
        return description;
    }

    public void setDescription(String description) {
        this.description = description;
    }

    @NotNull
    public Set getExternalNames() {
        if (externalNames == null) {
            externalNames = new HashSet<>();
        }
        return externalNames;
    }

    public void setExternalNames(@NotNull Set externalNames) {
        this.externalNames = externalNames;
    }

    @NotNull
    public List getPermissions() {
        if (permissions == null) {
            permissions = new ArrayList<>();
        }
        return permissions;
    }

    public void setPermissions(@NotNull List permissions) {
        this.permissions = permissions;
    }

    public void provision(Organization org, ArrayList envs) throws ProvisioningException, HttpException {
        try {
            if (StringUtils.isBlank(name)) {
                throw new ProvisioningException("role name missing");
            }
            List roleGroups = org.findAllRoleGroups().getAll();
            Optional roleGroupOpt = roleGroups.stream().filter(roleGroup -> roleGroup.getName().equalsIgnoreCase(name)).findFirst();
            RoleGroup roleGroup;
            if (!roleGroupOpt.isPresent()) {
                roleGroup = org.createRoleGroup(name, description);
            } else {
                roleGroup = roleGroupOpt.get();
                if (!roleGroup.same(this)) {
                    roleGroup.setDescription(description);
                    roleGroup.setExternalNames(externalNames);
                    roleGroup.update();
                }
            }
            if (roleGroup.isEditable()) {
                do {
                    roleGroup.deleteAllRoleAssignment();
                    ThreadUtils.sleep(1000);
                } while (roleGroup.findRoleAssignments().size() > 0);
                if (permissions != null && !permissions.isEmpty()) {
                    Map roles = roleGroup.getParent().findAllRolesIndexedByName();
                    HashSet assignments = new HashSet<>();
                    for (RolePermissionDescriptor permission : permissions) {
                        Role role = roles.get(permission.getName());
                        if (role == null) {
                            throw new ProvisioningException("Role not found: " + permission.getName());
                        }
                        List scopes = permission.getScopes();
                        if (!scopes.isEmpty()) {
                            for (ProvisioningScope scope : scopes) {
                                for (Environment matchEnvironment : scope.matchEnvironments(envs)) {
                                    logger.debug("Assigning role " + role.getName() + " with env " + matchEnvironment.getName() + " to " + roleGroup.getName());
                                    assignments.add(new RoleAssignmentAddition(role.getId(), matchEnvironment));
                                }
                            }
                        } else {
                            logger.debug("Assigning role " + role.getName() + " to " + roleGroup.getName());
                            assignments.add(new RoleAssignmentAddition(role.getId(), null));
                        }
                    }
                    try {
                        roleGroup.assignRoles(assignments);
                        assignments.clear();
                    } catch (HttpException | RuntimeException e) {
                        logger.error("Failed to assign roles to " + roleGroup.getName() + " : " + assignments);
                        throw e;
                    }
                }
            }
        } catch (NotFoundException e) {
            throw new ProvisioningException(e);
        }
    }

    public void toMarkdown(Writer w, int headingDepth) throws IOException {
        writeHeader(w, headingDepth + 2, getName());
        if (StringUtils.isNotEmpty(getDescription())) {
            writeParagraph(w, "Description: " + getDescription());
        }
        if (!getExternalNames().isEmpty()) {
            writeParagraph(w, "Mapped to SSO Roles: " + String.join(", ", getExternalNames()));
        }
        if (!getPermissions().isEmpty()) {
            writeParagraph(w, "Permissions:");
        }
        for (RolePermissionDescriptor permission : getPermissions()) {
            StringBuilder perms = new StringBuilder();
            perms.append("- ").append(permission.getName());
            if (!permission.getScopes().isEmpty()) {
                List scopes = permission.getScopes().stream().map(ProvisioningScope::toShortMarkdown)
                        .collect(Collectors.toList());
                perms.append(" for environment");
                if (scopes.size() > 1) {
                    perms.append("s");
                }
                perms.append(": ").append(String.join(", ", scopes));
            }
            writeParagraph(w, perms.toString());
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy