Skip to content

Commit

Permalink
Update to support Cassandra 3.x - Contrast-Security-OSS#12
Browse files Browse the repository at this point in the history
  • Loading branch information
Sean Ryan committed Feb 2, 2016
1 parent b954468 commit 9bfe574
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 14 deletions.
2 changes: 1 addition & 1 deletion pom.xml
100644 → 100755
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,7 @@
<dependency>
<groupId>com.datastax.cassandra</groupId>
<artifactId>cassandra-driver-core</artifactId>
<version>2.1.9</version>
<version>3.0.0</version>
</dependency>
<dependency>
<groupId>junit</groupId>
Expand Down
39 changes: 26 additions & 13 deletions src/main/java/com/contrastsecurity/cassandra/migration/dao/SchemaVersionDAO.java
100644 → 100755
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
import com.contrastsecurity.cassandra.migration.logging.LogFactory;
import com.contrastsecurity.cassandra.migration.utils.CachePrepareStatement;
import com.datastax.driver.core.*;
import com.datastax.driver.core.exceptions.InvalidQueryException;
import com.datastax.driver.core.querybuilder.QueryBuilder;
import com.datastax.driver.core.querybuilder.Select;

Expand All @@ -17,7 +18,6 @@
import java.util.List;

import static com.datastax.driver.core.querybuilder.QueryBuilder.eq;
import static com.datastax.driver.core.querybuilder.QueryBuilder.in;

public class SchemaVersionDAO {

Expand Down Expand Up @@ -81,24 +81,37 @@ public boolean tablesExist() {
boolean schemaVersionTableExists = false;
boolean schemaVersionCountsTableExists = false;

Statement statement = QueryBuilder
Statement schemaVersionStatement = QueryBuilder
.select()
.column("columnfamily_name")
.from("System", "schema_columnfamilies")
.where(eq("keyspace_name", keyspace.getName()))
.and(in("columnfamily_name", tableName, tableName + COUNTS_TABLE_NAME_SUFFIX));
.countAll()
.from(keyspace.getName(), tableName);

statement.setConsistencyLevel(this.consistencyLevel);
ResultSet results = session.execute(statement);
for (Row row : results) {
String table = row.getString("columnfamily_name");
if (null != table && table.equalsIgnoreCase(tableName)) {
Statement schemaVersionCountsStatement = QueryBuilder
.select()
.countAll()
.from(keyspace.getName(), tableName + COUNTS_TABLE_NAME_SUFFIX);

schemaVersionStatement.setConsistencyLevel(this.consistencyLevel);
schemaVersionCountsStatement.setConsistencyLevel(this.consistencyLevel);

try {
ResultSet resultsSchemaVersion = session.execute(schemaVersionStatement);
if (resultsSchemaVersion.one() != null) {
schemaVersionTableExists = true;
}
if (null != table && table.equalsIgnoreCase(tableName + COUNTS_TABLE_NAME_SUFFIX)) {
} catch (InvalidQueryException e) {
LOG.debug("No schema version table found with a name of " + tableName);
}

try {
ResultSet resultsSchemaVersionCounts = session.execute(schemaVersionCountsStatement);
if (resultsSchemaVersionCounts.one() != null) {
schemaVersionCountsTableExists = true;
}
} catch (InvalidQueryException e) {
LOG.debug("No schema version counts table found with a name of " + tableName + COUNTS_TABLE_NAME_SUFFIX);
}

return schemaVersionTableExists && schemaVersionCountsTableExists;
}

Expand Down Expand Up @@ -169,7 +182,7 @@ public List<AppliedMigration> findAppliedMigrations() {
MigrationType.valueOf(row.getString("type")),
row.getString("script"),
row.isNull("checksum") ? null : row.getInt("checksum"),
row.getDate("installed_on"),
row.getTimestamp("installed_on"),
row.getString("installed_by"),
row.getInt("execution_time"),
row.getBool("success")
Expand Down

0 comments on commit 9bfe574

Please sign in to comment.