Class MutableHandler<M>
java.lang.Object
io.fluxzero.sdk.tracking.handling.MutableHandler<M>
- Type Parameters:
M- the message type this handler supports
- All Implemented Interfaces:
Handler<M>
A specialized
Handler that maintains and mutates an internal delegate instance.
This handler is designed for use cases where the state of the handler may evolve dynamically across message invocations. It is particularly suited for temporarily scoped objects (e.g. sagas, user sessions).
Behavior
When a handler method returns an instance of the handler’s target class, this instance is stored as the new delegate:Object result = method.invoke(target);
if (result instanceof MyHandler) {
target = result; // promote new version
}
If the method returns null and the method's return type matches the target class, the internal
target is cleared, and any registered delete callbacks are triggered.
Lifecycle Hooks
A delete callback can be registered usingonDelete(Runnable) to perform cleanup when
the handler deletes its state (i.e., returns null).-
Nested Class Summary
Nested classes/interfaces inherited from interface Handler
Handler.DelegatingHandler<M> -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptiongetInvoker(M message) Returns aHandlerInvokercapable of processing the given message, if available.booleanisEmpty()Methods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface Handler
getTargetClass, or
-
Constructor Details
-
MutableHandler
public MutableHandler()
-
-
Method Details
-
getInvoker
Description copied from interface:HandlerReturns aHandlerInvokercapable of processing the given message, if available.- Specified by:
getInvokerin interfaceHandler<M>- Parameters:
message- the message to be handled- Returns:
- an optional
HandlerInvokerif this handler can handle the message; otherwiseOptional.empty()
-
instantiateTarget
-
isEmpty
public boolean isEmpty() -
onDelete
-