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

io.probedock.maven.plugin.glassfish.command.CommandBuilder Maven / Gradle / Ivy

package io.probedock.maven.plugin.glassfish.command;

import io.probedock.maven.plugin.glassfish.command.argument.Argument;
import io.probedock.maven.plugin.glassfish.command.argument.AsadminArgumentName;
import io.probedock.maven.plugin.glassfish.command.argument.CommandArgumentName;
import io.probedock.maven.plugin.glassfish.model.Configuration;
import java.util.ArrayList;
import java.util.List;

/**
 * The Command Builder class provides the mechanism to build an ASADMIN command line
 * with the different parts of the commands:
 *	- ASADMIN utils args
 *  - Command name
 *  - Command arguments
 *
 * Once the builder has all the command lines stuff, you can retrieve the command line elements
 * ready to be used with a {@link ProcessBuilder}
 * 
 * @author Laurent Prevost [email protected]
 */
public class CommandBuilder {
	/**
	 * The command name
	 */
	private final CommandName name;
	
	/**
	 * The ASADMIN util arguments
	 */
	private final List asadminArguments;

	/**
	 * The command arguments
	 */
	private final List commandArguments;
	
	/**
	 * A friendly message to add in case of error
	 */
	private String friendlyErrorMessage;
	
	/**
	 * Constructor
	 * 
	 * @param name The command name
	 */
	public CommandBuilder(CommandName name) {
		this.name = name;
		commandArguments = new ArrayList<>();
		asadminArguments = new ArrayList<>();
	}
	
	/**
	 * Add a command argument
	 * 
	 * @param argument The argument to add
	 * @return this
	 */
	public CommandBuilder addArgument(Argument argument) {
		if (argument != null) {
			commandArguments.addAll(argument.buildArgument());
		}
		return this;
	}
	
	/**
	 * @param message The friendly error message
	 * @return this
	 */
	public CommandBuilder setFriendlyErrorMessage(String message) {
		this.friendlyErrorMessage = message;
		return this;
	}

	/**
	 * @return Retrieve the friendly error message
	 */
	public String getFriendlyErrorMessage() {
		return friendlyErrorMessage;
	}
	
	/**
	 * Setup the main ASADMIN arguments like user/password, interactive mode
	 * trace and debug, host and port...
	 * 
	 * @param configuration The configuration to get the different value for the arguments
	 * @return this
	 */
	public CommandBuilder setupAsadminArguments(Configuration configuration) {
		asadminArguments.addAll(AsadminArgumentName.INTERACTIVE.create().buildArgument());

		// Trace arguments
		if (configuration.getGlassfish().isEcho()) {
			asadminArguments.addAll(AsadminArgumentName.ECHO.create().buildArgument());
		}
		asadminArguments.addAll(AsadminArgumentName.TERSE.create(configuration).buildArgument());
		
		// Credentials arguments
		asadminArguments.addAll(AsadminArgumentName.USER.create(configuration).buildArgument());
		asadminArguments.addAll(AsadminArgumentName.PASSWORDFILE.create(configuration).buildArgument());

		// Connection info
		if (configuration.getDomain().getHost() != null) {
			asadminArguments.addAll(AsadminArgumentName.HOST.create(configuration).buildArgument());
		}
		if (configuration.getDomain().getAdminPort() > 0) {
			asadminArguments.addAll(AsadminArgumentName.PORT.create(configuration).buildArgument());
		}
		
		return this;
	}
	
	/**
	 * Get the command list. Consists in a list of all different elements
	 * to be injected in {@link ProcessBuilder}
	 * 
	 * @param asadminPath The ASADMIN util path
	 * @return The command elements
	 */
	public List getCommandLine(String asadminPath) {
		List cmdLine = new ArrayList<>();
		
		// The command line tool
		cmdLine.add(asadminPath);
		
		// The command line util arguments
		if (!asadminArguments.isEmpty()) {
			cmdLine.addAll(asadminArguments);
		}
		
		// The command
		cmdLine.add(name.getCmd());
		
		// The command arguments
		if (!commandArguments.isEmpty()) {
			cmdLine.addAll(commandArguments);
		}
		
		return cmdLine;
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy