com.nesscomputing.migratory.maven.HistoryMojo Maven / Gradle / Ivy
/**
* Copyright (C) 2012 Ness Computing, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.nesscomputing.migratory.maven;
import java.util.List;
import java.util.Map;
import com.nesscomputing.migratory.Migratory;
import com.nesscomputing.migratory.maven.util.FormatInfo;
import com.nesscomputing.migratory.metadata.MetadataInfo;
import com.nesscomputing.migratory.migration.MigrationPlanner.MigrationDirection;
import org.joda.time.format.DateTimeFormatter;
import org.joda.time.format.ISODateTimeFormat;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import edu.umd.cs.findbugs.annotations.SuppressFBWarnings;
/**
* Maven goal that shows the history (all applied migrations) of the database.
*
* @aggregator true
* @requiresProject false
* @goal history
*/
public class HistoryMojo extends AbstractMigratoryMojo
{
private static final Logger CONSOLE = LoggerFactory.getLogger("console");
private static final FormatInfo SHORT = new FormatInfo(
"+-----------+------+-------+-----+--------------------+---------------------+",
"| %-73s |\n",
"| Migration | Type | State | Dir | User | Date |",
"| %4d-%-4d | %-4s | %-5s | %-3s | %-18s | %18s |\n"
);
private static final FormatInfo VERBOSE = new FormatInfo(
"+-----------+------+-------+-----+-----------+--------------------------------+-------+------------------------------------------+------------------------------------------+",
"| %-169s |\n",
"| Migration | Type | State | Dir | User | Date | Time | Description | Script |",
"| %4d-%-4d | %-4s | %-5s | %-3s | %-20s | %18s | %5d | %-40s | %-40s |\n"
);
private static final DateTimeFormatter DATE_FORMAT = ISODateTimeFormat.dateHourMinuteSecond();
/**
* @parameter expression="${verbose}"
*/
private final boolean verbose = false;
/**
* @parameter expression="${personalities}"
*/
@SuppressFBWarnings("UWF_NULL_FIELD")
private final String personalities = null;
@Override
protected void doExecute(Migratory migratory) throws Exception
{
final List personalityList = parsePersonalities(personalities);
final Map> results = migratory.dbHistory(personalityList, optionList);
for (Map.Entry> personality : results.entrySet()) {
dump(verbose, personality.getKey(), personality.getValue());
}
}
public static void dump(final boolean verbose, final String personality, final List info)
{
if (info == null || info.isEmpty()) {
return;
}
final FormatInfo formatInfo = verbose ? VERBOSE : SHORT;
CONSOLE.info("{}", formatInfo.getFrame());
CONSOLE.info("{}", String.format(formatInfo.getName(), personality));
CONSOLE.info("{}", formatInfo.getFrame());
CONSOLE.info("{}", formatInfo.getHeader());
CONSOLE.info("{}", formatInfo.getFrame());
for (MetadataInfo metadataInfo : info) {
CONSOLE.info("{}", String.format(formatInfo.getFormat(),
metadataInfo.getStartVersion(),
metadataInfo.getEndVersion(),
metadataInfo.getType(),
metadataInfo.getState(),
shortDir(metadataInfo.getDirection()),
metadataInfo.getUser(),
metadataInfo.getCreated(),
metadataInfo.getExecutionTime(),
metadataInfo.getDescription(),
metadataInfo.getScriptName()));
}
CONSOLE.info("{}", formatInfo.getFrame());
}
private static String shortDir(final MigrationDirection dir)
{
switch (dir) {
case FORWARD:
return "FWD";
case BACK:
return "BCK";
default:
return dir.name();
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy