liquibase.ui.UIService Maven / Gradle / Ivy
package liquibase.ui;
import liquibase.ExtensibleObject;
import liquibase.exception.LiquibaseException;
import liquibase.plugin.Plugin;
import java.io.PrintWriter;
/**
* Service for interacting with the user.
*/
public interface UIService extends ExtensibleObject, Plugin {
int getPriority();
/**
* Send a "normal" message to the user.
*/
void sendMessage(String message);
/**
* Send an "error" message to the user.
*/
void sendErrorMessage(String message);
/**
* Send an "error" message to the user along with a stacktrace.
*/
void sendErrorMessage(String message, Throwable exception);
/**
* Prompt the user with the message and wait for a response.
* If this UIService implementation does not support user prompts, return the default value.
* If inputHandler is null, {@link DefaultInputHandler} will be used.
* If inputHandler throws an {@link IllegalArgumentException}, the user will be given the chance to re-enter the value.
* If the inputHandler returns true for {@link InputHandler#shouldAllowEmptyInput()} and the user enters an empty value
* when prompted, or hits "enter", the valueIfNoEntry will be returned. If the inputHandler returns false for
* {@link InputHandler#shouldAllowEmptyInput()}, the user will be reprompted until they enter a non-empty value,
* which will then be returned.
*/
T prompt(String prompt, T valueIfNoEntry, InputHandler inputHandler, Class type);
/**
*
* Method to set flag indicating whether prompting is allowed
*
* @param allowPrompt New flag value
* @throws IllegalArgumentException If parameter is not allowed
*
*/
void setAllowPrompt(boolean allowPrompt) throws IllegalArgumentException;
/**
*
* Return current setting of allow prompt flag
*
* @return boolean
*
*/
boolean getAllowPrompt();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy