@typeberry/lib 0.5.10-ec38e0b → 0.5.11-019e542
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 +2 -2
- 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.d.ts +5 -0
- package/packages/core/pvm-host-calls/ecalli-trace-logger.d.ts.map +1 -1
- package/packages/core/pvm-host-calls/ecalli-trace-logger.js +8 -1
- 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/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/index.d.ts +1 -1
- package/packages/jam/executor/index.d.ts.map +1 -1
- package/packages/jam/executor/index.js +1 -1
- package/packages/jam/executor/pvm-executor.js +24 -24
- 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/index.d.ts +4 -0
- package/packages/jam/in-core/externalities/index.d.ts.map +1 -0
- package/packages/jam/in-core/externalities/index.js +3 -0
- package/packages/jam/{transition/externalities/is-authorized-fetch-externalities.d.ts → in-core/externalities/is-authorized-fetch.d.ts} +7 -9
- package/packages/jam/in-core/externalities/is-authorized-fetch.d.ts.map +1 -0
- package/packages/jam/in-core/externalities/is-authorized-fetch.js +41 -0
- package/packages/jam/in-core/externalities/is-authorized-fetch.test.d.ts +2 -0
- package/packages/jam/in-core/externalities/is-authorized-fetch.test.d.ts.map +1 -0
- package/packages/jam/in-core/externalities/is-authorized-fetch.test.js +101 -0
- package/packages/jam/in-core/externalities/refine-fetch.d.ts +51 -0
- package/packages/jam/in-core/externalities/refine-fetch.d.ts.map +1 -0
- package/packages/jam/in-core/externalities/refine-fetch.js +80 -0
- package/packages/jam/in-core/externalities/refine-fetch.test.d.ts +2 -0
- package/packages/jam/in-core/externalities/refine-fetch.test.d.ts.map +1 -0
- package/packages/jam/in-core/externalities/refine-fetch.test.js +219 -0
- package/packages/jam/in-core/externalities/refine.d.ts +3 -3
- package/packages/jam/in-core/externalities/refine.d.ts.map +1 -1
- package/packages/jam/in-core/externalities/refine.js +33 -5
- package/packages/jam/in-core/externalities/refine.test.js +66 -1
- package/packages/jam/in-core/in-core.d.ts +4 -3
- package/packages/jam/in-core/in-core.d.ts.map +1 -1
- package/packages/jam/in-core/in-core.js +9 -4
- package/packages/jam/in-core/in-core.test.js +6 -6
- package/packages/jam/in-core/is-authorized.d.ts +3 -2
- package/packages/jam/in-core/is-authorized.d.ts.map +1 -1
- package/packages/jam/in-core/is-authorized.js +7 -6
- package/packages/jam/in-core/is-authorized.test.js +51 -9
- package/packages/jam/in-core/refine.d.ts +5 -8
- package/packages/jam/in-core/refine.d.ts.map +1 -1
- package/packages/jam/in-core/refine.js +12 -6
- 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 +3 -0
- 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/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 +2 -1
- package/packages/jam/jam-host-calls/general/fetch.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/general/fetch.js +3 -0
- package/packages/jam/jam-host-calls/general/fetch.test.js +27 -28
- 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 +4 -1
- 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.d.ts.map +1 -1
- package/packages/jam/transition/accumulate/accumulate.js +18 -6
- package/packages/jam/transition/accumulate/accumulate.test.js +1 -1
- 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 +20 -6
- package/packages/jam/transition/externalities/accumulate-externalities.d.ts.map +1 -1
- package/packages/jam/transition/externalities/accumulate-externalities.js +29 -22
- package/packages/jam/transition/externalities/accumulate-externalities.test.js +590 -100
- package/packages/jam/transition/externalities/fetch-externalities.d.ts +55 -2
- package/packages/jam/transition/externalities/fetch-externalities.d.ts.map +1 -1
- package/packages/jam/transition/externalities/fetch-externalities.js +44 -2
- package/packages/jam/transition/externalities/index.d.ts +0 -2
- package/packages/jam/transition/externalities/index.d.ts.map +1 -1
- package/packages/jam/transition/externalities/index.js +0 -2
- 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
- package/packages/jam/transition/externalities/is-authorized-fetch-externalities.d.ts.map +0 -1
- package/packages/jam/transition/externalities/is-authorized-fetch-externalities.js +0 -41
- package/packages/jam/transition/externalities/refine-fetch-externalities.d.ts +0 -23
- package/packages/jam/transition/externalities/refine-fetch-externalities.d.ts.map +0 -1
- package/packages/jam/transition/externalities/refine-fetch-externalities.js +0 -56
- package/packages/jam/transition/externalities/refine-fetch-externalities.test.d.ts +0 -2
- package/packages/jam/transition/externalities/refine-fetch-externalities.test.d.ts.map +0 -1
- package/packages/jam/transition/externalities/refine-fetch-externalities.test.js +0 -32
|
@@ -0,0 +1,219 @@
|
|
|
1
|
+
import assert from "node:assert";
|
|
2
|
+
import { describe, it } from "node:test";
|
|
3
|
+
import { tryAsServiceGas, tryAsServiceId, tryAsTimeSlot } from "#@typeberry/block";
|
|
4
|
+
import { RefineContext } from "#@typeberry/block/refine-context.js";
|
|
5
|
+
import { ImportSpec, WorkItem, WorkItemExtrinsicSpec } from "#@typeberry/block/work-item.js";
|
|
6
|
+
import { SEGMENT_BYTES, tryAsSegmentIndex } from "#@typeberry/block/work-item-segment.js";
|
|
7
|
+
import { tryAsWorkItemsCount, WorkPackage } from "#@typeberry/block/work-package.js";
|
|
8
|
+
import { Bytes, BytesBlob } from "#@typeberry/bytes";
|
|
9
|
+
import { Encoder } from "#@typeberry/codec";
|
|
10
|
+
import { asKnownSize, FixedSizeArray } from "#@typeberry/collections";
|
|
11
|
+
import { fullChainSpec, tinyChainSpec } from "#@typeberry/config";
|
|
12
|
+
import { HASH_SIZE } from "#@typeberry/hash";
|
|
13
|
+
import { tryAsU16, tryAsU32, tryAsU64 } from "#@typeberry/numbers";
|
|
14
|
+
import { buildWorkPackageFetchData } from "#@typeberry/transition/externalities/fetch-externalities.js";
|
|
15
|
+
import { asOpaqueType } from "#@typeberry/utils";
|
|
16
|
+
import { RefineFetchExternalities } from "./refine-fetch.js";
|
|
17
|
+
const asExtrinsic = (bytes) => asOpaqueType(bytes);
|
|
18
|
+
function buildWorkItem(overrides) {
|
|
19
|
+
const codeHash = Bytes.fill(HASH_SIZE, 7).asOpaque();
|
|
20
|
+
const imports = Array.from({ length: overrides.importCount ?? 0 }, (_, i) => ImportSpec.create({ treeRoot: Bytes.zero(HASH_SIZE), index: tryAsSegmentIndex(i) }));
|
|
21
|
+
const extrinsicSpecs = Array.from({ length: overrides.extrinsicCount ?? 0 }, () => WorkItemExtrinsicSpec.create({ hash: Bytes.zero(HASH_SIZE).asOpaque(), len: tryAsU32(0) }));
|
|
22
|
+
return WorkItem.create({
|
|
23
|
+
service: tryAsServiceId(overrides.service ?? 1),
|
|
24
|
+
codeHash,
|
|
25
|
+
payload: BytesBlob.blobFrom(new Uint8Array(overrides.payloadLen ?? 3).fill(0xab)),
|
|
26
|
+
refineGasLimit: tryAsServiceGas(1_000_000),
|
|
27
|
+
accumulateGasLimit: tryAsServiceGas(2_000_000),
|
|
28
|
+
importSegments: asKnownSize(imports),
|
|
29
|
+
extrinsic: extrinsicSpecs,
|
|
30
|
+
exportCount: tryAsU16(overrides.exportCount ?? 0),
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
function buildWorkPackage(items) {
|
|
34
|
+
return WorkPackage.create({
|
|
35
|
+
authToken: BytesBlob.blobFrom(new Uint8Array([1, 2, 3])),
|
|
36
|
+
authCodeHost: tryAsServiceId(42),
|
|
37
|
+
authCodeHash: Bytes.fill(HASH_SIZE, 9).asOpaque(),
|
|
38
|
+
authConfiguration: BytesBlob.blobFrom(new Uint8Array([4, 5, 6, 7])),
|
|
39
|
+
context: RefineContext.create({
|
|
40
|
+
anchor: Bytes.fill(HASH_SIZE, 1).asOpaque(),
|
|
41
|
+
stateRoot: Bytes.fill(HASH_SIZE, 2).asOpaque(),
|
|
42
|
+
beefyRoot: Bytes.fill(HASH_SIZE, 3).asOpaque(),
|
|
43
|
+
lookupAnchor: Bytes.fill(HASH_SIZE, 4).asOpaque(),
|
|
44
|
+
lookupAnchorSlot: tryAsTimeSlot(16),
|
|
45
|
+
prerequisites: [],
|
|
46
|
+
}),
|
|
47
|
+
items: FixedSizeArray.new(items, tryAsWorkItemsCount(items.length)),
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
function prepareRefineData(opts = {}) {
|
|
51
|
+
const chainSpec = opts.chainSpec ?? tinyChainSpec;
|
|
52
|
+
const items = opts.items ?? [buildWorkItem({})];
|
|
53
|
+
const workPackage = buildWorkPackage(items);
|
|
54
|
+
const packageData = buildWorkPackageFetchData(chainSpec, workPackage);
|
|
55
|
+
return new RefineFetchExternalities(chainSpec, {
|
|
56
|
+
packageData,
|
|
57
|
+
currentWorkItemIndex: opts.currentWorkItemIndex ?? 0,
|
|
58
|
+
imports: opts.imports ?? asKnownSize(items.map(() => [])),
|
|
59
|
+
extrinsics: opts.extrinsics ?? asKnownSize(items.map(() => [])),
|
|
60
|
+
authorizerTrace: opts.authorizerTrace ?? BytesBlob.empty(),
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
describe("RefineFetchExternalities", () => {
|
|
64
|
+
it("should return different constants for different chain specs", () => {
|
|
65
|
+
const tinyExt = prepareRefineData({ chainSpec: tinyChainSpec });
|
|
66
|
+
const fullExt = prepareRefineData({ chainSpec: fullChainSpec });
|
|
67
|
+
assert.notStrictEqual(tinyExt.constants().length, 0);
|
|
68
|
+
assert.notStrictEqual(fullExt.constants().length, 0);
|
|
69
|
+
assert.notDeepStrictEqual(tinyExt.constants(), fullExt.constants());
|
|
70
|
+
});
|
|
71
|
+
it("should return entropy H_0 (zero hash) per GP §B.3", () => {
|
|
72
|
+
const ext = prepareRefineData();
|
|
73
|
+
const entropy = ext.entropy();
|
|
74
|
+
assert.strictEqual(entropy.length, HASH_SIZE);
|
|
75
|
+
assert.ok(entropy.isEqualTo(Bytes.zero(HASH_SIZE).asOpaque()));
|
|
76
|
+
});
|
|
77
|
+
it("should return the supplied authorizer trace", () => {
|
|
78
|
+
const trace = BytesBlob.blobFrom(new Uint8Array([0xaa, 0xbb, 0xcc]));
|
|
79
|
+
const ext = prepareRefineData({ authorizerTrace: trace });
|
|
80
|
+
assert.deepStrictEqual(ext.authorizerTrace().raw, trace.raw);
|
|
81
|
+
});
|
|
82
|
+
it("should return an extrinsic by work item index and extrinsic index", () => {
|
|
83
|
+
const items = [buildWorkItem({}), buildWorkItem({ service: 2 })];
|
|
84
|
+
const extrinsics = asKnownSize([
|
|
85
|
+
[asExtrinsic(BytesBlob.blobFrom(new Uint8Array([1])))],
|
|
86
|
+
[
|
|
87
|
+
asExtrinsic(BytesBlob.blobFrom(new Uint8Array([2, 2]))),
|
|
88
|
+
asExtrinsic(BytesBlob.blobFrom(new Uint8Array([3, 3, 3]))),
|
|
89
|
+
],
|
|
90
|
+
]);
|
|
91
|
+
const ext = prepareRefineData({ items, extrinsics });
|
|
92
|
+
const other = ext.workItemExtrinsic(tryAsU64(1), tryAsU64(1));
|
|
93
|
+
assert.ok(other !== null);
|
|
94
|
+
assert.deepStrictEqual(other.raw, new Uint8Array([3, 3, 3]));
|
|
95
|
+
});
|
|
96
|
+
it("should return current item's extrinsic when workItem is null", () => {
|
|
97
|
+
const items = [buildWorkItem({}), buildWorkItem({ service: 2 })];
|
|
98
|
+
const extrinsics = asKnownSize([
|
|
99
|
+
[asExtrinsic(BytesBlob.blobFrom(new Uint8Array([9])))],
|
|
100
|
+
[asExtrinsic(BytesBlob.blobFrom(new Uint8Array([8])))],
|
|
101
|
+
]);
|
|
102
|
+
const ext = prepareRefineData({ items, extrinsics, currentWorkItemIndex: 1 });
|
|
103
|
+
const mine = ext.workItemExtrinsic(null, tryAsU64(0));
|
|
104
|
+
assert.ok(mine !== null);
|
|
105
|
+
assert.deepStrictEqual(mine.raw, new Uint8Array([8]));
|
|
106
|
+
});
|
|
107
|
+
it("should return null for out-of-range extrinsic indices", () => {
|
|
108
|
+
const items = [buildWorkItem({})];
|
|
109
|
+
const extrinsics = asKnownSize([
|
|
110
|
+
[asExtrinsic(BytesBlob.blobFrom(new Uint8Array([1])))],
|
|
111
|
+
]);
|
|
112
|
+
const ext = prepareRefineData({ items, extrinsics });
|
|
113
|
+
assert.strictEqual(ext.workItemExtrinsic(tryAsU64(5), tryAsU64(0)), null);
|
|
114
|
+
assert.strictEqual(ext.workItemExtrinsic(tryAsU64(0), tryAsU64(5)), null);
|
|
115
|
+
assert.strictEqual(ext.workItemExtrinsic(null, tryAsU64(5)), null);
|
|
116
|
+
});
|
|
117
|
+
it("should treat U64 indices above the safe-integer range as out of range", () => {
|
|
118
|
+
const items = [buildWorkItem({})];
|
|
119
|
+
const ext = prepareRefineData({ items });
|
|
120
|
+
const huge = tryAsU64(2n ** 53n); // first value > Number.MAX_SAFE_INTEGER
|
|
121
|
+
assert.strictEqual(ext.workItemExtrinsic(huge, tryAsU64(0)), null);
|
|
122
|
+
assert.strictEqual(ext.workItemExtrinsic(null, huge), null);
|
|
123
|
+
assert.strictEqual(ext.workItemImport(huge, tryAsU64(0)), null);
|
|
124
|
+
assert.strictEqual(ext.oneWorkItem(huge), null);
|
|
125
|
+
assert.strictEqual(ext.workItemPayload(huge), null);
|
|
126
|
+
});
|
|
127
|
+
it("should return an import segment by work item index and segment index", () => {
|
|
128
|
+
const items = [buildWorkItem({}), buildWorkItem({ service: 2 })];
|
|
129
|
+
const segBytes = new Uint8Array(SEGMENT_BYTES).fill(0x55);
|
|
130
|
+
const imports = asKnownSize([
|
|
131
|
+
[],
|
|
132
|
+
[{ index: tryAsSegmentIndex(0), data: Bytes.fromBlob(segBytes, SEGMENT_BYTES) }],
|
|
133
|
+
]);
|
|
134
|
+
const ext = prepareRefineData({ items, imports });
|
|
135
|
+
const imp = ext.workItemImport(tryAsU64(1), tryAsU64(0));
|
|
136
|
+
assert.ok(imp !== null);
|
|
137
|
+
assert.deepStrictEqual(imp.raw, segBytes);
|
|
138
|
+
});
|
|
139
|
+
it("should return null for out-of-range import indices", () => {
|
|
140
|
+
const ext = prepareRefineData();
|
|
141
|
+
assert.strictEqual(ext.workItemImport(tryAsU64(10), tryAsU64(0)), null);
|
|
142
|
+
assert.strictEqual(ext.workItemImport(null, tryAsU64(10)), null);
|
|
143
|
+
assert.strictEqual(ext.workItemImport(tryAsU64(0), tryAsU64(10)), null);
|
|
144
|
+
});
|
|
145
|
+
it("should return encoded work package", () => {
|
|
146
|
+
const items = [buildWorkItem({})];
|
|
147
|
+
const ext = prepareRefineData({ items });
|
|
148
|
+
const expected = Encoder.encodeObject(WorkPackage.Codec, buildWorkPackage(items), tinyChainSpec);
|
|
149
|
+
assert.deepStrictEqual(ext.workPackage().raw, expected.raw);
|
|
150
|
+
});
|
|
151
|
+
it("should return auth configuration and auth token from the package", () => {
|
|
152
|
+
const ext = prepareRefineData();
|
|
153
|
+
assert.deepStrictEqual(ext.authConfiguration().raw, new Uint8Array([4, 5, 6, 7]));
|
|
154
|
+
assert.deepStrictEqual(ext.authToken().raw, new Uint8Array([1, 2, 3]));
|
|
155
|
+
});
|
|
156
|
+
it("should return encoded refine context", () => {
|
|
157
|
+
const ext = prepareRefineData();
|
|
158
|
+
const context = RefineContext.create({
|
|
159
|
+
anchor: Bytes.fill(HASH_SIZE, 1).asOpaque(),
|
|
160
|
+
stateRoot: Bytes.fill(HASH_SIZE, 2).asOpaque(),
|
|
161
|
+
beefyRoot: Bytes.fill(HASH_SIZE, 3).asOpaque(),
|
|
162
|
+
lookupAnchor: Bytes.fill(HASH_SIZE, 4).asOpaque(),
|
|
163
|
+
lookupAnchorSlot: tryAsTimeSlot(16),
|
|
164
|
+
prerequisites: [],
|
|
165
|
+
});
|
|
166
|
+
const expected = Encoder.encodeObject(RefineContext.Codec, context);
|
|
167
|
+
assert.deepStrictEqual(ext.refineContext().raw, expected.raw);
|
|
168
|
+
});
|
|
169
|
+
it("should return concatenated work item summaries (kind 11) with 62 bytes per item", () => {
|
|
170
|
+
const items = [
|
|
171
|
+
buildWorkItem({ service: 1, payloadLen: 7, exportCount: 2, importCount: 1, extrinsicCount: 0 }),
|
|
172
|
+
buildWorkItem({ service: 2, payloadLen: 4, exportCount: 0, importCount: 0, extrinsicCount: 3 }),
|
|
173
|
+
];
|
|
174
|
+
const ext = prepareRefineData({ items });
|
|
175
|
+
const all = ext.allWorkItems();
|
|
176
|
+
assert.strictEqual(all.length, 62 * items.length);
|
|
177
|
+
});
|
|
178
|
+
it("should return a single work item summary (kind 12)", () => {
|
|
179
|
+
const items = [buildWorkItem({ service: 1 }), buildWorkItem({ service: 2, payloadLen: 10 })];
|
|
180
|
+
const ext = prepareRefineData({ items });
|
|
181
|
+
const one = ext.oneWorkItem(tryAsU64(1));
|
|
182
|
+
assert.ok(one !== null);
|
|
183
|
+
assert.strictEqual(one.length, 62);
|
|
184
|
+
// first 4 bytes are the service id (u32 LE).
|
|
185
|
+
const serviceId = new DataView(one.raw.buffer, one.raw.byteOffset, 4).getUint32(0, true);
|
|
186
|
+
assert.strictEqual(serviceId, 2);
|
|
187
|
+
// payload length is the last 4 bytes (u32 LE).
|
|
188
|
+
const payloadLen = new DataView(one.raw.buffer, one.raw.byteOffset + 58, 4).getUint32(0, true);
|
|
189
|
+
assert.strictEqual(payloadLen, 10);
|
|
190
|
+
});
|
|
191
|
+
it("should return null for one work item when index is out of range", () => {
|
|
192
|
+
const ext = prepareRefineData();
|
|
193
|
+
assert.strictEqual(ext.oneWorkItem(tryAsU64(99)), null);
|
|
194
|
+
});
|
|
195
|
+
it("should return the raw payload of a work item (kind 13)", () => {
|
|
196
|
+
const items = [buildWorkItem({ service: 1, payloadLen: 2 }), buildWorkItem({ service: 2, payloadLen: 5 })];
|
|
197
|
+
const ext = prepareRefineData({ items });
|
|
198
|
+
const payload = ext.workItemPayload(tryAsU64(1));
|
|
199
|
+
assert.ok(payload !== null);
|
|
200
|
+
assert.strictEqual(payload.length, 5);
|
|
201
|
+
assert.ok(payload.raw.every((x) => x === 0xab));
|
|
202
|
+
});
|
|
203
|
+
it("should return null for payload when index is out of range", () => {
|
|
204
|
+
const ext = prepareRefineData();
|
|
205
|
+
assert.strictEqual(ext.workItemPayload(tryAsU64(99)), null);
|
|
206
|
+
});
|
|
207
|
+
// guard against silent accidental changes to the helpers — tryAsU32 ensures
|
|
208
|
+
// encoded lengths match GP's S(w) spec.
|
|
209
|
+
it("uses unsigned little-endian u32 for payload length regardless of platform", () => {
|
|
210
|
+
const items = [buildWorkItem({ service: 1, payloadLen: 0x1234 })];
|
|
211
|
+
const ext = prepareRefineData({ items });
|
|
212
|
+
const one = ext.oneWorkItem(tryAsU64(0));
|
|
213
|
+
assert.ok(one !== null);
|
|
214
|
+
const payloadLen = new DataView(one.raw.buffer, one.raw.byteOffset + 58, 4).getUint32(0, true);
|
|
215
|
+
assert.strictEqual(payloadLen, 0x1234);
|
|
216
|
+
// tryAsU32 would throw on negative values
|
|
217
|
+
assert.doesNotThrow(() => tryAsU32(0x1234));
|
|
218
|
+
});
|
|
219
|
+
});
|
|
@@ -3,8 +3,8 @@ import type { BytesBlob } from "#@typeberry/bytes";
|
|
|
3
3
|
import type { PvmBackend } from "#@typeberry/config";
|
|
4
4
|
import type { Blake2bHash } from "#@typeberry/hash";
|
|
5
5
|
import { type MachineId, type MachineResult, type MemoryOperation, NoMachineError, type PagesError, type PeekPokeError, type ProgramCounter, type RefineExternalities, SegmentExportError, type ZeroVoidError } from "#@typeberry/jam-host-calls";
|
|
6
|
-
import type
|
|
7
|
-
import { type HostCallMemory,
|
|
6
|
+
import { type U64 } from "#@typeberry/numbers";
|
|
7
|
+
import { type HostCallMemory, HostCallRegisters } from "#@typeberry/pvm-host-calls";
|
|
8
8
|
import { type BigGas } from "#@typeberry/pvm-interface";
|
|
9
9
|
import { type ProgramDecoderError } from "#@typeberry/pvm-interpreter";
|
|
10
10
|
import type { State } from "#@typeberry/state";
|
|
@@ -48,7 +48,7 @@ export declare class RefineExternalitiesImpl implements RefineExternalities {
|
|
|
48
48
|
machinePeekFrom(_machineIndex: MachineId, _destinationStart: U64, _sourceStart: U64, _length: U64, _destination: HostCallMemory): Promise<Result<OK, PeekPokeError>>;
|
|
49
49
|
machinePokeInto(_machineIndex: MachineId, _sourceStart: U64, _destinationStart: U64, _length: U64, _source: HostCallMemory): Promise<Result<OK, PeekPokeError>>;
|
|
50
50
|
machineInit(code: BytesBlob, programCounter: ProgramCounter): Promise<Result<MachineId, ProgramDecoderError>>;
|
|
51
|
-
machineInvoke(
|
|
51
|
+
machineInvoke(machineIndex: MachineId, gas: BigGas, registers: HostCallRegisters): Promise<Result<MachineResult, NoMachineError>>;
|
|
52
52
|
exportSegment(segment: Segment): Result<SegmentIndex, SegmentExportError>;
|
|
53
53
|
historicalLookup(serviceId: ServiceId | null, hash: Blake2bHash): Promise<BytesBlob | null>;
|
|
54
54
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"refine.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/in-core/externalities/refine.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,KAAK,OAAO,EACZ,KAAK,YAAY,EACjB,KAAK,SAAS,EAEf,MAAM,kBAAkB,CAAC;AAC1B,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAElD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EACL,KAAK,SAAS,EACd,KAAK,aAAa,
|
|
1
|
+
{"version":3,"file":"refine.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/in-core/externalities/refine.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,KAAK,OAAO,EACZ,KAAK,YAAY,EACjB,KAAK,SAAS,EAEf,MAAM,kBAAkB,CAAC;AAC1B,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAElD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EACL,KAAK,SAAS,EACd,KAAK,aAAa,EAElB,KAAK,eAAe,EACpB,cAAc,EACd,KAAK,UAAU,EACf,KAAK,aAAa,EAClB,KAAK,cAAc,EACnB,KAAK,mBAAmB,EACxB,kBAAkB,EAGlB,KAAK,aAAa,EACnB,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAY,KAAK,GAAG,EAAE,MAAM,oBAAoB,CAAC;AAExD,OAAO,EAAE,KAAK,cAAc,EAAE,iBAAiB,EAAsB,MAAM,2BAA2B,CAAC;AACvG,OAAO,EAAE,KAAK,MAAM,EAAuD,MAAM,0BAA0B,CAAC;AAC5G,OAAO,EAAkB,KAAK,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACtF,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAiBnD;;GAEG;AACH,MAAM,MAAM,yBAAyB,GAAG;IACtC,2CAA2C;IAC3C,gBAAgB,EAAE,SAAS,CAAC;IAC5B,8EAA8E;IAC9E,WAAW,EAAE,KAAK,CAAC;IACnB,6EAA6E;IAC7E,YAAY,EAAE,MAAM,CAAC;IACrB;;;OAGG;IACH,UAAU,EAAE,UAAU,CAAC;CACxB,CAAC;AAEF,qBAAa,uBAAwB,YAAW,mBAAmB;IACjE,+CAA+C;IAC/C,OAAO,CAAC,QAAQ,CAA6E;IAC7F,oEAAoE;IACpE,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAY;IAC7C,uDAAuD;IACvD,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAQ;IACpC,6DAA6D;IAC7D,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAiB;IAClD,qEAAqE;IACrE,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAS;IACtC,+CAA+C;IAC/C,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;IAExC,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,yBAAyB;IAI/C,OAAO;IAOP,mBAAmB,IAAI,SAAS,OAAO,EAAE;IAIzC,cAAc,CAAC,YAAY,EAAE,SAAS,GAAG,OAAO,CAAC,MAAM,CAAC,cAAc,EAAE,cAAc,CAAC,CAAC;IAWxF,YAAY,CACV,aAAa,EAAE,SAAS,EACxB,UAAU,EAAE,GAAG,EACf,UAAU,EAAE,GAAG,EACf,YAAY,EAAE,eAAe,GAAG,IAAI,GACnC,OAAO,CAAC,MAAM,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;IAIlC,gBAAgB,CAAC,aAAa,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG,EAAE,UAAU,EAAE,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,EAAE,EAAE,aAAa,CAAC,CAAC;IAIhH,gBAAgB,CAAC,aAAa,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG,EAAE,UAAU,EAAE,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,EAAE,EAAE,aAAa,CAAC,CAAC;IAIhH,eAAe,CACb,aAAa,EAAE,SAAS,EACxB,iBAAiB,EAAE,GAAG,EACtB,YAAY,EAAE,GAAG,EACjB,OAAO,EAAE,GAAG,EACZ,YAAY,EAAE,cAAc,GAC3B,OAAO,CAAC,MAAM,CAAC,EAAE,EAAE,aAAa,CAAC,CAAC;IAIrC,eAAe,CACb,aAAa,EAAE,SAAS,EACxB,YAAY,EAAE,GAAG,EACjB,iBAAiB,EAAE,GAAG,EACtB,OAAO,EAAE,GAAG,EACZ,OAAO,EAAE,cAAc,GACtB,OAAO,CAAC,MAAM,CAAC,EAAE,EAAE,aAAa,CAAC,CAAC;IAI/B,WAAW,CAAC,IAAI,EAAE,SAAS,EAAE,cAAc,EAAE,cAAc,GAAG,OAAO,CAAC,MAAM,CAAC,SAAS,EAAE,mBAAmB,CAAC,CAAC;IAgCnH,aAAa,CACX,YAAY,EAAE,SAAS,EACvB,GAAG,EAAE,MAAM,EACX,SAAS,EAAE,iBAAiB,GAC3B,OAAO,CAAC,MAAM,CAAC,aAAa,EAAE,cAAc,CAAC,CAAC;IAiCjD,aAAa,CAAC,OAAO,EAAE,OAAO,GAAG,MAAM,CAAC,YAAY,EAAE,kBAAkB,CAAC;IAezE,gBAAgB,CAAC,SAAS,EAAE,SAAS,GAAG,IAAI,EAAE,IAAI,EAAE,WAAW,GAAG,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC;CAW5F"}
|
|
@@ -1,11 +1,14 @@
|
|
|
1
1
|
import { MAX_NUMBER_OF_EXPORTS_WP, tryAsSegmentIndex, } from "#@typeberry/block";
|
|
2
2
|
import { SortedArray } from "#@typeberry/collections";
|
|
3
3
|
import { NoMachineError, SegmentExportError, tryAsMachineId, tryAsProgramCounter, } from "#@typeberry/jam-host-calls";
|
|
4
|
+
import { tryAsU64 } from "#@typeberry/numbers";
|
|
4
5
|
import { Ordering } from "#@typeberry/ordering";
|
|
5
|
-
import { PvmInstanceManager } from "#@typeberry/pvm-host-calls";
|
|
6
|
-
import { tryAsGas } from "#@typeberry/pvm-interface";
|
|
6
|
+
import { HostCallRegisters, PvmInstanceManager } from "#@typeberry/pvm-host-calls";
|
|
7
|
+
import { Status, tryAsBigGas, tryAsGas } from "#@typeberry/pvm-interface";
|
|
7
8
|
import { ProgramDecoder } from "#@typeberry/pvm-interpreter";
|
|
8
9
|
import { Result } from "#@typeberry/utils";
|
|
10
|
+
/** Used when searching by MachineId only — the comparator ignores this field. */
|
|
11
|
+
const NULL_INTERPRETER = undefined;
|
|
9
12
|
const machineComparator = (a, b) => {
|
|
10
13
|
if (a[0] < b[0]) {
|
|
11
14
|
return Ordering.Less;
|
|
@@ -42,7 +45,7 @@ export class RefineExternalitiesImpl {
|
|
|
42
45
|
}
|
|
43
46
|
machineExpunge(machineIndex) {
|
|
44
47
|
// We just care about machineIndex
|
|
45
|
-
const entry = this.machines.findExact([machineIndex,
|
|
48
|
+
const entry = this.machines.findExact([machineIndex, NULL_INTERPRETER]);
|
|
46
49
|
if (entry === undefined) {
|
|
47
50
|
return Promise.resolve(Result.error(NoMachineError, () => `Machine not found (id: ${machineIndex})`));
|
|
48
51
|
}
|
|
@@ -93,8 +96,33 @@ export class RefineExternalitiesImpl {
|
|
|
93
96
|
this.machines.insert([machineId, innerPvm]);
|
|
94
97
|
return Result.ok(machineId);
|
|
95
98
|
}
|
|
96
|
-
machineInvoke(
|
|
97
|
-
|
|
99
|
+
machineInvoke(machineIndex, gas, registers) {
|
|
100
|
+
const entry = this.machines.findExact([machineIndex, NULL_INTERPRETER]);
|
|
101
|
+
if (entry === undefined) {
|
|
102
|
+
return Promise.resolve(Result.error(NoMachineError, () => `Machine not found (id: ${machineIndex})`));
|
|
103
|
+
}
|
|
104
|
+
const innerPvm = entry[1];
|
|
105
|
+
// Prepare inner PVM
|
|
106
|
+
innerPvm.registers.setAllEncoded(registers.getEncoded());
|
|
107
|
+
innerPvm.gas.set(gas);
|
|
108
|
+
// Execute program
|
|
109
|
+
innerPvm.runProgram();
|
|
110
|
+
// Status
|
|
111
|
+
const status = innerPvm.getStatus();
|
|
112
|
+
const exitParam = innerPvm.getExitParam() ?? 0;
|
|
113
|
+
const remainingGas = tryAsBigGas(innerPvm.gas.get());
|
|
114
|
+
const outRegisters = HostCallRegisters.fromRaw(new Uint8Array(innerPvm.registers.getAllEncoded()));
|
|
115
|
+
let machineStatus;
|
|
116
|
+
if (status === Status.HOST) {
|
|
117
|
+
machineStatus = { status, hostCallIndex: tryAsU64(exitParam) };
|
|
118
|
+
}
|
|
119
|
+
else if (status === Status.FAULT) {
|
|
120
|
+
machineStatus = { status, address: tryAsU64(exitParam) };
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
machineStatus = { status };
|
|
124
|
+
}
|
|
125
|
+
return Promise.resolve(Result.ok({ result: machineStatus, gas: remainingGas, registers: outRegisters }));
|
|
98
126
|
}
|
|
99
127
|
exportSegment(segment) {
|
|
100
128
|
// https://graypaper.fluffylabs.dev/#/ab2cdbd/335d03335d03?v=0.7.2
|
|
@@ -7,6 +7,8 @@ import { PvmBackend, tinyChainSpec } from "#@typeberry/config";
|
|
|
7
7
|
import { HASH_SIZE } from "#@typeberry/hash";
|
|
8
8
|
import { SegmentExportError, tryAsMachineId, tryAsProgramCounter } from "#@typeberry/jam-host-calls";
|
|
9
9
|
import { tryAsU32, tryAsU64 } from "#@typeberry/numbers";
|
|
10
|
+
import { HostCallRegisters } from "#@typeberry/pvm-host-calls";
|
|
11
|
+
import { Status, tryAsBigGas } from "#@typeberry/pvm-interface";
|
|
10
12
|
import { InMemoryService, InMemoryState, PreimageItem, ServiceAccountInfo } from "#@typeberry/state";
|
|
11
13
|
import { RefineExternalitiesImpl } from "./refine.js";
|
|
12
14
|
const MINIMAL_PROGRAM = new Uint8Array([0, 1, 1, 0, 0x00]);
|
|
@@ -34,7 +36,7 @@ function createMockState(services) {
|
|
|
34
36
|
preimages.set(hash, item);
|
|
35
37
|
}
|
|
36
38
|
const serviceId = tryAsServiceId(svc.id);
|
|
37
|
-
serviceMap.set(serviceId, new
|
|
39
|
+
serviceMap.set(serviceId, InMemoryService.new(serviceId, {
|
|
38
40
|
info: ServiceAccountInfo.create({
|
|
39
41
|
codeHash: Bytes.zero(HASH_SIZE).asOpaque(),
|
|
40
42
|
balance: tryAsU64(1000000000n),
|
|
@@ -64,6 +66,9 @@ function createExt(overrides = {}) {
|
|
|
64
66
|
...overrides,
|
|
65
67
|
});
|
|
66
68
|
}
|
|
69
|
+
function emptyRegisters() {
|
|
70
|
+
return HostCallRegisters.empty();
|
|
71
|
+
}
|
|
67
72
|
describe("RefineExternalitiesImpl", () => {
|
|
68
73
|
describe("historicalLookup", () => {
|
|
69
74
|
const PREIMAGE_HASH = "0xaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa";
|
|
@@ -260,4 +265,64 @@ describe("RefineExternalitiesImpl", () => {
|
|
|
260
265
|
assert.strictEqual(result.ok, tryAsProgramCounter(10));
|
|
261
266
|
});
|
|
262
267
|
});
|
|
268
|
+
describe("machineInvoke", () => {
|
|
269
|
+
it("should return NoMachineError for non-existent machine", async () => {
|
|
270
|
+
const ext = createExt();
|
|
271
|
+
const regs = emptyRegisters();
|
|
272
|
+
const result = await ext.machineInvoke(tryAsMachineId(999), tryAsBigGas(1000n), regs);
|
|
273
|
+
assert.strictEqual(result.isError, true);
|
|
274
|
+
});
|
|
275
|
+
it("should execute inner PVM and return PANIC for TRAP instruction", async () => {
|
|
276
|
+
const ext = createExt();
|
|
277
|
+
const code = BytesBlob.blobFrom(MINIMAL_PROGRAM);
|
|
278
|
+
const initResult = await ext.machineInit(code, tryAsProgramCounter(0));
|
|
279
|
+
assert.strictEqual(initResult.isOk, true);
|
|
280
|
+
const machineId = initResult.ok;
|
|
281
|
+
const regs = emptyRegisters();
|
|
282
|
+
const result = await ext.machineInvoke(machineId, tryAsBigGas(1000n), regs);
|
|
283
|
+
assert.strictEqual(result.isOk, true);
|
|
284
|
+
assert.strictEqual(result.ok.result.status, Status.PANIC);
|
|
285
|
+
});
|
|
286
|
+
it("should return OOG when gas is exhausted", async () => {
|
|
287
|
+
const ext = createExt();
|
|
288
|
+
const code = BytesBlob.blobFrom(MINIMAL_PROGRAM);
|
|
289
|
+
const initResult = await ext.machineInit(code, tryAsProgramCounter(0));
|
|
290
|
+
assert.strictEqual(initResult.isOk, true);
|
|
291
|
+
const machineId = initResult.ok;
|
|
292
|
+
const regs = emptyRegisters();
|
|
293
|
+
// With 0 gas, should immediately OOG
|
|
294
|
+
const result = await ext.machineInvoke(machineId, tryAsBigGas(0n), regs);
|
|
295
|
+
assert.strictEqual(result.isOk, true);
|
|
296
|
+
assert.strictEqual(result.ok.result.status, Status.OOG);
|
|
297
|
+
});
|
|
298
|
+
it("should pass registers to inner PVM and return them back", async () => {
|
|
299
|
+
const ext = createExt();
|
|
300
|
+
const code = BytesBlob.blobFrom(MINIMAL_PROGRAM);
|
|
301
|
+
const initResult = await ext.machineInit(code, tryAsProgramCounter(0));
|
|
302
|
+
assert.strictEqual(initResult.isOk, true);
|
|
303
|
+
const machineId = initResult.ok;
|
|
304
|
+
const regs = emptyRegisters();
|
|
305
|
+
regs.set(0, tryAsU64(0xdeadbeefn));
|
|
306
|
+
regs.set(5, tryAsU64(0xcafebaben));
|
|
307
|
+
const result = await ext.machineInvoke(machineId, tryAsBigGas(1000n), regs);
|
|
308
|
+
assert.strictEqual(result.isOk, true);
|
|
309
|
+
// Registers should be returned (TRAP doesn't modify registers)
|
|
310
|
+
assert.strictEqual(result.ok.registers.get(0), tryAsU64(0xdeadbeefn));
|
|
311
|
+
assert.strictEqual(result.ok.registers.get(5), tryAsU64(0xcafebaben));
|
|
312
|
+
});
|
|
313
|
+
it("should return remaining gas after execution", async () => {
|
|
314
|
+
const ext = createExt();
|
|
315
|
+
const code = BytesBlob.blobFrom(MINIMAL_PROGRAM);
|
|
316
|
+
const initResult = await ext.machineInit(code, tryAsProgramCounter(0));
|
|
317
|
+
assert.strictEqual(initResult.isOk, true);
|
|
318
|
+
const machineId = initResult.ok;
|
|
319
|
+
const regs = emptyRegisters();
|
|
320
|
+
const result = await ext.machineInvoke(machineId, tryAsBigGas(1000n), regs);
|
|
321
|
+
assert.strictEqual(result.isOk, true);
|
|
322
|
+
// TRAP costs 1 gas, so remaining should be 999
|
|
323
|
+
const remaining = Number(result.ok.gas);
|
|
324
|
+
assert.ok(remaining < 1000);
|
|
325
|
+
assert.ok(remaining >= 0);
|
|
326
|
+
});
|
|
327
|
+
});
|
|
263
328
|
});
|
|
@@ -7,8 +7,8 @@ import type { ChainSpec, PvmBackend } from "#@typeberry/config";
|
|
|
7
7
|
import type { StatesDb } from "#@typeberry/database";
|
|
8
8
|
import type { Blake2b, WithHash } from "#@typeberry/hash";
|
|
9
9
|
import { Result } from "#@typeberry/utils";
|
|
10
|
-
import {
|
|
11
|
-
export type { ImportedSegment, PerWorkItem
|
|
10
|
+
import type { ImportedSegment, PerWorkItem } from "./externalities/index.js";
|
|
11
|
+
export type { ImportedSegment, PerWorkItem };
|
|
12
12
|
export type RefineResult = {
|
|
13
13
|
report: WorkReport;
|
|
14
14
|
exports: PerWorkItem<Segment[]>;
|
|
@@ -28,7 +28,8 @@ export declare class InCore {
|
|
|
28
28
|
private readonly states;
|
|
29
29
|
private readonly isAuthorized;
|
|
30
30
|
private readonly refineItem;
|
|
31
|
-
|
|
31
|
+
static new(chainSpec: ChainSpec, states: StatesDb, pvmBackend: PvmBackend, blake2b: Blake2b): InCore;
|
|
32
|
+
private constructor();
|
|
32
33
|
/**
|
|
33
34
|
* Work-report computation function.
|
|
34
35
|
*
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"in-core.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/in-core/in-core.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAC3D,OAAO,EAAsB,KAAK,eAAe,EAAmB,MAAM,oCAAoC,CAAC;AAC/G,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AACvE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kCAAkC,CAAC;AACpE,OAAO,EAAmB,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAG9E,OAAO,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC/D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"in-core.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/in-core/in-core.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAC3D,OAAO,EAAsB,KAAK,eAAe,EAAmB,MAAM,oCAAoC,CAAC;AAC/G,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AACvE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kCAAkC,CAAC;AACpE,OAAO,EAAmB,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAG9E,OAAO,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC/D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAKzD,OAAO,EAAe,MAAM,EAAE,MAAM,kBAAkB,CAAC;AACvD,OAAO,KAAK,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAE7E,YAAY,EAAE,eAAe,EAAE,WAAW,EAAE,CAAC;AAI7C,MAAM,MAAM,YAAY,GAAG;IACzB,MAAM,EAAE,UAAU,CAAC;IACnB,OAAO,EAAE,WAAW,CAAC,OAAO,EAAE,CAAC,CAAC;CACjC,CAAC;AAEF,oBAAY,WAAW;IACrB,8EAA8E;IAC9E,YAAY,IAAI;IAChB,qFAAqF;IACrF,iBAAiB,IAAI;IACrB,wEAAwE;IACxE,uBAAuB,IAAI;IAC3B,2BAA2B;IAC3B,kBAAkB,IAAI;CACvB;AAID,qBAAa,MAAM;aASC,SAAS,EAAE,SAAS;IACpC,OAAO,CAAC,QAAQ,CAAC,MAAM;IATzB,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAe;IAC5C,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAS;IAEpC,MAAM,CAAC,GAAG,CAAC,SAAS,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,UAAU,EAAE,UAAU,EAAE,OAAO,EAAE,OAAO;IAI3F,OAAO;IAUP;;;;;;;;;OASG;IACG,MAAM,CACV,kBAAkB,EAAE,QAAQ,CAAC,eAAe,EAAE,WAAW,CAAC,EAC1D,IAAI,EAAE,SAAS,EACf,OAAO,EAAE,WAAW,CAAC,eAAe,EAAE,CAAC,EACvC,UAAU,EAAE,WAAW,CAAC,iBAAiB,EAAE,CAAC,GAC3C,OAAO,CAAC,MAAM,CAAC,YAAY,EAAE,WAAW,CAAC,CAAC;IAoF7C,OAAO,CAAC,MAAM,CAAC,oBAAoB;CAsDpC"}
|
|
@@ -5,6 +5,7 @@ import { asKnownSize, FixedSizeArray } from "#@typeberry/collections";
|
|
|
5
5
|
import { HASH_SIZE } from "#@typeberry/hash";
|
|
6
6
|
import { Logger } from "#@typeberry/logger";
|
|
7
7
|
import { tryAsU8, tryAsU16, tryAsU32 } from "#@typeberry/numbers";
|
|
8
|
+
import { buildWorkPackageFetchData } from "#@typeberry/transition/externalities/fetch-externalities.js";
|
|
8
9
|
import { assertEmpty, Result } from "#@typeberry/utils";
|
|
9
10
|
import { AuthorizationError, IsAuthorized } from "./is-authorized.js";
|
|
10
11
|
import { Refine } from "./refine.js";
|
|
@@ -25,6 +26,9 @@ export class InCore {
|
|
|
25
26
|
states;
|
|
26
27
|
isAuthorized;
|
|
27
28
|
refineItem;
|
|
29
|
+
static new(chainSpec, states, pvmBackend, blake2b) {
|
|
30
|
+
return new InCore(chainSpec, states, pvmBackend, blake2b);
|
|
31
|
+
}
|
|
28
32
|
constructor(chainSpec, states, pvmBackend, blake2b) {
|
|
29
33
|
this.chainSpec = chainSpec;
|
|
30
34
|
this.states = states;
|
|
@@ -43,8 +47,7 @@ export class InCore {
|
|
|
43
47
|
*/
|
|
44
48
|
async refine(workPackageAndHash, core, imports, extrinsics) {
|
|
45
49
|
const workPackageHash = workPackageAndHash.hash;
|
|
46
|
-
const { context,
|
|
47
|
-
assertEmpty(rest);
|
|
50
|
+
const { context, items } = workPackageAndHash.data;
|
|
48
51
|
// TODO [ToDr] Verify BEEFY root
|
|
49
52
|
// TODO [ToDr] Verify prerequisites
|
|
50
53
|
logger.log `[core:${core}] Attempting to refine work package with ${items.length} items.`;
|
|
@@ -69,8 +72,10 @@ export class InCore {
|
|
|
69
72
|
if (lookupState.timeslot !== context.lookupAnchorSlot) {
|
|
70
73
|
return Result.error(RefineError.InvalidLookupAnchorSlot, () => `Lookup anchor slot does not match the one is state. Ours: ${lookupState.timeslot}, expected: ${context.lookupAnchorSlot}`);
|
|
71
74
|
}
|
|
75
|
+
// Eagerly build the per-package fetch data so we pay the encoding cost
|
|
76
|
+
const packageFetchData = buildWorkPackageFetchData(this.chainSpec, workPackageAndHash.data);
|
|
72
77
|
// Check authorization
|
|
73
|
-
const authResult = await this.isAuthorized.invoke(state, core,
|
|
78
|
+
const authResult = await this.isAuthorized.invoke(state, core, packageFetchData);
|
|
74
79
|
if (authResult.isError) {
|
|
75
80
|
return Result.error(RefineError.AuthorizationError, () => `Authorization error: ${AuthorizationError[authResult.error]}: ${authResult.details()}.`);
|
|
76
81
|
}
|
|
@@ -80,7 +85,7 @@ export class InCore {
|
|
|
80
85
|
const refineResults = [];
|
|
81
86
|
for (const [idx, item] of items.entries()) {
|
|
82
87
|
logger.info `[core:${core}][i:${idx}] Refining item for service ${item.service}.`;
|
|
83
|
-
const result = await this.refineItem.invoke(state, lookupState, idx, item, imports, extrinsics, core, workPackageHash, exportOffset);
|
|
88
|
+
const result = await this.refineItem.invoke(state, lookupState, packageFetchData, idx, item, imports, extrinsics, core, workPackageHash, exportOffset, authResult.ok.authorizationOutput);
|
|
84
89
|
refineResults.push(result);
|
|
85
90
|
exportOffset += result.exports.length;
|
|
86
91
|
}
|
|
@@ -26,7 +26,7 @@ function getAuthCodeHash() {
|
|
|
26
26
|
return blake2b.hashBytes(AUTHORIZER_PVM).asOpaque();
|
|
27
27
|
}
|
|
28
28
|
function createService(serviceId, codeHash, code) {
|
|
29
|
-
return new
|
|
29
|
+
return InMemoryService.new(serviceId, {
|
|
30
30
|
info: ServiceAccountInfo.create({
|
|
31
31
|
codeHash: codeHash.asOpaque(),
|
|
32
32
|
balance: tryAsU64(10_000_000_000),
|
|
@@ -77,13 +77,13 @@ function hashWorkPackage(spec, workPackage) {
|
|
|
77
77
|
const workPackageHash = blake2b
|
|
78
78
|
.hashBytes(Encoder.encodeObject(WorkPackage.Codec, workPackage, spec))
|
|
79
79
|
.asOpaque();
|
|
80
|
-
return new
|
|
80
|
+
return WithHash.new(workPackageHash, workPackage);
|
|
81
81
|
}
|
|
82
82
|
describe("InCore", () => {
|
|
83
83
|
it("should return StateMissing error when anchor block state is not in DB", async () => {
|
|
84
84
|
const spec = tinyChainSpec;
|
|
85
|
-
const states = new
|
|
86
|
-
const inCore = new
|
|
85
|
+
const states = InMemoryStates.new(spec);
|
|
86
|
+
const inCore = InCore.new(spec, states, PvmBackend.BuiltIn, blake2b);
|
|
87
87
|
const anchorHash = Bytes.fill(HASH_SIZE, 1).asOpaque();
|
|
88
88
|
const stateRoot = Bytes.zero(HASH_SIZE).asOpaque();
|
|
89
89
|
const authCodeHash = getAuthCodeHash();
|
|
@@ -94,8 +94,8 @@ describe("InCore", () => {
|
|
|
94
94
|
});
|
|
95
95
|
it("should refine work package and produce a report when state is set up", async () => {
|
|
96
96
|
const spec = tinyChainSpec;
|
|
97
|
-
const states = new
|
|
98
|
-
const inCore = new
|
|
97
|
+
const states = InMemoryStates.new(spec);
|
|
98
|
+
const inCore = InCore.new(spec, states, PvmBackend.BuiltIn, blake2b);
|
|
99
99
|
const authCodeHash = getAuthCodeHash();
|
|
100
100
|
const anchorHash = Bytes.fill(HASH_SIZE, 1).asOpaque();
|
|
101
101
|
const state = InMemoryState.partial(spec, {
|
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
import { type
|
|
1
|
+
import { type CoreIndex, type ServiceGas } from "#@typeberry/block";
|
|
2
2
|
import type { AuthorizerHash } from "#@typeberry/block/refine-context.js";
|
|
3
3
|
import { BytesBlob } from "#@typeberry/bytes";
|
|
4
4
|
import type { ChainSpec, PvmBackend } from "#@typeberry/config";
|
|
5
5
|
import type { Blake2b } from "#@typeberry/hash";
|
|
6
6
|
import type { State } from "#@typeberry/state";
|
|
7
|
+
import type { WorkPackageFetchData } from "#@typeberry/transition/externalities/fetch-externalities.js";
|
|
7
8
|
import { Result } from "#@typeberry/utils";
|
|
8
9
|
export declare enum AuthorizationError {
|
|
9
10
|
/** BAD: authorizer code not found (service or preimage missing). */
|
|
@@ -28,6 +29,6 @@ export declare class IsAuthorized {
|
|
|
28
29
|
private readonly pvmBackend;
|
|
29
30
|
private readonly blake2b;
|
|
30
31
|
constructor(chainSpec: ChainSpec, pvmBackend: PvmBackend, blake2b: Blake2b);
|
|
31
|
-
invoke(state: State, coreIndex: CoreIndex,
|
|
32
|
+
invoke(state: State, coreIndex: CoreIndex, packageFetchData: WorkPackageFetchData): Promise<Result<AuthorizationOk, AuthorizationError>>;
|
|
32
33
|
}
|
|
33
34
|
//# sourceMappingURL=is-authorized.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"is-authorized.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/in-core/is-authorized.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,
|
|
1
|
+
{"version":3,"file":"is-authorized.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/in-core/is-authorized.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAE,KAAK,UAAU,EAAmB,MAAM,kBAAkB,CAAC;AAEpF,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAE7C,OAAO,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAE/D,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,4DAA4D,CAAC;AACvG,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAG1C,oBAAY,kBAAkB;IAC5B,oEAAoE;IACpE,YAAY,IAAI;IAChB,8CAA8C;IAC9C,UAAU,IAAI;IACd,uCAAuC;IACvC,SAAS,IAAI;CACd;AAED,MAAM,MAAM,eAAe,GAAG;IAC5B,cAAc,EAAE,cAAc,CAAC;IAC/B,oBAAoB,EAAE,UAAU,CAAC;IACjC,mBAAmB,EAAE,SAAS,CAAC;CAChC,CAAC;AAMF;;;;GAIG;AACH,qBAAa,YAAY;IAErB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,OAAO;gBAFP,SAAS,EAAE,SAAS,EACpB,UAAU,EAAE,UAAU,EACtB,OAAO,EAAE,OAAO;IAG7B,MAAM,CACV,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,SAAS,EACpB,gBAAgB,EAAE,oBAAoB,GACrC,OAAO,CAAC,MAAM,CAAC,eAAe,EAAE,kBAAkB,CAAC,CAAC;CAiExD"}
|
|
@@ -3,8 +3,8 @@ import { G_I, W_A } from "#@typeberry/block/gp-constants.js";
|
|
|
3
3
|
import { BytesBlob } from "#@typeberry/bytes";
|
|
4
4
|
import { codec, Encoder } from "#@typeberry/codec";
|
|
5
5
|
import { PvmExecutor, ReturnStatus } from "#@typeberry/executor";
|
|
6
|
-
import { IsAuthorizedFetchExternalities } from "#@typeberry/transition/externalities/is-authorized-fetch-externalities.js";
|
|
7
6
|
import { Result } from "#@typeberry/utils";
|
|
7
|
+
import { IsAuthorizedFetchExternalities } from "./externalities/index.js";
|
|
8
8
|
export var AuthorizationError;
|
|
9
9
|
(function (AuthorizationError) {
|
|
10
10
|
/** BAD: authorizer code not found (service or preimage missing). */
|
|
@@ -31,7 +31,11 @@ export class IsAuthorized {
|
|
|
31
31
|
this.pvmBackend = pvmBackend;
|
|
32
32
|
this.blake2b = blake2b;
|
|
33
33
|
}
|
|
34
|
-
async invoke(state, coreIndex,
|
|
34
|
+
async invoke(state, coreIndex, packageFetchData) {
|
|
35
|
+
const packageView = packageFetchData.packageView;
|
|
36
|
+
const authCodeHost = packageView.authCodeHost.materialize();
|
|
37
|
+
const authCodeHash = packageView.authCodeHash.materialize();
|
|
38
|
+
const authConfiguration = packageView.authConfiguration.materialize();
|
|
35
39
|
// Look up the authorizer code from the auth code host service
|
|
36
40
|
const service = state.getService(authCodeHost);
|
|
37
41
|
// https://graypaper.fluffylabs.dev/#/ab2cdbd/2eca002eca00?v=0.7.2
|
|
@@ -48,10 +52,7 @@ export class IsAuthorized {
|
|
|
48
52
|
return Result.error(AuthorizationError.CodeTooBig, () => `Auth code is too big: ${code.length} bytes vs ${W_A} max.`);
|
|
49
53
|
}
|
|
50
54
|
// Prepare fetch externalities and executor
|
|
51
|
-
const fetchExternalities = new IsAuthorizedFetchExternalities(this.chainSpec,
|
|
52
|
-
authToken,
|
|
53
|
-
authConfiguration,
|
|
54
|
-
});
|
|
55
|
+
const fetchExternalities = new IsAuthorizedFetchExternalities(this.chainSpec, packageFetchData);
|
|
55
56
|
const executor = await PvmExecutor.createIsAuthorizedExecutor(authCodeHost, code, { fetchExternalities }, this.pvmBackend);
|
|
56
57
|
const args = Encoder.encodeObject(AUTH_ARGS_CODEC, {
|
|
57
58
|
coreIndex,
|