akka.projection.grpc.producer.scaladsl.EventProducer
EventProducerSource
Companion object EventProducerSource
final class EventProducerSource extends AnyRef
- Annotations
- @ApiMayChange()
- Source
- EventProducer.scala
- Alphabetic
- By Inheritance
- EventProducerSource
- AnyRef
- Any
- Hide All
- Show All
- Public
- Protected
Value Members
- def copy(entityType: String = entityType, streamId: String = streamId, transformation: Transformation = transformation, settings: EventProducerSettings = settings, producerFilter: (EventEnvelope[Any]) => Boolean = producerFilter, transformSnapshot: Option[(Any) => Any] = transformSnapshot, replicatedEventOriginFilter: Option[EventOriginFilter] = replicatedEventOriginFilter): EventProducerSource
- val entityType: String
- val producerFilter: (EventEnvelope[Any]) => Boolean
- val settings: EventProducerSettings
- val streamId: String
- val transformSnapshot: Option[(Any) => Any]
- val transformation: Transformation
- def withProducerFilter[Event](producerFilter: (EventEnvelope[Event]) => Boolean): EventProducerSource
Filter events matching the predicate, for example based on tags.
- def withReplicatedEventOriginFilter(filter: EventOriginFilter): EventProducerSource
- def withStartingFromSnapshots[Snapshot, Event](transformSnapshot: (Snapshot) => Event): EventProducerSource
Use snapshots as starting points and thereby reducing number of events that have to be loaded.
Use snapshots as starting points and thereby reducing number of events that have to be loaded. This can be useful if the consumer start from zero without any previously processed offset or if it has been disconnected for a long while and its offset is far behind.
First it loads all snapshots with timestamps greater than or equal to the offset timestamp. There is at most one snapshot per persistenceId. The snapshots are transformed to events with the given
transformSnapshot
function.After emitting the snapshot events the ordinary events with sequence numbers after the snapshots are emitted.
Important note: This should not be used together with EventProducerPush. In that case
SourceProvider
witheventsBySlicesStartingFromSnapshots
should be used instead. - def withTopicProducerFilter(topicExpression: String): EventProducerSource
Filter events matching the topic expression according to MQTT specification, including wildcards.
Filter events matching the topic expression according to MQTT specification, including wildcards. The topic of an event is defined by a tag with certain prefix, see
topic-tag-prefix
configuration.