Package kalix.javasdk.workflow
Class AbstractWorkflow<S>
Object
kalix.javasdk.workflow.AbstractWorkflow<S>
- Direct Known Subclasses:
- ProtoWorkflow,- Workflow
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic classstatic classstatic interfaceAn Effect is a description of what Kalix needs to do after the command is handled.static classstatic interfacestatic classstatic class
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoid_internalSetCommandContext(Optional<CommandContext> context) INTERNAL APIvoid_internalSetCurrentState(S state, boolean deleted) INTERNAL APIvoid_internalSetTimerScheduler(Optional<TimerScheduler> timerScheduler) INTERNAL APIprotected final CommandContextAdditional context and metadata for a command handler.protected final SReturns the state as currently stored by Kalix.abstract AbstractWorkflow.WorkflowDef<S> protected final AbstractWorkflow.Effect.Builder<S> effects()Returns the initial empty state object.protected booleanReturns true if the entity has been deleted.maxRetries(int maxRetries) Starts defining a recover strategy for the workflow or a specific step.final TimerSchedulertimers()Returns aTimerSchedulerthat can be used to schedule further in time.workflow()
- 
Constructor Details- 
AbstractWorkflowpublic AbstractWorkflow()
 
- 
- 
Method Details- 
emptyStateReturns the initial empty state object. This object will be passed into the command and step handlers, until a new state replaces it.Also known as "zero state" or "neutral state". The default implementation of this method returns null. It can be overridden to return a more sensible initial state.
- 
commandContextAdditional context and metadata for a command handler.It will throw an exception if accessed from constructor. - Throws:
- IllegalStateException- if accessed outside a handler method
 
- 
_internalSetCommandContextINTERNAL API
- 
_internalSetTimerSchedulerINTERNAL API
- 
timersReturns aTimerSchedulerthat can be used to schedule further in time.
- 
_internalSetCurrentStateINTERNAL API
- 
currentStateReturns the state as currently stored by Kalix.Note that modifying the state directly will not update it in storage. To save the state, one must call { effects().updateState()}.This method can only be called when handling a command. Calling it outside a method (eg: in the constructor) will raise a IllegalStateException exception. - Throws:
- IllegalStateException- if accessed outside a handler method
 
- 
isDeleted@ApiMayChange protected boolean isDeleted()Returns true if the entity has been deleted.
- 
definition- Returns:
- A workflow definition in a form of steps and transitions between them.
 
- 
effects
- 
workflow
- 
maxRetriesStarts defining a recover strategy for the workflow or a specific step.- Parameters:
- maxRetries- number of retries before giving up.
- Returns:
- MaxRetries strategy.
 
 
-