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

liquibase.command.CommandStep Maven / Gradle / Ivy

There is a newer version: 4.30.0
Show newest version
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; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy