mirror of
https://github.com/corda/corda.git
synced 2025-01-08 14:03:06 +00:00
53 lines
3.7 KiB
ReStructuredText
53 lines
3.7 KiB
ReStructuredText
|
Vault
|
|||
|
=====
|
|||
|
|
|||
|
The vault contains data extracted from the ledger that is considered relevant to the node’s owner, stored in a relational model
|
|||
|
that can be easily queried and worked with.
|
|||
|
|
|||
|
The vault keeps track of both unconsumed and consumed states:
|
|||
|
|
|||
|
* Unconsumed (or unspent) states represent fungible states available for spending (including spend-to-self transactions)
|
|||
|
and linear states available for evolution (eg. in response to a lifecycle event on a deal) or transfer to another party.
|
|||
|
* Consumed (or spent) states represent ledger immutable state for the purpose of transaction reporting, audit and archival, including the ability to perform joins with app-private data (like customer notes)
|
|||
|
|
|||
|
By fungible we refer to assets of measurable quantity (eg. a cash currency, units of stock) which can be combined
|
|||
|
together to represent a single ledger state.
|
|||
|
|
|||
|
Like with a cryptocurrency wallet, the Corda vault can create transactions that send value (eg. transfer of state) to someone else
|
|||
|
by combining fungible states and possibly adding a change output that makes the values balance (this process is usually referred to as ‘coin selection’).
|
|||
|
Vault spending ensures that transactions respect the fungibility rules in order to ensure that the issuer and reference data is preserved as the assets pass from hand to hand.
|
|||
|
|
|||
|
.. note:: Basic 'coin selection' is currently implemented. Future work includes fungible state optimisation (splitting and
|
|||
|
merging of states in the background), 'soft locking' (ability to automatically or explicitly reserve states to prevent
|
|||
|
multiple transactions trying to use the same output simultaneously), 'state re-issuance' (sending of states back to the
|
|||
|
issuer for re-issuance, thus pruning long transaction chains and improving privacy).
|
|||
|
|
|||
|
There is also a facility for attaching descriptive textual notes against any transaction stored in the vault.
|
|||
|
|
|||
|
The vault supports the management of data in both authoritative ("on-ledger") form and, where appropriate, shadow ("off-ledger") form:
|
|||
|
|
|||
|
* "On-ledger" data refers to distributed ledger state (cash, deals, trades) to which a firm is participant.
|
|||
|
* "Off-ledger" data refers to a firm's internal reference, static and systems data.
|
|||
|
|
|||
|
The following diagram illustrates the breakdown of the vault into sub-system components:
|
|||
|
|
|||
|
.. image:: resources/vault.png
|
|||
|
|
|||
|
Note the following:
|
|||
|
|
|||
|
* the vault "On Ledger" store tracks unconsumed state and is updated internally by the node upon recording of a transaction on the ledger
|
|||
|
(following successful smart contract verification and signature by all participants)
|
|||
|
* the vault "Off Ledger" store refers to additional data added by the node owner subsequent to transaction recording
|
|||
|
* the vault performs fungible state spending (and in future, fungible state optimisation management including merging, splitting and re-issuance)
|
|||
|
* vault extensions represent additional custom plugin code a developer may write to query specific custom contract state attributes.
|
|||
|
* customer "Off Ledger" (private store) represents internal organisational data that may be joined with the vault data to perform additional reporting or processing
|
|||
|
* a vault query API is exposed to developers using standard Corda RPC and CorDapp plugin mechanisms
|
|||
|
* a vault update API is internally used by transaction recording flows.
|
|||
|
* the vault database schemas are directly accessible via JDBC for customer joins and queries
|
|||
|
|
|||
|
Section 8 of the `Technical white paper`_ describes features of the vault yet to be implemented including private key managament,
|
|||
|
soft state locking, state splitting and merging, asset re-issuance and node event scheduling.
|
|||
|
|
|||
|
.. _`Technical white paper`: _static/corda-technical-whitepaper.pdf
|
|||
|
|