Skip to content

Commit

Permalink
Merge branch 'master' into bugfix/vertica-data-mismatch
Browse files Browse the repository at this point in the history
  • Loading branch information
aimethed authored Dec 26, 2024
2 parents f034de2 + 1c686a9 commit f525c4b
Show file tree
Hide file tree
Showing 5 changed files with 8 additions and 11 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -37,14 +37,14 @@ public Map<String, String> connectionPropertiesToEnvironment(Map<String, String>
HashMap<String, String> environment = new HashMap<>();

// now construct jdbc string
String connectionString = String.join("db2as400://jdbc:as400://", connectionProperties.get(HOST),
";", connectionProperties.getOrDefault(JDBC_PARAMS, ""));
String connectionString = "db2as400://jdbc:as400://" + connectionProperties.get(HOST)
+ ";" + connectionProperties.getOrDefault(JDBC_PARAMS, "");

if (connectionProperties.containsKey(SECRET_NAME)) {
if (connectionProperties.containsKey(JDBC_PARAMS)) { // need to add delimiter
connectionString = connectionString + ";";
}
connectionString = String.join(connectionString, ":${", connectionProperties.get(SECRET_NAME), "}");
connectionString = connectionString + ":${" + connectionProperties.get(SECRET_NAME) + "}";
}

logger.debug("Constructed connection string: {}", connectionString);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -96,8 +96,6 @@ public class DocDBMetadataHandler
//The Glue table property that indicates that a table matching the name of an DocDB table
//is indeed enabled for use by this connector.
private static final String DOCDB_METADATA_FLAG = "docdb-metadata-flag";
//The prefix of a connection string
protected static final String DOCDB_CONN_STRING_PREFIX = "mongodb://";
//Used to filter out Glue tables which lack a docdb metadata flag.
private static final TableFilter TABLE_FILTER = (Table table) -> table.parameters().containsKey(DOCDB_METADATA_FLAG);
//The number of documents to scan when attempting to infer schema from an DocDB collection.
Expand Down Expand Up @@ -136,7 +134,7 @@ private MongoClient getOrCreateConn(MetadataRequest request)
{
String connStr = getConnStr(request);
if (configOptions.containsKey(SECRET_NAME) && !hasEmbeddedSecret(connStr)) {
connStr = String.join(connStr.substring(0, DOCDB_CONN_STRING_PREFIX.length()), "${", configOptions.get(SECRET_NAME), "}@", connStr.substring(DOCDB_CONN_STRING_PREFIX.length()));
connStr = connStr.substring(0, 10) + "${" + configOptions.get(SECRET_NAME) + "}@" + connStr.substring(10);
}
String endpoint = resolveSecrets(connStr);
return connectionFactory.getOrCreateConn(endpoint);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,6 @@
import static com.amazonaws.athena.connector.lambda.handlers.GlueMetadataHandler.SOURCE_TABLE_PROPERTY;
import static com.amazonaws.athena.connectors.docdb.DocDBFieldResolver.DEFAULT_FIELD_RESOLVER;
import static com.amazonaws.athena.connectors.docdb.DocDBMetadataHandler.DOCDB_CONN_STR;
import static com.amazonaws.athena.connectors.docdb.DocDBMetadataHandler.DOCDB_CONN_STRING_PREFIX;

/**
* Handles data read record requests for the Athena DocumentDB Connector.
Expand Down Expand Up @@ -111,7 +110,7 @@ private MongoClient getOrCreateConn(Split split)
throw new RuntimeException(DOCDB_CONN_STR + " Split property is null! Unable to create connection.");
}
if (configOptions.containsKey(SECRET_NAME) && !hasEmbeddedSecret(connStr)) {
connStr = String.join(connStr.substring(0, DOCDB_CONN_STRING_PREFIX.length()), "${", configOptions.get(SECRET_NAME), "}@", connStr.substring(DOCDB_CONN_STRING_PREFIX.length()));
connStr = connStr.substring(0, 10) + "${" + configOptions.get(SECRET_NAME) + "}@" + connStr.substring(10);
}
String endpoint = resolveSecrets(connStr);
return connectionFactory.getOrCreateConn(endpoint);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -39,8 +39,8 @@ public Map<String, String> connectionPropertiesToEnvironment(Map<String, String>
HashMap<String, String> environment = new HashMap<>();

// now construct jdbc string
String connectionString = String.join(getConnectionStringPrefix(connectionProperties), connectionProperties.get(HOST),
":", connectionProperties.get(PORT), getDatabase(connectionProperties), getJdbcParameters(connectionProperties));
String connectionString = getConnectionStringPrefix(connectionProperties) + connectionProperties.get(HOST)
+ ":" + connectionProperties.get(PORT) + getDatabase(connectionProperties) + getJdbcParameters(connectionProperties);

environment.put(DEFAULT, connectionString);
return environment;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -161,7 +161,7 @@ public void getPartitions(final BlockWriter blockWriter, final GetTableLayoutReq
LOGGER.debug("{}: Schema {}, table {}", getTableLayoutRequest.getQueryId(), transformString(getTableLayoutRequest.getTableName().getSchemaName(), true),
transformString(getTableLayoutRequest.getTableName().getTableName(), true));
try (Connection connection = getJdbcConnectionFactory().getConnection(getCredentialProvider())) {
List<String> parameters = Arrays.asList(transformString(getTableLayoutRequest.getTableName().getTableName(), true));
List<String> parameters = Arrays.asList(transformString(getTableLayoutRequest.getTableName().getTableName(), true));
try (PreparedStatement preparedStatement = new PreparedStatementBuilder().withConnection(connection).withQuery(GET_PARTITIONS_QUERY).withParameters(parameters).build();
ResultSet resultSet = preparedStatement.executeQuery()) {
// Return a single partition if no partitions defined
Expand Down

0 comments on commit f525c4b

Please sign in to comment.