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

org.openstreetmap.osmosis.pgsimple.common.SchemaVersionValidator Maven / Gradle / Ivy

There is a newer version: 0.49.2
Show newest version
// This software is released into the Public Domain.  See copying.txt for details.
package org.openstreetmap.osmosis.pgsimple.common;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

import org.openstreetmap.osmosis.core.OsmosisRuntimeException;
import org.openstreetmap.osmosis.core.database.DatabasePreferences;


/**
 * Reads the version number stored in the schema_info table and verifies that it
 * matches the expected version.
 * 
 * @author Brett Henderson
 */
public class SchemaVersionValidator {
	private static final String SELECT_SQL = "SELECT version FROM schema_info";
	
	private DatabasePreferences preferences;
	private DatabaseContext dbCtx;
	private boolean validated;
	
	
	/**
	 * Creates a new instance.
	 * 
	 * @param dbCtx
	 *            The database context to use for accessing the database.
	 * @param preferences
	 *            The database preferences.
	 */
	public SchemaVersionValidator(DatabaseContext dbCtx, DatabasePreferences preferences) {
		this.dbCtx = dbCtx;
		this.preferences = preferences;
	}
	
	
	/**
	 * Validates that the version number of the schema matches the expected
	 * version. This method caches the result allowing it to be called multiple
	 * times without a performance penalty.
	 * 
	 * @param expectedVersion
	 *            The expected version number.
	 */
	public void validateVersion(int expectedVersion) {
		if (!validated) {
			validateDBVersion(expectedVersion);
			
			validated = true;
		}
	}
	
	
	/**
	 * Performs the database lookup and validates the expected version.
	 * 
	 * @param expectedVersion
	 *            The expected version number.
	 */
	private void validateDBVersion(int expectedVersion) {
		if (preferences.getValidateSchemaVersion()) {
			try {
				Statement statement;
				ResultSet resultSet;
				int dbVersion;
				
				statement = dbCtx.createStatement();
				resultSet = statement.executeQuery(SELECT_SQL);
				
				if (!resultSet.next()) {
					throw new OsmosisRuntimeException("No rows were found in the schema info table.");
				}
				
				dbVersion = resultSet.getInt("version");
				
				if (dbVersion != expectedVersion) {
					throw new OsmosisRuntimeException(
						"The database schema version of " + dbVersion
						+ " does not match the expected version of " + expectedVersion + "."
					);
				}
				
				resultSet.close();
				statement.close();
				
			} catch (SQLException e) {
				throw new OsmosisRuntimeException("Unable to read the schema version from the schema info table.", e);
			}
		}
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy