@typeberry/lib 0.5.10 → 0.5.11-10b197e
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/encoder.d.ts +1 -1
- package/packages/core/codec/encoder.d.ts.map +1 -1
- package/packages/core/codec/encoder.js +3 -2
- 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-interface/pvm.d.ts +2 -0
- package/packages/core/pvm-interface/pvm.d.ts.map +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/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.d.ts +9 -2
- 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 +18 -8
- package/packages/jam/in-core/externalities/refine.d.ts.map +1 -1
- package/packages/jam/in-core/externalities/refine.js +86 -7
- package/packages/jam/in-core/externalities/refine.test.js +168 -3
- 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 -186
- 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 +166 -104
- package/packages/jam/jam-host-calls/general/fetch.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/general/fetch.js +120 -23
- package/packages/jam/jam-host-calls/general/fetch.test.js +125 -92
- 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.d.ts.map +1 -1
- package/packages/jam/transition/accumulate/accumulate.js +20 -8
- 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/accumulate-fetch-externalities.d.ts +19 -0
- package/packages/jam/transition/externalities/accumulate-fetch-externalities.d.ts.map +1 -0
- package/packages/jam/transition/externalities/accumulate-fetch-externalities.js +45 -0
- package/packages/jam/transition/externalities/accumulate-fetch-externalities.test.d.ts +2 -0
- package/packages/jam/transition/externalities/accumulate-fetch-externalities.test.d.ts.map +1 -0
- package/packages/jam/transition/externalities/accumulate-fetch-externalities.test.js +192 -0
- package/packages/jam/transition/externalities/fetch-externalities.d.ts +3 -39
- package/packages/jam/transition/externalities/fetch-externalities.d.ts.map +1 -1
- package/packages/jam/transition/externalities/fetch-externalities.js +2 -88
- package/packages/jam/transition/externalities/index.d.ts +3 -0
- package/packages/jam/transition/externalities/index.d.ts.map +1 -1
- package/packages/jam/transition/externalities/index.js +3 -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 +24 -0
- package/packages/jam/transition/externalities/refine-fetch-externalities.d.ts.map +1 -0
- package/packages/jam/transition/externalities/refine-fetch-externalities.js +59 -0
- package/packages/jam/transition/externalities/refine-fetch-externalities.test.d.ts +2 -0
- package/packages/jam/transition/externalities/refine-fetch-externalities.test.d.ts.map +1 -0
- package/packages/jam/transition/externalities/refine-fetch-externalities.test.js +32 -0
- 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/fetch-externalities.test.d.ts +0 -2
- package/packages/jam/transition/externalities/fetch-externalities.test.d.ts.map +0 -1
- package/packages/jam/transition/externalities/fetch-externalities.test.js +0 -254
|
@@ -1,4 +1,6 @@
|
|
|
1
1
|
import assert from "node:assert";
|
|
2
|
+
import { readFileSync } from "node:fs";
|
|
3
|
+
import { resolve } from "node:path";
|
|
2
4
|
import { before, describe, it } from "node:test";
|
|
3
5
|
import { tryAsCoreIndex, tryAsServiceGas, tryAsServiceId, tryAsTimeSlot } from "#@typeberry/block";
|
|
4
6
|
import { RefineContext } from "#@typeberry/block/refine-context.js";
|
|
@@ -6,21 +8,46 @@ import { WorkItem } from "#@typeberry/block/work-item.js";
|
|
|
6
8
|
import { tryAsWorkItemsCount, WorkPackage } from "#@typeberry/block/work-package.js";
|
|
7
9
|
import { Bytes, BytesBlob } from "#@typeberry/bytes";
|
|
8
10
|
import { Encoder } from "#@typeberry/codec";
|
|
9
|
-
import { asKnownSize, FixedSizeArray } from "#@typeberry/collections";
|
|
11
|
+
import { asKnownSize, FixedSizeArray, HashDictionary } from "#@typeberry/collections";
|
|
10
12
|
import { PvmBackend, tinyChainSpec } from "#@typeberry/config";
|
|
11
13
|
import { InMemoryStates } from "#@typeberry/database";
|
|
12
14
|
import { Blake2b, HASH_SIZE, WithHash } from "#@typeberry/hash";
|
|
13
|
-
import { tryAsU16 } from "#@typeberry/numbers";
|
|
14
|
-
import {
|
|
15
|
+
import { tryAsU16, tryAsU32, tryAsU64 } from "#@typeberry/numbers";
|
|
16
|
+
import { InMemoryService, InMemoryState, PreimageItem, ServiceAccountInfo } from "#@typeberry/state";
|
|
15
17
|
import { InCore, RefineError } from "./in-core.js";
|
|
18
|
+
// Load the authorizer PVM fixture (checks authToken === authConfiguration).
|
|
19
|
+
const AUTHORIZER_PVM = BytesBlob.blobFrom(readFileSync(resolve(import.meta.dirname, "fixtures/authorizer.pvm")));
|
|
20
|
+
const AUTH_SERVICE_ID = tryAsServiceId(1);
|
|
16
21
|
let blake2b;
|
|
17
22
|
before(async () => {
|
|
18
23
|
blake2b = await Blake2b.createHasher();
|
|
19
24
|
});
|
|
20
|
-
function
|
|
25
|
+
function getAuthCodeHash() {
|
|
26
|
+
return blake2b.hashBytes(AUTHORIZER_PVM).asOpaque();
|
|
27
|
+
}
|
|
28
|
+
function createService(serviceId, codeHash, code) {
|
|
29
|
+
return InMemoryService.new(serviceId, {
|
|
30
|
+
info: ServiceAccountInfo.create({
|
|
31
|
+
codeHash: codeHash.asOpaque(),
|
|
32
|
+
balance: tryAsU64(10_000_000_000),
|
|
33
|
+
accumulateMinGas: tryAsServiceGas(0n),
|
|
34
|
+
onTransferMinGas: tryAsServiceGas(0n),
|
|
35
|
+
storageUtilisationBytes: tryAsU64(0),
|
|
36
|
+
storageUtilisationCount: tryAsU32(0),
|
|
37
|
+
gratisStorage: tryAsU64(0),
|
|
38
|
+
created: tryAsTimeSlot(0),
|
|
39
|
+
lastAccumulation: tryAsTimeSlot(0),
|
|
40
|
+
parentService: tryAsServiceId(0),
|
|
41
|
+
}),
|
|
42
|
+
preimages: HashDictionary.fromEntries([PreimageItem.create({ hash: codeHash.asOpaque(), blob: code })].map((x) => [x.hash, x])),
|
|
43
|
+
lookupHistory: HashDictionary.fromEntries([]),
|
|
44
|
+
storage: new Map(),
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
function createWorkItem(codeHash, serviceId = 1) {
|
|
21
48
|
return WorkItem.create({
|
|
22
49
|
service: tryAsServiceId(serviceId),
|
|
23
|
-
codeHash
|
|
50
|
+
codeHash,
|
|
24
51
|
payload: BytesBlob.empty(),
|
|
25
52
|
refineGasLimit: tryAsServiceGas(1_000_000),
|
|
26
53
|
accumulateGasLimit: tryAsServiceGas(1_000_000),
|
|
@@ -29,12 +56,12 @@ function createWorkItem(serviceId = 1) {
|
|
|
29
56
|
exportCount: tryAsU16(0),
|
|
30
57
|
});
|
|
31
58
|
}
|
|
32
|
-
function createWorkPackage(anchorHash, stateRoot, lookupAnchorSlot = 0) {
|
|
59
|
+
function createWorkPackage(anchorHash, stateRoot, authCodeHash, lookupAnchorSlot = 0) {
|
|
33
60
|
return WorkPackage.create({
|
|
34
|
-
|
|
35
|
-
authCodeHost:
|
|
36
|
-
authCodeHash
|
|
37
|
-
|
|
61
|
+
authToken: BytesBlob.empty(),
|
|
62
|
+
authCodeHost: AUTH_SERVICE_ID,
|
|
63
|
+
authCodeHash,
|
|
64
|
+
authConfiguration: BytesBlob.empty(),
|
|
38
65
|
context: RefineContext.create({
|
|
39
66
|
anchor: anchorHash,
|
|
40
67
|
stateRoot,
|
|
@@ -43,38 +70,43 @@ function createWorkPackage(anchorHash, stateRoot, lookupAnchorSlot = 0) {
|
|
|
43
70
|
lookupAnchorSlot: tryAsTimeSlot(lookupAnchorSlot),
|
|
44
71
|
prerequisites: [],
|
|
45
72
|
}),
|
|
46
|
-
items: FixedSizeArray.new([createWorkItem()], tryAsWorkItemsCount(1)),
|
|
73
|
+
items: FixedSizeArray.new([createWorkItem(authCodeHash)], tryAsWorkItemsCount(1)),
|
|
47
74
|
});
|
|
48
75
|
}
|
|
49
76
|
function hashWorkPackage(spec, workPackage) {
|
|
50
77
|
const workPackageHash = blake2b
|
|
51
78
|
.hashBytes(Encoder.encodeObject(WorkPackage.Codec, workPackage, spec))
|
|
52
79
|
.asOpaque();
|
|
53
|
-
return new
|
|
80
|
+
return WithHash.new(workPackageHash, workPackage);
|
|
54
81
|
}
|
|
55
82
|
describe("InCore", () => {
|
|
56
83
|
it("should return StateMissing error when anchor block state is not in DB", async () => {
|
|
57
84
|
const spec = tinyChainSpec;
|
|
58
|
-
const states = new
|
|
59
|
-
const inCore = new
|
|
85
|
+
const states = InMemoryStates.new(spec);
|
|
86
|
+
const inCore = InCore.new(spec, states, PvmBackend.BuiltIn, blake2b);
|
|
60
87
|
const anchorHash = Bytes.fill(HASH_SIZE, 1).asOpaque();
|
|
61
88
|
const stateRoot = Bytes.zero(HASH_SIZE).asOpaque();
|
|
62
|
-
const
|
|
89
|
+
const authCodeHash = getAuthCodeHash();
|
|
90
|
+
const workPackage = createWorkPackage(anchorHash, stateRoot, authCodeHash);
|
|
63
91
|
const result = await inCore.refine(hashWorkPackage(spec, workPackage), tryAsCoreIndex(0), asKnownSize([[]]), asKnownSize([[]]));
|
|
64
92
|
assert.strictEqual(result.isError, true);
|
|
65
93
|
assert.strictEqual(result.error, RefineError.StateMissing);
|
|
66
94
|
});
|
|
67
95
|
it("should refine work package and produce a report when state is set up", async () => {
|
|
68
96
|
const spec = tinyChainSpec;
|
|
69
|
-
const states = new
|
|
70
|
-
const inCore = new
|
|
97
|
+
const states = InMemoryStates.new(spec);
|
|
98
|
+
const inCore = InCore.new(spec, states, PvmBackend.BuiltIn, blake2b);
|
|
99
|
+
const authCodeHash = getAuthCodeHash();
|
|
71
100
|
const anchorHash = Bytes.fill(HASH_SIZE, 1).asOpaque();
|
|
72
|
-
const state =
|
|
101
|
+
const state = InMemoryState.partial(spec, {
|
|
102
|
+
timeslot: tryAsTimeSlot(16),
|
|
103
|
+
services: new Map([[AUTH_SERVICE_ID, createService(AUTH_SERVICE_ID, authCodeHash, AUTHORIZER_PVM)]]),
|
|
104
|
+
});
|
|
73
105
|
await states.insertInitialState(anchorHash, state);
|
|
74
106
|
const correctStateRoot = await states.getStateRoot(state);
|
|
75
|
-
const workPackage = createWorkPackage(anchorHash, correctStateRoot, state.timeslot);
|
|
107
|
+
const workPackage = createWorkPackage(anchorHash, correctStateRoot, authCodeHash, state.timeslot);
|
|
76
108
|
const result = await inCore.refine(hashWorkPackage(spec, workPackage), tryAsCoreIndex(0), asKnownSize([[]]), asKnownSize([[]]));
|
|
77
|
-
assert.strictEqual(result.isOk, true);
|
|
109
|
+
assert.strictEqual(result.isOk, true, `Expected OK but got error: ${result.isError ? result.details() : ""}`);
|
|
78
110
|
assert.strictEqual(result.ok.report.coreIndex, 0);
|
|
79
111
|
assert.strictEqual(result.ok.report.results.length, 1);
|
|
80
112
|
});
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { type CodeHash, type CoreIndex, type ServiceGas, type ServiceId } from "#@typeberry/block";
|
|
2
|
+
import type { AuthorizerHash } from "#@typeberry/block/refine-context.js";
|
|
3
|
+
import { BytesBlob } from "#@typeberry/bytes";
|
|
4
|
+
import type { ChainSpec, PvmBackend } from "#@typeberry/config";
|
|
5
|
+
import type { Blake2b } from "#@typeberry/hash";
|
|
6
|
+
import type { State } from "#@typeberry/state";
|
|
7
|
+
import { Result } from "#@typeberry/utils";
|
|
8
|
+
export declare enum AuthorizationError {
|
|
9
|
+
/** BAD: authorizer code not found (service or preimage missing). */
|
|
10
|
+
CodeNotFound = 0,
|
|
11
|
+
/** BIG: authorizer code exceeds W_A limit. */
|
|
12
|
+
CodeTooBig = 1,
|
|
13
|
+
/** PANIC/OOG: PVM execution failed. */
|
|
14
|
+
PvmFailed = 2
|
|
15
|
+
}
|
|
16
|
+
export type AuthorizationOk = {
|
|
17
|
+
authorizerHash: AuthorizerHash;
|
|
18
|
+
authorizationGasUsed: ServiceGas;
|
|
19
|
+
authorizationOutput: BytesBlob;
|
|
20
|
+
};
|
|
21
|
+
/**
|
|
22
|
+
* IsAuthorized PVM invocation (Psi_I).
|
|
23
|
+
*
|
|
24
|
+
* https://graypaper.fluffylabs.dev/#/ab2cdbd/2e64002e6400?v=0.7.2
|
|
25
|
+
*/
|
|
26
|
+
export declare class IsAuthorized {
|
|
27
|
+
private readonly chainSpec;
|
|
28
|
+
private readonly pvmBackend;
|
|
29
|
+
private readonly blake2b;
|
|
30
|
+
constructor(chainSpec: ChainSpec, pvmBackend: PvmBackend, blake2b: Blake2b);
|
|
31
|
+
invoke(state: State, coreIndex: CoreIndex, authToken: BytesBlob, authCodeHost: ServiceId, authCodeHash: CodeHash, authConfiguration: BytesBlob): Promise<Result<AuthorizationOk, AuthorizationError>>;
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=is-authorized.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"is-authorized.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/in-core/is-authorized.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,QAAQ,EAAE,KAAK,SAAS,EAAE,KAAK,UAAU,EAAE,KAAK,SAAS,EAAmB,MAAM,kBAAkB,CAAC;AAEnH,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;AAE9C,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAE1C,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,SAAS,EAAE,SAAS,EACpB,YAAY,EAAE,SAAS,EACvB,YAAY,EAAE,QAAQ,EACtB,iBAAiB,EAAE,SAAS,GAC3B,OAAO,CAAC,MAAM,CAAC,eAAe,EAAE,kBAAkB,CAAC,CAAC;CA+DxD"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { tryAsServiceGas } from "#@typeberry/block";
|
|
2
|
+
import { G_I, W_A } from "#@typeberry/block/gp-constants.js";
|
|
3
|
+
import { BytesBlob } from "#@typeberry/bytes";
|
|
4
|
+
import { codec, Encoder } from "#@typeberry/codec";
|
|
5
|
+
import { PvmExecutor, ReturnStatus } from "#@typeberry/executor";
|
|
6
|
+
import { IsAuthorizedFetchExternalities } from "#@typeberry/transition/externalities/is-authorized-fetch-externalities.js";
|
|
7
|
+
import { Result } from "#@typeberry/utils";
|
|
8
|
+
export var AuthorizationError;
|
|
9
|
+
(function (AuthorizationError) {
|
|
10
|
+
/** BAD: authorizer code not found (service or preimage missing). */
|
|
11
|
+
AuthorizationError[AuthorizationError["CodeNotFound"] = 0] = "CodeNotFound";
|
|
12
|
+
/** BIG: authorizer code exceeds W_A limit. */
|
|
13
|
+
AuthorizationError[AuthorizationError["CodeTooBig"] = 1] = "CodeTooBig";
|
|
14
|
+
/** PANIC/OOG: PVM execution failed. */
|
|
15
|
+
AuthorizationError[AuthorizationError["PvmFailed"] = 2] = "PvmFailed";
|
|
16
|
+
})(AuthorizationError || (AuthorizationError = {}));
|
|
17
|
+
const AUTH_ARGS_CODEC = codec.object({
|
|
18
|
+
coreIndex: codec.u16,
|
|
19
|
+
});
|
|
20
|
+
/**
|
|
21
|
+
* IsAuthorized PVM invocation (Psi_I).
|
|
22
|
+
*
|
|
23
|
+
* https://graypaper.fluffylabs.dev/#/ab2cdbd/2e64002e6400?v=0.7.2
|
|
24
|
+
*/
|
|
25
|
+
export class IsAuthorized {
|
|
26
|
+
chainSpec;
|
|
27
|
+
pvmBackend;
|
|
28
|
+
blake2b;
|
|
29
|
+
constructor(chainSpec, pvmBackend, blake2b) {
|
|
30
|
+
this.chainSpec = chainSpec;
|
|
31
|
+
this.pvmBackend = pvmBackend;
|
|
32
|
+
this.blake2b = blake2b;
|
|
33
|
+
}
|
|
34
|
+
async invoke(state, coreIndex, authToken, authCodeHost, authCodeHash, authConfiguration) {
|
|
35
|
+
// Look up the authorizer code from the auth code host service
|
|
36
|
+
const service = state.getService(authCodeHost);
|
|
37
|
+
// https://graypaper.fluffylabs.dev/#/ab2cdbd/2eca002eca00?v=0.7.2
|
|
38
|
+
if (service === null) {
|
|
39
|
+
return Result.error(AuthorizationError.CodeNotFound, () => `Auth code host service ${authCodeHost} not found in state.`);
|
|
40
|
+
}
|
|
41
|
+
const code = service.getPreimage(authCodeHash.asOpaque());
|
|
42
|
+
if (code === null) {
|
|
43
|
+
return Result.error(AuthorizationError.CodeNotFound, () => `Auth code preimage ${authCodeHash} not found in service ${authCodeHost}.`);
|
|
44
|
+
}
|
|
45
|
+
// BIG: code exceeds W_A
|
|
46
|
+
// https://graypaper.fluffylabs.dev/#/ab2cdbd/2ed6002ed600?v=0.7.2
|
|
47
|
+
if (code.length > W_A) {
|
|
48
|
+
return Result.error(AuthorizationError.CodeTooBig, () => `Auth code is too big: ${code.length} bytes vs ${W_A} max.`);
|
|
49
|
+
}
|
|
50
|
+
// Prepare fetch externalities and executor
|
|
51
|
+
const fetchExternalities = new IsAuthorizedFetchExternalities(this.chainSpec, {
|
|
52
|
+
authToken,
|
|
53
|
+
authConfiguration,
|
|
54
|
+
});
|
|
55
|
+
const executor = await PvmExecutor.createIsAuthorizedExecutor(authCodeHost, code, { fetchExternalities }, this.pvmBackend);
|
|
56
|
+
const args = Encoder.encodeObject(AUTH_ARGS_CODEC, {
|
|
57
|
+
coreIndex,
|
|
58
|
+
});
|
|
59
|
+
// Run PVM with gas budget G_I
|
|
60
|
+
const gasLimit = tryAsServiceGas(G_I);
|
|
61
|
+
const execResult = await executor.run(args, gasLimit);
|
|
62
|
+
if (execResult.status !== ReturnStatus.OK) {
|
|
63
|
+
return Result.error(AuthorizationError.PvmFailed, () => `IsAuthorized PVM ${ReturnStatus[execResult.status]} (gas used: ${execResult.consumedGas}).`);
|
|
64
|
+
}
|
|
65
|
+
// Compute authorizer hash: H(code_hash ++ configuration)
|
|
66
|
+
// https://graypaper.fluffylabs.dev/#/ab2cdbd/1b81011b8401?v=0.7.2
|
|
67
|
+
const authorizerHash = this.blake2b.hashBlobs([authCodeHash, authConfiguration]);
|
|
68
|
+
const authorizationOutput = BytesBlob.blobFrom(execResult.memorySlice);
|
|
69
|
+
const authorizationGasUsed = tryAsServiceGas(execResult.consumedGas);
|
|
70
|
+
return Result.ok({ authorizerHash, authorizationGasUsed, authorizationOutput });
|
|
71
|
+
}
|
|
72
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"is-authorized.test.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/in-core/is-authorized.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
import assert from "node:assert";
|
|
2
|
+
import { readFileSync } from "node:fs";
|
|
3
|
+
import { resolve } from "node:path";
|
|
4
|
+
import { before, describe, it } from "node:test";
|
|
5
|
+
import { tryAsCoreIndex, tryAsServiceGas, tryAsServiceId, tryAsTimeSlot } from "#@typeberry/block";
|
|
6
|
+
import { Bytes, BytesBlob } from "#@typeberry/bytes";
|
|
7
|
+
import { HashDictionary } from "#@typeberry/collections";
|
|
8
|
+
import { PvmBackend, tinyChainSpec } from "#@typeberry/config";
|
|
9
|
+
import { Blake2b, HASH_SIZE } from "#@typeberry/hash";
|
|
10
|
+
import { tryAsU32, tryAsU64 } from "#@typeberry/numbers";
|
|
11
|
+
import { InMemoryService, InMemoryState, PreimageItem, ServiceAccountInfo } from "#@typeberry/state";
|
|
12
|
+
import { AuthorizationError, IsAuthorized } from "./is-authorized.js";
|
|
13
|
+
let blake2b;
|
|
14
|
+
before(async () => {
|
|
15
|
+
blake2b = await Blake2b.createHasher();
|
|
16
|
+
});
|
|
17
|
+
// Load the authorizer PVM fixture.
|
|
18
|
+
// This authorizer checks that authToken === authConfiguration and returns "Auth=<token>".
|
|
19
|
+
// https://github.com/tomusdrw/as-lan/blob/main/examples/authorizer/assembly/authorize.ts
|
|
20
|
+
const AUTHORIZER_PVM = BytesBlob.blobFrom(readFileSync(resolve(import.meta.dirname, "fixtures/authorizer.pvm")));
|
|
21
|
+
const AUTH_SERVICE_ID = tryAsServiceId(42);
|
|
22
|
+
function createService(serviceId, codeHash, code) {
|
|
23
|
+
return InMemoryService.new(serviceId, {
|
|
24
|
+
info: ServiceAccountInfo.create({
|
|
25
|
+
codeHash: codeHash.asOpaque(),
|
|
26
|
+
balance: tryAsU64(10_000_000_000),
|
|
27
|
+
accumulateMinGas: tryAsServiceGas(0n),
|
|
28
|
+
onTransferMinGas: tryAsServiceGas(0n),
|
|
29
|
+
storageUtilisationBytes: tryAsU64(0),
|
|
30
|
+
storageUtilisationCount: tryAsU32(0),
|
|
31
|
+
gratisStorage: tryAsU64(0),
|
|
32
|
+
created: tryAsTimeSlot(0),
|
|
33
|
+
lastAccumulation: tryAsTimeSlot(0),
|
|
34
|
+
parentService: tryAsServiceId(0),
|
|
35
|
+
}),
|
|
36
|
+
preimages: HashDictionary.fromEntries([PreimageItem.create({ hash: codeHash.asOpaque(), blob: code })].map((x) => [x.hash, x])),
|
|
37
|
+
lookupHistory: HashDictionary.fromEntries([]),
|
|
38
|
+
storage: new Map(),
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
describe("IsAuthorized", () => {
|
|
42
|
+
const spec = tinyChainSpec;
|
|
43
|
+
function getAuthCodeHash() {
|
|
44
|
+
return blake2b.hashBytes(AUTHORIZER_PVM).asOpaque();
|
|
45
|
+
}
|
|
46
|
+
function createStateWithService(codeHash, code) {
|
|
47
|
+
return InMemoryState.partial(spec, {
|
|
48
|
+
timeslot: tryAsTimeSlot(16),
|
|
49
|
+
services: new Map([[AUTH_SERVICE_ID, createService(AUTH_SERVICE_ID, codeHash, code)]]),
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
it("should authorize when token matches configuration", async () => {
|
|
53
|
+
const authCodeHash = getAuthCodeHash();
|
|
54
|
+
const state = createStateWithService(authCodeHash, AUTHORIZER_PVM);
|
|
55
|
+
const isAuthorized = new IsAuthorized(spec, PvmBackend.BuiltIn, blake2b);
|
|
56
|
+
const token = BytesBlob.blobFromString("hello");
|
|
57
|
+
const result = await isAuthorized.invoke(state, tryAsCoreIndex(0), token, AUTH_SERVICE_ID, authCodeHash, token);
|
|
58
|
+
assert.strictEqual(result.isOk, true, `Expected OK but got error: ${result.isError ? result.details() : ""}`);
|
|
59
|
+
// Verify the authorization output starts with "Auth=<hello>"
|
|
60
|
+
const outputStr = Buffer.from(result.ok.authorizationOutput.raw).toString("utf8");
|
|
61
|
+
assert.ok(outputStr.startsWith("Auth=<hello>"), `Expected "Auth=<hello>" prefix but got "${outputStr.slice(0, 30)}"`);
|
|
62
|
+
// Verify the authorizer hash is H(code_hash ++ configuration)
|
|
63
|
+
const expectedHash = blake2b.hashBlobs([authCodeHash, token]);
|
|
64
|
+
assert.ok(result.ok.authorizerHash.isEqualTo(expectedHash), "authorizerHash should be H(code_hash || config)");
|
|
65
|
+
// Verify gas was consumed
|
|
66
|
+
assert.ok(Number(result.ok.authorizationGasUsed) > 0, "should have consumed some gas");
|
|
67
|
+
});
|
|
68
|
+
it("should authorize with empty token and configuration", async () => {
|
|
69
|
+
const authCodeHash = getAuthCodeHash();
|
|
70
|
+
const state = createStateWithService(authCodeHash, AUTHORIZER_PVM);
|
|
71
|
+
const isAuthorized = new IsAuthorized(spec, PvmBackend.BuiltIn, blake2b);
|
|
72
|
+
const result = await isAuthorized.invoke(state, tryAsCoreIndex(0), BytesBlob.empty(), AUTH_SERVICE_ID, authCodeHash, BytesBlob.empty());
|
|
73
|
+
assert.strictEqual(result.isOk, true, `Expected OK but got error: ${result.isError ? result.details() : ""}`);
|
|
74
|
+
const outputStr = Buffer.from(result.ok.authorizationOutput.raw).toString("utf8");
|
|
75
|
+
assert.ok(outputStr.startsWith("Auth=<>"), `Expected "Auth=<>" prefix but got "${outputStr.slice(0, 30)}"`);
|
|
76
|
+
});
|
|
77
|
+
it("should fail when token does not match configuration", async () => {
|
|
78
|
+
const authCodeHash = getAuthCodeHash();
|
|
79
|
+
const state = createStateWithService(authCodeHash, AUTHORIZER_PVM);
|
|
80
|
+
const isAuthorized = new IsAuthorized(spec, PvmBackend.BuiltIn, blake2b);
|
|
81
|
+
const result = await isAuthorized.invoke(state, tryAsCoreIndex(0), BytesBlob.blobFromString("wrong"), AUTH_SERVICE_ID, authCodeHash, BytesBlob.blobFromString("right"));
|
|
82
|
+
assert.strictEqual(result.isError, true);
|
|
83
|
+
assert.strictEqual(result.error, AuthorizationError.PvmFailed);
|
|
84
|
+
});
|
|
85
|
+
it("should fail when auth code host service is missing", async () => {
|
|
86
|
+
const authCodeHash = getAuthCodeHash();
|
|
87
|
+
const state = InMemoryState.partial(spec, {
|
|
88
|
+
timeslot: tryAsTimeSlot(16),
|
|
89
|
+
services: new Map(),
|
|
90
|
+
});
|
|
91
|
+
const isAuthorized = new IsAuthorized(spec, PvmBackend.BuiltIn, blake2b);
|
|
92
|
+
const result = await isAuthorized.invoke(state, tryAsCoreIndex(0), BytesBlob.empty(), AUTH_SERVICE_ID, authCodeHash, BytesBlob.empty());
|
|
93
|
+
assert.strictEqual(result.isError, true);
|
|
94
|
+
assert.strictEqual(result.error, AuthorizationError.CodeNotFound);
|
|
95
|
+
});
|
|
96
|
+
it("should fail when auth code preimage is missing", async () => {
|
|
97
|
+
const authCodeHash = getAuthCodeHash();
|
|
98
|
+
// Service exists but with no preimages
|
|
99
|
+
const emptyService = InMemoryService.new(AUTH_SERVICE_ID, {
|
|
100
|
+
info: ServiceAccountInfo.create({
|
|
101
|
+
codeHash: Bytes.zero(HASH_SIZE).asOpaque(),
|
|
102
|
+
balance: tryAsU64(0),
|
|
103
|
+
accumulateMinGas: tryAsServiceGas(0n),
|
|
104
|
+
onTransferMinGas: tryAsServiceGas(0n),
|
|
105
|
+
storageUtilisationBytes: tryAsU64(0),
|
|
106
|
+
storageUtilisationCount: tryAsU32(0),
|
|
107
|
+
gratisStorage: tryAsU64(0),
|
|
108
|
+
created: tryAsTimeSlot(0),
|
|
109
|
+
lastAccumulation: tryAsTimeSlot(0),
|
|
110
|
+
parentService: tryAsServiceId(0),
|
|
111
|
+
}),
|
|
112
|
+
preimages: HashDictionary.fromEntries([]),
|
|
113
|
+
lookupHistory: HashDictionary.fromEntries([]),
|
|
114
|
+
storage: new Map(),
|
|
115
|
+
});
|
|
116
|
+
const state = InMemoryState.partial(spec, {
|
|
117
|
+
timeslot: tryAsTimeSlot(16),
|
|
118
|
+
services: new Map([[AUTH_SERVICE_ID, emptyService]]),
|
|
119
|
+
});
|
|
120
|
+
const isAuthorized = new IsAuthorized(spec, PvmBackend.BuiltIn, blake2b);
|
|
121
|
+
const result = await isAuthorized.invoke(state, tryAsCoreIndex(0), BytesBlob.empty(), AUTH_SERVICE_ID, authCodeHash, BytesBlob.empty());
|
|
122
|
+
assert.strictEqual(result.isError, true);
|
|
123
|
+
assert.strictEqual(result.error, AuthorizationError.CodeNotFound);
|
|
124
|
+
});
|
|
125
|
+
});
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { type CoreIndex, type Segment, type SegmentIndex, type ServiceGas } from "#@typeberry/block";
|
|
2
|
+
import type { WorkPackageHash } from "#@typeberry/block/refine-context.js";
|
|
3
|
+
import type { WorkItem, WorkItemExtrinsic } from "#@typeberry/block/work-item.js";
|
|
4
|
+
import { WorkExecResult, WorkResult } from "#@typeberry/block/work-result.js";
|
|
5
|
+
import type { KnownSizeArray } from "#@typeberry/collections";
|
|
6
|
+
import type { ChainSpec, PvmBackend } from "#@typeberry/config";
|
|
7
|
+
import { type ReturnValue } from "#@typeberry/executor";
|
|
8
|
+
import { type Blake2b } from "#@typeberry/hash";
|
|
9
|
+
import type { State } from "#@typeberry/state";
|
|
10
|
+
export type RefineItemResult = {
|
|
11
|
+
result: WorkResult;
|
|
12
|
+
exports: readonly Segment[];
|
|
13
|
+
};
|
|
14
|
+
export type PerWorkItem<T> = KnownSizeArray<T, "for each work item">;
|
|
15
|
+
export type ImportedSegment = {
|
|
16
|
+
index: SegmentIndex;
|
|
17
|
+
data: Segment;
|
|
18
|
+
};
|
|
19
|
+
/**
|
|
20
|
+
* Refine PVM invocation (Psi_R).
|
|
21
|
+
*
|
|
22
|
+
* Executes a single work item's refinement logic.
|
|
23
|
+
*/
|
|
24
|
+
export declare class Refine {
|
|
25
|
+
private readonly chainSpec;
|
|
26
|
+
private readonly pvmBackend;
|
|
27
|
+
private readonly blake2b;
|
|
28
|
+
constructor(chainSpec: ChainSpec, pvmBackend: PvmBackend, blake2b: Blake2b);
|
|
29
|
+
invoke(state: State, lookupState: State, idx: number, item: WorkItem, allImports: PerWorkItem<ImportedSegment[]>, allExtrinsics: PerWorkItem<WorkItemExtrinsic[]>, coreIndex: CoreIndex, workPackageHash: WorkPackageHash, exportOffset: number): Promise<RefineItemResult>;
|
|
30
|
+
static extractWorkResult(execResult: ReturnValue<ServiceGas>): WorkExecResult;
|
|
31
|
+
private getServiceCode;
|
|
32
|
+
private createRefineExternalities;
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=refine.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"refine.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/in-core/refine.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,SAAS,EACd,KAAK,OAAO,EACZ,KAAK,YAAY,EACjB,KAAK,UAAU,EAIhB,MAAM,kBAAkB,CAAC;AAE1B,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,oCAAoC,CAAC;AAC1E,OAAO,KAAK,EAAE,QAAQ,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AACjF,OAAO,EAAE,cAAc,EAAsC,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAGjH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAC7D,OAAO,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC/D,OAAO,EAA+D,KAAK,WAAW,EAAE,MAAM,qBAAqB,CAAC;AACpH,OAAO,EAAE,KAAK,OAAO,EAAa,MAAM,iBAAiB,CAAC;AAE1D,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAK9C,MAAM,MAAM,gBAAgB,GAAG;IAC7B,MAAM,EAAE,UAAU,CAAC;IACnB,OAAO,EAAE,SAAS,OAAO,EAAE,CAAC;CAC7B,CAAC;AAEF,MAAM,MAAM,WAAW,CAAC,CAAC,IAAI,cAAc,CAAC,CAAC,EAAE,oBAAoB,CAAC,CAAC;AAErE,MAAM,MAAM,eAAe,GAAG;IAC5B,KAAK,EAAE,YAAY,CAAC;IACpB,IAAI,EAAE,OAAO,CAAC;CACf,CAAC;AAyBF;;;;GAIG;AACH,qBAAa,MAAM;IAEf,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,WAAW,EAAE,KAAK,EAClB,GAAG,EAAE,MAAM,EACX,IAAI,EAAE,QAAQ,EACd,UAAU,EAAE,WAAW,CAAC,eAAe,EAAE,CAAC,EAC1C,aAAa,EAAE,WAAW,CAAC,iBAAiB,EAAE,CAAC,EAC/C,SAAS,EAAE,SAAS,EACpB,eAAe,EAAE,eAAe,EAChC,YAAY,EAAE,MAAM,GACnB,OAAO,CAAC,gBAAgB,CAAC;IA0F5B,MAAM,CAAC,iBAAiB,CAAC,UAAU,EAAE,WAAW,CAAC,UAAU,CAAC;IAiB5D,OAAO,CAAC,cAAc;IAyCtB,OAAO,CAAC,yBAAyB;CAsBlC"}
|
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
import { tryAsCoreIndex, tryAsServiceGas, } from "#@typeberry/block";
|
|
2
|
+
import { W_C } from "#@typeberry/block/gp-constants.js";
|
|
3
|
+
import { WorkExecResult, WorkExecResultKind, WorkRefineLoad, WorkResult } from "#@typeberry/block/work-result.js";
|
|
4
|
+
import { BytesBlob } from "#@typeberry/bytes";
|
|
5
|
+
import { codec, Encoder } from "#@typeberry/codec";
|
|
6
|
+
import { PvmExecutor, ReturnStatus } from "#@typeberry/executor";
|
|
7
|
+
import { HASH_SIZE } from "#@typeberry/hash";
|
|
8
|
+
import { tryAsU32 } from "#@typeberry/numbers";
|
|
9
|
+
import { RefineFetchExternalities } from "#@typeberry/transition/externalities/refine-fetch-externalities.js";
|
|
10
|
+
import { assertNever, Result } from "#@typeberry/utils";
|
|
11
|
+
import { RefineExternalitiesImpl } from "./externalities/refine.js";
|
|
12
|
+
var ServiceCodeError;
|
|
13
|
+
(function (ServiceCodeError) {
|
|
14
|
+
/** Service id is not found in the state. */
|
|
15
|
+
ServiceCodeError[ServiceCodeError["ServiceNotFound"] = 0] = "ServiceNotFound";
|
|
16
|
+
/** Expected service code does not match the state one. */
|
|
17
|
+
ServiceCodeError[ServiceCodeError["ServiceCodeMismatch"] = 1] = "ServiceCodeMismatch";
|
|
18
|
+
/** Code preimage missing. */
|
|
19
|
+
ServiceCodeError[ServiceCodeError["ServiceCodeMissing"] = 2] = "ServiceCodeMissing";
|
|
20
|
+
/** Code blob is too big. */
|
|
21
|
+
ServiceCodeError[ServiceCodeError["ServiceCodeTooBig"] = 3] = "ServiceCodeTooBig";
|
|
22
|
+
})(ServiceCodeError || (ServiceCodeError = {}));
|
|
23
|
+
/** https://graypaper.fluffylabs.dev/#/ab2cdbd/2ffe002ffe00?v=0.7.2 */
|
|
24
|
+
const REFINE_ARGS_CODEC = codec.object({
|
|
25
|
+
core: codec.varU32.convert((x) => tryAsU32(x), (x) => tryAsCoreIndex(x)),
|
|
26
|
+
workItemIndex: codec.varU32,
|
|
27
|
+
serviceId: codec.varU32.asOpaque(),
|
|
28
|
+
payloadLength: codec.varU32,
|
|
29
|
+
packageHash: codec.bytes(HASH_SIZE).asOpaque(),
|
|
30
|
+
});
|
|
31
|
+
/**
|
|
32
|
+
* Refine PVM invocation (Psi_R).
|
|
33
|
+
*
|
|
34
|
+
* Executes a single work item's refinement logic.
|
|
35
|
+
*/
|
|
36
|
+
export class Refine {
|
|
37
|
+
chainSpec;
|
|
38
|
+
pvmBackend;
|
|
39
|
+
blake2b;
|
|
40
|
+
constructor(chainSpec, pvmBackend, blake2b) {
|
|
41
|
+
this.chainSpec = chainSpec;
|
|
42
|
+
this.pvmBackend = pvmBackend;
|
|
43
|
+
this.blake2b = blake2b;
|
|
44
|
+
}
|
|
45
|
+
async invoke(state, lookupState, idx, item, allImports, allExtrinsics, coreIndex, workPackageHash, exportOffset) {
|
|
46
|
+
const payloadHash = this.blake2b.hashBytes(item.payload);
|
|
47
|
+
const baseResult = {
|
|
48
|
+
serviceId: item.service,
|
|
49
|
+
codeHash: item.codeHash,
|
|
50
|
+
payloadHash,
|
|
51
|
+
gas: item.refineGasLimit,
|
|
52
|
+
};
|
|
53
|
+
const imports = allImports[idx];
|
|
54
|
+
const extrinsics = allExtrinsics[idx];
|
|
55
|
+
const baseLoad = {
|
|
56
|
+
importedSegments: tryAsU32(imports.length),
|
|
57
|
+
extrinsicCount: tryAsU32(extrinsics.length),
|
|
58
|
+
extrinsicSize: tryAsU32(extrinsics.reduce((acc, x) => acc + x.length, 0)),
|
|
59
|
+
};
|
|
60
|
+
const maybeCode = this.getServiceCode(state, idx, item);
|
|
61
|
+
if (maybeCode.isError) {
|
|
62
|
+
const error = maybeCode.error === ServiceCodeError.ServiceCodeTooBig
|
|
63
|
+
? WorkExecResultKind.codeOversize
|
|
64
|
+
: WorkExecResultKind.badCode;
|
|
65
|
+
return {
|
|
66
|
+
exports: [],
|
|
67
|
+
result: WorkResult.create({
|
|
68
|
+
...baseResult,
|
|
69
|
+
result: WorkExecResult.error(error),
|
|
70
|
+
load: WorkRefineLoad.create({
|
|
71
|
+
...baseLoad,
|
|
72
|
+
gasUsed: tryAsServiceGas(item.refineGasLimit),
|
|
73
|
+
exportedSegments: tryAsU32(0),
|
|
74
|
+
}),
|
|
75
|
+
}),
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
const code = maybeCode.ok;
|
|
79
|
+
const externalities = this.createRefineExternalities({
|
|
80
|
+
payload: item.payload,
|
|
81
|
+
imports: allImports,
|
|
82
|
+
extrinsics: allExtrinsics,
|
|
83
|
+
currentServiceId: item.service,
|
|
84
|
+
lookupState,
|
|
85
|
+
exportOffset,
|
|
86
|
+
});
|
|
87
|
+
const executor = await PvmExecutor.createRefineExecutor(item.service, code, externalities, this.pvmBackend);
|
|
88
|
+
const args = Encoder.encodeObject(REFINE_ARGS_CODEC, {
|
|
89
|
+
serviceId: item.service,
|
|
90
|
+
core: coreIndex,
|
|
91
|
+
workItemIndex: tryAsU32(idx),
|
|
92
|
+
payloadLength: tryAsU32(item.payload.length),
|
|
93
|
+
packageHash: workPackageHash,
|
|
94
|
+
});
|
|
95
|
+
const execResult = await executor.run(args, item.refineGasLimit);
|
|
96
|
+
const exports = externalities.refine.getExportedSegments();
|
|
97
|
+
if (exports.length !== item.exportCount) {
|
|
98
|
+
return {
|
|
99
|
+
exports: [],
|
|
100
|
+
result: WorkResult.create({
|
|
101
|
+
...baseResult,
|
|
102
|
+
result: WorkExecResult.error(WorkExecResultKind.incorrectNumberOfExports),
|
|
103
|
+
load: WorkRefineLoad.create({
|
|
104
|
+
...baseLoad,
|
|
105
|
+
gasUsed: tryAsServiceGas(item.refineGasLimit),
|
|
106
|
+
exportedSegments: tryAsU32(0),
|
|
107
|
+
}),
|
|
108
|
+
}),
|
|
109
|
+
};
|
|
110
|
+
}
|
|
111
|
+
const result = Refine.extractWorkResult(execResult);
|
|
112
|
+
return {
|
|
113
|
+
exports,
|
|
114
|
+
result: WorkResult.create({
|
|
115
|
+
...baseResult,
|
|
116
|
+
result,
|
|
117
|
+
load: WorkRefineLoad.create({
|
|
118
|
+
...baseLoad,
|
|
119
|
+
gasUsed: tryAsServiceGas(execResult.consumedGas),
|
|
120
|
+
exportedSegments: tryAsU32(exports.length),
|
|
121
|
+
}),
|
|
122
|
+
}),
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
static extractWorkResult(execResult) {
|
|
126
|
+
if (execResult.status === ReturnStatus.OK) {
|
|
127
|
+
const slice = execResult.memorySlice;
|
|
128
|
+
// TODO [ToDr] Verify the output size and change digestTooBig?
|
|
129
|
+
return WorkExecResult.ok(BytesBlob.blobFrom(slice));
|
|
130
|
+
}
|
|
131
|
+
switch (execResult.status) {
|
|
132
|
+
case ReturnStatus.OOG:
|
|
133
|
+
return WorkExecResult.error(WorkExecResultKind.outOfGas);
|
|
134
|
+
case ReturnStatus.PANIC:
|
|
135
|
+
return WorkExecResult.error(WorkExecResultKind.panic);
|
|
136
|
+
default:
|
|
137
|
+
assertNever(execResult);
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
getServiceCode(state, idx, item) {
|
|
141
|
+
const serviceId = item.service;
|
|
142
|
+
const service = state.getService(serviceId);
|
|
143
|
+
// TODO [ToDr] GP link
|
|
144
|
+
// missing service
|
|
145
|
+
if (service === null) {
|
|
146
|
+
return Result.error(ServiceCodeError.ServiceNotFound, () => `[i:${idx}] Service ${serviceId} is missing in state.`);
|
|
147
|
+
}
|
|
148
|
+
// TODO [ToDr] GP link
|
|
149
|
+
// TODO [ToDr] shall we rather use the old codehash instead
|
|
150
|
+
if (!service.getInfo().codeHash.isEqualTo(item.codeHash)) {
|
|
151
|
+
return Result.error(ServiceCodeError.ServiceCodeMismatch, () => `[i:${idx}] Service ${serviceId} has invalid code hash. Ours: ${service.getInfo().codeHash}, expected: ${item.codeHash}`);
|
|
152
|
+
}
|
|
153
|
+
const code = service.getPreimage(item.codeHash.asOpaque());
|
|
154
|
+
if (code === null) {
|
|
155
|
+
return Result.error(ServiceCodeError.ServiceCodeMissing, () => `[i:${idx}] Code ${item.codeHash} for service ${serviceId} was not found.`);
|
|
156
|
+
}
|
|
157
|
+
if (code.length > W_C) {
|
|
158
|
+
return Result.error(ServiceCodeError.ServiceCodeTooBig, () => `[i:${idx}] Code ${item.codeHash} for service ${serviceId} is too big! ${code.length} bytes vs ${W_C} bytes max.`);
|
|
159
|
+
}
|
|
160
|
+
return Result.ok(code);
|
|
161
|
+
}
|
|
162
|
+
createRefineExternalities(args) {
|
|
163
|
+
// TODO [ToDr] Pass all required fetch data
|
|
164
|
+
const fetchExternalities = RefineFetchExternalities.new(this.chainSpec);
|
|
165
|
+
const refine = RefineExternalitiesImpl.create({
|
|
166
|
+
currentServiceId: args.currentServiceId,
|
|
167
|
+
lookupState: args.lookupState,
|
|
168
|
+
exportOffset: args.exportOffset,
|
|
169
|
+
pvmBackend: this.pvmBackend,
|
|
170
|
+
});
|
|
171
|
+
return {
|
|
172
|
+
fetchExternalities,
|
|
173
|
+
refine,
|
|
174
|
+
};
|
|
175
|
+
}
|
|
176
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"refine.test.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/in-core/refine.test.ts"],"names":[],"mappings":""}
|
|
@@ -16,7 +16,8 @@ export declare class Assign implements HostCallHandler {
|
|
|
16
16
|
index: number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"HostCallIndex[U32]">;
|
|
17
17
|
basicGasCost: number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"SmallGas[U32]">;
|
|
18
18
|
tracedRegisters: (number & import("@typeberry/utils").WithOpaque<"register index">)[];
|
|
19
|
-
|
|
19
|
+
static new(currentServiceId: ServiceId, partialState: PartialState, chainSpec: ChainSpec): Assign;
|
|
20
|
+
private constructor();
|
|
20
21
|
execute(_gas: IGasCounter, regs: HostCallRegisters, memory: HostCallMemory): Promise<undefined | PvmExecution>;
|
|
21
22
|
}
|
|
22
23
|
//# sourceMappingURL=assign.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"assign.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jam-host-calls/accumulate/assign.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAkB,MAAM,kBAAkB,CAAC;AAGlE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAEnD,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AACpG,OAAO,EAAE,YAAY,EAAsC,MAAM,2BAA2B,CAAC;AAC7F,OAAO,EAAE,KAAK,WAAW,EAAiB,MAAM,0BAA0B,CAAC;AAG3E,OAAO,EAAE,KAAK,YAAY,EAAyB,MAAM,mCAAmC,CAAC;AAO7F;;;;GAIG;AACH,qBAAa,MAAO,YAAW,eAAe;
|
|
1
|
+
{"version":3,"file":"assign.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jam-host-calls/accumulate/assign.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAkB,MAAM,kBAAkB,CAAC;AAGlE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAEnD,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AACpG,OAAO,EAAE,YAAY,EAAsC,MAAM,2BAA2B,CAAC;AAC7F,OAAO,EAAE,KAAK,WAAW,EAAiB,MAAM,0BAA0B,CAAC;AAG3E,OAAO,EAAE,KAAK,YAAY,EAAyB,MAAM,mCAAmC,CAAC;AAO7F;;;;GAIG;AACH,qBAAa,MAAO,YAAW,eAAe;aAU1B,gBAAgB,EAAE,SAAS;IAC3C,OAAO,CAAC,QAAQ,CAAC,YAAY;IAC7B,OAAO,CAAC,QAAQ,CAAC,SAAS;IAX5B,KAAK,iIAA0B;IAC/B,YAAY,4HAAqB;IACjC,eAAe,uEAAiC;IAEhD,MAAM,CAAC,GAAG,CAAC,gBAAgB,EAAE,SAAS,EAAE,YAAY,EAAE,YAAY,EAAE,SAAS,EAAE,SAAS;IAIxF,OAAO;IAMD,OAAO,CAAC,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,iBAAiB,EAAE,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,SAAS,GAAG,YAAY,CAAC;CAkDrH"}
|
|
@@ -23,6 +23,9 @@ export class Assign {
|
|
|
23
23
|
index = tryAsHostCallIndex(15);
|
|
24
24
|
basicGasCost = tryAsSmallGas(10);
|
|
25
25
|
tracedRegisters = traceRegisters(IN_OUT_REG, 8);
|
|
26
|
+
static new(currentServiceId, partialState, chainSpec) {
|
|
27
|
+
return new Assign(currentServiceId, partialState, chainSpec);
|
|
28
|
+
}
|
|
26
29
|
constructor(currentServiceId, partialState, chainSpec) {
|
|
27
30
|
this.currentServiceId = currentServiceId;
|
|
28
31
|
this.partialState = partialState;
|