/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package com.wcs.netbeans.liquiface.database;
/*
* #%L
* Liquiface - GUI for Liquibase
* %%
* Copyright (C) 2013 Webstar Csoport Kft.
* %%
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this program. If not, see
* <http://www.gnu.org/licenses/gpl-3.0.html>.
* #L%
*/
import com.wcs.netbeans.liquiface.change.loader.ChangeLoader;
import com.wcs.netbeans.liquiface.util.Utils;
import java.io.File;
import java.sql.Connection;
import java.util.List;
import java.util.logging.Level;
import java.util.logging.Logger;
import liquibase.changelog.ChangeLogParameters;
import liquibase.changelog.ChangeSet;
import liquibase.changelog.DatabaseChangeLog;
import liquibase.database.Database;
import liquibase.diff.Diff;
import liquibase.diff.DiffResult;
import liquibase.parser.core.xml.XMLChangeLogSAXParser;
import liquibase.resource.FileSystemResourceAccessor;
import org.netbeans.api.db.explorer.DatabaseConnection;
/**
*
* @author tveki
*/
public class DatabaseChangeLoader extends DatabaseHandler implements ChangeLoader {
private static final Logger logger = Logger.getLogger(DatabaseChangeLoader.class.getName());
private static final String INPUT_CHANGELOG = "inputChangelog.xml";
private DatabaseChangeLog changeLog;
private DatabaseConnection databaseConnection;
public DatabaseChangeLoader(DatabaseConnection databaseConnection) {
this.databaseConnection = databaseConnection;
}
private String getChangeLogFile() {
return Utils.getUserHome() + File.separator + INPUT_CHANGELOG;
}
private void generateChangeLog() {
Connection conn = null;
try {
conn = createConnection(databaseConnection);
if (conn == null) {
return;
}
Database database = createDatabase(conn);
String defaultSchema = null;
Diff diff = new Diff(database, defaultSchema);
diff.setDiffTypes(null);
DiffResult diffResult = diff.compare();
diffResult.setChangeSetAuthor("liquface");
diffResult.printChangeLog(getChangeLogFile(), database);
} catch (Exception ex) {
logger.log(Level.SEVERE, null, ex);
} finally {
disconnect(databaseConnection);
}
}
private DatabaseChangeLog getChangeLog() {
if (changeLog == null) {
try {
ChangeLogParameters params = new ChangeLogParameters();
changeLog = new XMLChangeLogSAXParser().parse(getChangeLogFile(), params, new FileSystemResourceAccessor());
} catch (Exception ex) {
logger.log(Level.SEVERE, null, ex);
}
}
return changeLog;
}
private void regenerateChangeLog() {
File file = new File(getChangeLogFile());
if (file.exists()) {
file.delete();
logger.log(Level.INFO, "{0} is deleted", getChangeLogFile());
}
generateChangeLog();
logger.log(Level.INFO, "{0} is generated", getChangeLogFile());
}
@Override
public List<ChangeSet> loadChangeSets() {
regenerateChangeLog();
List<ChangeSet> changeSets = getChangeLog().getChangeSets();
logger.log(Level.INFO, "{0} change sets loaded", changeSets.size());
return changeSets;
}
}