Class InMemoryScheduleStore
java.lang.Object
io.fluxzero.sdk.tracking.client.InMemoryMessageStore
io.fluxzero.sdk.scheduling.client.InMemoryScheduleStore
- All Implemented Interfaces:
Monitored<List<SerializedMessage>>, HasMessageStore, MessageStore, SchedulingClient, AutoCloseable
An in-memory implementation of a scheduling store that allows the scheduling, retrieval, and management of scheduled
messages. It extends `InMemoryMessageStore` to reuse the functionalities for storing and managing messages and
implements `SchedulingClient` to support scheduling-specific operations.
This implementation provides thread-safe mechanisms for scheduling, retrieving, and cancelling messages. Messages are scheduled to be processed at specific timestamps, with support for expiration and filtering of schedules.
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionappend(SerializedMessage... messages) Appends the given messages to the store.append(List<SerializedMessage> messages) Appends a list of messages to the store.asList(Map<Long, String> scheduleIdsByIndex, Serializer serializer) cancelSchedule(String scheduleId, Guarantee guarantee) Cancel a scheduled message using the provided delivery guarantee.protected Collection<SerializedMessage> filterMessages(Collection<SerializedMessage> messages) getFutureSchedules(Serializer serializer) getSchedule(String scheduleId) Retrieves the serialized schedule associated with the given ID.protected voidpurgeExpiredMessages(Duration messageExpiration) removeExpiredSchedules(Serializer serializer) schedule(Guarantee guarantee, SerializedSchedule... schedules) Schedule one or more serialized schedules with a specifiedGuarantee.voidtoString()Methods inherited from class InMemoryMessageStore
close, getBatch, getMessage, notifyMonitors, notifyMonitors, registerMonitorMethods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface MessageStore
getBatch, getMessageStore, setRetentionTime, unwrapMethods inherited from interface SchedulingClient
cancelSchedule, close, hasSchedule, schedule
-
Constructor Details
-
InMemoryScheduleStore
public InMemoryScheduleStore() -
InMemoryScheduleStore
-
-
Method Details
-
filterMessages
- Overrides:
filterMessagesin classInMemoryMessageStore
-
append
Description copied from interface:MessageStoreAppends the given messages to the store.- Specified by:
appendin interfaceMessageStore- Parameters:
messages- messages to append- Returns:
- a
CompletableFuturethat completes when the messages have been successfully appended
-
schedule
Description copied from interface:SchedulingClientSchedule one or more serialized schedules with a specifiedGuarantee.- Specified by:
schedulein interfaceSchedulingClient- Parameters:
guarantee- Delivery guarantee to apply (e.g., none, sent, stored).schedules- One or more schedules to register.- Returns:
- A future that completes when the scheduling is acknowledged.
-
cancelSchedule
Description copied from interface:SchedulingClientCancel a scheduled message using the provided delivery guarantee.- Specified by:
cancelSchedulein interfaceSchedulingClient- Parameters:
scheduleId- The identifier of the schedule to cancel.guarantee- Delivery guarantee for the cancellation request.- Returns:
- A future that completes when the cancellation is processed.
-
getSchedule
Description copied from interface:SchedulingClientRetrieves the serialized schedule associated with the given ID.- Specified by:
getSchedulein interfaceSchedulingClient- Parameters:
scheduleId- The ID of the schedule to retrieve.- Returns:
- The matching
SerializedSchedule, ornullif none is found.
-
append
Description copied from interface:MessageStoreAppends a list of messages to the store.- Specified by:
appendin interfaceMessageStore- Overrides:
appendin classInMemoryMessageStore- Parameters:
messages- messages to append- Returns:
- a
CompletableFuturethat completes when the messages have been successfully appended
-
setClock
-
getFutureSchedules
-
removeExpiredSchedules
-
asList
-
purgeExpiredMessages
- Overrides:
purgeExpiredMessagesin classInMemoryMessageStore
-
toString
- Overrides:
toStringin classInMemoryMessageStore
-