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

org.keycloak.provider.ProviderConfigurationBuilder Maven / Gradle / Ivy

There is a newer version: 26.0.5
Show newest version
/*
 * Copyright 2016 Red Hat, Inc. and/or its affiliates
 * and other contributors as indicated by the @author tags.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.keycloak.provider;

import java.util.Arrays;
import java.util.LinkedList;
import java.util.List;

/**
 * Builds a list of ProviderConfigProperty instances.
 *
 *
 * @author Stian Thorgersen
 */
public class ProviderConfigurationBuilder {

    private List properties = new LinkedList<>();

    private ProviderConfigurationBuilder() {
    }

    public static ProviderConfigurationBuilder create() {
        return new ProviderConfigurationBuilder();
    }

    public ProviderConfigPropertyBuilder property() {
        return new ProviderConfigPropertyBuilder();
    }

    public ProviderConfigurationBuilder property(ProviderConfigProperty property) {
        properties.add(property);
        return this;
    }

    public ProviderConfigurationBuilder property(String name, String label, String helpText, String type, Object defaultValue, List options, boolean secret) {
        ProviderConfigProperty property = new ProviderConfigProperty(name, label, helpText, type, defaultValue);
        property.setOptions(options);
        property.setSecret(secret);
        properties.add(property);
        return this;
    }
    public ProviderConfigurationBuilder property(String name, String label, String helpText, String type, Object defaultValue, List options) {
        ProviderConfigProperty property = new ProviderConfigProperty(name, label, helpText, type, defaultValue);
        property.setOptions(options);
        properties.add(property);
        return this;
    }

    /**
     * Create the list.
     *
     * @return
     */
    public List build() {
        return properties;
    }

    public class ProviderConfigPropertyBuilder {

        private String name;
        private String label;
        private String helpText;
        private String type;
        private Object defaultValue;
        private List options;
        private boolean secret;
        private boolean required;

        public ProviderConfigPropertyBuilder name(String name) {
            this.name = name;
            return this;
        }

        /**
         * Label that will be shown for this configuration property in the admin console
         *
         * @param label
         * @return
         */
        public ProviderConfigPropertyBuilder label(String label) {
            this.label = label;
            return this;
        }

        /**
         * Help text that will be shown for this configuration property in the admin console
         * when you hover over the tooltip
         *
         * @param helpText
         * @return
         */
        public ProviderConfigPropertyBuilder helpText(String helpText) {
            this.helpText = helpText;
            return this;
        }

        /**
         * Property type.  i.e. boolean, string.
         * @see ProviderConfigProperty
         *
         *
         * @param type
         * @return
         */
        public ProviderConfigPropertyBuilder type(String type) {
            this.type = type;
            return this;
        }

        /**
         * Default value that will be shown when configuring this property for the first time
         *
         * @param defaultValue
         * @return
         */
        public ProviderConfigPropertyBuilder defaultValue(Object defaultValue) {
            this.defaultValue = defaultValue;
            return this;
        }

        /**
         * If configuring a list type, these are the options you can choose from.
         *
         * @param options
         * @return
         */
        public ProviderConfigPropertyBuilder options(String... options) {
            this.options = Arrays.asList(options);
            return this;
        }

        /**
         * If configuring a list type, these are the options you can choose from.
         *
         * @param options
         * @return
         */
        public ProviderConfigPropertyBuilder options(List options) {
            this.options = options;
            return this;
        }


        /**
         * If turned on, this property is only writable and never readable.
         * This is useful for things like passwords where you never want an admin
         * to be able to see what the password is.
         *
         * @param secret
         * @return
         */
        public ProviderConfigPropertyBuilder secret(boolean secret) {
            this.secret = secret;
            return this;
        }

        /**
         * If turned on, this property will be marked as required in the admin console
         *
         * @param required
         * @return
         */
        public ProviderConfigPropertyBuilder required(boolean required) {
            this.required = required;
            return this;
        }

        /**
         * Add the current property, and start building the next one
         *
         * @return
         */
        public ProviderConfigurationBuilder add() {
            ProviderConfigProperty property = new ProviderConfigProperty();
            property.setName(name);
            property.setLabel(label);
            property.setHelpText(helpText);
            property.setType(type);
            property.setDefaultValue(defaultValue);
            property.setOptions(options);
            property.setSecret(secret);
            property.setRequired(required);
            ProviderConfigurationBuilder.this.properties.add(property);
            return ProviderConfigurationBuilder.this;
        }

    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy