class WithReferencedStatesFlow<T : Any> : FlowLogic<T>
Given a flow which uses reference states, the WithReferencedStatesFlow will execute the flow as a subFlow. If the flow fails due to a NotaryError.Conflict for a reference state, then WithReferencedStatesFlow will be suspended until the state refs for the reference states are consumed. In this case, a consumption means that:
WARNING: Caution should be taken when using this flow as it facilitates automated re-running of flows which use reference states. The flow using reference states should include checks to ensure that the reference data is reasonable, especially if some economics transaction depends upon it.
progressTracker
- a progress tracker instance.
flowLogicProducer
- a lambda which creates the FlowLogic instance using reference states. This will be executed at least once.
It is recommended a new FlowLogic instance be returned each time.
object ATTEMPT : Step |
|
object RETRYING : Step |
|
object SUCCESS : Step |
WithReferencedStatesFlow(progressTracker: ProgressTracker = tracker(), flowLogicProducer: () -> FlowLogic<T>)
Given a flow which uses reference states, the WithReferencedStatesFlow will execute the flow as a subFlow. If the flow fails due to a NotaryError.Conflict for a reference state, then WithReferencedStatesFlow will be suspended until the state refs for the reference states are consumed. In this case, a consumption means that: |
val progressTracker: ProgressTracker
a progress tracker instance. |
val isKilled: Boolean
Returns |
|
val logger: <ERROR CLASS>
This is where you should log things to. |
|
val ourIdentity: Party
Specifies the identity to use for this flow. This will be one of the multiple identities that belong to this node.
This is the same as calling |
|
val ourIdentityAndCert: PartyAndCertificate
Specifies the identity, with certificate, to use for this flow. This will be one of the multiple identities that belong to this node. |
|
val runId: StateMachineRunId
Returns a wrapped java.util.UUID object that identifies this state machine run (i.e. subflows have the same identifier as their parents). |
|
val serviceHub: ServiceHub
Provides access to big, heavy classes that may be reconstructed from time to time, e.g. across restarts. It is only available once the flow has started, which means it cannot be accessed in the constructor. Either access this lazily or from inside call. |
fun call(): T
This is where you fill out your business logic. |
fun <R : Any> await(operation: FlowExternalAsyncOperation<R>): R fun <R : Any> await(operation: FlowExternalOperation<R>): R
Executes the specified operation and suspends until operation completion. |
|
fun checkFlowIsNotKilled(): Unit
Helper function that throws a KilledFlowException if the current FlowLogic has been killed. fun checkFlowIsNotKilled(lazyMessage: () -> Any): Unit
Helper function that throws a KilledFlowException if the current FlowLogic has been killed. The provided message is added to the thrown KilledFlowException. |
|
fun checkFlowPermission(permissionName: String, extraAuditData: Map<String, String>): Unit
Flows can call this method to ensure that the active FlowInitiator is authorised for a particular action. This provides fine grained control over application level permissions, when RPC control over starting the flow is insufficient, or the permission is runtime dependent upon the choices made inside long lived flow code. For example some users may have restricted limits on how much cash they can transfer, or whether they can change certain fields. An audit event is always recorded whenever this method is used. If the permission is not granted for the FlowInitiator a FlowException is thrown. |
|
fun close(sessions: NonEmptySet<FlowSession>): Unit
Closes the provided sessions and performs cleanup of any resources tied to these sessions. |
|
fun flowStackSnapshot(): FlowStackSnapshot?
Returns a shallow copy of the Quasar stack frames at the time of call to flowStackSnapshot. Use this to inspect what objects would be serialised at the time of call to a suspending action (e.g. send/receive). Note: This logic is only available during tests and is not meant to be used during the production deployment. Therefore the default implementation does nothing. |
|
fun
Returns a FlowInfo object describing the flow otherParty is using. With FlowInfo.flowVersion it provides the necessary information needed for the evolution of flows and enabling backwards compatibility. |
|
fun initiateFlow(destination: Destination): FlowSession
Creates a communication session with destination. Subsequently you may send/receive using this session object. How the messaging is routed depends on the Destination type, including whether this call does any initial communication. fun initiateFlow(party: Party): FlowSession
Creates a communication session with party. Subsequently you may send/receive using this session object. Note that this function does not communicate in itself, the counter-flow will be kicked off by the first send/receive. |
|
fun persistFlowStackSnapshot(): Unit
Persists a shallow copy of the Quasar stack frames at the time of call to persistFlowStackSnapshot. Use this to track the monitor evolution of the quasar stack values during the flow execution. The flow stack snapshot is stored in a file located in {baseDir}/flowStackSnapshots/YYYY-MM-DD/{flowId}/ where baseDir is the node running directory and flowId is the flow unique identifier generated by the platform. |
|
fun <R : Any>
Suspends until the specified otherParty sends us a message of type R. open fun <R : Any>
Suspends until the specified otherParty sends us a message of type receiveType. |
|
open fun <R : Any> receiveAll(receiveType: Class<R>, sessions: List<FlowSession>, maySkipCheckpoint: Boolean = false): List<UntrustworthyData<R>>
Suspends until a message has been received for each session in the specified sessions. |
|
open fun receiveAllMap(sessions: Map<FlowSession, Class<out Any>>, maySkipCheckpoint: Boolean = false): Map<FlowSession, UntrustworthyData<Any>>
Suspends until a message has been received for each session in the specified sessions. |
|
fun recordAuditEvent(eventType: String, comment: String, extraAuditData: Map<String, String>): Unit
Flows can call this method to record application level flow audit events |
|
open fun
Queues the given payload for sending to the otherParty and continues without suspending. |
|
fun sendAll(payload: Any, sessions: Set<FlowSession>, maySkipCheckpoint: Boolean = false): Unit
Queues the given payload for sending to the provided sessions and continues without suspending. |
|
fun sendAllMap(payloadsPerSession: Map<FlowSession, Any>, maySkipCheckpoint: Boolean = false): Unit
Queues the given payloads for sending to the provided sessions and continues without suspending. |
|
fun <R : Any>
Serializes and queues the given payload object for sending to the otherParty. Suspends until a response is received, which must be of the given R type. open fun <R : Any>
Serializes and queues the given payload object for sending to the otherParty. Suspends until a response is received, which must be of the given receiveType. Remember that when receiving data from other parties the data should not be trusted until it's been thoroughly verified for consistency and that all expectations are satisfied, as a malicious peer may send you subtly corrupted data in order to exploit your code. |
|
open fun <R> subFlow(subLogic: FlowLogic<R>): R
Invokes the given subflow. This function returns once the subflow completes successfully with the result returned by that subflow's call method. If the subflow has a progress tracker, it is attached to the current step in this flow's progress tracker. |
|
fun track(): DataFeed<String, String>?
Returns a pair of the current progress step, as a string, and an observable of stringified changes to the progressTracker. |
|
fun trackStepsTree(): DataFeed<List<<ERROR CLASS><Int, String>>, List<<ERROR CLASS><Int, String>>>?
Returns a pair of the current steps tree of current progressTracker as pairs of zero-based depth and stringified step label and observable of upcoming changes to the structure. |
|
fun trackStepsTreeIndex(): DataFeed<Int, Int>?
Returns a pair of the current progress step index (as integer) in steps tree of current progressTracker, and an observable of its upcoming changes. |
|
fun waitForLedgerCommit(hash: SecureHash, maySkipCheckpoint: Boolean = false): SignedTransaction
Suspends the flow until the transaction with the specified ID is received, successfully verified and sent to the vault for processing. Note that this call suspends until the transaction is considered valid by the local node, but that doesn't imply the vault will consider it relevant. |
|
fun waitForStateConsumption(stateRefs: Set<StateRef>): Unit
Suspends the current flow until all the provided StateRefs have been consumed. |
fun tracker(): ProgressTracker |
fun Any.contextLogger(): <ERROR CLASS>
When called from a companion object, returns the logger for the enclosing class. |
|
fun FlowLogic<*>.receiveAll(session: <ERROR CLASS><FlowSession, Class<out Any>>, vararg sessions: <ERROR CLASS><FlowSession, Class<out Any>>): Map<FlowSession, UntrustworthyData<Any>> fun <R : Any> FlowLogic<*>.receiveAll(receiveType: Class<R>, session: FlowSession, vararg sessions: FlowSession): List<UntrustworthyData<R>> fun <R : Any> FlowLogic<*>.receiveAll(session: FlowSession, vararg sessions: FlowSession): List<UntrustworthyData<R>>
Suspends until a message has been received for each session in the specified sessions. |