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

org.wildfly.plugin.cli.BaseCommandConfiguration Maven / Gradle / Ivy

/*
 * Copyright The WildFly Authors
 * SPDX-License-Identifier: Apache-2.0
 */
package org.wildfly.plugin.cli;

import java.io.File;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.LinkedHashMap;
import java.util.Map;

/**
 * The configuration used to execute forked offline CLI commands.
 *
 * @author [email protected]
 */
public class BaseCommandConfiguration {

    private final Collection jvmOptions;
    private final Collection cliArguments;
    private final Collection commands;
    private final Map systemProperties;
    private final Collection propertiesFiles;
    private final Collection scripts;
    private final boolean batch;
    private final boolean failOnError;
    private final Path jbossHome;
    private final String stdout;
    private final int timeout;
    private final boolean append;
    private final boolean resolveExpression;

    protected abstract static class AbstractBuilder> {

        private final Collection jvmOptions = new ArrayList<>();
        private final Collection cliArguments = new ArrayList<>();
        private final Collection commands = new ArrayList<>();
        private final Map systemProperties = new LinkedHashMap<>();
        private final Collection propertiesFiles = new ArrayList<>();
        private final Collection scripts = new ArrayList<>();
        private boolean batch;
        private boolean failOnError = true;
        private Path jbossHome;
        private String stdout;
        private int timeout;
        private boolean append;
        private boolean resolveExpression;

        protected abstract T builderInstance();

        /**
         * If true append output to file, otherwise a new file is created.
         *
         * @param append true to append to the file.
         * @return this
         */
        public T setAppend(boolean append) {
            this.append = append;
            return builderInstance();
        }

        /**
         * Sets whether or not the commands should be executed in a batch or
         * not.
         *
         * @param batch {@code true} if the commands should be executed in a
         *                  batch, otherwise {@code false}
         *
         * @return this configuration
         */
        public T setBatch(final boolean batch) {
            this.batch = batch;
            return builderInstance();
        }

        /**
         * Sets the JBoss Home directory.
         *
         * @param jbossHome the JBoss Home directory or {@code null} if the
         *                      value is not required
         *
         * @return this configuration
         */
        public T setJBossHome(final String jbossHome) {
            if (jbossHome == null) {
                this.jbossHome = null;
            } else {
                this.jbossHome = Paths.get(jbossHome);
            }
            return builderInstance();
        }

        /**
         * Sets the JBoss Home directory.
         *
         * @param jbossHome the JBoss Home directory or {@code null} if the
         *                      value is not required
         *
         * @return this configuration
         */
        public T setJBossHome(final Path jbossHome) {
            this.jbossHome = jbossHome;
            return builderInstance();
        }

        /**
         * Adds the JVM options used if running in a forked process.
         *
         * @param jvmOptions the JVM options or {@code null}
         *
         * @return this configuration
         */
        public T addJvmOptions(final String... jvmOptions) {
            if (jvmOptions != null) {
                Collections.addAll(this.jvmOptions, jvmOptions);
            }
            return builderInstance();
        }

        /**
         * Adds the CLI arguments used if running in a forked process.
         *
         * @param arguments the CLI arguments or {@code null}
         *
         * @return this configuration
         */
        public T addCLIArguments(final String... arguments) {
            if (arguments != null) {
                Collections.addAll(this.cliArguments, arguments);
            }
            return builderInstance();
        }

        /**
         * Adds to the system properties to set before the CLI commands are
         * executed.
         *
         * @param systemProperties the system properties or {@code null}
         *
         * @return this configuration
         */
        public T addSystemProperties(final Map systemProperties) {
            if (systemProperties != null) {
                this.systemProperties.putAll(systemProperties);
            }
            return builderInstance();
        }

        /**
         * Adds the properties files to use when executing CLI scripts or
         * commands.
         *
         * @param propertiesFiles the property files to add
         *
         * @return this configuration
         */
        public T addPropertiesFiles(final Collection propertiesFiles) {
            propertiesFiles.forEach(f -> this.propertiesFiles.add(f.toPath()));
            return builderInstance();
        }

        /**
         * Adds the commands to the CLI commands that should be executed.
         *
         * @param commands the commands to be executed
         *
         * @return this configuration
         */
        public T addCommands(final Collection commands) {
            if (commands != null) {
                this.commands.addAll(commands);
            }
            return builderInstance();
        }

        /**
         * Adds the scripts to be executed.
         *
         * @param scripts the scripts to be executed
         *
         * @return this configuration
         */
        public T addScripts(final Collection scripts) {
            scripts.forEach(f -> this.scripts.add(f.toPath()));
            return builderInstance();
        }

        /**
         * Sets whether or not CLI commands should fail if the command ends in
         * an error or not.
         *
         * @param failOnError {@code true} if a CLI command fails then the
         *                        execution should fail
         *
         * @return this configuration
         */
        public T setFailOnError(final boolean failOnError) {
            this.failOnError = failOnError;
            return builderInstance();
        }

        /**
         * Sets how the standard output stream should be handled if running in a forked process.
         *
         * @param stdout the pattern for standard out
         *
         * @return this configuration
         */
        public T setStdout(final String stdout) {
            this.stdout = stdout;
            return builderInstance();
        }

        /**
         * Sets the timeout, in seconds, used for the management client
         * connection.
         *
         * @param timeout the timeout to use in seconds
         *
         * @return this configuration
         */
        public T setTimeout(final int timeout) {
            this.timeout = timeout;
            return builderInstance();
        }

        /**
         * Set to {@code true} to resolve expressions prior to sending the operation to the server.
         *
         * @param resolveExpression {@code true} if expressions should be resolved before the operation is sent to the
         *                              server
         * @return this configuration
         */
        public T setResolveExpression(final boolean resolveExpression) {
            this.resolveExpression = resolveExpression;
            return builderInstance();
        }

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

    public static class Builder extends AbstractBuilder {

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

    protected BaseCommandConfiguration(AbstractBuilder builder) {
        jvmOptions = builder.jvmOptions;
        commands = builder.commands;
        systemProperties = builder.systemProperties;
        propertiesFiles = builder.propertiesFiles;
        scripts = builder.scripts;
        cliArguments = builder.cliArguments;
        batch = builder.batch;
        failOnError = builder.failOnError;
        jbossHome = builder.jbossHome;
        stdout = builder.stdout;
        timeout = builder.timeout;
        append = builder.append;
        resolveExpression = builder.resolveExpression;
    }

    /**
     * Is output appended to file.
     *
     * @return true to append to the file
     */
    public boolean isAppend() {
        return append;
    }

    /**
     * Indicates whether the commands should be run in a batch or not.
     *
     * @return {@code true} if the commands should be executed in a batch,
     *             otherwise {@code false}
     */
    public boolean isBatch() {
        return batch;
    }

    /**
     * Returns the JBoss Home directory.
     *
     * @return the JBoss Home directory or {@code null} if the value was not set
     */
    public Path getJBossHome() {
        return jbossHome;
    }

    /**
     * Returns the JVM options used if running in a forked process.
     *
     * @return the JVM options
     */
    public Collection getJvmOptions() {
        return Collections.unmodifiableCollection(jvmOptions);
    }

    /**
     * Returns the CLI arguments used if running in a forked process.
     *
     * @return the CLI arguments
     */
    public Collection getCLIArguments() {
        return Collections.unmodifiableCollection(cliArguments);
    }

    /**
     * Returns the system properties to set before CLI commands are executed.
     *
     * @return the system properties to set before CLI commands are executed
     */
    public Map getSystemProperties() {
        return Collections.unmodifiableMap(systemProperties);
    }

    /**
     * The properties files to use when executing CLI scripts or commands.
     *
     * @return the paths to the properties files
     */
    public Collection getPropertiesFiles() {
        return Collections.unmodifiableCollection(propertiesFiles);
    }

    /**
     * Returns the commands to be executed.
     *
     * @return the commands to be executed
     */
    public Collection getCommands() {
        return Collections.unmodifiableCollection(commands);
    }

    /**
     * Returns the scripts to be executed.
     *
     * @return the scripts to be executed
     */
    public Collection getScripts() {
        return Collections.unmodifiableCollection(scripts);
    }

    /**
     * Indicates whether or not CLI commands should fail if the command ends in
     * an error or not.
     *
     * @return {@code true} if a CLI command fails then the execution should
     *             fail
     */
    public boolean isFailOnError() {
        return failOnError;
    }

    /**
     * The pattern used to determine how standard out is handled for a new CLI
     * process.
     *
     * @return the standard out pattern
     */
    public String getStdout() {
        return stdout;
    }

    /**
     * Gets the timeout, in seconds, used for the management connection.
     *
     * @return the timeout used for the management connection
     */
    public int getTimeout() {
        return timeout;
    }

    /**
     * Is expression resolved.
     *
     * @return true is expressions are resolved.
     */
    public boolean isExpressionResolved() {
        return resolveExpression;
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy