Package liquibase.ui
Class ConsoleUIService
- java.lang.Object
-
- liquibase.AbstractExtensibleObject
-
- liquibase.ui.ConsoleUIService
-
- All Implemented Interfaces:
Cloneable,ExtensibleObject,Plugin,UIService
- Direct Known Subclasses:
MavenUi
public class ConsoleUIService extends AbstractExtensibleObject implements UIService
UIServiceimplementation that sends messages to stdout and stderr.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classConsoleUIService.ConsoleWrapperWrapper aroundConsoleto allow replacements as needed.
-
Field Summary
Fields Modifier and Type Field Description static StringMINGW64static StringMINTTYstatic StringMSYSTEMstatic StringTERM_PROGRAM-
Fields inherited from interface liquibase.plugin.Plugin
PRIORITY_DATABASE, PRIORITY_DEFAULT, PRIORITY_NOT_APPLICABLE, PRIORITY_SPECIALIZED
-
-
Constructor Summary
Constructors Modifier Constructor Description ConsoleUIService()protectedConsoleUIService(ConsoleUIService.ConsoleWrapper console)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description booleangetAllowPrompt()Return current setting of allow prompt flagprotected ConsoleUIService.ConsoleWrappergetConsole()Creates theConsoleUIService.ConsoleWrapperto use.PrintStreamgetErrorStream()booleangetOutputStackTraces()PrintStreamgetOutputStream()intgetPriority()ReturnsPlugin.PRIORITY_NOT_APPLICABLEbecause it must be manually configured as needed<T> Tprompt(String prompt, T valueIfNoEntry, InputHandler<T> inputHandler, Class<T> type)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,DefaultInputHandlerwill be used.
If inputHandler throws anIllegalArgumentException, the user will be given the chance to re-enter the value.
If the inputHandler returns true forInputHandler.shouldAllowEmptyInput()and the user enters an empty value when prompted, or hits "enter", the valueIfNoEntry will be returned.voidsendErrorMessage(String message)Send an "error" message to the user.voidsendErrorMessage(String message, Throwable exception)Send an "error" message to the user along with a stacktrace.voidsendMessage(String message)Send a "normal" message to the user.voidsetAllowPrompt(boolean allowPrompt)Method to set flag indicating whether prompting is allowedvoidsetErrorStream(PrintStream errorStream)voidsetOutputStackTraces(boolean outputStackTraces)Set to true to output stacktraces.voidsetOutputStream(PrintStream outputStream)-
Methods inherited from class liquibase.AbstractExtensibleObject
clone, describe, equals, get, get, get, getAttributes, getFieldValue, getObjectMetaData, getValuePath, has, hashCode, set, toString
-
Methods inherited from class java.lang.Object
finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface liquibase.ExtensibleObject
clone, describe, get, get, getAttributes, getObjectMetaData, getValuePath, has, set
-
-
-
-
Field Detail
-
TERM_PROGRAM
public static final String TERM_PROGRAM
- See Also:
- Constant Field Values
-
MINTTY
public static final String MINTTY
- See Also:
- Constant Field Values
-
MSYSTEM
public static final String MSYSTEM
- See Also:
- Constant Field Values
-
MINGW64
public static final String MINGW64
- See Also:
- Constant Field Values
-
-
Constructor Detail
-
ConsoleUIService
public ConsoleUIService()
-
ConsoleUIService
protected ConsoleUIService(ConsoleUIService.ConsoleWrapper console)
-
-
Method Detail
-
getPriority
public int getPriority()
ReturnsPlugin.PRIORITY_NOT_APPLICABLEbecause it must be manually configured as needed- Specified by:
getPriorityin interfaceUIService
-
sendMessage
public void sendMessage(String message)
Description copied from interface:UIServiceSend a "normal" message to the user.- Specified by:
sendMessagein interfaceUIService
-
sendErrorMessage
public void sendErrorMessage(String message)
Description copied from interface:UIServiceSend an "error" message to the user.- Specified by:
sendErrorMessagein interfaceUIService
-
sendErrorMessage
public void sendErrorMessage(String message, Throwable exception)
Description copied from interface:UIServiceSend an "error" message to the user along with a stacktrace.- Specified by:
sendErrorMessagein interfaceUIService
-
setAllowPrompt
public void setAllowPrompt(boolean allowPrompt) throws IllegalArgumentExceptionDescription copied from interface:UIServiceMethod to set flag indicating whether prompting is allowed- Specified by:
setAllowPromptin interfaceUIService- Parameters:
allowPrompt- New flag value- Throws:
IllegalArgumentException- If parameter is not allowed
-
getAllowPrompt
public boolean getAllowPrompt()
Description copied from interface:UIServiceReturn current setting of allow prompt flag- Specified by:
getAllowPromptin interfaceUIService- Returns:
- boolean
-
prompt
public <T> T prompt(String prompt, T valueIfNoEntry, InputHandler<T> inputHandler, Class<T> type)
Description copied from interface:UIServicePrompt 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,DefaultInputHandlerwill be used.
If inputHandler throws anIllegalArgumentException, the user will be given the chance to re-enter the value.
If the inputHandler returns true forInputHandler.shouldAllowEmptyInput()and the user enters an empty value when prompted, or hits "enter", the valueIfNoEntry will be returned. If the inputHandler returns false forInputHandler.shouldAllowEmptyInput(), the user will be reprompted until they enter a non-empty value, which will then be returned.
-
getConsole
protected ConsoleUIService.ConsoleWrapper getConsole()
Creates theConsoleUIService.ConsoleWrapperto use.
-
getOutputStream
public PrintStream getOutputStream()
-
setOutputStream
public void setOutputStream(PrintStream outputStream)
-
getErrorStream
public PrintStream getErrorStream()
-
setErrorStream
public void setErrorStream(PrintStream errorStream)
-
getOutputStackTraces
public boolean getOutputStackTraces()
-
setOutputStackTraces
public void setOutputStackTraces(boolean outputStackTraces)
Set to true to output stacktraces. Defaults to not outputing them.
-
-