Core db update storage root management for sub tries (#1964)
* Aristo: Re-phrase `LayerDelta` and `LayerFinal` as object references
why:
Avoids copying in some cases
* Fix copyright header
* Aristo: Verify `leafTie.root` function argument for `merge()` proc
why:
Zero root will lead to inconsistent DB entry
* Aristo: Update failure condition for hash labels compiler `hashify()`
why:
Node need not be rejected as long as links are on the schedule. In
that case, `redo[]` is to become `wff.base[]` at a later stage.
This amends an earlier fix, part of #1952 by also testing against
the target nodes of the `wff.base[]` sets.
* Aristo: Add storage root glue record to `hashify()` schedule
why:
An account leaf node might refer to a non-resolvable storage root ID.
Storage root node chains will end up at the storage root. So the link
`storage-root->account-leaf` needs an extra item in the schedule.
* Aristo: fix error code returned by `fetchPayload()`
details:
Final error code is implied by the error code form the `hikeUp()`
function.
* CoreDb: Discard `createOk` argument in API `getRoot()` function
why:
Not needed for the legacy DB. For the `Arsto` DB, a lazy approach is
implemented where a stprage root node is created on-the-fly.
* CoreDb: Prevent `$$` logging in some cases
why:
Logging the function `$$` is not useful when it is used for internal
use, i.e. retrieving an an error text for logging.
* CoreDb: Add `tryHashFn()` to API for pretty printing
why:
Pretty printing must not change the hashification status for the
`Aristo` DB. So there is an independent API wrapper for getting the
node hash which never updated the hashes.
* CoreDb: Discard `update` argument in API `hash()` function
why:
When calling the API function `hash()`, the latest state is always
wanted. For a version that uses the current state as-is without checking,
the function `tryHash()` was added to the backend.
* CoreDb: Update opaque vertex ID objects for the `Aristo` backend
why:
For `Aristo`, vID objects encapsulate a numeric `VertexID`
referencing a vertex (rather than a node hash as used on the
legacy backend.) For storage sub-tries, there might be no initial
vertex known when the descriptor is created. So opaque vertex ID
objects are supported without a valid `VertexID` which will be
initalised on-the-fly when the first item is merged.
* CoreDb: Add pretty printer for opaque vertex ID objects
* Cosmetics, printing profiling data
* CoreDb: Fix segfault in `Aristo` backend when creating MPT descriptor
why:
Missing initialisation error
* CoreDb: Allow MPT to inherit shared context on `Aristo` backend
why:
Creates descriptors with different storage roots for the same
shared `Aristo` DB descriptor.
* Cosmetics, update diagnostic message items for `Aristo` backend
* Fix Copyright year
2024-01-11 19:11:38 +00:00
|
|
|
# Copyright (c) 2023-2024 Status Research & Development GmbH
|
2023-09-26 09:21:13 +00:00
|
|
|
# Licensed under either of
|
|
|
|
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0)
|
|
|
|
# * MIT license ([LICENSE-MIT](LICENSE-MIT) or
|
|
|
|
# http://opensource.org/licenses/MIT)
|
|
|
|
# at your option. This file may not be copied, modified, or distributed except
|
|
|
|
# according to those terms.
|
|
|
|
|
|
|
|
{.push raises: [].}
|
|
|
|
|
|
|
|
import
|
|
|
|
./base_desc
|
|
|
|
|
|
|
|
type
|
|
|
|
EphemMethodsDesc =
|
2023-10-11 19:09:11 +00:00
|
|
|
CoreDbBackendRef | CoreDbKvtBackendRef | CoreDbMptBackendRef |
|
2024-02-02 20:23:04 +00:00
|
|
|
CoreDbAccBackendRef | CoreDbTrieRef
|
2023-09-26 09:21:13 +00:00
|
|
|
|
|
|
|
MethodsDesc =
|
2023-10-11 19:09:11 +00:00
|
|
|
CoreDxKvtRef |
|
|
|
|
CoreDxMptRef | CoreDxPhkRef | CoreDxAccRef |
|
|
|
|
CoreDxTxRef | CoreDxTxID |
|
2023-09-26 09:21:13 +00:00
|
|
|
CoreDxCaptRef
|
|
|
|
|
2023-10-11 19:09:11 +00:00
|
|
|
ValidateDesc* = MethodsDesc | EphemMethodsDesc | CoreDbErrorRef
|
|
|
|
|
2023-09-26 09:21:13 +00:00
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
# Private helpers
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
2023-10-11 19:09:11 +00:00
|
|
|
proc validateMethodsDesc(base: CoreDbBaseFns) =
|
2024-02-02 20:23:04 +00:00
|
|
|
doAssert not base.verifyFn.isNil
|
2023-10-11 19:09:11 +00:00
|
|
|
doAssert not base.backendFn.isNil
|
|
|
|
doAssert not base.destroyFn.isNil
|
Core db update storage root management for sub tries (#1964)
* Aristo: Re-phrase `LayerDelta` and `LayerFinal` as object references
why:
Avoids copying in some cases
* Fix copyright header
* Aristo: Verify `leafTie.root` function argument for `merge()` proc
why:
Zero root will lead to inconsistent DB entry
* Aristo: Update failure condition for hash labels compiler `hashify()`
why:
Node need not be rejected as long as links are on the schedule. In
that case, `redo[]` is to become `wff.base[]` at a later stage.
This amends an earlier fix, part of #1952 by also testing against
the target nodes of the `wff.base[]` sets.
* Aristo: Add storage root glue record to `hashify()` schedule
why:
An account leaf node might refer to a non-resolvable storage root ID.
Storage root node chains will end up at the storage root. So the link
`storage-root->account-leaf` needs an extra item in the schedule.
* Aristo: fix error code returned by `fetchPayload()`
details:
Final error code is implied by the error code form the `hikeUp()`
function.
* CoreDb: Discard `createOk` argument in API `getRoot()` function
why:
Not needed for the legacy DB. For the `Arsto` DB, a lazy approach is
implemented where a stprage root node is created on-the-fly.
* CoreDb: Prevent `$$` logging in some cases
why:
Logging the function `$$` is not useful when it is used for internal
use, i.e. retrieving an an error text for logging.
* CoreDb: Add `tryHashFn()` to API for pretty printing
why:
Pretty printing must not change the hashification status for the
`Aristo` DB. So there is an independent API wrapper for getting the
node hash which never updated the hashes.
* CoreDb: Discard `update` argument in API `hash()` function
why:
When calling the API function `hash()`, the latest state is always
wanted. For a version that uses the current state as-is without checking,
the function `tryHash()` was added to the backend.
* CoreDb: Update opaque vertex ID objects for the `Aristo` backend
why:
For `Aristo`, vID objects encapsulate a numeric `VertexID`
referencing a vertex (rather than a node hash as used on the
legacy backend.) For storage sub-tries, there might be no initial
vertex known when the descriptor is created. So opaque vertex ID
objects are supported without a valid `VertexID` which will be
initalised on-the-fly when the first item is merged.
* CoreDb: Add pretty printer for opaque vertex ID objects
* Cosmetics, printing profiling data
* CoreDb: Fix segfault in `Aristo` backend when creating MPT descriptor
why:
Missing initialisation error
* CoreDb: Allow MPT to inherit shared context on `Aristo` backend
why:
Creates descriptors with different storage roots for the same
shared `Aristo` DB descriptor.
* Cosmetics, update diagnostic message items for `Aristo` backend
* Fix Copyright year
2024-01-11 19:11:38 +00:00
|
|
|
doAssert not base.tryHashFn.isNil
|
2024-02-02 20:23:04 +00:00
|
|
|
doAssert not base.rootHashFn.isNil
|
|
|
|
doAssert not base.triePrintFn.isNil
|
2023-10-11 19:09:11 +00:00
|
|
|
doAssert not base.errorPrintFn.isNil
|
|
|
|
doAssert not base.legacySetupFn.isNil
|
2024-02-02 20:23:04 +00:00
|
|
|
doAssert not base.getTrieFn.isNil
|
2023-11-24 22:16:21 +00:00
|
|
|
doAssert not base.levelFn.isNil
|
2023-10-11 19:09:11 +00:00
|
|
|
doAssert not base.newKvtFn.isNil
|
|
|
|
doAssert not base.newMptFn.isNil
|
|
|
|
doAssert not base.newAccFn.isNil
|
|
|
|
doAssert not base.getIdFn.isNil
|
|
|
|
doAssert not base.beginFn.isNil
|
|
|
|
doAssert not base.captureFn.isNil
|
2023-09-26 09:21:13 +00:00
|
|
|
|
|
|
|
proc validateMethodsDesc(kvt: CoreDbKvtFns) =
|
|
|
|
doAssert not kvt.backendFn.isNil
|
|
|
|
doAssert not kvt.getFn.isNil
|
|
|
|
doAssert not kvt.delFn.isNil
|
|
|
|
doAssert not kvt.putFn.isNil
|
2023-11-24 22:16:21 +00:00
|
|
|
doAssert not kvt.persistentFn.isNil
|
|
|
|
doAssert not kvt.forgetFn.isNil
|
2023-11-08 12:18:32 +00:00
|
|
|
doAssert not kvt.hasKeyFn.isNil
|
2023-09-26 09:21:13 +00:00
|
|
|
|
|
|
|
proc validateMethodsDesc(fns: CoreDbMptFns) =
|
|
|
|
doAssert not fns.backendFn.isNil
|
2023-10-11 19:09:11 +00:00
|
|
|
doAssert not fns.fetchFn.isNil
|
|
|
|
doAssert not fns.deleteFn.isNil
|
|
|
|
doAssert not fns.mergeFn.isNil
|
2023-11-08 12:18:32 +00:00
|
|
|
doAssert not fns.hasPathFn.isNil
|
2024-02-02 20:23:04 +00:00
|
|
|
doAssert not fns.getTrieFn.isNil
|
2023-09-26 09:21:13 +00:00
|
|
|
doAssert not fns.isPruningFn.isNil
|
2023-11-24 22:16:21 +00:00
|
|
|
doAssert not fns.persistentFn.isNil
|
|
|
|
doAssert not fns.forgetFn.isNil
|
2023-09-26 09:21:13 +00:00
|
|
|
|
2023-10-11 19:09:11 +00:00
|
|
|
proc validateMethodsDesc(fns: CoreDbAccFns) =
|
|
|
|
doAssert not fns.backendFn.isNil
|
Optional accounts cache module for creating genesis (#1897)
* Split off `ReadOnlyStateDB` from `AccountStateDB` from `state_db.nim`
why:
Apart from testing, applications use `ReadOnlyStateDB` as an easy
way to access the accounts ledger. This is well supported by the
`Aristo` db, but writable mode is only parially supported.
The writable AccountStateDB` object for modifying accounts is not
used by production code.
So, for lecgacy and testing apps, the full support of the previous
`AccountStateDB` is now enabled by `import db/state_db/read_write`
and the `import db/state_db` provides read-only mode.
* Encapsulate `AccountStateDB` as `GenesisLedgerRef` or genesis creation
why:
`AccountStateDB` has poor support for `Aristo` and is not widely used
in favour of `AccountsLedger` (which will be abstracted as `ledger`.)
Currently, using other than the `AccountStateDB` ledgers within the
`GenesisLedgerRef` wrapper is experimental and test only. Eventually,
the wrapper should disappear so that the `Ledger` object (which
encapsulates `AccountsCache` and `AccountsLedger`) will prevail.
* For the `Ledger`, provide access to raw accounts `MPT`
why:
This gives to the `CoreDbMptRef` descriptor from the `CoreDb` (which is
the legacy version of CoreDxMptRef`.) For the new `ledger` API, the
accounts are based on the `CoreDxMAccRef` descriptor which uses a
particular sub-system for accounts while legacy applications use the
`CoreDbPhkRef` equivalent of the `SecureHexaryTrie`.
The only place where this feature will currently be used is the
`genesis.nim` source file.
* Fix `Aristo` bugs, missing boundary checks, typos, etc.
* Verify root vertex in `MPT` and account constructors
why:
Was missing so far, in particular the accounts constructor must
verify `VertexID(1)
* Fix include file
2023-11-20 11:51:43 +00:00
|
|
|
doAssert not fns.newMptFn.isNil
|
2023-10-11 19:09:11 +00:00
|
|
|
doAssert not fns.fetchFn.isNil
|
|
|
|
doAssert not fns.deleteFn.isNil
|
2024-02-12 19:37:00 +00:00
|
|
|
doAssert not fns.stoFlushFn.isNil
|
2023-10-11 19:09:11 +00:00
|
|
|
doAssert not fns.mergeFn.isNil
|
2023-11-08 12:18:32 +00:00
|
|
|
doAssert not fns.hasPathFn.isNil
|
2024-02-02 20:23:04 +00:00
|
|
|
doAssert not fns.getTrieFn.isNil
|
2023-10-11 19:09:11 +00:00
|
|
|
doAssert not fns.isPruningFn.isNil
|
2023-11-24 22:16:21 +00:00
|
|
|
doAssert not fns.persistentFn.isNil
|
|
|
|
doAssert not fns.forgetFn.isNil
|
2023-09-26 09:21:13 +00:00
|
|
|
|
|
|
|
# ------------
|
|
|
|
|
2024-02-02 20:23:04 +00:00
|
|
|
proc validateMethodsDesc(trie: CoreDbTrieRef) =
|
|
|
|
doAssert not trie.isNil
|
|
|
|
doAssert not trie.parent.isNil
|
|
|
|
doAssert trie.ready == true
|
2023-10-11 19:09:11 +00:00
|
|
|
|
2023-10-02 18:05:17 +00:00
|
|
|
proc validateMethodsDesc(e: CoreDbErrorRef) =
|
2023-11-08 12:18:32 +00:00
|
|
|
doAssert e.error != CoreDbErrorCode(0)
|
2023-10-02 18:05:17 +00:00
|
|
|
doAssert not e.isNil
|
2023-09-26 09:21:13 +00:00
|
|
|
doAssert not e.parent.isNil
|
|
|
|
|
|
|
|
proc validateMethodsDesc(eph: EphemMethodsDesc) =
|
|
|
|
doAssert not eph.isNil
|
|
|
|
doAssert not eph.parent.isNil
|
2023-10-11 19:09:11 +00:00
|
|
|
|
2023-09-26 09:21:13 +00:00
|
|
|
proc validateMethodsDesc(kvt: CoreDxKvtRef) =
|
|
|
|
doAssert not kvt.isNil
|
|
|
|
doAssert not kvt.parent.isNil
|
|
|
|
kvt.methods.validateMethodsDesc
|
|
|
|
|
|
|
|
proc validateMethodsDesc(mpt: CoreDxMptRef) =
|
|
|
|
doAssert not mpt.isNil
|
|
|
|
doAssert not mpt.parent.isNil
|
|
|
|
mpt.methods.validateMethodsDesc
|
|
|
|
|
2023-10-11 19:09:11 +00:00
|
|
|
proc validateMethodsDesc(acc: CoreDxAccRef) =
|
|
|
|
doAssert not acc.isNil
|
|
|
|
doAssert not acc.parent.isNil
|
|
|
|
acc.methods.validateMethodsDesc
|
|
|
|
|
2023-09-26 09:21:13 +00:00
|
|
|
proc validateMethodsDesc(phk: CoreDxPhkRef) =
|
|
|
|
doAssert not phk.isNil
|
|
|
|
doAssert not phk.fromMpt.isNil
|
|
|
|
phk.methods.validateMethodsDesc
|
|
|
|
|
|
|
|
proc validateMethodsDesc(cpt: CoreDxCaptRef) =
|
|
|
|
doAssert not cpt.isNil
|
|
|
|
doAssert not cpt.parent.isNil
|
|
|
|
doAssert not cpt.methods.recorderFn.isNil
|
|
|
|
doAssert not cpt.methods.getFlagsFn.isNil
|
|
|
|
|
|
|
|
proc validateMethodsDesc(tx: CoreDxTxRef) =
|
|
|
|
doAssert not tx.isNil
|
|
|
|
doAssert not tx.parent.isNil
|
2023-11-24 22:16:21 +00:00
|
|
|
doAssert not tx.methods.levelFn.isNil
|
2023-09-26 09:21:13 +00:00
|
|
|
doAssert not tx.methods.commitFn.isNil
|
|
|
|
doAssert not tx.methods.rollbackFn.isNil
|
|
|
|
doAssert not tx.methods.disposeFn.isNil
|
|
|
|
doAssert not tx.methods.safeDisposeFn.isNil
|
|
|
|
|
|
|
|
proc validateMethodsDesc(id: CoreDxTxID) =
|
|
|
|
doAssert not id.isNil
|
|
|
|
doAssert not id.parent.isNil
|
|
|
|
doAssert not id.methods.roWrapperFn.isNil
|
|
|
|
|
|
|
|
proc validateMethodsDesc(db: CoreDbRef) =
|
|
|
|
doAssert not db.isNil
|
|
|
|
doAssert db.dbType != CoreDbType(0)
|
|
|
|
db.methods.validateMethodsDesc
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
# Public debugging helpers
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
2023-10-11 19:09:11 +00:00
|
|
|
proc validate*(dsc: ValidateDesc) =
|
|
|
|
dsc.validateMethodsDesc
|
2023-09-26 09:21:13 +00:00
|
|
|
|
|
|
|
proc validate*(db: CoreDbRef) =
|
|
|
|
db.validateMethodsDesc
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
# End
|
|
|
|
# ------------------------------------------------------------------------------
|