@typeberry/lib 0.5.10-9567cee → 0.5.10-9ffd7ac
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/bin/lib/examples/pvm-usage.test.js +2 -2
- package/package.json +1 -1
- package/packages/core/codec/descriptor.js +1 -1
- package/packages/core/codec/descriptors.js +7 -4
- package/packages/core/codec/index.test.js +1 -1
- package/packages/core/codec/skip.d.ts +2 -1
- package/packages/core/codec/skip.d.ts.map +1 -1
- package/packages/core/codec/skip.js +3 -0
- package/packages/core/codec/view.js +2 -2
- package/packages/core/collections/multi-map.d.ts +2 -1
- package/packages/core/collections/multi-map.d.ts.map +1 -1
- package/packages/core/collections/multi-map.js +3 -0
- package/packages/core/collections/multi-map.test.js +2 -2
- package/packages/core/concurrent/parent.js +4 -1
- package/packages/core/crypto/ed25519.d.ts +2 -5
- package/packages/core/crypto/ed25519.d.ts.map +1 -1
- package/packages/core/crypto/ed25519.js +4 -1
- package/packages/core/hash/hash.d.ts +4 -2
- package/packages/core/hash/hash.d.ts.map +1 -1
- package/packages/core/hash/hash.js +6 -1
- package/packages/core/networking/quic-network.d.ts +3 -2
- package/packages/core/networking/quic-network.d.ts.map +1 -1
- package/packages/core/networking/quic-network.js +3 -0
- package/packages/core/networking/quic-peer.d.ts +2 -1
- package/packages/core/networking/quic-peer.d.ts.map +1 -1
- package/packages/core/networking/quic-peer.js +5 -2
- package/packages/core/networking/quic-stream.d.ts +2 -1
- package/packages/core/networking/quic-stream.d.ts.map +1 -1
- package/packages/core/networking/quic-stream.js +3 -0
- package/packages/core/networking/setup.js +2 -2
- package/packages/core/pvm-host-calls/bin.js +2 -2
- package/packages/core/pvm-host-calls/ecalli-trace-logger.test.js +1 -1
- package/packages/core/pvm-host-calls/host-call-memory.d.ts +2 -1
- package/packages/core/pvm-host-calls/host-call-memory.d.ts.map +1 -1
- package/packages/core/pvm-host-calls/host-call-memory.js +3 -0
- package/packages/core/pvm-host-calls/host-call-memory.test.js +1 -1
- package/packages/core/pvm-host-calls/host-call-registers.d.ts +5 -1
- package/packages/core/pvm-host-calls/host-call-registers.d.ts.map +1 -1
- package/packages/core/pvm-host-calls/host-call-registers.js +11 -1
- package/packages/core/pvm-host-calls/host-call-registers.test.js +2 -2
- package/packages/core/pvm-host-calls/host-calls-executor.d.ts +2 -1
- package/packages/core/pvm-host-calls/host-calls-executor.d.ts.map +1 -1
- package/packages/core/pvm-host-calls/host-calls-executor.js +5 -2
- package/packages/core/pvm-host-calls/host-calls.d.ts +4 -2
- package/packages/core/pvm-host-calls/host-calls.d.ts.map +1 -1
- package/packages/core/pvm-host-calls/host-calls.js +9 -4
- package/packages/core/pvm-host-calls/pvm-instance-manager.js +1 -1
- package/packages/core/pvm-interpreter/args-decoder/args-decoder.js +1 -1
- package/packages/core/pvm-interpreter/args-decoder/args-decoder.test.js +3 -3
- package/packages/core/pvm-interpreter/args-decoder/args-decoding-results.js +11 -11
- package/packages/core/pvm-interpreter/args-decoder/decoders/extended-with-immediate-decoder.d.ts +2 -1
- package/packages/core/pvm-interpreter/args-decoder/decoders/extended-with-immediate-decoder.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/args-decoder/decoders/extended-with-immediate-decoder.js +3 -0
- package/packages/core/pvm-interpreter/args-decoder/decoders/extended-with-immediate-decoder.test.js +2 -2
- package/packages/core/pvm-interpreter/args-decoder/decoders/immediate-decoder.d.ts +2 -1
- package/packages/core/pvm-interpreter/args-decoder/decoders/immediate-decoder.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/args-decoder/decoders/immediate-decoder.js +3 -0
- package/packages/core/pvm-interpreter/args-decoder/decoders/immediate-decoder.test.js +26 -26
- package/packages/core/pvm-interpreter/basic-blocks/basic-blocks.test.js +8 -8
- package/packages/core/pvm-interpreter/bin.js +1 -1
- package/packages/core/pvm-interpreter/debugger-adapter.d.ts +2 -1
- package/packages/core/pvm-interpreter/debugger-adapter.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/debugger-adapter.js +6 -3
- package/packages/core/pvm-interpreter/gas.js +4 -1
- package/packages/core/pvm-interpreter/interpreter.d.ts +2 -1
- package/packages/core/pvm-interpreter/interpreter.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/interpreter.js +19 -16
- package/packages/core/pvm-interpreter/memory/memory-builder.js +2 -2
- package/packages/core/pvm-interpreter/memory/memory-builder.test.js +7 -7
- package/packages/core/pvm-interpreter/memory/memory.d.ts +2 -1
- package/packages/core/pvm-interpreter/memory/memory.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/memory/memory.js +4 -1
- package/packages/core/pvm-interpreter/memory/memory.test.js +31 -31
- package/packages/core/pvm-interpreter/memory/pages/readable-page.d.ts +2 -1
- package/packages/core/pvm-interpreter/memory/pages/readable-page.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/memory/pages/readable-page.js +3 -0
- package/packages/core/pvm-interpreter/memory/pages/readable-page.test.js +3 -3
- package/packages/core/pvm-interpreter/memory/pages/writeable-page.d.ts +2 -1
- package/packages/core/pvm-interpreter/memory/pages/writeable-page.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/memory/pages/writeable-page.js +3 -0
- package/packages/core/pvm-interpreter/memory/pages/writeable-page.test.js +4 -4
- package/packages/core/pvm-interpreter/ops/bit-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/bit-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/bit-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/bit-ops.test.js +3 -3
- package/packages/core/pvm-interpreter/ops/bit-rotation-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/bit-rotation-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/bit-rotation-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/bit-rotation-ops.test.js +5 -5
- package/packages/core/pvm-interpreter/ops/boolean-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/boolean-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/boolean-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/boolean-ops.test.js +3 -3
- package/packages/core/pvm-interpreter/ops/branch-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/branch-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/branch-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/branch-ops.test.js +4 -4
- package/packages/core/pvm-interpreter/ops/dynamic-jump-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/dynamic-jump-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/dynamic-jump-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/dynamic-jump-ops.test.js +5 -5
- package/packages/core/pvm-interpreter/ops/host-call-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/host-call-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/host-call-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/host-call-ops.test.js +2 -2
- package/packages/core/pvm-interpreter/ops/load-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/load-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/load-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/load-ops.test.js +10 -10
- package/packages/core/pvm-interpreter/ops/math-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/math-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/math-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/math-ops.test.js +3 -3
- package/packages/core/pvm-interpreter/ops/memory-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/memory-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/memory-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/memory-ops.test.js +3 -3
- package/packages/core/pvm-interpreter/ops/move-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/move-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/move-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/move-ops.test.js +3 -3
- package/packages/core/pvm-interpreter/ops/no-args-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/no-args-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/no-args-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/no-args-ops.test.js +2 -2
- package/packages/core/pvm-interpreter/ops/shift-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/shift-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/shift-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/shift-ops.test.js +3 -3
- package/packages/core/pvm-interpreter/ops/store-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/store-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/store-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/store-ops.test.js +7 -7
- package/packages/core/pvm-interpreter/ops-dispatchers/no-args-dispatcher.test.js +1 -1
- package/packages/core/pvm-interpreter/ops-dispatchers/one-imm-dispatcher.test.js +4 -4
- package/packages/core/pvm-interpreter/ops-dispatchers/one-offset-dispatcher.test.js +2 -2
- package/packages/core/pvm-interpreter/ops-dispatchers/one-reg-one-ext-imm-dispatcher.test.js +4 -4
- package/packages/core/pvm-interpreter/ops-dispatchers/one-reg-one-imm-dispatcher.test.js +7 -7
- package/packages/core/pvm-interpreter/ops-dispatchers/one-reg-one-imm-one-offset-dispatcher.test.js +10 -10
- package/packages/core/pvm-interpreter/ops-dispatchers/one-reg-two-imms-dispatcher.test.js +5 -5
- package/packages/core/pvm-interpreter/ops-dispatchers/three-regs-dispatcher.test.js +7 -7
- package/packages/core/pvm-interpreter/ops-dispatchers/two-imms-dispatcher.test.js +5 -5
- package/packages/core/pvm-interpreter/ops-dispatchers/two-regs-dispatcher.test.js +6 -6
- package/packages/core/pvm-interpreter/ops-dispatchers/two-regs-one-imm-dispatcher.test.js +11 -11
- package/packages/core/pvm-interpreter/ops-dispatchers/two-regs-one-offset-dispatcher.test.js +2 -2
- package/packages/core/pvm-interpreter/ops-dispatchers/two-regs-two-imms-dispatcher.test.js +14 -14
- package/packages/core/pvm-interpreter/program-decoder/jump-table.d.ts +5 -2
- package/packages/core/pvm-interpreter/program-decoder/jump-table.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/program-decoder/jump-table.js +9 -4
- package/packages/core/pvm-interpreter/program-decoder/jump-table.test.js +6 -6
- package/packages/core/pvm-interpreter/program-decoder/mask.d.ts +2 -1
- package/packages/core/pvm-interpreter/program-decoder/mask.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/program-decoder/mask.js +3 -0
- package/packages/core/pvm-interpreter/program-decoder/mask.test.js +10 -10
- package/packages/core/pvm-interpreter/program-decoder/program-decoder.d.ts +2 -1
- package/packages/core/pvm-interpreter/program-decoder/program-decoder.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/program-decoder/program-decoder.js +6 -3
- package/packages/core/pvm-interpreter/program-decoder/program-decoder.test.js +5 -5
- package/packages/core/pvm-interpreter/program.js +3 -3
- package/packages/core/pvm-interpreter/registers.d.ts +5 -2
- package/packages/core/pvm-interpreter/registers.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/registers.js +10 -6
- package/packages/core/pvm-interpreter/registers.test.js +10 -10
- package/packages/core/pvm-interpreter/spi-decoder/decode-standard-program.d.ts +6 -3
- package/packages/core/pvm-interpreter/spi-decoder/decode-standard-program.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/spi-decoder/decode-standard-program.js +11 -2
- package/packages/core/pvm-interpreter-ananas/index.d.ts +6 -3
- package/packages/core/pvm-interpreter-ananas/index.d.ts.map +1 -1
- package/packages/core/pvm-interpreter-ananas/index.js +12 -3
- package/packages/core/trie/nodes.d.ts +7 -2
- package/packages/core/trie/nodes.d.ts.map +1 -1
- package/packages/core/trie/nodes.js +20 -11
- package/packages/core/trie/nodesDb.d.ts +3 -1
- package/packages/core/trie/nodesDb.d.ts.map +1 -1
- package/packages/core/trie/nodesDb.js +6 -0
- package/packages/core/trie/trie.js +2 -2
- package/packages/extensions/ipc/index.js +5 -2
- package/packages/extensions/ipc/jamnp/handler.d.ts +4 -2
- package/packages/extensions/ipc/jamnp/handler.d.ts.map +1 -1
- package/packages/extensions/ipc/jamnp/handler.js +9 -3
- package/packages/extensions/ipc/jamnp/server.js +3 -3
- package/packages/extensions/ipc/server.d.ts +2 -1
- package/packages/extensions/ipc/server.d.ts.map +1 -1
- package/packages/extensions/ipc/server.js +4 -1
- package/packages/jam/block/header.js +1 -1
- package/packages/jam/block/work-package.d.ts +7 -7
- package/packages/jam/block/work-package.d.ts.map +1 -1
- package/packages/jam/block/work-package.js +12 -12
- package/packages/jam/config/chain-spec.d.ts +2 -1
- package/packages/jam/config/chain-spec.d.ts.map +1 -1
- package/packages/jam/config/chain-spec.js +5 -2
- package/packages/jam/config/network.d.ts +2 -7
- package/packages/jam/config/network.d.ts.map +1 -1
- package/packages/jam/config/network.js +3 -0
- package/packages/jam/config-node/jip-chain-spec.js +1 -1
- package/packages/jam/database/blocks.test.js +1 -1
- package/packages/jam/database/states.d.ts +2 -1
- package/packages/jam/database/states.d.ts.map +1 -1
- package/packages/jam/database/states.js +3 -0
- package/packages/jam/database/states.test.js +1 -1
- package/packages/jam/database-lmdb/blocks.d.ts +2 -1
- package/packages/jam/database-lmdb/blocks.d.ts.map +1 -1
- package/packages/jam/database-lmdb/blocks.js +3 -0
- package/packages/jam/database-lmdb/root.d.ts +2 -1
- package/packages/jam/database-lmdb/root.d.ts.map +1 -1
- package/packages/jam/database-lmdb/root.js +3 -0
- package/packages/jam/database-lmdb/states.d.ts +2 -1
- package/packages/jam/database-lmdb/states.d.ts.map +1 -1
- package/packages/jam/database-lmdb/states.js +3 -0
- package/packages/jam/database-lmdb/states.test.js +9 -9
- package/packages/jam/executor/pvm-executor.d.ts +7 -0
- package/packages/jam/executor/pvm-executor.d.ts.map +1 -1
- package/packages/jam/executor/pvm-executor.js +36 -21
- package/packages/jam/fuzz-proto/v1/handler.d.ts +2 -1
- package/packages/jam/fuzz-proto/v1/handler.d.ts.map +1 -1
- package/packages/jam/fuzz-proto/v1/handler.js +3 -0
- package/packages/jam/fuzz-proto/v1/handler.test.js +10 -10
- package/packages/jam/in-core/externalities/refine.d.ts +5 -5
- package/packages/jam/in-core/externalities/refine.d.ts.map +1 -1
- package/packages/jam/in-core/externalities/refine.js +42 -7
- package/packages/jam/in-core/externalities/refine.test.js +119 -1
- package/packages/jam/in-core/in-core.d.ts +9 -23
- package/packages/jam/in-core/in-core.d.ts.map +1 -1
- package/packages/jam/in-core/in-core.js +19 -184
- package/packages/jam/in-core/in-core.test.js +52 -20
- package/packages/jam/in-core/is-authorized.d.ts +33 -0
- package/packages/jam/in-core/is-authorized.d.ts.map +1 -0
- package/packages/jam/in-core/is-authorized.js +72 -0
- package/packages/jam/in-core/is-authorized.test.d.ts +2 -0
- package/packages/jam/in-core/is-authorized.test.d.ts.map +1 -0
- package/packages/jam/in-core/is-authorized.test.js +125 -0
- package/packages/jam/in-core/refine.d.ts +34 -0
- package/packages/jam/in-core/refine.d.ts.map +1 -0
- package/packages/jam/in-core/refine.js +176 -0
- package/packages/jam/in-core/refine.test.d.ts +2 -0
- package/packages/jam/in-core/refine.test.d.ts.map +1 -0
- package/packages/jam/in-core/refine.test.js +6 -0
- package/packages/jam/jam-host-calls/accumulate/assign.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/assign.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/assign.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/assign.test.js +8 -9
- package/packages/jam/jam-host-calls/accumulate/bless.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/bless.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/bless.js +12 -9
- package/packages/jam/jam-host-calls/accumulate/bless.test.js +11 -12
- package/packages/jam/jam-host-calls/accumulate/checkpoint.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/checkpoint.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/checkpoint.js +4 -1
- package/packages/jam/jam-host-calls/accumulate/checkpoint.test.js +2 -3
- package/packages/jam/jam-host-calls/accumulate/designate.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/designate.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/designate.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/designate.test.js +5 -6
- package/packages/jam/jam-host-calls/accumulate/eject.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/eject.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/eject.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/eject.test.js +8 -9
- package/packages/jam/jam-host-calls/accumulate/forget.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/forget.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/forget.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/forget.test.js +5 -6
- package/packages/jam/jam-host-calls/accumulate/new.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/new.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/new.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/new.test.js +9 -10
- package/packages/jam/jam-host-calls/accumulate/provide.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/provide.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/provide.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/provide.test.js +8 -9
- package/packages/jam/jam-host-calls/accumulate/query.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/query.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/query.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/query.test.js +8 -9
- package/packages/jam/jam-host-calls/accumulate/solicit.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/solicit.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/solicit.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/solicit.test.js +7 -8
- package/packages/jam/jam-host-calls/accumulate/transfer.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/transfer.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/transfer.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/transfer.test.js +9 -10
- package/packages/jam/jam-host-calls/accumulate/upgrade.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/upgrade.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/upgrade.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/upgrade.test.js +4 -5
- package/packages/jam/jam-host-calls/accumulate/yield.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/yield.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/yield.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/yield.test.js +4 -5
- package/packages/jam/jam-host-calls/externalities/partial-state.d.ts +1 -1
- package/packages/jam/jam-host-calls/externalities/refine-externalities.d.ts +1 -1
- package/packages/jam/jam-host-calls/externalities/refine-externalities.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/externalities/refine-externalities.test.js +9 -9
- package/packages/jam/jam-host-calls/externalities/state-update.d.ts +2 -3
- package/packages/jam/jam-host-calls/externalities/state-update.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/externalities/state-update.js +5 -2
- package/packages/jam/jam-host-calls/externalities/test-accounts.js +2 -2
- package/packages/jam/jam-host-calls/general/fetch.d.ts +42 -41
- package/packages/jam/jam-host-calls/general/fetch.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/general/fetch.js +33 -30
- package/packages/jam/jam-host-calls/general/fetch.test.js +44 -42
- package/packages/jam/jam-host-calls/general/gas.d.ts +2 -1
- package/packages/jam/jam-host-calls/general/gas.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/general/gas.js +3 -0
- package/packages/jam/jam-host-calls/general/gas.test.js +4 -5
- package/packages/jam/jam-host-calls/general/info.d.ts +2 -1
- package/packages/jam/jam-host-calls/general/info.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/general/info.js +3 -0
- package/packages/jam/jam-host-calls/general/info.test.js +6 -7
- package/packages/jam/jam-host-calls/general/log.d.ts +2 -1
- package/packages/jam/jam-host-calls/general/log.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/general/log.js +3 -0
- package/packages/jam/jam-host-calls/general/lookup.d.ts +2 -1
- package/packages/jam/jam-host-calls/general/lookup.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/general/lookup.js +3 -0
- package/packages/jam/jam-host-calls/general/lookup.test.js +8 -9
- package/packages/jam/jam-host-calls/general/read.d.ts +2 -1
- package/packages/jam/jam-host-calls/general/read.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/general/read.js +3 -0
- package/packages/jam/jam-host-calls/general/read.test.js +11 -12
- package/packages/jam/jam-host-calls/general/write.d.ts +2 -1
- package/packages/jam/jam-host-calls/general/write.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/general/write.js +3 -0
- package/packages/jam/jam-host-calls/general/write.test.js +10 -11
- package/packages/jam/jam-host-calls/refine/export.d.ts +2 -1
- package/packages/jam/jam-host-calls/refine/export.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/refine/export.js +3 -0
- package/packages/jam/jam-host-calls/refine/export.test.js +6 -7
- package/packages/jam/jam-host-calls/refine/expunge.d.ts +2 -1
- package/packages/jam/jam-host-calls/refine/expunge.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/refine/expunge.js +3 -0
- package/packages/jam/jam-host-calls/refine/expunge.test.js +3 -4
- package/packages/jam/jam-host-calls/refine/historical-lookup.d.ts +2 -1
- package/packages/jam/jam-host-calls/refine/historical-lookup.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/refine/historical-lookup.js +3 -0
- package/packages/jam/jam-host-calls/refine/historical-lookup.test.js +11 -12
- package/packages/jam/jam-host-calls/refine/invoke.d.ts +2 -1
- package/packages/jam/jam-host-calls/refine/invoke.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/refine/invoke.js +4 -1
- package/packages/jam/jam-host-calls/refine/invoke.test.js +10 -11
- package/packages/jam/jam-host-calls/refine/machine.d.ts +2 -1
- package/packages/jam/jam-host-calls/refine/machine.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/refine/machine.js +3 -0
- package/packages/jam/jam-host-calls/refine/machine.test.js +6 -7
- package/packages/jam/jam-host-calls/refine/pages.d.ts +2 -1
- package/packages/jam/jam-host-calls/refine/pages.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/refine/pages.js +3 -0
- package/packages/jam/jam-host-calls/refine/pages.test.js +3 -4
- package/packages/jam/jam-host-calls/refine/peek.d.ts +2 -1
- package/packages/jam/jam-host-calls/refine/peek.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/refine/peek.js +3 -0
- package/packages/jam/jam-host-calls/refine/peek.test.js +3 -4
- package/packages/jam/jam-host-calls/refine/poke.d.ts +2 -1
- package/packages/jam/jam-host-calls/refine/poke.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/refine/poke.js +3 -0
- package/packages/jam/jam-host-calls/refine/poke.test.js +3 -4
- package/packages/jam/jamnp-s/network.js +1 -1
- package/packages/jam/jamnp-s/peers.d.ts +2 -1
- package/packages/jam/jamnp-s/peers.d.ts.map +1 -1
- package/packages/jam/jamnp-s/peers.js +3 -0
- package/packages/jam/jamnp-s/protocol/ce-128-block-request.d.ts +4 -2
- package/packages/jam/jamnp-s/protocol/ce-128-block-request.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/ce-128-block-request.js +6 -0
- package/packages/jam/jamnp-s/protocol/ce-128-block-request.test.js +2 -2
- package/packages/jam/jamnp-s/protocol/ce-129-state-request.d.ts +4 -2
- package/packages/jam/jamnp-s/protocol/ce-129-state-request.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/ce-129-state-request.js +6 -0
- package/packages/jam/jamnp-s/protocol/ce-129-state-request.test.js +4 -4
- package/packages/jam/jamnp-s/protocol/ce-131-ce-132-safrole-ticket-distribution.d.ts +4 -2
- package/packages/jam/jamnp-s/protocol/ce-131-ce-132-safrole-ticket-distribution.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/ce-131-ce-132-safrole-ticket-distribution.js +6 -0
- package/packages/jam/jamnp-s/protocol/ce-131-ce-132-safrole-ticket-distribution.test.js +2 -2
- package/packages/jam/jamnp-s/protocol/ce-133-work-package-submission.d.ts +6 -3
- package/packages/jam/jamnp-s/protocol/ce-133-work-package-submission.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/ce-133-work-package-submission.js +7 -0
- package/packages/jam/jamnp-s/protocol/ce-133-work-package-submission.test.js +2 -2
- package/packages/jam/jamnp-s/protocol/ce-134-work-package-sharing.d.ts +5 -2
- package/packages/jam/jamnp-s/protocol/ce-134-work-package-sharing.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/ce-134-work-package-sharing.js +7 -0
- package/packages/jam/jamnp-s/protocol/ce-134-work-package-sharing.test.js +2 -2
- package/packages/jam/jamnp-s/protocol/ce-135-work-report-distribution.d.ts +4 -2
- package/packages/jam/jamnp-s/protocol/ce-135-work-report-distribution.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/ce-135-work-report-distribution.js +6 -0
- package/packages/jam/jamnp-s/protocol/ce-135-work-report-distribution.test.js +2 -2
- package/packages/jam/jamnp-s/protocol/up-0-block-announcement.d.ts +2 -1
- package/packages/jam/jamnp-s/protocol/up-0-block-announcement.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/up-0-block-announcement.js +3 -0
- package/packages/jam/jamnp-s/stream-manager.d.ts +2 -1
- package/packages/jam/jamnp-s/stream-manager.d.ts.map +1 -1
- package/packages/jam/jamnp-s/stream-manager.js +4 -1
- package/packages/jam/jamnp-s/tasks/sync.js +4 -4
- package/packages/jam/jamnp-s/tasks/sync.test.js +4 -4
- package/packages/jam/jamnp-s/tasks/ticket-distribution.js +2 -2
- package/packages/jam/jamnp-s/tasks/ticket-distribution.test.js +1 -1
- package/packages/jam/node/common.d.ts.map +1 -1
- package/packages/jam/node/common.js +3 -3
- package/packages/jam/rpc-client/index.d.ts +4 -2
- package/packages/jam/rpc-client/index.d.ts.map +1 -1
- package/packages/jam/rpc-client/index.js +7 -1
- package/packages/jam/state/in-memory-state-view.d.ts +2 -1
- package/packages/jam/state/in-memory-state-view.d.ts.map +1 -1
- package/packages/jam/state/in-memory-state-view.js +3 -0
- package/packages/jam/state/in-memory-state.d.ts +16 -21
- package/packages/jam/state/in-memory-state.d.ts.map +1 -1
- package/packages/jam/state/in-memory-state.js +10 -6
- package/packages/jam/state/in-memory-state.test.js +2 -2
- package/packages/jam/state/service.d.ts +2 -6
- package/packages/jam/state/service.d.ts.map +1 -1
- package/packages/jam/state/service.js +3 -0
- package/packages/jam/state/test.utils.js +3 -3
- package/packages/jam/state-json/accounts.js +5 -5
- package/packages/jam/state-merkleization/in-memory-state-codec.d.ts +3 -34
- package/packages/jam/state-merkleization/in-memory-state-codec.d.ts.map +1 -1
- package/packages/jam/state-merkleization/in-memory-state-codec.js +1 -1
- package/packages/jam/state-merkleization/serialized-state-view.d.ts +8 -3
- package/packages/jam/state-merkleization/serialized-state-view.d.ts.map +1 -1
- package/packages/jam/state-merkleization/serialized-state-view.js +6 -3
- package/packages/jam/state-merkleization/serialized-state.d.ts +2 -3
- package/packages/jam/state-merkleization/serialized-state.d.ts.map +1 -1
- package/packages/jam/state-merkleization/serialized-state.js +10 -2
- package/packages/jam/state-merkleization/serialized-state.test.js +1 -1
- package/packages/jam/transition/accumulate/accumulate.js +10 -3
- package/packages/jam/transition/accumulate/accumulate.test.js +1 -1
- package/packages/jam/transition/accumulate/accumulation-result-merge-utils.js +48 -39
- package/packages/jam/transition/block-verifier.d.ts +2 -1
- package/packages/jam/transition/block-verifier.d.ts.map +1 -1
- package/packages/jam/transition/block-verifier.js +3 -0
- package/packages/jam/transition/block-verifier.test.js +8 -8
- package/packages/jam/transition/chain-stf.d.ts +12 -4
- package/packages/jam/transition/chain-stf.d.ts.map +1 -1
- package/packages/jam/transition/chain-stf.js +7 -3
- package/packages/jam/transition/externalities/accumulate-externalities.d.ts +22 -8
- package/packages/jam/transition/externalities/accumulate-externalities.d.ts.map +1 -1
- package/packages/jam/transition/externalities/accumulate-externalities.js +49 -29
- package/packages/jam/transition/externalities/accumulate-externalities.test.js +661 -101
- package/packages/jam/transition/externalities/index.d.ts +1 -0
- package/packages/jam/transition/externalities/index.d.ts.map +1 -1
- package/packages/jam/transition/externalities/index.js +1 -0
- package/packages/jam/transition/externalities/is-authorized-fetch-externalities.d.ts +22 -0
- package/packages/jam/transition/externalities/is-authorized-fetch-externalities.d.ts.map +1 -0
- package/packages/jam/transition/externalities/is-authorized-fetch-externalities.js +41 -0
- package/packages/jam/transition/externalities/refine-fetch-externalities.d.ts +9 -8
- package/packages/jam/transition/externalities/refine-fetch-externalities.d.ts.map +1 -1
- package/packages/jam/transition/externalities/refine-fetch-externalities.js +20 -9
- package/packages/jam/transition/externalities/refine-fetch-externalities.test.js +1 -1
- package/packages/jam/transition/hasher.d.ts +2 -1
- package/packages/jam/transition/hasher.d.ts.map +1 -1
- package/packages/jam/transition/hasher.js +5 -2
- package/packages/jam/transition/hasher.test.js +1 -1
- package/packages/jam/transition/preimages.test.js +4 -4
- package/packages/jam/transition/reports/test.utils.js +1 -1
- package/packages/workers/api-node/config.js +4 -4
- package/packages/workers/api-node/port.d.ts +2 -1
- package/packages/workers/api-node/port.d.ts.map +1 -1
- package/packages/workers/api-node/port.js +4 -1
- package/packages/workers/api-node/port.test.js +2 -2
- package/packages/workers/api-node/protocol.js +2 -2
- package/packages/workers/block-authorship/generator.d.ts +13 -2
- package/packages/workers/block-authorship/generator.d.ts.map +1 -1
- package/packages/workers/block-authorship/generator.js +13 -9
- package/packages/workers/block-authorship/generator.test.js +16 -2
- package/packages/workers/block-authorship/main.d.ts.map +1 -1
- package/packages/workers/block-authorship/main.js +8 -1
- package/packages/workers/importer/finality.test.js +1 -1
- package/packages/workers/importer/importer.d.ts +23 -6
- package/packages/workers/importer/importer.d.ts.map +1 -1
- package/packages/workers/importer/importer.js +34 -19
- package/packages/workers/importer/main.d.ts.map +1 -1
- package/packages/workers/importer/main.js +13 -5
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"service.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/state/service.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"service.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/state/service.ts"],"names":[],"mappings":"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"}
|
|
@@ -169,6 +169,9 @@ export class LookupHistoryItem {
|
|
|
169
169
|
hash;
|
|
170
170
|
length;
|
|
171
171
|
slots;
|
|
172
|
+
static new(hash, length, slots) {
|
|
173
|
+
return new LookupHistoryItem(hash, length, slots);
|
|
174
|
+
}
|
|
172
175
|
constructor(hash, length,
|
|
173
176
|
/**
|
|
174
177
|
* Preimage availability history as a sequence of time slots.
|
|
@@ -110,7 +110,7 @@ export const testState = () => {
|
|
|
110
110
|
services: new Map([
|
|
111
111
|
[
|
|
112
112
|
tryAsServiceId(0),
|
|
113
|
-
new
|
|
113
|
+
InMemoryService.new(tryAsServiceId(0), {
|
|
114
114
|
info: ServiceAccountInfo.create({
|
|
115
115
|
codeHash: b32("0x15f8485e3a88e86182e63280720d5ec9892578f0e577fb1bcdda5cf497950815"),
|
|
116
116
|
balance: tryAsU64(10000000000),
|
|
@@ -134,8 +134,8 @@ export const testState = () => {
|
|
|
134
134
|
}),
|
|
135
135
|
].map((x) => [x.hash, x])),
|
|
136
136
|
lookupHistory: HashDictionary.fromEntries([
|
|
137
|
-
new
|
|
138
|
-
new
|
|
137
|
+
LookupHistoryItem.new(b32("0xc16326432b5b3213dfd1609495e13c6b276cb474d679645337e5c2c09f19b53c"), tryAsU32(35), asKnownSize([tryAsTimeSlot(0)])),
|
|
138
|
+
LookupHistoryItem.new(b32("0x15f8485e3a88e86182e63280720d5ec9892578f0e577fb1bcdda5cf497950815"), tryAsU32(1099), asKnownSize([tryAsTimeSlot(0)])),
|
|
139
139
|
].map((x) => [x.hash, [x]])),
|
|
140
140
|
storage: new Map(),
|
|
141
141
|
}),
|
|
@@ -67,7 +67,7 @@ const preimageStatusFromJson = json.object({
|
|
|
67
67
|
length: "number",
|
|
68
68
|
},
|
|
69
69
|
value: json.array("number"),
|
|
70
|
-
}, ({ key, value }) => new
|
|
70
|
+
}, ({ key, value }) => LookupHistoryItem.new(key.hash, tryAsU32(key.length), value));
|
|
71
71
|
export class JsonService {
|
|
72
72
|
static fromJson = json.object({
|
|
73
73
|
id: "number",
|
|
@@ -93,7 +93,7 @@ export class JsonService {
|
|
|
93
93
|
for (const [key, item] of entries) {
|
|
94
94
|
storage.set(key.toString(), item);
|
|
95
95
|
}
|
|
96
|
-
return new
|
|
96
|
+
return InMemoryService.new(id, {
|
|
97
97
|
info: data.service,
|
|
98
98
|
preimages,
|
|
99
99
|
storage,
|
|
@@ -106,7 +106,7 @@ export class JsonService {
|
|
|
106
106
|
const preimageStatusFromJson072 = json.object({
|
|
107
107
|
hash: fromJson.bytes32(),
|
|
108
108
|
status: json.array("number"),
|
|
109
|
-
}, ({ hash, status }) => new
|
|
109
|
+
}, ({ hash, status }) => LookupHistoryItem.new(hash, tryAsU32(0), status));
|
|
110
110
|
export class JsonServicePre072 {
|
|
111
111
|
static fromJson = json.object({
|
|
112
112
|
id: "number",
|
|
@@ -122,7 +122,7 @@ export class JsonServicePre072 {
|
|
|
122
122
|
for (const item of data.lookup_meta ?? data.preimages_status ?? []) {
|
|
123
123
|
const data = lookupHistory.get(item.hash) ?? [];
|
|
124
124
|
const length = tryAsU32(preimages.get(item.hash)?.blob.length ?? item.length);
|
|
125
|
-
data.push(new
|
|
125
|
+
data.push(LookupHistoryItem.new(item.hash, length, item.slots));
|
|
126
126
|
lookupHistory.set(item.hash, data);
|
|
127
127
|
}
|
|
128
128
|
const storage = new Map();
|
|
@@ -133,7 +133,7 @@ export class JsonServicePre072 {
|
|
|
133
133
|
for (const [key, item] of entries) {
|
|
134
134
|
storage.set(key.toString(), item);
|
|
135
135
|
}
|
|
136
|
-
return new
|
|
136
|
+
return InMemoryService.new(id, {
|
|
137
137
|
info: data.service,
|
|
138
138
|
preimages,
|
|
139
139
|
storage,
|
|
@@ -1,31 +1,15 @@
|
|
|
1
1
|
import { type CodecHashDictionaryOptions } from "#@typeberry/block/codec-utils.js";
|
|
2
|
-
import type { PreimageHash } from "#@typeberry/block/preimage.js";
|
|
3
2
|
import { Ticket } from "#@typeberry/block/tickets.js";
|
|
4
3
|
import { type CodecRecord, Descriptor } from "#@typeberry/codec";
|
|
5
4
|
import { HashDictionary } from "#@typeberry/collections";
|
|
6
5
|
import type { ChainSpec } from "#@typeberry/config";
|
|
7
|
-
import { InMemoryService, InMemoryState,
|
|
6
|
+
import { InMemoryService, InMemoryState, ValidatorData } from "#@typeberry/state";
|
|
8
7
|
/** Codec for a map with string keys. */
|
|
9
8
|
export declare const codecMap: <T>(value: Descriptor<T>, extractKey: (val: T) => string, { typicalLength, compare, }?: CodecHashDictionaryOptions<T>) => Descriptor<Map<string, T>>;
|
|
10
9
|
declare class ServiceWithCodec extends InMemoryService {
|
|
11
10
|
static Codec: Descriptor<ServiceWithCodec, import("@typeberry/codec").ViewOf<ServiceWithCodec, {
|
|
12
11
|
serviceId: Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"ServiceId[u32]">, import("@typeberry/bytes").Bytes<4>>;
|
|
13
|
-
data: Descriptor<
|
|
14
|
-
info: ServiceAccountInfo;
|
|
15
|
-
readonly preimages: HashDictionary<PreimageHash, PreimageItem>;
|
|
16
|
-
readonly lookupHistory: HashDictionary<PreimageHash, LookupHistoryItem[]>;
|
|
17
|
-
readonly storage: Map<string, StorageItem>;
|
|
18
|
-
}, import("@typeberry/codec").ViewOf<{
|
|
19
|
-
info: ServiceAccountInfo;
|
|
20
|
-
readonly preimages: HashDictionary<PreimageHash, PreimageItem>;
|
|
21
|
-
readonly lookupHistory: HashDictionary<PreimageHash, LookupHistoryItem[]>;
|
|
22
|
-
readonly storage: Map<string, StorageItem>;
|
|
23
|
-
}, import("@typeberry/codec").SimpleDescriptorRecord<{
|
|
24
|
-
info: ServiceAccountInfo;
|
|
25
|
-
readonly preimages: HashDictionary<PreimageHash, PreimageItem>;
|
|
26
|
-
readonly lookupHistory: HashDictionary<PreimageHash, LookupHistoryItem[]>;
|
|
27
|
-
readonly storage: Map<string, StorageItem>;
|
|
28
|
-
}>>>;
|
|
12
|
+
data: Descriptor<import("@typeberry/state").InMemoryServiceData, import("@typeberry/codec").ViewOf<import("@typeberry/state").InMemoryServiceData, import("@typeberry/codec").SimpleDescriptorRecord<import("@typeberry/state").InMemoryServiceData>>>;
|
|
29
13
|
}>>;
|
|
30
14
|
private constructor();
|
|
31
15
|
static create({ serviceId, data }: CodecRecord<ServiceWithCodec>): ServiceWithCodec;
|
|
@@ -240,22 +224,7 @@ export declare const inMemoryStateCodec: (spec: ChainSpec) => Descriptor<InMemor
|
|
|
240
224
|
accumulationOutputLog: Descriptor<import("@typeberry/collections").SortedArray<import("@typeberry/state").AccumulationOutput>, import("@typeberry/collections").SortedArray<import("@typeberry/state").AccumulationOutput>>;
|
|
241
225
|
services: Descriptor<Map<number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"ServiceId[u32]">, ServiceWithCodec>, Map<number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"ServiceId[u32]">, import("@typeberry/codec").ViewOf<ServiceWithCodec, {
|
|
242
226
|
serviceId: Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"ServiceId[u32]">, import("@typeberry/bytes").Bytes<4>>;
|
|
243
|
-
data: Descriptor<
|
|
244
|
-
info: ServiceAccountInfo;
|
|
245
|
-
readonly preimages: HashDictionary<PreimageHash, PreimageItem>;
|
|
246
|
-
readonly lookupHistory: HashDictionary<PreimageHash, LookupHistoryItem[]>;
|
|
247
|
-
readonly storage: Map<string, StorageItem>;
|
|
248
|
-
}, import("@typeberry/codec").ViewOf<{
|
|
249
|
-
info: ServiceAccountInfo;
|
|
250
|
-
readonly preimages: HashDictionary<PreimageHash, PreimageItem>;
|
|
251
|
-
readonly lookupHistory: HashDictionary<PreimageHash, LookupHistoryItem[]>;
|
|
252
|
-
readonly storage: Map<string, StorageItem>;
|
|
253
|
-
}, import("@typeberry/codec").SimpleDescriptorRecord<{
|
|
254
|
-
info: ServiceAccountInfo;
|
|
255
|
-
readonly preimages: HashDictionary<PreimageHash, PreimageItem>;
|
|
256
|
-
readonly lookupHistory: HashDictionary<PreimageHash, LookupHistoryItem[]>;
|
|
257
|
-
readonly storage: Map<string, StorageItem>;
|
|
258
|
-
}>>>;
|
|
227
|
+
data: Descriptor<import("@typeberry/state").InMemoryServiceData, import("@typeberry/codec").ViewOf<import("@typeberry/state").InMemoryServiceData, import("@typeberry/codec").SimpleDescriptorRecord<import("@typeberry/state").InMemoryServiceData>>>;
|
|
259
228
|
}>>>;
|
|
260
229
|
}>>;
|
|
261
230
|
export {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"in-memory-state-codec.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/state-merkleization/in-memory-state-codec.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,0BAA0B,EAAuB,MAAM,iCAAiC,CAAC;
|
|
1
|
+
{"version":3,"file":"in-memory-state-codec.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/state-merkleization/in-memory-state-codec.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,0BAA0B,EAAuB,MAAM,iCAAiC,CAAC;AAEvG,OAAO,EAAE,MAAM,EAAE,MAAM,6BAA6B,CAAC;AACrD,OAAO,EAAE,KAAK,WAAW,EAAS,UAAU,EAAE,MAAM,kBAAkB,CAAC;AACvE,OAAO,EAAe,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACrE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAKnD,OAAO,EACL,eAAe,EACf,aAAa,EAOb,aAAa,EACd,MAAM,kBAAkB,CAAC;AAU1B,wCAAwC;AACxC,eAAO,MAAM,QAAQ,GAAI,CAAC,EACxB,OAAO,UAAU,CAAC,CAAC,CAAC,EACpB,YAAY,CAAC,GAAG,EAAE,CAAC,KAAK,MAAM,EAC9B,8BAgBG,0BAA0B,CAAC,CAAC,CAAM,KACpC,UAAU,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC,CA0C3B,CAAC;AA2CF,cAAM,gBAAiB,SAAQ,eAAe;IAC5C,MAAM,CAAC,KAAK;;;QAQT;IAEH,OAAO;IAIP,MAAM,CAAC,MAAM,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,EAAE,WAAW,CAAC,gBAAgB,CAAC;CAGjE;AAED,eAAO,MAAM,kBAAkB,GAAI,MAAM,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqD/C,CAAC"}
|
|
@@ -61,7 +61,7 @@ const lookupHistoryItemCodec = codec.object({
|
|
|
61
61
|
slots: codec
|
|
62
62
|
.readonlyArray(codec.sequenceVarLen(codec.u32.asOpaque()))
|
|
63
63
|
.convert(seeThrough, tryAsLookupHistorySlots),
|
|
64
|
-
}, "LookupHistoryItem", ({ hash, length, slots }) => new
|
|
64
|
+
}, "LookupHistoryItem", ({ hash, length, slots }) => LookupHistoryItem.new(hash, length, slots));
|
|
65
65
|
const lookupHistoryEntryCodec = codec.object({
|
|
66
66
|
key: codec.bytes(HASH_SIZE).asOpaque(),
|
|
67
67
|
data: codec.sequenceVarLen(lookupHistoryItemCodec),
|
|
@@ -22,9 +22,14 @@ export declare class SerializedStateView<T extends SerializedStateBackend> imple
|
|
|
22
22
|
/** Best-effort list of recently active services. */
|
|
23
23
|
private readonly recentlyUsedServices;
|
|
24
24
|
private readonly viewCache;
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
25
|
+
/** Build a new view over an existing serialized-state backend. */
|
|
26
|
+
static new<T extends SerializedStateBackend>(args: {
|
|
27
|
+
spec: ChainSpec;
|
|
28
|
+
backend: T;
|
|
29
|
+
recentlyUsedServices: ServiceId[];
|
|
30
|
+
viewCache: HashDictionary<StateKey, unknown>;
|
|
31
|
+
}): SerializedStateView<T>;
|
|
32
|
+
private constructor();
|
|
28
33
|
private retrieveView;
|
|
29
34
|
availabilityAssignmentView(): AvailabilityAssignmentsView;
|
|
30
35
|
designatedValidatorDataView(): SequenceView<ValidatorData, ValidatorDataView>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"serialized-state-view.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/state-merkleization/serialized-state-view.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAA+B,KAAK,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAClF,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAC7D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,KAAK,EACV,qBAAqB,EACrB,iBAAiB,EACjB,kBAAkB,EAClB,2BAA2B,EAC3B,gBAAgB,EAChB,uBAAuB,EACvB,eAAe,EACf,sBAAsB,EACtB,kBAAkB,EAClB,aAAa,EACb,iBAAiB,EAClB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gCAAgC,CAAC;AAChE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAG1C;;;;GAIG;AACH,MAAM,WAAW,sBAAsB;IACrC,gCAAgC;IAChC,GAAG,CAAC,GAAG,EAAE,QAAQ,GAAG,SAAS,GAAG,IAAI,CAAC;CACtC;AAED,qBAAa,mBAAmB,CAAC,CAAC,SAAS,sBAAsB,CAAE,YAAW,SAAS;
|
|
1
|
+
{"version":3,"file":"serialized-state-view.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/state-merkleization/serialized-state-view.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAA+B,KAAK,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAClF,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAC7D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,KAAK,EACV,qBAAqB,EACrB,iBAAiB,EACjB,kBAAkB,EAClB,2BAA2B,EAC3B,gBAAgB,EAChB,uBAAuB,EACvB,eAAe,EACf,sBAAsB,EACtB,kBAAkB,EAClB,aAAa,EACb,iBAAiB,EAClB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gCAAgC,CAAC;AAChE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAG1C;;;;GAIG;AACH,MAAM,WAAW,sBAAsB;IACrC,gCAAgC;IAChC,GAAG,CAAC,GAAG,EAAE,QAAQ,GAAG,SAAS,GAAG,IAAI,CAAC;CACtC;AAED,qBAAa,mBAAmB,CAAC,CAAC,SAAS,sBAAsB,CAAE,YAAW,SAAS;IACrF,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAY;IAC1B,OAAO,EAAE,CAAC,CAAC;IAClB,oDAAoD;IACpD,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAc;IACnD,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAoC;IAE9D,kEAAkE;IAClE,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,sBAAsB,EAAE,IAAI,EAAE;QACjD,IAAI,EAAE,SAAS,CAAC;QAChB,OAAO,EAAE,CAAC,CAAC;QACX,oBAAoB,EAAE,SAAS,EAAE,CAAC;QAClC,SAAS,EAAE,cAAc,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;KAC9C,GAAG,mBAAmB,CAAC,CAAC,CAAC;IAI1B,OAAO;IAYP,OAAO,CAAC,YAAY;IAoBpB,0BAA0B,IAAI,2BAA2B;IAIzD,2BAA2B,IAAI,YAAY,CAAC,aAAa,EAAE,iBAAiB,CAAC;IAI7E,wBAAwB,IAAI,YAAY,CAAC,aAAa,EAAE,iBAAiB,CAAC;IAI1E,yBAAyB,IAAI,YAAY,CAAC,aAAa,EAAE,iBAAiB,CAAC;IAI3E,aAAa,IAAI,YAAY,CAAC,iBAAiB,EAAE,YAAY,CAAC,cAAc,CAAC,CAAC;IAI9E,cAAc,IAAI,YAAY,CAAC,kBAAkB,EAAE,YAAY,CAAC,cAAc,CAAC,CAAC;IAIhF,gBAAgB,IAAI,gBAAgB;IAIpC,cAAc,IAAI,kBAAkB;IAIpC,qBAAqB,IAAI,qBAAqB;IAI9C,uBAAuB,IAAI,uBAAuB;IAIlD,eAAe,IAAI,eAAe;IAIlC,kBAAkB,CAAC,EAAE,EAAE,SAAS,GAAG,sBAAsB,GAAG,IAAI;CAYjE"}
|
|
@@ -3,11 +3,14 @@ import { serialize } from "./serialize.js";
|
|
|
3
3
|
export class SerializedStateView {
|
|
4
4
|
spec;
|
|
5
5
|
backend;
|
|
6
|
+
/** Best-effort list of recently active services. */
|
|
6
7
|
recentlyUsedServices;
|
|
7
8
|
viewCache;
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
9
|
+
/** Build a new view over an existing serialized-state backend. */
|
|
10
|
+
static new(args) {
|
|
11
|
+
return new SerializedStateView(args.spec, args.backend, args.recentlyUsedServices, args.viewCache);
|
|
12
|
+
}
|
|
13
|
+
constructor(spec, backend, recentlyUsedServices, viewCache) {
|
|
11
14
|
this.spec = spec;
|
|
12
15
|
this.backend = backend;
|
|
13
16
|
this.recentlyUsedServices = recentlyUsedServices;
|
|
@@ -68,9 +68,8 @@ export declare class SerializedService implements Service {
|
|
|
68
68
|
readonly serviceId: ServiceId;
|
|
69
69
|
private readonly accountInfo;
|
|
70
70
|
private readonly retrieveOptional;
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
serviceId: ServiceId, accountInfo: ServiceAccountInfo, retrieveOptional: <T>(key: KeyAndCodec<T>) => T | undefined);
|
|
71
|
+
static new(blake2b: Blake2b, serviceId: ServiceId, accountInfo: ServiceAccountInfo, retrieveOptional: <T>(key: KeyAndCodec<T>) => T | undefined): SerializedService;
|
|
72
|
+
private constructor();
|
|
74
73
|
/** Service account info. */
|
|
75
74
|
getInfo(): ServiceAccountInfo;
|
|
76
75
|
/** Retrieve a storage item. */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"serialized-state.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/state-merkleization/serialized-state.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAiB,MAAM,kBAAkB,CAAC;AACjE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,KAAK,MAAM,EAAW,MAAM,kBAAkB,CAAC;AAExD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,EACL,KAAK,eAAe,EACpB,KAAK,kBAAkB,EACvB,KAAK,OAAO,EACZ,KAAK,kBAAkB,EACvB,KAAK,KAAK,EACV,KAAK,UAAU,EAEhB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,KAAK,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/E,OAAO,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AACtD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAE1C,OAAO,EAAE,KAAK,sBAAsB,EAAuB,MAAM,4BAA4B,CAAC;AAC9F,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAEvD;;;;;;;GAOG;AACH,qBAAa,eAAe,CAAC,CAAC,SAAS,sBAAsB,GAAG,sBAAsB,CACpF,YAAW,KAAK,EAAE,aAAa,EAAE,eAAe;IAqB9C,OAAO,CAAC,QAAQ,CAAC,IAAI;IACrB,OAAO,CAAC,QAAQ,CAAC,OAAO;IACjB,OAAO,EAAE,CAAC;IACjB,oDAAoD;IACpD,OAAO,CAAC,QAAQ,CAAC,oBAAoB;IAvBvC,wEAAwE;IACxE,MAAM,CAAC,gBAAgB,CAAC,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,YAAY,EAAE,cAAc,GAAE,SAAS,EAAO;IAIhH,oDAAoD;IACpD,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,sBAAsB,EACzC,IAAI,EAAE,SAAS,EACf,OAAO,EAAE,OAAO,EAChB,EAAE,EAAE,CAAC,EACL,cAAc,GAAE,SAAS,EAAO,GAC/B,eAAe,CAAC,CAAC,CAAC;IAIrB,OAAO,CAAC,SAAS,CAA2D;IAC5E,OAAO,CAAC,SAAS,CAA2D;IAE5E,OAAO;IAQP,4EAA4E;IAC5E,CAAC,kBAAkB,CAAC;IAIpB,kDAAkD;IAClD,IAAI,IAAI,SAAS;
|
|
1
|
+
{"version":3,"file":"serialized-state.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/state-merkleization/serialized-state.ts"],"names":[],"mappings":"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"}
|
|
@@ -42,7 +42,12 @@ export class SerializedState {
|
|
|
42
42
|
}
|
|
43
43
|
/** Return a non-decoding version of the state. */
|
|
44
44
|
view() {
|
|
45
|
-
return new
|
|
45
|
+
return SerializedStateView.new({
|
|
46
|
+
spec: this.spec,
|
|
47
|
+
backend: this.backend,
|
|
48
|
+
recentlyUsedServices: this.recentlyUsedServices,
|
|
49
|
+
viewCache: this.viewCache,
|
|
50
|
+
});
|
|
46
51
|
}
|
|
47
52
|
// TODO [ToDr] Temporary method to update the state,
|
|
48
53
|
// without changing references.
|
|
@@ -62,7 +67,7 @@ export class SerializedState {
|
|
|
62
67
|
if (!this.recentlyUsedServices.includes(id)) {
|
|
63
68
|
this.recentlyUsedServices.push(id);
|
|
64
69
|
}
|
|
65
|
-
return new
|
|
70
|
+
return SerializedService.new(this.blake2b, id, serviceData, (key) => this.retrieveOptional(key));
|
|
66
71
|
}
|
|
67
72
|
retrieve(k, description) {
|
|
68
73
|
const data = this.retrieveOptional(k);
|
|
@@ -148,6 +153,9 @@ export class SerializedService {
|
|
|
148
153
|
serviceId;
|
|
149
154
|
accountInfo;
|
|
150
155
|
retrieveOptional;
|
|
156
|
+
static new(blake2b, serviceId, accountInfo, retrieveOptional) {
|
|
157
|
+
return new SerializedService(blake2b, serviceId, accountInfo, retrieveOptional);
|
|
158
|
+
}
|
|
151
159
|
constructor(blake2b,
|
|
152
160
|
/** Service id */
|
|
153
161
|
serviceId, accountInfo, retrieveOptional) {
|
|
@@ -33,7 +33,7 @@ describe("SerializedState", () => {
|
|
|
33
33
|
lastAccumulation: tryAsTimeSlot(12),
|
|
34
34
|
parentService: tryAsServiceId(10),
|
|
35
35
|
}),
|
|
36
|
-
lookupHistory: new
|
|
36
|
+
lookupHistory: LookupHistoryItem.new(Bytes.fill(HASH_SIZE, 5).asOpaque(), tryAsU32(10_000), tryAsLookupHistorySlots([])),
|
|
37
37
|
}),
|
|
38
38
|
],
|
|
39
39
|
]),
|
|
@@ -85,7 +85,14 @@ export class Accumulate {
|
|
|
85
85
|
return Result.error(PvmInvocationError.PreimageTooLong, () => `Accumulate: code length ${code.length} exceeds max ${W_C} for service ${serviceId}`);
|
|
86
86
|
}
|
|
87
87
|
const nextServiceId = generateNextServiceId({ serviceId, entropy, timeslot: slot }, this.chainSpec, this.blake2b);
|
|
88
|
-
const partialState =
|
|
88
|
+
const partialState = AccumulateExternalities.forService({
|
|
89
|
+
chainSpec: this.chainSpec,
|
|
90
|
+
blake2b: this.blake2b,
|
|
91
|
+
updatedState: updatedState,
|
|
92
|
+
currentServiceId: serviceId,
|
|
93
|
+
nextNewServiceIdCandidate: nextServiceId,
|
|
94
|
+
currentTimeslot: slot,
|
|
95
|
+
});
|
|
89
96
|
const fetchExternalities = new AccumulateFetchExternalities(entropy, transfers, operands, this.chainSpec);
|
|
90
97
|
const externalities = {
|
|
91
98
|
partialState,
|
|
@@ -134,7 +141,7 @@ export class Accumulate {
|
|
|
134
141
|
*/
|
|
135
142
|
async accumulateSingleService(serviceId, transfers, operands, gasCost, slot, entropy, inputStateUpdate) {
|
|
136
143
|
logger.log `Accumulating service ${serviceId}, transfers: ${transfers.length} operands: ${operands.length} at slot: ${slot}`;
|
|
137
|
-
const updatedState = new
|
|
144
|
+
const updatedState = PartiallyUpdatedState.new(this.state, inputStateUpdate);
|
|
138
145
|
const serviceInfo = updatedState.getServiceInfo(serviceId);
|
|
139
146
|
if (serviceInfo !== null) {
|
|
140
147
|
// update the balance from incoming transfers
|
|
@@ -300,7 +307,7 @@ export class Accumulate {
|
|
|
300
307
|
}
|
|
301
308
|
}
|
|
302
309
|
// δ†
|
|
303
|
-
const partialStateUpdate = new
|
|
310
|
+
const partialStateUpdate = PartiallyUpdatedState.new(this.state, AccumulationStateUpdate.new(servicesUpdate));
|
|
304
311
|
// update last accumulation
|
|
305
312
|
for (const serviceId of accumulatedServices) {
|
|
306
313
|
// https://graypaper.fluffylabs.dev/#/7e6ff6a/181003185103?v=0.6.7
|
|
@@ -216,7 +216,7 @@ const createServices = (items) => {
|
|
|
216
216
|
const createService = (serviceId, hash, blob, info) => {
|
|
217
217
|
const preimages = HashDictionary.new();
|
|
218
218
|
preimages.set(hash.asOpaque(), PreimageItem.create({ hash: hash.asOpaque(), blob }));
|
|
219
|
-
return new
|
|
219
|
+
return InMemoryService.new(serviceId, {
|
|
220
220
|
info: ServiceAccountInfo.create({
|
|
221
221
|
accumulateMinGas: tryAsServiceGas(0n),
|
|
222
222
|
codeHash: hash.asOpaque(),
|
|
@@ -44,47 +44,56 @@ function mergePrivilegedServices(mergeContext, [serviceId, { stateUpdate }]) {
|
|
|
44
44
|
const currentDelegator = currentPrivilegedServices.delegator;
|
|
45
45
|
const currentAssigners = currentPrivilegedServices.assigners;
|
|
46
46
|
const { privilegedServices } = stateUpdate;
|
|
47
|
-
if (privilegedServices
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
});
|
|
71
|
-
}
|
|
72
|
-
let shouldUpdateAssigners = false;
|
|
73
|
-
const newAssigners = currentAssigners.map((currentAssigner, coreIndex) => {
|
|
74
|
-
if (serviceId === currentAssigner) {
|
|
75
|
-
const newAssigner = updatePrivilegedService(currentPrivilegedServices.assigners[coreIndex], privilegedServicesUpdatedByManager.assigners[coreIndex], privilegedServices.assigners[coreIndex]);
|
|
76
|
-
shouldUpdateAssigners = shouldUpdateAssigners || newAssigner !== currentAssigner;
|
|
77
|
-
return newAssigner;
|
|
78
|
-
}
|
|
79
|
-
return currentAssigner;
|
|
47
|
+
if (privilegedServices === null) {
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
// initial value (ignore the update, because it might not be authorized)
|
|
51
|
+
if (outputState.privilegedServices === null) {
|
|
52
|
+
outputState.privilegedServices = PrivilegedServices.create({
|
|
53
|
+
...currentPrivilegedServices,
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
// manager can override everything and it always takes precedence over
|
|
57
|
+
// everything else
|
|
58
|
+
if (serviceId === currentManager) {
|
|
59
|
+
outputState.privilegedServices = PrivilegedServices.create({
|
|
60
|
+
...privilegedServices,
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
// current registrar can transfer out it's permissions, but only if
|
|
64
|
+
// it wasn't overwritten by manager in current run
|
|
65
|
+
if (serviceId === currentRegistrar) {
|
|
66
|
+
const newRegistrar = updatePrivilegedService(currentPrivilegedServices.registrar, privilegedServicesUpdatedByManager.registrar, privilegedServices.registrar);
|
|
67
|
+
outputState.privilegedServices = PrivilegedServices.create({
|
|
68
|
+
...outputState.privilegedServices,
|
|
69
|
+
registrar: newRegistrar,
|
|
80
70
|
});
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
71
|
+
}
|
|
72
|
+
// current delegator can transfer out it's permissions, but only if
|
|
73
|
+
// it wasn't overwritten by manager in current run
|
|
74
|
+
if (serviceId === currentDelegator) {
|
|
75
|
+
const newDelegator = updatePrivilegedService(currentPrivilegedServices.delegator, privilegedServicesUpdatedByManager.delegator, privilegedServices.delegator);
|
|
76
|
+
outputState.privilegedServices = PrivilegedServices.create({
|
|
77
|
+
...outputState.privilegedServices,
|
|
78
|
+
delegator: newDelegator,
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
let shouldUpdateAssigners = false;
|
|
82
|
+
// same with assigners - they are free to transfer out their core
|
|
83
|
+
const newAssigners = currentAssigners.map((currentAssigner, coreIndex) => {
|
|
84
|
+
if (serviceId === currentAssigner) {
|
|
85
|
+
const newAssigner = updatePrivilegedService(currentPrivilegedServices.assigners[coreIndex], privilegedServicesUpdatedByManager.assigners[coreIndex], privilegedServices.assigners[coreIndex]);
|
|
86
|
+
shouldUpdateAssigners = shouldUpdateAssigners || newAssigner !== currentAssigner;
|
|
87
|
+
return newAssigner;
|
|
87
88
|
}
|
|
89
|
+
return currentAssigner;
|
|
90
|
+
});
|
|
91
|
+
if (shouldUpdateAssigners) {
|
|
92
|
+
const newAssignersPerCore = tryAsPerCore(newAssigners, chainSpec);
|
|
93
|
+
outputState.privilegedServices = PrivilegedServices.create({
|
|
94
|
+
...outputState.privilegedServices,
|
|
95
|
+
assigners: newAssignersPerCore,
|
|
96
|
+
});
|
|
88
97
|
}
|
|
89
98
|
}
|
|
90
99
|
function mergeValidatorsData(mergeContext, [serviceId, { stateUpdate }]) {
|
|
@@ -17,7 +17,8 @@ type BlockVerificationOptions = {
|
|
|
17
17
|
export declare class BlockVerifier {
|
|
18
18
|
readonly hasher: TransitionHasher;
|
|
19
19
|
private readonly blocks;
|
|
20
|
-
|
|
20
|
+
static new(hasher: TransitionHasher, blocks: BlocksDb): BlockVerifier;
|
|
21
|
+
private constructor();
|
|
21
22
|
verifyBlock(block: BlockView, options?: BlockVerificationOptions): Promise<Result<HeaderHash, BlockVerifierError>>;
|
|
22
23
|
}
|
|
23
24
|
export {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"block-verifier.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/transition/block-verifier.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE9D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAEpD,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAC1C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAEpD,oBAAY,kBAAkB;IAC5B,cAAc,IAAI;IAClB,eAAe,IAAI;IACnB,gBAAgB,IAAI;IACpB,iBAAiB,IAAI;IACrB,gBAAgB,IAAI;IACpB,eAAe,IAAI;CACpB;AAID,KAAK,wBAAwB,GAAG;IAC9B,iEAAiE;IACjE,sBAAsB,EAAE,OAAO,CAAC;CACjC,CAAC;AAEF,qBAAa,aAAa;
|
|
1
|
+
{"version":3,"file":"block-verifier.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/transition/block-verifier.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE9D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAEpD,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAC1C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAEpD,oBAAY,kBAAkB;IAC5B,cAAc,IAAI;IAClB,eAAe,IAAI;IACnB,gBAAgB,IAAI;IACpB,iBAAiB,IAAI;IACrB,gBAAgB,IAAI;IACpB,eAAe,IAAI;CACpB;AAID,KAAK,wBAAwB,GAAG;IAC9B,iEAAiE;IACjE,sBAAsB,EAAE,OAAO,CAAC;CACjC,CAAC;AAEF,qBAAa,aAAa;aAMN,MAAM,EAAE,gBAAgB;IACxC,OAAO,CAAC,QAAQ,CAAC,MAAM;IANzB,MAAM,CAAC,GAAG,CAAC,MAAM,EAAE,gBAAgB,EAAE,MAAM,EAAE,QAAQ;IAIrD,OAAO;IAKD,WAAW,CACf,KAAK,EAAE,SAAS,EAChB,OAAO,GAAE,wBAA4D,GACpE,OAAO,CAAC,MAAM,CAAC,UAAU,EAAE,kBAAkB,CAAC,CAAC;CAgEnD"}
|
|
@@ -14,6 +14,9 @@ const ZERO_HASH = Bytes.zero(HASH_SIZE).asOpaque();
|
|
|
14
14
|
export class BlockVerifier {
|
|
15
15
|
hasher;
|
|
16
16
|
blocks;
|
|
17
|
+
static new(hasher, blocks) {
|
|
18
|
+
return new BlockVerifier(hasher, blocks);
|
|
19
|
+
}
|
|
17
20
|
constructor(hasher, blocks) {
|
|
18
21
|
this.hasher = hasher;
|
|
19
22
|
this.blocks = blocks;
|
|
@@ -15,7 +15,7 @@ const DEFAULT_STATE_ROOT = Bytes.fill(HASH_SIZE, 10).asOpaque();
|
|
|
15
15
|
const DEFAULT_TIME_SLOT = tryAsTimeSlot(1);
|
|
16
16
|
describe("Block Verifier", async () => {
|
|
17
17
|
const spec = tinyChainSpec;
|
|
18
|
-
const hasher = new
|
|
18
|
+
const hasher = TransitionHasher.new(await keccak.KeccakHasher.create(), await Blake2b.createHasher());
|
|
19
19
|
const toBlockView = (block) => {
|
|
20
20
|
const encodedBlock = Encoder.encodeObject(Block.Codec, block, spec);
|
|
21
21
|
const blockView = Decoder.decodeObject(Block.Codec.View, encodedBlock, spec);
|
|
@@ -29,7 +29,7 @@ describe("Block Verifier", async () => {
|
|
|
29
29
|
const blockView = toBlockView(block);
|
|
30
30
|
const headerHashOrDefault = headerHash ?? DEFAULT_HEADER_HASH;
|
|
31
31
|
const stateRoot = stateRootHash ?? DEFAULT_STATE_ROOT;
|
|
32
|
-
db.insertBlock(new
|
|
32
|
+
db.insertBlock(WithHash.new(headerHashOrDefault, blockView));
|
|
33
33
|
if (prepareStateRoot) {
|
|
34
34
|
db.setPostStateRoot(headerHashOrDefault, stateRoot);
|
|
35
35
|
}
|
|
@@ -52,7 +52,7 @@ describe("Block Verifier", async () => {
|
|
|
52
52
|
it("should return ParentNotFound error if parent block is not found", async () => {
|
|
53
53
|
const blocksDb = InMemoryBlocks.new();
|
|
54
54
|
prepareBlocksDb(blocksDb, { headerHash: Bytes.fill(HASH_SIZE, 7).asOpaque() });
|
|
55
|
-
const blockVerifier = new
|
|
55
|
+
const blockVerifier = BlockVerifier.new(hasher, blocksDb);
|
|
56
56
|
const block = prepareBlock({ parentHash: Bytes.fill(HASH_SIZE, 8).asOpaque() });
|
|
57
57
|
const result = await blockVerifier.verifyBlock(toBlockView(block));
|
|
58
58
|
deepEqual(result, Result.error(BlockVerifierError.ParentNotFound, () => "Parent 0x0808080808080808080808080808080808080808080808080808080808080808 not found"));
|
|
@@ -61,7 +61,7 @@ describe("Block Verifier", async () => {
|
|
|
61
61
|
const timeSlot = tryAsTimeSlot(42);
|
|
62
62
|
const blocksDb = InMemoryBlocks.new();
|
|
63
63
|
prepareBlocksDb(blocksDb, { timeSlot });
|
|
64
|
-
const blockVerifier = new
|
|
64
|
+
const blockVerifier = BlockVerifier.new(hasher, blocksDb);
|
|
65
65
|
const block = prepareBlock({ timeSlot: tryAsTimeSlot(timeSlot - 2) });
|
|
66
66
|
const result = await blockVerifier.verifyBlock(toBlockView(block));
|
|
67
67
|
deepEqual(result, Result.error(BlockVerifierError.InvalidTimeSlot, () => "Invalid time slot index: 40, expected > 42"));
|
|
@@ -69,7 +69,7 @@ describe("Block Verifier", async () => {
|
|
|
69
69
|
it("should return InvalidExtrinsic error if current block extrinsic hash is incorrect", async () => {
|
|
70
70
|
const blocksDb = InMemoryBlocks.new();
|
|
71
71
|
prepareBlocksDb(blocksDb);
|
|
72
|
-
const blockVerifier = new
|
|
72
|
+
const blockVerifier = BlockVerifier.new(hasher, blocksDb);
|
|
73
73
|
const block = prepareBlock({ correctExtrinsic: false });
|
|
74
74
|
const result = await blockVerifier.verifyBlock(toBlockView(block));
|
|
75
75
|
deepEqual(result, Result.error(BlockVerifierError.InvalidExtrinsic, () => "Invalid extrinsic hash: 0x0202020202020202020202020202020202020202020202020202020202020202, expected 0x0377c11c61a370e532ce1b18a652aecdd060a3a3a257d53dac8f8e1cb32dea98"));
|
|
@@ -80,7 +80,7 @@ describe("Block Verifier", async () => {
|
|
|
80
80
|
stateRootHash: Bytes.fill(HASH_SIZE, 6).asOpaque(),
|
|
81
81
|
prepareStateRoot: false,
|
|
82
82
|
});
|
|
83
|
-
const blockVerifier = new
|
|
83
|
+
const blockVerifier = BlockVerifier.new(hasher, blocksDb);
|
|
84
84
|
const block = prepareBlock({
|
|
85
85
|
priorStateRootHash: Bytes.fill(HASH_SIZE, 7).asOpaque(),
|
|
86
86
|
correctExtrinsic: true,
|
|
@@ -94,7 +94,7 @@ describe("Block Verifier", async () => {
|
|
|
94
94
|
stateRootHash: Bytes.fill(HASH_SIZE, 6).asOpaque(),
|
|
95
95
|
prepareStateRoot: true,
|
|
96
96
|
});
|
|
97
|
-
const blockVerifier = new
|
|
97
|
+
const blockVerifier = BlockVerifier.new(hasher, blocksDb);
|
|
98
98
|
const block = prepareBlock({
|
|
99
99
|
priorStateRootHash: Bytes.fill(HASH_SIZE, 7).asOpaque(),
|
|
100
100
|
correctExtrinsic: true,
|
|
@@ -105,7 +105,7 @@ describe("Block Verifier", async () => {
|
|
|
105
105
|
it("should return valid header hash if all checks pass", async () => {
|
|
106
106
|
const blocksDb = InMemoryBlocks.new();
|
|
107
107
|
prepareBlocksDb(blocksDb, { prepareStateRoot: true });
|
|
108
|
-
const blockVerifier = new
|
|
108
|
+
const blockVerifier = BlockVerifier.new(hasher, blocksDb);
|
|
109
109
|
const block = prepareBlock({
|
|
110
110
|
correctExtrinsic: true,
|
|
111
111
|
});
|
|
@@ -44,9 +44,6 @@ export declare const stfError: <Kind extends StfErrorKind, Err extends StfError[
|
|
|
44
44
|
toString(): string;
|
|
45
45
|
}>;
|
|
46
46
|
export declare class OnChain {
|
|
47
|
-
readonly chainSpec: ChainSpec;
|
|
48
|
-
readonly state: State & WithStateView;
|
|
49
|
-
readonly hasher: TransitionHasher;
|
|
50
47
|
private readonly safrole;
|
|
51
48
|
private readonly safroleSeal;
|
|
52
49
|
private readonly disputes;
|
|
@@ -59,7 +56,18 @@ export declare class OnChain {
|
|
|
59
56
|
private readonly authorization;
|
|
60
57
|
private readonly statistics;
|
|
61
58
|
private isReadyForNextEpoch;
|
|
62
|
-
|
|
59
|
+
readonly chainSpec: ChainSpec;
|
|
60
|
+
readonly state: State & WithStateView;
|
|
61
|
+
readonly hasher: TransitionHasher;
|
|
62
|
+
/** Wire up a full on-chain STF from its dependencies. */
|
|
63
|
+
static assemble(args: {
|
|
64
|
+
chainSpec: ChainSpec;
|
|
65
|
+
state: State & WithStateView;
|
|
66
|
+
hasher: TransitionHasher;
|
|
67
|
+
options: AccumulateOptions;
|
|
68
|
+
headerChain: HeaderChain;
|
|
69
|
+
}): OnChain;
|
|
70
|
+
private constructor();
|
|
63
71
|
/** Pre-populate things worth caching for the next epoch. */
|
|
64
72
|
prepareForNextEpoch(): Promise<void>;
|
|
65
73
|
private verifySeal;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chain-stf.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/transition/chain-stf.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"chain-stf.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/transition/chain-stf.ts"],"names":[],"mappings":"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"}
|
|
@@ -60,9 +60,6 @@ export const stfError = (kind, nested) => {
|
|
|
60
60
|
};
|
|
61
61
|
const logger = Logger.new(import.meta.filename, "stf");
|
|
62
62
|
export class OnChain {
|
|
63
|
-
chainSpec;
|
|
64
|
-
state;
|
|
65
|
-
hasher;
|
|
66
63
|
// chapter 6: https://graypaper.fluffylabs.dev/#/68eaa1f/0d13000d1300?v=0.6.4
|
|
67
64
|
safrole;
|
|
68
65
|
safroleSeal;
|
|
@@ -84,6 +81,13 @@ export class OnChain {
|
|
|
84
81
|
// chapter 13: https://graypaper.fluffylabs.dev/#/68eaa1f/18b60118b601?v=0.6.4
|
|
85
82
|
statistics;
|
|
86
83
|
isReadyForNextEpoch = Promise.resolve(false);
|
|
84
|
+
chainSpec;
|
|
85
|
+
state;
|
|
86
|
+
hasher;
|
|
87
|
+
/** Wire up a full on-chain STF from its dependencies. */
|
|
88
|
+
static assemble(args) {
|
|
89
|
+
return new OnChain(args.chainSpec, args.state, args.hasher, args.options, args.headerChain);
|
|
90
|
+
}
|
|
87
91
|
constructor(chainSpec, state, hasher, options, headerChain) {
|
|
88
92
|
this.chainSpec = chainSpec;
|
|
89
93
|
this.state = state;
|