public class FilteringEventStorageEngine extends Object implements EventStorageEngine
| Constructor and Description | 
|---|
| FilteringEventStorageEngine(EventStorageEngine delegate,
                           Predicate<? super EventMessage<?>> filter)Initializes the FilteringEventStorageEngine delegating all event messages matching the given  filterto
 the givendelegate. | 
| Modifier and Type | Method and Description | 
|---|---|
| void | appendEvents(EventMessage<?>... events)Append one or more events to the event storage. | 
| void | appendEvents(List<? extends EventMessage<?>> events)Append a list of events to the event storage. | 
| TrackingToken | createHeadToken()Creates a token that is at the head of an event stream - that tracks all new events. | 
| TrackingToken | createTailToken()Creates a token that is at the tail of an event stream - that tracks events from the beginning of time. | 
| TrackingToken | createTokenAt(Instant dateTime)Creates a token that tracks all events after given  dateTime. | 
| Optional<Long> | lastSequenceNumberFor(String aggregateIdentifier)Returns the last known sequence number for the given  aggregateIdentifier. | 
| DomainEventStream | readEvents(String aggregateIdentifier)Get a  DomainEventStreamcontaining all events published by the aggregate with givenaggregateIdentifier. | 
| DomainEventStream | readEvents(String aggregateIdentifier,
          long firstSequenceNumber)Get a  DomainEventStreamcontaining all events published by the aggregate with givenaggregateIdentifierstarting with the first event having a sequence number that is equal or larger than the
 givenfirstSequenceNumber. | 
| Stream<? extends TrackedEventMessage<?>> | readEvents(TrackingToken trackingToken,
          boolean mayBlock)Open an event stream containing all events stored since given tracking token. | 
| Optional<DomainEventMessage<?>> | readSnapshot(String aggregateIdentifier)Try to load a snapshot event of the aggregate with given  aggregateIdentifier. | 
| void | storeSnapshot(DomainEventMessage<?> snapshot)Store an event that contains a snapshot of an aggregate. | 
public FilteringEventStorageEngine(EventStorageEngine delegate, Predicate<? super EventMessage<?>> filter)
filter to
 the given delegate.
 
 Note that this only affects events stored in the StorageEngine. The EventStore will still publish these
 events to Subscribed event handlers. Tracking Event Processors take their events from the stored events, and
 will therefore not receive any events blocked by this instance.
delegate - the EventStorageEngine to store matching messages infilter - the predicate that event messages must match against to be storedpublic void appendEvents(EventMessage<?>... events)
EventStorageEngine
 Note that all events should have a unique event identifier. When storing domain events
 events should also have a unique combination of aggregate id and sequence number.
 
 By default this method creates a list of the offered events and then invokes EventStorageEngine.appendEvents(List).
appendEvents in interface EventStorageEngineevents - Events to append to the event storagepublic void appendEvents(List<? extends EventMessage<?>> events)
EventStorageEngine
 Note that all events should have a unique event identifier. When storing domain events
 events should also have a unique combination of aggregate id and sequence number.
appendEvents in interface EventStorageEngineevents - Events to append to the event storagepublic void storeSnapshot(DomainEventMessage<?> snapshot)
EventStorageEnginestoreSnapshot in interface EventStorageEnginesnapshot - The snapshot event of the aggregate that is to be storedpublic Stream<? extends TrackedEventMessage<?>> readEvents(TrackingToken trackingToken, boolean mayBlock)
EventStorageEnginetrackingToken of null to open
 a stream containing all available events.
 
 If the value of the given mayBlock is true the returned stream is allowed to block while waiting
 for new event messages if the end of the stream is reached.
readEvents in interface EventStorageEnginetrackingToken - Object describing the global index of the last processed event or null to create a
                      stream of all events in the storemayBlock - If true the storage engine may optionally choose to block to wait for new event
                      messages if the end of the stream is reached.public DomainEventStream readEvents(String aggregateIdentifier)
EventStorageEngineDomainEventStream containing all events published by the aggregate with given aggregateIdentifier. By default calling this method is shorthand for an invocation of
 EventStorageEngine.readEvents(String, long) with a sequence number of 0.
 The returned stream is finite, i.e. it should not block to wait for further events if the end of the event stream of the aggregate is reached.
readEvents in interface EventStorageEngineaggregateIdentifier - The identifier of the aggregate to return an event stream forpublic DomainEventStream readEvents(String aggregateIdentifier, long firstSequenceNumber)
EventStorageEngineDomainEventStream containing all events published by the aggregate with given aggregateIdentifier starting with the first event having a sequence number that is equal or larger than the
 given firstSequenceNumber.
 The returned stream is finite, i.e. it should not block to wait for further events if the end of the event stream of the aggregate is reached.
readEvents in interface EventStorageEngineaggregateIdentifier - The identifier of the aggregatefirstSequenceNumber - The expected sequence number of the first event in the returned streampublic Optional<DomainEventMessage<?>> readSnapshot(String aggregateIdentifier)
EventStorageEngineaggregateIdentifier. If the storage engine has
 no snapshot event of the aggregate, an empty Optional is returned.readSnapshot in interface EventStorageEngineaggregateIdentifier - The identifier of the aggregatepublic Optional<Long> lastSequenceNumberFor(String aggregateIdentifier)
EventStorageEngineaggregateIdentifier.
 
 While it's recommended to use the sequence numbers from the DomainEventStream, there are cases where
 knowing the sequence number is required, without having read the actual events. In such case, this method is a
 viable alternative.
lastSequenceNumberFor in interface EventStorageEngineaggregateIdentifier - The identifier to find the last sequence number forpublic TrackingToken createTailToken()
EventStorageEnginecreateTailToken in interface EventStorageEnginenull is returnedpublic TrackingToken createHeadToken()
EventStorageEnginecreateHeadToken in interface EventStorageEnginenull is returnedpublic TrackingToken createTokenAt(Instant dateTime)
EventStorageEnginedateTime. If there is an event exactly at the given
 dateTime, it will be tracked too.createTokenAt in interface EventStorageEnginedateTime - The date and time for determining criteria how the tracking token should be created. A tracking
                 token should point to very first event before this date and time.dateTime, if there aren't events matching this criteria null is returnedCopyright © 2010–2018. All rights reserved.