/**
* This Source Code Form is subject to the terms of the Mozilla Public License,
* v. 2.0. If a copy of the MPL was not distributed with this file, You can
* obtain one at http://mozilla.org/MPL/2.0/. OpenMRS is also distributed under
* the terms of the Healthcare Disclaimer located at http://openmrs.org/license.
*
* Copyright (C) OpenMRS Inc. OpenMRS is a registered trademark and the OpenMRS
* graphic logo is a trademark of OpenMRS Inc.
*/
package org.openmrs.util.databasechange;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import liquibase.change.custom.CustomTaskChange;
import liquibase.database.Database;
import liquibase.database.jvm.JdbcConnection;
import liquibase.exception.CustomChangeException;
import liquibase.exception.DatabaseException;
import liquibase.exception.SetupException;
import liquibase.exception.ValidationErrors;
import liquibase.resource.ResourceAccessor;
/**
* This change set is run to update layout.address.format global property
*/
public class UpdateLayoutAddressFormatChangeSet implements CustomTaskChange {
private final static Logger log = LoggerFactory.getLogger(UpdateLayoutAddressFormatChangeSet.class);
/**
* @see CustomTaskChange#execute(Database)
*/
@Override
public void execute(Database database) throws CustomChangeException {
JdbcConnection connection = (JdbcConnection) database.getConnection();
Statement stmt = null;
PreparedStatement pStmt = null;
try {
stmt = connection.createStatement();
ResultSet rs = stmt
.executeQuery("SELECT property_value FROM global_property WHERE property = 'layout.address.format'");
if (rs.next()) {
String value = rs.getString("property_value");
value = value.replace("org.openmrs.layout.web.", "org.openmrs.layout.");
pStmt = connection
.prepareStatement("UPDATE global_property SET property_value = ? WHERE property = 'layout.address.format'");
pStmt.setString(1, value);
pStmt.addBatch();
pStmt.executeBatch();
}
}
catch (DatabaseException e) {
log.warn("Error generated", e);
}
catch (SQLException e) {
log.warn("Error generated", e);
}
finally {
if (stmt != null) {
try {
stmt.close();
}
catch (SQLException e) {
log.warn("Failed to close the statement object");
}
}
if (pStmt != null) {
try {
pStmt.close();
}
catch (SQLException e) {
log.warn("Failed to close the prepared statement object");
}
}
}
}
/**
* @see liquibase.change.custom.CustomChange#getConfirmationMessage()
*/
@Override
public String getConfirmationMessage() {
return "Finished updating global property";
}
/**
* @see liquibase.change.custom.CustomChange#setUp()
*/
@Override
public void setUp() throws SetupException {
}
/**
* @see liquibase.change.custom.CustomChange#setFileOpener(liquibase.resource.ResourceAccessor)
*/
@Override
public void setFileOpener(ResourceAccessor resourceAccessor) {
}
/**
* @see liquibase.change.custom.CustomChange#validate(liquibase.database.Database)
*/
@Override
public ValidationErrors validate(Database database) {
return null;
}
}