
software.amazon.awssdk.enhanced.dynamodb.internal.operations.BatchGetItemOperation Maven / Gradle / Ivy
/*
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file is distributed
* on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
package software.amazon.awssdk.enhanced.dynamodb.internal.operations;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.function.Function;
import java.util.stream.Collectors;
import java.util.stream.Stream;
import software.amazon.awssdk.annotations.SdkInternalApi;
import software.amazon.awssdk.core.async.SdkPublisher;
import software.amazon.awssdk.core.pagination.sync.SdkIterable;
import software.amazon.awssdk.enhanced.dynamodb.DynamoDbEnhancedClientExtension;
import software.amazon.awssdk.enhanced.dynamodb.model.BatchGetItemEnhancedRequest;
import software.amazon.awssdk.enhanced.dynamodb.model.BatchGetResultPage;
import software.amazon.awssdk.enhanced.dynamodb.model.ReadBatch;
import software.amazon.awssdk.services.dynamodb.DynamoDbAsyncClient;
import software.amazon.awssdk.services.dynamodb.DynamoDbClient;
import software.amazon.awssdk.services.dynamodb.model.AttributeValue;
import software.amazon.awssdk.services.dynamodb.model.BatchGetItemRequest;
import software.amazon.awssdk.services.dynamodb.model.BatchGetItemResponse;
import software.amazon.awssdk.services.dynamodb.model.KeysAndAttributes;
@SdkInternalApi
public class BatchGetItemOperation
implements PaginatedDatabaseOperation {
private final BatchGetItemEnhancedRequest request;
private BatchGetItemOperation(BatchGetItemEnhancedRequest request) {
this.request = request;
}
public static BatchGetItemOperation create(BatchGetItemEnhancedRequest request) {
return new BatchGetItemOperation(request);
}
@Override
public BatchGetItemRequest generateRequest(DynamoDbEnhancedClientExtension extension) {
Map requestItems = new HashMap<>();
request.readBatches().forEach(readBatch -> addReadRequestsToMap(readBatch, requestItems));
return BatchGetItemRequest.builder()
.requestItems(Collections.unmodifiableMap(requestItems))
.build();
}
@Override
public BatchGetResultPage transformResponse(BatchGetItemResponse response,
DynamoDbEnhancedClientExtension extension) {
return BatchGetResultPage.builder().batchGetItemResponse(response).mapperExtension(extension).build();
}
@Override
public Function> serviceCall(DynamoDbClient dynamoDbClient) {
return dynamoDbClient::batchGetItemPaginator;
}
@Override
public Function> asyncServiceCall(
DynamoDbAsyncClient dynamoDbAsyncClient) {
return dynamoDbAsyncClient::batchGetItemPaginator;
}
private void addReadRequestsToMap(ReadBatch readBatch, Map readRequestMap) {
KeysAndAttributes newKeysAndAttributes = readBatch.keysAndAttributes();
KeysAndAttributes existingKeysAndAttributes = readRequestMap.get(readBatch.tableName());
if (existingKeysAndAttributes == null) {
readRequestMap.put(readBatch.tableName(), newKeysAndAttributes);
return;
}
KeysAndAttributes mergedKeysAndAttributes =
mergeKeysAndAttributes(existingKeysAndAttributes, newKeysAndAttributes);
readRequestMap.put(readBatch.tableName(), mergedKeysAndAttributes);
}
private static KeysAndAttributes mergeKeysAndAttributes(KeysAndAttributes first, KeysAndAttributes second) {
if (!compareNullableBooleans(first.consistentRead(), second.consistentRead())) {
throw new IllegalArgumentException("All batchable read requests for the same table must have the "
+ "same 'consistentRead' setting.");
}
Boolean consistentRead = first.consistentRead() == null ? second.consistentRead() : first.consistentRead();
List
© 2015 - 2025 Weber Informatics LLC | Privacy Policy