liquibase.command.CommandStep Maven / Gradle / Ivy
package liquibase.command;
import liquibase.exception.CommandValidationException;
/**
* Defines a particular step in a command pipeline.
* When a command is executed, Liquibase will find all the steps whose {@link #defineCommandNames()} matches the command
* and run them in {@link #getOrder(CommandDefinition)} order.
*
* @see CommandScope#execute()
*/
public interface CommandStep {
/**
* Returned by {@link #getOrder(CommandDefinition)} if you are unsure where in the pipeline your step should go, use this value.
*/
int ORDER_DEFAULT = 1000;
/**
* Returned by {@link #getOrder(CommandDefinition)} if this step should not be a part of the pipeline.
*/
int ORDER_NOT_APPLICABLE = -1;
/**
* Defines new command names
* For example, if it is part of `liquibase update`, this should return new String[][]{ new String[] {"update"}}.
* If it is a part of `liquibase example init`, this should return {"example", "init"}.
*
* This is used to determine the available command names.
*
* This can return null if this step is not defining a new command but "cross-cutting" existing commands.
*/
String[][] defineCommandNames();
/**
* The order in the pipeline that this step should be executed in.
* Logic is generally based off {@link CommandDefinition#getName()} but it can check other things in the definition such as arguments.
*
* @return -1 if this step does not apply to the given command
*/
int getOrder(CommandDefinition commandDefinition);
/**
* Called by the command pipeline setup to adjust the {@link CommandDefinition} metadata about the overall command.
* This method should not be called directly. It is called by the overall pipeline logic in the {@link #getOrder(CommandDefinition)} order.
*/
void adjustCommandDefinition(CommandDefinition commandDefinition);
/**
* Validates that the {@link CommandScope} is correctly set up for this step to run.
* Any validation in {@link CommandArgumentDefinition#validate(CommandScope)} will be checked previous to this method being called.
* This method should not be called directly. It is called by the overall pipeline logic in the {@link #getOrder(CommandDefinition)} order.
*/
void validate(CommandScope commandScope) throws CommandValidationException;
/**
* Performs the business logic.
* This method should not be called directly. It is called by the overall pipeline logic in the {@link #getOrder(CommandDefinition)} order.
*/
void run(CommandResultsBuilder resultsBuilder) throws Exception;
}