io.camunda.zeebe.logstreams.log.LogStreamBatchReader Maven / Gradle / Ivy
/*
* Copyright Camunda Services GmbH and/or licensed to Camunda Services GmbH under
* one or more contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright ownership.
* Licensed under the Zeebe Community License 1.1. You may not use this file
* except in compliance with the Zeebe Community License 1.1.
*/
package io.camunda.zeebe.logstreams.log;
import io.camunda.zeebe.logstreams.log.LogStreamBatchReader.Batch;
import io.camunda.zeebe.util.CloseableSilently;
import java.util.Iterator;
/**
* Reads the log stream in batches. Similar to {@link LogStreamReader} but groups events with the
* same source event position in batches. Can be used to read all follow-up events at once.
*
*
*
*
* // optionally
* reader.seekToNextBatch(position);
*
* while (reader.hasNext()) {
* final Batch batch = reader.next();
* while (batch.hasNext()) {
* final LoggedEvent event = batch.next();
* // ...
* }
* }
*
*
*/
public interface LogStreamBatchReader extends Iterator, CloseableSilently {
/**
* Seeks to the next batch after the given position. If the position is negative then it seeks to
* the first event.
*
* @param position the position to seek for the next event
* @return true
, if the given position exists, or if it is negative
*/
boolean seekToNextBatch(long position);
/**
* A batch of events that share the same source record position. Events with no source event
* position are in a singleton batch.
*
*
*
*
* while (batch.hasNext()) {
* final LoggedEvent event = batch.next();
* // ...
* }
*
*
*/
interface Batch extends Iterator {
/**
* Move to the head of the batch. Reads the first event of the batch next. Can be used to read
* the whole batch again.
*/
void head();
/**
* @return the current head of the batch without moving to the next event.
*/
LoggedEvent current();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy