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

org.wildfly.test.security.common.elytron.SimplePermissionMapper Maven / Gradle / Ivy

/*
 * JBoss, Home of Professional Open Source.
 * Copyright 2017, Red Hat, Inc., and individual contributors
 * as indicated by the @author tags. See the copyright.txt file in the
 * distribution for a full listing of individual contributors.
 *
 * This is free software; you can redistribute it and/or modify it
 * under the terms of the GNU Lesser General Public License as
 * published by the Free Software Foundation; either version 2.1 of
 * the License, or (at your option) any later version.
 *
 * This software is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this software; if not, write to the Free
 * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
 * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
 */

package org.wildfly.test.security.common.elytron;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;

import org.apache.commons.lang3.StringUtils;
import org.jboss.as.test.integration.management.util.CLIWrapper;

/**
 * @author Jan Martiska
 */
public class SimplePermissionMapper extends AbstractConfigurableElement implements PermissionMapper {

    private final List mappings;
    private final MappingMode mappingMode;

    private SimplePermissionMapper(Builder builder) {
        super(builder);
        this.mappings = builder.mappings;
        this.mappingMode = builder.mappingMode;
    }

    @Override
    public void create(CLIWrapper cli) throws Exception {
        final StringBuilder cliCommand = new StringBuilder();
        cliCommand.append("/subsystem=elytron/simple-permission-mapper=")
                .append(name)
                .append(":add(");
        if (mappingMode != null) {
            cliCommand.append("mapping-mode=").append(mappingMode.toString()).append(",");
        }
        cliCommand.append("permission-mappings=[");

        cliCommand.append(mappings
                .stream()
                .map(PermissionMapping::toCLIString)
                .collect(Collectors.joining(",")));

        cliCommand.append("]");
        cliCommand.append(")");

        cli.sendLine(cliCommand.toString());
    }

    @Override
    public void remove(CLIWrapper cli) throws Exception {
        cli.sendLine("/subsystem=elytron/simple-permission-mapper=" + name + ":remove");
    }

    public static Builder builder() {
        return new Builder();
    }

    /**
     * Builder to build {@link UndertowSslContext}. The name attribute refers to ssl-context capability name.
     */
    public static final class Builder
            extends AbstractConfigurableElement.Builder {

        private MappingMode mappingMode;
        private List mappings;

        public Builder() {
            mappings = new ArrayList<>();
        }

        @Override
        protected Builder self() {
            return this;
        }

        public SimplePermissionMapper build() {
            return new SimplePermissionMapper(this);
        }

        public Builder mappingMode(MappingMode mappingMode) {
            this.mappingMode = mappingMode;
            return this;
        }

        public Builder permissionMapping(PermissionMapping mapping) {
            this.mappings.add(mapping);
            return this;
        }

        public Builder permissionMappings(PermissionMapping... mappings) {
            this.mappings.addAll(Arrays.asList(mappings));
            return this;
        }

    }

    public static final class PermissionMapping {

        private final List permissions;
        private final List principals;
        private final List roles;

        private PermissionMapping(Builder builder) {
            this.permissions = builder.permissions;
            this.principals = builder.principals;
            this.roles = builder.roles;
        }

        public List getPermissions() {
            return permissions;
        }

        public List getPrincipals() {
            return principals;
        }

        public List getRoles() {
            return roles;
        }

        public static Builder builder() {
            return new Builder();
        }

        public String toCLIString() {
            StringBuilder result = new StringBuilder();
            result.append("{permissions=[");
            result.append(permissions.stream()
                    .map(PermissionRef::toCLIString)
                    .collect(Collectors.joining(",")));
            result.append("]");
            if (principals.size() > 0) {
                result.append(",principals=[");
                result.append(StringUtils.join(principals, ","));
                result.append("]");
            }
            if (roles.size() > 0) {
                result.append(",roles=[");
                result.append(StringUtils.join(roles, ","));
                result.append("]");
            }
            result.append("}");
            return result.toString();
        }

        public static final class Builder {

            private List permissions;
            private List principals;
            private List roles;

            public Builder() {
                permissions = new ArrayList<>();
                principals = new ArrayList<>();
                roles = new ArrayList<>();
            }

            public Builder withPermissions(PermissionRef... permissions) {
                this.permissions.addAll(Arrays.asList(permissions));
                return this;
            }

            public Builder withPrincipals(String... principals) {
                this.principals.addAll(Arrays.asList(principals));
                return this;
            }

            public Builder withRoles(String... roles) {
                this.roles.addAll(Arrays.asList(roles));
                return this;
            }

            public PermissionMapping build() {
                return new PermissionMapping(this);
            }

        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy