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

software.amazon.kinesis.retrieval.IteratorBuilder Maven / Gradle / Ivy

package software.amazon.kinesis.retrieval;

import java.time.Instant;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;

import software.amazon.awssdk.services.kinesis.model.GetShardIteratorRequest;
import software.amazon.awssdk.services.kinesis.model.ShardIteratorType;
import software.amazon.awssdk.services.kinesis.model.StartingPosition;
import software.amazon.awssdk.services.kinesis.model.SubscribeToShardRequest;
import software.amazon.kinesis.annotations.KinesisClientInternalApi;
import software.amazon.kinesis.checkpoint.SentinelCheckpoint;
import software.amazon.kinesis.common.InitialPositionInStreamExtended;

@KinesisClientInternalApi
public class IteratorBuilder {

    public static SubscribeToShardRequest.Builder request(SubscribeToShardRequest.Builder builder,
            String sequenceNumber, InitialPositionInStreamExtended initialPosition) {
        return builder.startingPosition(request(StartingPosition.builder(), sequenceNumber, initialPosition).build());
    }

    public static SubscribeToShardRequest.Builder reconnectRequest(SubscribeToShardRequest.Builder builder,
            String sequenceNumber, InitialPositionInStreamExtended initialPosition) {
        return builder.startingPosition(
                reconnectRequest(StartingPosition.builder(), sequenceNumber, initialPosition).build());
    }

    public static StartingPosition.Builder request(StartingPosition.Builder builder, String sequenceNumber,
            InitialPositionInStreamExtended initialPosition) {
        return apply(builder, StartingPosition.Builder::type, StartingPosition.Builder::timestamp,
                StartingPosition.Builder::sequenceNumber, initialPosition, sequenceNumber,
                ShardIteratorType.AT_SEQUENCE_NUMBER);
    }

    public static StartingPosition.Builder reconnectRequest(StartingPosition.Builder builder, String sequenceNumber,
            InitialPositionInStreamExtended initialPosition) {
        return apply(builder, StartingPosition.Builder::type, StartingPosition.Builder::timestamp,
                StartingPosition.Builder::sequenceNumber, initialPosition, sequenceNumber,
                ShardIteratorType.AFTER_SEQUENCE_NUMBER);
    }

    public static GetShardIteratorRequest.Builder request(GetShardIteratorRequest.Builder builder,
            String sequenceNumber, InitialPositionInStreamExtended initialPosition) {
        return apply(builder, GetShardIteratorRequest.Builder::shardIteratorType, GetShardIteratorRequest.Builder::timestamp,
                GetShardIteratorRequest.Builder::startingSequenceNumber, initialPosition, sequenceNumber,
                ShardIteratorType.AT_SEQUENCE_NUMBER);
    }

    private final static Map SHARD_ITERATOR_MAPPING;

    static {
        Map map = new HashMap<>();
        map.put(SentinelCheckpoint.LATEST.name(), ShardIteratorType.LATEST);
        map.put(SentinelCheckpoint.TRIM_HORIZON.name(), ShardIteratorType.TRIM_HORIZON);
        map.put(SentinelCheckpoint.AT_TIMESTAMP.name(), ShardIteratorType.AT_TIMESTAMP);

        SHARD_ITERATOR_MAPPING = Collections.unmodifiableMap(map);
    }

    @FunctionalInterface
    private interface UpdatingFunction {
        R apply(R updated, T value);
    }

    private static  R apply(R initial, UpdatingFunction shardIterFunc,
            UpdatingFunction dateFunc, UpdatingFunction sequenceFunction,
            InitialPositionInStreamExtended initialPositionInStreamExtended, String sequenceNumber,
            ShardIteratorType defaultIteratorType) {
        ShardIteratorType iteratorType = SHARD_ITERATOR_MAPPING.getOrDefault(
                sequenceNumber, defaultIteratorType);
        R result = shardIterFunc.apply(initial, iteratorType);
        switch (iteratorType) {
        case AT_TIMESTAMP:
            return dateFunc.apply(result, initialPositionInStreamExtended.getTimestamp().toInstant());
        case AT_SEQUENCE_NUMBER:
        case AFTER_SEQUENCE_NUMBER:
            return sequenceFunction.apply(result, sequenceNumber);
        default:
            return result;
        }
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy