package io.dropwizard.migrations; import com.google.common.annotations.VisibleForTesting; import com.google.common.base.Joiner; import io.dropwizard.Configuration; import io.dropwizard.db.DatabaseConfiguration; import liquibase.Liquibase; import net.sourceforge.argparse4j.impl.Arguments; import net.sourceforge.argparse4j.inf.Namespace; import net.sourceforge.argparse4j.inf.Subparser; import java.io.OutputStreamWriter; import java.io.PrintStream; import java.nio.charset.StandardCharsets; import java.util.List; public class DbPrepareRollbackCommand<T extends Configuration> extends AbstractLiquibaseCommand<T> { private PrintStream outputStream = System.out; public DbPrepareRollbackCommand(DatabaseConfiguration<T> strategy, Class<T> configurationClass, String migrationsFileName) { super("prepare-rollback", "Generate rollback DDL scripts for pending change sets.", strategy, configurationClass, migrationsFileName); } @VisibleForTesting void setOutputStream(PrintStream outputStream) { this.outputStream = outputStream; } @Override public void configure(Subparser subparser) { super.configure(subparser); subparser.addArgument("-c", "--count") .dest("count") .type(Integer.class) .help("limit script to the specified number of pending change sets"); subparser.addArgument("-i", "--include") .action(Arguments.append()) .dest("contexts") .help("include change sets from the given context"); } @Override public void run(Namespace namespace, Liquibase liquibase) throws Exception { final String context = getContext(namespace); final Integer count = namespace.getInt("count"); if (count != null) { liquibase.futureRollbackSQL(count, context, new OutputStreamWriter(outputStream, StandardCharsets.UTF_8)); } else { liquibase.futureRollbackSQL(context, new OutputStreamWriter(outputStream, StandardCharsets.UTF_8)); } } private String getContext(Namespace namespace) { final List<Object> contexts = namespace.getList("contexts"); if (contexts == null) { return ""; } return Joiner.on(',').join(contexts); } }