mirror of
https://github.com/corda/corda.git
synced 2024-12-22 14:22:28 +00:00
bef8630fe0
* Improvements to Vault Query Service soft locked state querying (removed old mechanism from VaultService). * Fixed rst document formatting. * Added additional soft locking criteria mode: all unlocked plus those locked as specified by lockId(s). * Addressed comments from PR feedback.
62 lines
3.8 KiB
ReStructuredText
62 lines
3.8 KiB
ReStructuredText
Soft Locking
|
|
============
|
|
|
|
Soft Locking is implemented in the vault to try and prevent a node constructing transactions that attempt to use the same input(s) simultaneously.
|
|
Such transactions would result in naturally wasted work when the notary rejects them as double spend attempts.
|
|
|
|
Soft locks are automatically applied to coin selection (eg. cash spending) to ensure that no two transactions attempt to
|
|
spend the same fungible states. The outcome of such an eventuality will result in an ``InsufficientBalanceException`` for one
|
|
of the requesters if there are insufficient number of fungible states available to satisfy both requests.
|
|
|
|
.. note:: The Cash Contract schema table is now automatically generated upon node startup as Coin Selection now uses
|
|
this table to ensure correct locking and selection of states to satisfy minimum requested spending amounts.
|
|
|
|
Soft locks are also automatically applied within flows that issue or receive new states.
|
|
These states are effectively soft locked until flow termination (exit or error) or by explicit release.
|
|
|
|
In addition, the ``VaultService`` exposes a number of functions a developer may use to explicitly reserve, release and
|
|
query soft locks associated with states as required by their CorDapp application logic:
|
|
|
|
.. literalinclude:: ../../core/src/main/kotlin/net/corda/core/node/services/VaultService.kt
|
|
:language: kotlin
|
|
:start-after: DOCSTART SoftLockAPI
|
|
:end-before: DOCEND SoftLockAPI
|
|
|
|
Query
|
|
-----
|
|
By default vault queries will always include locked states in its result sets.
|
|
Custom filterable criteria can be specified using the ``SoftLockingCondition`` attribute of ``VaultQueryCriteria``:
|
|
|
|
.. literalinclude:: ../../core/src/main/kotlin/net/corda/core/node/services/vault/QueryCriteria.kt
|
|
:language: kotlin
|
|
:start-after: DOCSTART VaultQuerySoftLockingCriteria
|
|
:end-before: DOCEND VaultQuerySoftLockingCriteria
|
|
|
|
Explicit Usage
|
|
--------------
|
|
|
|
Soft locks are associated with transactions, and typically within the lifecycle of a flow. Specifically, every time a
|
|
flow is started a soft lock identifier is associated with that flow for its duration (and released upon it's natural
|
|
termination or in the event of an exception). The ``VaultSoftLockManager`` is responsible within the Node for
|
|
automatically managing this soft lock registration and release process for flows. The ``TransactionBuilder`` class has a
|
|
new ``lockId`` field for the purpose of tracking lockable states. By default, it is automatically set to a random
|
|
``UUID`` (outside of a flow) or to a flow's unique ID (within a flow).
|
|
|
|
Upon building a new transaction to perform some action for a set of states on a contract, a developer must explicitly
|
|
register any states they may wish to hold until that transaction is committed to the ledger. These states will be effectively 'soft
|
|
locked' (not usable by any other transaction) until the developer explicitly releases these or the flow terminates or errors
|
|
(at which point they are automatically released).
|
|
|
|
Use Cases
|
|
---------
|
|
|
|
A prime example where *soft locking* is automatically enabled is within the process of issuance and transfer of fungible
|
|
state (eg. Cash). An issuer of some fungible asset (eg. Bank of Corda) may wish to transfer that new issue immediately
|
|
to the issuance requester (eg. Big Corporation). This issuance and transfer operation must be *atomic* such that another
|
|
flow (or instance of the same flow) does not step in and unintentionally spend the states issued by Bank of Corda
|
|
before they are transferred to the intended recipient. Soft locking will automatically prevent new issued states within
|
|
``IssuerFlow`` from being spendable by any other flow until such time as the ``IssuerFlow`` itself terminates.
|
|
|
|
Other use cases for *soft locking* may involve competing flows attempting to match trades or any other concurrent
|
|
activities that may involve operating on an identical set of unconsumed states.
|