@typeberry/lib 0.5.10-9567cee → 0.5.10-9ffd7ac
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/bin/lib/examples/pvm-usage.test.js +2 -2
- package/package.json +1 -1
- package/packages/core/codec/descriptor.js +1 -1
- package/packages/core/codec/descriptors.js +7 -4
- package/packages/core/codec/index.test.js +1 -1
- package/packages/core/codec/skip.d.ts +2 -1
- package/packages/core/codec/skip.d.ts.map +1 -1
- package/packages/core/codec/skip.js +3 -0
- package/packages/core/codec/view.js +2 -2
- package/packages/core/collections/multi-map.d.ts +2 -1
- package/packages/core/collections/multi-map.d.ts.map +1 -1
- package/packages/core/collections/multi-map.js +3 -0
- package/packages/core/collections/multi-map.test.js +2 -2
- package/packages/core/concurrent/parent.js +4 -1
- package/packages/core/crypto/ed25519.d.ts +2 -5
- package/packages/core/crypto/ed25519.d.ts.map +1 -1
- package/packages/core/crypto/ed25519.js +4 -1
- package/packages/core/hash/hash.d.ts +4 -2
- package/packages/core/hash/hash.d.ts.map +1 -1
- package/packages/core/hash/hash.js +6 -1
- package/packages/core/networking/quic-network.d.ts +3 -2
- package/packages/core/networking/quic-network.d.ts.map +1 -1
- package/packages/core/networking/quic-network.js +3 -0
- package/packages/core/networking/quic-peer.d.ts +2 -1
- package/packages/core/networking/quic-peer.d.ts.map +1 -1
- package/packages/core/networking/quic-peer.js +5 -2
- package/packages/core/networking/quic-stream.d.ts +2 -1
- package/packages/core/networking/quic-stream.d.ts.map +1 -1
- package/packages/core/networking/quic-stream.js +3 -0
- package/packages/core/networking/setup.js +2 -2
- package/packages/core/pvm-host-calls/bin.js +2 -2
- package/packages/core/pvm-host-calls/ecalli-trace-logger.test.js +1 -1
- package/packages/core/pvm-host-calls/host-call-memory.d.ts +2 -1
- package/packages/core/pvm-host-calls/host-call-memory.d.ts.map +1 -1
- package/packages/core/pvm-host-calls/host-call-memory.js +3 -0
- package/packages/core/pvm-host-calls/host-call-memory.test.js +1 -1
- package/packages/core/pvm-host-calls/host-call-registers.d.ts +5 -1
- package/packages/core/pvm-host-calls/host-call-registers.d.ts.map +1 -1
- package/packages/core/pvm-host-calls/host-call-registers.js +11 -1
- package/packages/core/pvm-host-calls/host-call-registers.test.js +2 -2
- package/packages/core/pvm-host-calls/host-calls-executor.d.ts +2 -1
- package/packages/core/pvm-host-calls/host-calls-executor.d.ts.map +1 -1
- package/packages/core/pvm-host-calls/host-calls-executor.js +5 -2
- package/packages/core/pvm-host-calls/host-calls.d.ts +4 -2
- package/packages/core/pvm-host-calls/host-calls.d.ts.map +1 -1
- package/packages/core/pvm-host-calls/host-calls.js +9 -4
- package/packages/core/pvm-host-calls/pvm-instance-manager.js +1 -1
- package/packages/core/pvm-interpreter/args-decoder/args-decoder.js +1 -1
- package/packages/core/pvm-interpreter/args-decoder/args-decoder.test.js +3 -3
- package/packages/core/pvm-interpreter/args-decoder/args-decoding-results.js +11 -11
- package/packages/core/pvm-interpreter/args-decoder/decoders/extended-with-immediate-decoder.d.ts +2 -1
- package/packages/core/pvm-interpreter/args-decoder/decoders/extended-with-immediate-decoder.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/args-decoder/decoders/extended-with-immediate-decoder.js +3 -0
- package/packages/core/pvm-interpreter/args-decoder/decoders/extended-with-immediate-decoder.test.js +2 -2
- package/packages/core/pvm-interpreter/args-decoder/decoders/immediate-decoder.d.ts +2 -1
- package/packages/core/pvm-interpreter/args-decoder/decoders/immediate-decoder.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/args-decoder/decoders/immediate-decoder.js +3 -0
- package/packages/core/pvm-interpreter/args-decoder/decoders/immediate-decoder.test.js +26 -26
- package/packages/core/pvm-interpreter/basic-blocks/basic-blocks.test.js +8 -8
- package/packages/core/pvm-interpreter/bin.js +1 -1
- package/packages/core/pvm-interpreter/debugger-adapter.d.ts +2 -1
- package/packages/core/pvm-interpreter/debugger-adapter.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/debugger-adapter.js +6 -3
- package/packages/core/pvm-interpreter/gas.js +4 -1
- package/packages/core/pvm-interpreter/interpreter.d.ts +2 -1
- package/packages/core/pvm-interpreter/interpreter.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/interpreter.js +19 -16
- package/packages/core/pvm-interpreter/memory/memory-builder.js +2 -2
- package/packages/core/pvm-interpreter/memory/memory-builder.test.js +7 -7
- package/packages/core/pvm-interpreter/memory/memory.d.ts +2 -1
- package/packages/core/pvm-interpreter/memory/memory.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/memory/memory.js +4 -1
- package/packages/core/pvm-interpreter/memory/memory.test.js +31 -31
- package/packages/core/pvm-interpreter/memory/pages/readable-page.d.ts +2 -1
- package/packages/core/pvm-interpreter/memory/pages/readable-page.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/memory/pages/readable-page.js +3 -0
- package/packages/core/pvm-interpreter/memory/pages/readable-page.test.js +3 -3
- package/packages/core/pvm-interpreter/memory/pages/writeable-page.d.ts +2 -1
- package/packages/core/pvm-interpreter/memory/pages/writeable-page.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/memory/pages/writeable-page.js +3 -0
- package/packages/core/pvm-interpreter/memory/pages/writeable-page.test.js +4 -4
- package/packages/core/pvm-interpreter/ops/bit-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/bit-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/bit-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/bit-ops.test.js +3 -3
- package/packages/core/pvm-interpreter/ops/bit-rotation-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/bit-rotation-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/bit-rotation-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/bit-rotation-ops.test.js +5 -5
- package/packages/core/pvm-interpreter/ops/boolean-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/boolean-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/boolean-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/boolean-ops.test.js +3 -3
- package/packages/core/pvm-interpreter/ops/branch-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/branch-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/branch-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/branch-ops.test.js +4 -4
- package/packages/core/pvm-interpreter/ops/dynamic-jump-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/dynamic-jump-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/dynamic-jump-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/dynamic-jump-ops.test.js +5 -5
- package/packages/core/pvm-interpreter/ops/host-call-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/host-call-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/host-call-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/host-call-ops.test.js +2 -2
- package/packages/core/pvm-interpreter/ops/load-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/load-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/load-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/load-ops.test.js +10 -10
- package/packages/core/pvm-interpreter/ops/math-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/math-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/math-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/math-ops.test.js +3 -3
- package/packages/core/pvm-interpreter/ops/memory-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/memory-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/memory-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/memory-ops.test.js +3 -3
- package/packages/core/pvm-interpreter/ops/move-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/move-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/move-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/move-ops.test.js +3 -3
- package/packages/core/pvm-interpreter/ops/no-args-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/no-args-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/no-args-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/no-args-ops.test.js +2 -2
- package/packages/core/pvm-interpreter/ops/shift-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/shift-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/shift-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/shift-ops.test.js +3 -3
- package/packages/core/pvm-interpreter/ops/store-ops.d.ts +2 -1
- package/packages/core/pvm-interpreter/ops/store-ops.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/ops/store-ops.js +3 -0
- package/packages/core/pvm-interpreter/ops/store-ops.test.js +7 -7
- package/packages/core/pvm-interpreter/ops-dispatchers/no-args-dispatcher.test.js +1 -1
- package/packages/core/pvm-interpreter/ops-dispatchers/one-imm-dispatcher.test.js +4 -4
- package/packages/core/pvm-interpreter/ops-dispatchers/one-offset-dispatcher.test.js +2 -2
- package/packages/core/pvm-interpreter/ops-dispatchers/one-reg-one-ext-imm-dispatcher.test.js +4 -4
- package/packages/core/pvm-interpreter/ops-dispatchers/one-reg-one-imm-dispatcher.test.js +7 -7
- package/packages/core/pvm-interpreter/ops-dispatchers/one-reg-one-imm-one-offset-dispatcher.test.js +10 -10
- package/packages/core/pvm-interpreter/ops-dispatchers/one-reg-two-imms-dispatcher.test.js +5 -5
- package/packages/core/pvm-interpreter/ops-dispatchers/three-regs-dispatcher.test.js +7 -7
- package/packages/core/pvm-interpreter/ops-dispatchers/two-imms-dispatcher.test.js +5 -5
- package/packages/core/pvm-interpreter/ops-dispatchers/two-regs-dispatcher.test.js +6 -6
- package/packages/core/pvm-interpreter/ops-dispatchers/two-regs-one-imm-dispatcher.test.js +11 -11
- package/packages/core/pvm-interpreter/ops-dispatchers/two-regs-one-offset-dispatcher.test.js +2 -2
- package/packages/core/pvm-interpreter/ops-dispatchers/two-regs-two-imms-dispatcher.test.js +14 -14
- package/packages/core/pvm-interpreter/program-decoder/jump-table.d.ts +5 -2
- package/packages/core/pvm-interpreter/program-decoder/jump-table.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/program-decoder/jump-table.js +9 -4
- package/packages/core/pvm-interpreter/program-decoder/jump-table.test.js +6 -6
- package/packages/core/pvm-interpreter/program-decoder/mask.d.ts +2 -1
- package/packages/core/pvm-interpreter/program-decoder/mask.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/program-decoder/mask.js +3 -0
- package/packages/core/pvm-interpreter/program-decoder/mask.test.js +10 -10
- package/packages/core/pvm-interpreter/program-decoder/program-decoder.d.ts +2 -1
- package/packages/core/pvm-interpreter/program-decoder/program-decoder.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/program-decoder/program-decoder.js +6 -3
- package/packages/core/pvm-interpreter/program-decoder/program-decoder.test.js +5 -5
- package/packages/core/pvm-interpreter/program.js +3 -3
- package/packages/core/pvm-interpreter/registers.d.ts +5 -2
- package/packages/core/pvm-interpreter/registers.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/registers.js +10 -6
- package/packages/core/pvm-interpreter/registers.test.js +10 -10
- package/packages/core/pvm-interpreter/spi-decoder/decode-standard-program.d.ts +6 -3
- package/packages/core/pvm-interpreter/spi-decoder/decode-standard-program.d.ts.map +1 -1
- package/packages/core/pvm-interpreter/spi-decoder/decode-standard-program.js +11 -2
- package/packages/core/pvm-interpreter-ananas/index.d.ts +6 -3
- package/packages/core/pvm-interpreter-ananas/index.d.ts.map +1 -1
- package/packages/core/pvm-interpreter-ananas/index.js +12 -3
- package/packages/core/trie/nodes.d.ts +7 -2
- package/packages/core/trie/nodes.d.ts.map +1 -1
- package/packages/core/trie/nodes.js +20 -11
- package/packages/core/trie/nodesDb.d.ts +3 -1
- package/packages/core/trie/nodesDb.d.ts.map +1 -1
- package/packages/core/trie/nodesDb.js +6 -0
- package/packages/core/trie/trie.js +2 -2
- package/packages/extensions/ipc/index.js +5 -2
- package/packages/extensions/ipc/jamnp/handler.d.ts +4 -2
- package/packages/extensions/ipc/jamnp/handler.d.ts.map +1 -1
- package/packages/extensions/ipc/jamnp/handler.js +9 -3
- package/packages/extensions/ipc/jamnp/server.js +3 -3
- package/packages/extensions/ipc/server.d.ts +2 -1
- package/packages/extensions/ipc/server.d.ts.map +1 -1
- package/packages/extensions/ipc/server.js +4 -1
- package/packages/jam/block/header.js +1 -1
- package/packages/jam/block/work-package.d.ts +7 -7
- package/packages/jam/block/work-package.d.ts.map +1 -1
- package/packages/jam/block/work-package.js +12 -12
- package/packages/jam/config/chain-spec.d.ts +2 -1
- package/packages/jam/config/chain-spec.d.ts.map +1 -1
- package/packages/jam/config/chain-spec.js +5 -2
- package/packages/jam/config/network.d.ts +2 -7
- package/packages/jam/config/network.d.ts.map +1 -1
- package/packages/jam/config/network.js +3 -0
- package/packages/jam/config-node/jip-chain-spec.js +1 -1
- package/packages/jam/database/blocks.test.js +1 -1
- package/packages/jam/database/states.d.ts +2 -1
- package/packages/jam/database/states.d.ts.map +1 -1
- package/packages/jam/database/states.js +3 -0
- package/packages/jam/database/states.test.js +1 -1
- package/packages/jam/database-lmdb/blocks.d.ts +2 -1
- package/packages/jam/database-lmdb/blocks.d.ts.map +1 -1
- package/packages/jam/database-lmdb/blocks.js +3 -0
- package/packages/jam/database-lmdb/root.d.ts +2 -1
- package/packages/jam/database-lmdb/root.d.ts.map +1 -1
- package/packages/jam/database-lmdb/root.js +3 -0
- package/packages/jam/database-lmdb/states.d.ts +2 -1
- package/packages/jam/database-lmdb/states.d.ts.map +1 -1
- package/packages/jam/database-lmdb/states.js +3 -0
- package/packages/jam/database-lmdb/states.test.js +9 -9
- package/packages/jam/executor/pvm-executor.d.ts +7 -0
- package/packages/jam/executor/pvm-executor.d.ts.map +1 -1
- package/packages/jam/executor/pvm-executor.js +36 -21
- package/packages/jam/fuzz-proto/v1/handler.d.ts +2 -1
- package/packages/jam/fuzz-proto/v1/handler.d.ts.map +1 -1
- package/packages/jam/fuzz-proto/v1/handler.js +3 -0
- package/packages/jam/fuzz-proto/v1/handler.test.js +10 -10
- package/packages/jam/in-core/externalities/refine.d.ts +5 -5
- package/packages/jam/in-core/externalities/refine.d.ts.map +1 -1
- package/packages/jam/in-core/externalities/refine.js +42 -7
- package/packages/jam/in-core/externalities/refine.test.js +119 -1
- package/packages/jam/in-core/in-core.d.ts +9 -23
- package/packages/jam/in-core/in-core.d.ts.map +1 -1
- package/packages/jam/in-core/in-core.js +19 -184
- package/packages/jam/in-core/in-core.test.js +52 -20
- package/packages/jam/in-core/is-authorized.d.ts +33 -0
- package/packages/jam/in-core/is-authorized.d.ts.map +1 -0
- package/packages/jam/in-core/is-authorized.js +72 -0
- package/packages/jam/in-core/is-authorized.test.d.ts +2 -0
- package/packages/jam/in-core/is-authorized.test.d.ts.map +1 -0
- package/packages/jam/in-core/is-authorized.test.js +125 -0
- package/packages/jam/in-core/refine.d.ts +34 -0
- package/packages/jam/in-core/refine.d.ts.map +1 -0
- package/packages/jam/in-core/refine.js +176 -0
- package/packages/jam/in-core/refine.test.d.ts +2 -0
- package/packages/jam/in-core/refine.test.d.ts.map +1 -0
- package/packages/jam/in-core/refine.test.js +6 -0
- package/packages/jam/jam-host-calls/accumulate/assign.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/assign.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/assign.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/assign.test.js +8 -9
- package/packages/jam/jam-host-calls/accumulate/bless.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/bless.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/bless.js +12 -9
- package/packages/jam/jam-host-calls/accumulate/bless.test.js +11 -12
- package/packages/jam/jam-host-calls/accumulate/checkpoint.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/checkpoint.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/checkpoint.js +4 -1
- package/packages/jam/jam-host-calls/accumulate/checkpoint.test.js +2 -3
- package/packages/jam/jam-host-calls/accumulate/designate.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/designate.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/designate.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/designate.test.js +5 -6
- package/packages/jam/jam-host-calls/accumulate/eject.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/eject.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/eject.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/eject.test.js +8 -9
- package/packages/jam/jam-host-calls/accumulate/forget.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/forget.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/forget.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/forget.test.js +5 -6
- package/packages/jam/jam-host-calls/accumulate/new.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/new.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/new.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/new.test.js +9 -10
- package/packages/jam/jam-host-calls/accumulate/provide.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/provide.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/provide.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/provide.test.js +8 -9
- package/packages/jam/jam-host-calls/accumulate/query.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/query.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/query.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/query.test.js +8 -9
- package/packages/jam/jam-host-calls/accumulate/solicit.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/solicit.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/solicit.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/solicit.test.js +7 -8
- package/packages/jam/jam-host-calls/accumulate/transfer.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/transfer.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/transfer.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/transfer.test.js +9 -10
- package/packages/jam/jam-host-calls/accumulate/upgrade.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/upgrade.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/upgrade.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/upgrade.test.js +4 -5
- package/packages/jam/jam-host-calls/accumulate/yield.d.ts +2 -1
- package/packages/jam/jam-host-calls/accumulate/yield.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/accumulate/yield.js +3 -0
- package/packages/jam/jam-host-calls/accumulate/yield.test.js +4 -5
- package/packages/jam/jam-host-calls/externalities/partial-state.d.ts +1 -1
- package/packages/jam/jam-host-calls/externalities/refine-externalities.d.ts +1 -1
- package/packages/jam/jam-host-calls/externalities/refine-externalities.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/externalities/refine-externalities.test.js +9 -9
- package/packages/jam/jam-host-calls/externalities/state-update.d.ts +2 -3
- package/packages/jam/jam-host-calls/externalities/state-update.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/externalities/state-update.js +5 -2
- package/packages/jam/jam-host-calls/externalities/test-accounts.js +2 -2
- package/packages/jam/jam-host-calls/general/fetch.d.ts +42 -41
- package/packages/jam/jam-host-calls/general/fetch.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/general/fetch.js +33 -30
- package/packages/jam/jam-host-calls/general/fetch.test.js +44 -42
- package/packages/jam/jam-host-calls/general/gas.d.ts +2 -1
- package/packages/jam/jam-host-calls/general/gas.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/general/gas.js +3 -0
- package/packages/jam/jam-host-calls/general/gas.test.js +4 -5
- package/packages/jam/jam-host-calls/general/info.d.ts +2 -1
- package/packages/jam/jam-host-calls/general/info.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/general/info.js +3 -0
- package/packages/jam/jam-host-calls/general/info.test.js +6 -7
- package/packages/jam/jam-host-calls/general/log.d.ts +2 -1
- package/packages/jam/jam-host-calls/general/log.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/general/log.js +3 -0
- package/packages/jam/jam-host-calls/general/lookup.d.ts +2 -1
- package/packages/jam/jam-host-calls/general/lookup.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/general/lookup.js +3 -0
- package/packages/jam/jam-host-calls/general/lookup.test.js +8 -9
- package/packages/jam/jam-host-calls/general/read.d.ts +2 -1
- package/packages/jam/jam-host-calls/general/read.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/general/read.js +3 -0
- package/packages/jam/jam-host-calls/general/read.test.js +11 -12
- package/packages/jam/jam-host-calls/general/write.d.ts +2 -1
- package/packages/jam/jam-host-calls/general/write.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/general/write.js +3 -0
- package/packages/jam/jam-host-calls/general/write.test.js +10 -11
- package/packages/jam/jam-host-calls/refine/export.d.ts +2 -1
- package/packages/jam/jam-host-calls/refine/export.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/refine/export.js +3 -0
- package/packages/jam/jam-host-calls/refine/export.test.js +6 -7
- package/packages/jam/jam-host-calls/refine/expunge.d.ts +2 -1
- package/packages/jam/jam-host-calls/refine/expunge.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/refine/expunge.js +3 -0
- package/packages/jam/jam-host-calls/refine/expunge.test.js +3 -4
- package/packages/jam/jam-host-calls/refine/historical-lookup.d.ts +2 -1
- package/packages/jam/jam-host-calls/refine/historical-lookup.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/refine/historical-lookup.js +3 -0
- package/packages/jam/jam-host-calls/refine/historical-lookup.test.js +11 -12
- package/packages/jam/jam-host-calls/refine/invoke.d.ts +2 -1
- package/packages/jam/jam-host-calls/refine/invoke.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/refine/invoke.js +4 -1
- package/packages/jam/jam-host-calls/refine/invoke.test.js +10 -11
- package/packages/jam/jam-host-calls/refine/machine.d.ts +2 -1
- package/packages/jam/jam-host-calls/refine/machine.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/refine/machine.js +3 -0
- package/packages/jam/jam-host-calls/refine/machine.test.js +6 -7
- package/packages/jam/jam-host-calls/refine/pages.d.ts +2 -1
- package/packages/jam/jam-host-calls/refine/pages.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/refine/pages.js +3 -0
- package/packages/jam/jam-host-calls/refine/pages.test.js +3 -4
- package/packages/jam/jam-host-calls/refine/peek.d.ts +2 -1
- package/packages/jam/jam-host-calls/refine/peek.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/refine/peek.js +3 -0
- package/packages/jam/jam-host-calls/refine/peek.test.js +3 -4
- package/packages/jam/jam-host-calls/refine/poke.d.ts +2 -1
- package/packages/jam/jam-host-calls/refine/poke.d.ts.map +1 -1
- package/packages/jam/jam-host-calls/refine/poke.js +3 -0
- package/packages/jam/jam-host-calls/refine/poke.test.js +3 -4
- package/packages/jam/jamnp-s/network.js +1 -1
- package/packages/jam/jamnp-s/peers.d.ts +2 -1
- package/packages/jam/jamnp-s/peers.d.ts.map +1 -1
- package/packages/jam/jamnp-s/peers.js +3 -0
- package/packages/jam/jamnp-s/protocol/ce-128-block-request.d.ts +4 -2
- package/packages/jam/jamnp-s/protocol/ce-128-block-request.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/ce-128-block-request.js +6 -0
- package/packages/jam/jamnp-s/protocol/ce-128-block-request.test.js +2 -2
- package/packages/jam/jamnp-s/protocol/ce-129-state-request.d.ts +4 -2
- package/packages/jam/jamnp-s/protocol/ce-129-state-request.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/ce-129-state-request.js +6 -0
- package/packages/jam/jamnp-s/protocol/ce-129-state-request.test.js +4 -4
- package/packages/jam/jamnp-s/protocol/ce-131-ce-132-safrole-ticket-distribution.d.ts +4 -2
- package/packages/jam/jamnp-s/protocol/ce-131-ce-132-safrole-ticket-distribution.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/ce-131-ce-132-safrole-ticket-distribution.js +6 -0
- package/packages/jam/jamnp-s/protocol/ce-131-ce-132-safrole-ticket-distribution.test.js +2 -2
- package/packages/jam/jamnp-s/protocol/ce-133-work-package-submission.d.ts +6 -3
- package/packages/jam/jamnp-s/protocol/ce-133-work-package-submission.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/ce-133-work-package-submission.js +7 -0
- package/packages/jam/jamnp-s/protocol/ce-133-work-package-submission.test.js +2 -2
- package/packages/jam/jamnp-s/protocol/ce-134-work-package-sharing.d.ts +5 -2
- package/packages/jam/jamnp-s/protocol/ce-134-work-package-sharing.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/ce-134-work-package-sharing.js +7 -0
- package/packages/jam/jamnp-s/protocol/ce-134-work-package-sharing.test.js +2 -2
- package/packages/jam/jamnp-s/protocol/ce-135-work-report-distribution.d.ts +4 -2
- package/packages/jam/jamnp-s/protocol/ce-135-work-report-distribution.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/ce-135-work-report-distribution.js +6 -0
- package/packages/jam/jamnp-s/protocol/ce-135-work-report-distribution.test.js +2 -2
- package/packages/jam/jamnp-s/protocol/up-0-block-announcement.d.ts +2 -1
- package/packages/jam/jamnp-s/protocol/up-0-block-announcement.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/up-0-block-announcement.js +3 -0
- package/packages/jam/jamnp-s/stream-manager.d.ts +2 -1
- package/packages/jam/jamnp-s/stream-manager.d.ts.map +1 -1
- package/packages/jam/jamnp-s/stream-manager.js +4 -1
- package/packages/jam/jamnp-s/tasks/sync.js +4 -4
- package/packages/jam/jamnp-s/tasks/sync.test.js +4 -4
- package/packages/jam/jamnp-s/tasks/ticket-distribution.js +2 -2
- package/packages/jam/jamnp-s/tasks/ticket-distribution.test.js +1 -1
- package/packages/jam/node/common.d.ts.map +1 -1
- package/packages/jam/node/common.js +3 -3
- package/packages/jam/rpc-client/index.d.ts +4 -2
- package/packages/jam/rpc-client/index.d.ts.map +1 -1
- package/packages/jam/rpc-client/index.js +7 -1
- package/packages/jam/state/in-memory-state-view.d.ts +2 -1
- package/packages/jam/state/in-memory-state-view.d.ts.map +1 -1
- package/packages/jam/state/in-memory-state-view.js +3 -0
- package/packages/jam/state/in-memory-state.d.ts +16 -21
- package/packages/jam/state/in-memory-state.d.ts.map +1 -1
- package/packages/jam/state/in-memory-state.js +10 -6
- package/packages/jam/state/in-memory-state.test.js +2 -2
- package/packages/jam/state/service.d.ts +2 -6
- package/packages/jam/state/service.d.ts.map +1 -1
- package/packages/jam/state/service.js +3 -0
- package/packages/jam/state/test.utils.js +3 -3
- package/packages/jam/state-json/accounts.js +5 -5
- package/packages/jam/state-merkleization/in-memory-state-codec.d.ts +3 -34
- package/packages/jam/state-merkleization/in-memory-state-codec.d.ts.map +1 -1
- package/packages/jam/state-merkleization/in-memory-state-codec.js +1 -1
- package/packages/jam/state-merkleization/serialized-state-view.d.ts +8 -3
- package/packages/jam/state-merkleization/serialized-state-view.d.ts.map +1 -1
- package/packages/jam/state-merkleization/serialized-state-view.js +6 -3
- package/packages/jam/state-merkleization/serialized-state.d.ts +2 -3
- package/packages/jam/state-merkleization/serialized-state.d.ts.map +1 -1
- package/packages/jam/state-merkleization/serialized-state.js +10 -2
- package/packages/jam/state-merkleization/serialized-state.test.js +1 -1
- package/packages/jam/transition/accumulate/accumulate.js +10 -3
- package/packages/jam/transition/accumulate/accumulate.test.js +1 -1
- package/packages/jam/transition/accumulate/accumulation-result-merge-utils.js +48 -39
- package/packages/jam/transition/block-verifier.d.ts +2 -1
- package/packages/jam/transition/block-verifier.d.ts.map +1 -1
- package/packages/jam/transition/block-verifier.js +3 -0
- package/packages/jam/transition/block-verifier.test.js +8 -8
- package/packages/jam/transition/chain-stf.d.ts +12 -4
- package/packages/jam/transition/chain-stf.d.ts.map +1 -1
- package/packages/jam/transition/chain-stf.js +7 -3
- package/packages/jam/transition/externalities/accumulate-externalities.d.ts +22 -8
- package/packages/jam/transition/externalities/accumulate-externalities.d.ts.map +1 -1
- package/packages/jam/transition/externalities/accumulate-externalities.js +49 -29
- package/packages/jam/transition/externalities/accumulate-externalities.test.js +661 -101
- package/packages/jam/transition/externalities/index.d.ts +1 -0
- package/packages/jam/transition/externalities/index.d.ts.map +1 -1
- package/packages/jam/transition/externalities/index.js +1 -0
- package/packages/jam/transition/externalities/is-authorized-fetch-externalities.d.ts +22 -0
- package/packages/jam/transition/externalities/is-authorized-fetch-externalities.d.ts.map +1 -0
- package/packages/jam/transition/externalities/is-authorized-fetch-externalities.js +41 -0
- package/packages/jam/transition/externalities/refine-fetch-externalities.d.ts +9 -8
- package/packages/jam/transition/externalities/refine-fetch-externalities.d.ts.map +1 -1
- package/packages/jam/transition/externalities/refine-fetch-externalities.js +20 -9
- package/packages/jam/transition/externalities/refine-fetch-externalities.test.js +1 -1
- package/packages/jam/transition/hasher.d.ts +2 -1
- package/packages/jam/transition/hasher.d.ts.map +1 -1
- package/packages/jam/transition/hasher.js +5 -2
- package/packages/jam/transition/hasher.test.js +1 -1
- package/packages/jam/transition/preimages.test.js +4 -4
- package/packages/jam/transition/reports/test.utils.js +1 -1
- package/packages/workers/api-node/config.js +4 -4
- package/packages/workers/api-node/port.d.ts +2 -1
- package/packages/workers/api-node/port.d.ts.map +1 -1
- package/packages/workers/api-node/port.js +4 -1
- package/packages/workers/api-node/port.test.js +2 -2
- package/packages/workers/api-node/protocol.js +2 -2
- package/packages/workers/block-authorship/generator.d.ts +13 -2
- package/packages/workers/block-authorship/generator.d.ts.map +1 -1
- package/packages/workers/block-authorship/generator.js +13 -9
- package/packages/workers/block-authorship/generator.test.js +16 -2
- package/packages/workers/block-authorship/main.d.ts.map +1 -1
- package/packages/workers/block-authorship/main.js +8 -1
- package/packages/workers/importer/finality.test.js +1 -1
- package/packages/workers/importer/importer.d.ts +23 -6
- package/packages/workers/importer/importer.d.ts.map +1 -1
- package/packages/workers/importer/importer.js +34 -19
- package/packages/workers/importer/main.d.ts.map +1 -1
- package/packages/workers/importer/main.js +13 -5
|
@@ -12,7 +12,8 @@ export declare class Machine implements HostCallHandler {
|
|
|
12
12
|
basicGasCost: number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"SmallGas[U32]">;
|
|
13
13
|
currentServiceId: number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"ServiceId[u32]">;
|
|
14
14
|
tracedRegisters: (number & import("@typeberry/utils").WithOpaque<"register index">)[];
|
|
15
|
-
|
|
15
|
+
static new(refine: RefineExternalities): Machine;
|
|
16
|
+
private constructor();
|
|
16
17
|
execute(_gas: IGasCounter, regs: HostCallRegisters, memory: HostCallMemory): Promise<PvmExecution | undefined>;
|
|
17
18
|
}
|
|
18
19
|
//# sourceMappingURL=machine.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"machine.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jam-host-calls/refine/machine.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,eAAe,EACpB,KAAK,cAAc,EACnB,KAAK,iBAAiB,EACtB,YAAY,EAGb,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,KAAK,WAAW,EAAiB,MAAM,0BAA0B,CAAC;AAE3E,OAAO,EAAE,KAAK,mBAAmB,EAAuB,MAAM,0CAA0C,CAAC;AAOzG;;;;GAIG;AACH,qBAAa,OAAQ,YAAW,eAAe;
|
|
1
|
+
{"version":3,"file":"machine.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jam-host-calls/refine/machine.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,eAAe,EACpB,KAAK,cAAc,EACnB,KAAK,iBAAiB,EACtB,YAAY,EAGb,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,KAAK,WAAW,EAAiB,MAAM,0BAA0B,CAAC;AAE3E,OAAO,EAAE,KAAK,mBAAmB,EAAuB,MAAM,0CAA0C,CAAC;AAOzG;;;;GAIG;AACH,qBAAa,OAAQ,YAAW,eAAe;IAUzB,OAAO,CAAC,QAAQ,CAAC,MAAM;IAT3C,KAAK,iIAAyB;IAC9B,YAAY,4HAAqB;IACjC,gBAAgB,6HAAsB;IACtC,eAAe,uEAAoC;IAEnD,MAAM,CAAC,GAAG,CAAC,MAAM,EAAE,mBAAmB;IAItC,OAAO;IAED,OAAO,CAAC,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,iBAAiB,EAAE,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,YAAY,GAAG,SAAS,CAAC;CA2BrH"}
|
|
@@ -18,6 +18,9 @@ export class Machine {
|
|
|
18
18
|
basicGasCost = tryAsSmallGas(10);
|
|
19
19
|
currentServiceId = CURRENT_SERVICE_ID;
|
|
20
20
|
tracedRegisters = traceRegisters(IN_OUT_REG, 8, 9);
|
|
21
|
+
static new(refine) {
|
|
22
|
+
return new Machine(refine);
|
|
23
|
+
}
|
|
21
24
|
constructor(refine) {
|
|
22
25
|
this.refine = refine;
|
|
23
26
|
}
|
|
@@ -11,7 +11,6 @@ import { PAGE_SIZE } from "#@typeberry/pvm-interpreter/spi-decoder/memory-conts.
|
|
|
11
11
|
import { tryAsMachineId, tryAsProgramCounter } from "../externalities/refine-externalities.js";
|
|
12
12
|
import { TestRefineExt } from "../externalities/refine-externalities.test.js";
|
|
13
13
|
import { HostCallResult } from "../general/results.js";
|
|
14
|
-
import { emptyRegistersBuffer } from "../utils.js";
|
|
15
14
|
import { Machine } from "./machine.js";
|
|
16
15
|
const gas = gasCounter(tryAsGas(0));
|
|
17
16
|
const CODE_START_REG = 7;
|
|
@@ -20,7 +19,7 @@ const CODE_LEN_REG = 8;
|
|
|
20
19
|
const PC_REG = 9;
|
|
21
20
|
function prepareRegsAndMemory(code, pc, { skipCode = false } = {}) {
|
|
22
21
|
const memStart = 2 ** 20;
|
|
23
|
-
const registers =
|
|
22
|
+
const registers = HostCallRegisters.empty();
|
|
24
23
|
registers.set(CODE_START_REG, tryAsU64(memStart));
|
|
25
24
|
registers.set(CODE_LEN_REG, tryAsU64(code.length));
|
|
26
25
|
registers.set(PC_REG, pc);
|
|
@@ -28,7 +27,7 @@ function prepareRegsAndMemory(code, pc, { skipCode = false } = {}) {
|
|
|
28
27
|
if (!skipCode) {
|
|
29
28
|
builder.setReadablePages(tryAsMemoryIndex(memStart), tryAsMemoryIndex(memStart + PAGE_SIZE), code.raw);
|
|
30
29
|
}
|
|
31
|
-
const memory = new
|
|
30
|
+
const memory = HostCallMemory.new(builder.finalize(tryAsMemoryIndex(0), tryAsSbrkIndex(0)));
|
|
32
31
|
return {
|
|
33
32
|
registers,
|
|
34
33
|
memory,
|
|
@@ -37,7 +36,7 @@ function prepareRegsAndMemory(code, pc, { skipCode = false } = {}) {
|
|
|
37
36
|
describe("HostCalls: Machine", () => {
|
|
38
37
|
it("should start a new nested machine with minimal code", async () => {
|
|
39
38
|
const refine = new TestRefineExt();
|
|
40
|
-
const machine = new
|
|
39
|
+
const machine = Machine.new(refine);
|
|
41
40
|
const machineId = tryAsMachineId(10_000);
|
|
42
41
|
machine.currentServiceId = tryAsServiceId(10_000);
|
|
43
42
|
const code = BytesBlob.blobFromNumbers([0, 0, 0]);
|
|
@@ -52,7 +51,7 @@ describe("HostCalls: Machine", () => {
|
|
|
52
51
|
});
|
|
53
52
|
it("should start a new nested machine with fibbonacci code", async () => {
|
|
54
53
|
const refine = new TestRefineExt();
|
|
55
|
-
const machine = new
|
|
54
|
+
const machine = Machine.new(refine);
|
|
56
55
|
const machineId = tryAsMachineId(10_000);
|
|
57
56
|
machine.currentServiceId = tryAsServiceId(10_000);
|
|
58
57
|
const code = BytesBlob.blobFromNumbers([
|
|
@@ -70,7 +69,7 @@ describe("HostCalls: Machine", () => {
|
|
|
70
69
|
});
|
|
71
70
|
it("should panic when code is unavailable", async () => {
|
|
72
71
|
const refine = new TestRefineExt();
|
|
73
|
-
const machine = new
|
|
72
|
+
const machine = Machine.new(refine);
|
|
74
73
|
machine.currentServiceId = tryAsServiceId(10_000);
|
|
75
74
|
const code = BytesBlob.blobFromString("amazing PVM code");
|
|
76
75
|
const programCounter = tryAsProgramCounter(5);
|
|
@@ -82,7 +81,7 @@ describe("HostCalls: Machine", () => {
|
|
|
82
81
|
});
|
|
83
82
|
it("should return HUH when code is invalid", async () => {
|
|
84
83
|
const refine = new TestRefineExt();
|
|
85
|
-
const machine = new
|
|
84
|
+
const machine = Machine.new(refine);
|
|
86
85
|
machine.currentServiceId = tryAsServiceId(10_000);
|
|
87
86
|
const code = BytesBlob.blobFromString("invalid PVM code");
|
|
88
87
|
const programCounter = tryAsProgramCounter(5);
|
|
@@ -13,7 +13,8 @@ export declare class Pages implements HostCallHandler {
|
|
|
13
13
|
basicGasCost: number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"SmallGas[U32]">;
|
|
14
14
|
currentServiceId: number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"ServiceId[u32]">;
|
|
15
15
|
tracedRegisters: (number & import("@typeberry/utils").WithOpaque<"register index">)[];
|
|
16
|
-
|
|
16
|
+
static new(refine: RefineExternalities): Pages;
|
|
17
|
+
private constructor();
|
|
17
18
|
execute(_gas: IGasCounter, regs: HostCallRegisters): Promise<PvmExecution | undefined>;
|
|
18
19
|
}
|
|
19
20
|
//# sourceMappingURL=pages.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pages.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jam-host-calls/refine/pages.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,eAAe,EACpB,KAAK,iBAAiB,EACtB,KAAK,YAAY,EAGlB,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,KAAK,WAAW,EAAiB,MAAM,0BAA0B,CAAC;AAE3E,OAAO,EAEL,KAAK,mBAAmB,EAGzB,MAAM,0CAA0C,CAAC;AAOlD;;;;;GAKG;AACH,qBAAa,KAAM,YAAW,eAAe;
|
|
1
|
+
{"version":3,"file":"pages.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jam-host-calls/refine/pages.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,eAAe,EACpB,KAAK,iBAAiB,EACtB,KAAK,YAAY,EAGlB,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,KAAK,WAAW,EAAiB,MAAM,0BAA0B,CAAC;AAE3E,OAAO,EAEL,KAAK,mBAAmB,EAGzB,MAAM,0CAA0C,CAAC;AAOlD;;;;;GAKG;AACH,qBAAa,KAAM,YAAW,eAAe;IAUvB,OAAO,CAAC,QAAQ,CAAC,MAAM;IAT3C,KAAK,iIAA0B;IAC/B,YAAY,4HAAqB;IACjC,gBAAgB,6HAAsB;IACtC,eAAe,uEAAwC;IAEvD,MAAM,CAAC,GAAG,CAAC,MAAM,EAAE,mBAAmB;IAItC,OAAO;IAED,OAAO,CAAC,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,iBAAiB,GAAG,OAAO,CAAC,YAAY,GAAG,SAAS,CAAC;CAgC7F"}
|
|
@@ -18,6 +18,9 @@ export class Pages {
|
|
|
18
18
|
basicGasCost = tryAsSmallGas(10);
|
|
19
19
|
currentServiceId = CURRENT_SERVICE_ID;
|
|
20
20
|
tracedRegisters = traceRegisters(IN_OUT_REG, 8, 9, 10);
|
|
21
|
+
static new(refine) {
|
|
22
|
+
return new Pages(refine);
|
|
23
|
+
}
|
|
21
24
|
constructor(refine) {
|
|
22
25
|
this.refine = refine;
|
|
23
26
|
}
|
|
@@ -9,18 +9,17 @@ import { OK, Result } from "#@typeberry/utils";
|
|
|
9
9
|
import { PagesError, toMemoryOperation, tryAsMachineId, } from "../externalities/refine-externalities.js";
|
|
10
10
|
import { TestRefineExt } from "../externalities/refine-externalities.test.js";
|
|
11
11
|
import { HostCallResult } from "../general/results.js";
|
|
12
|
-
import { emptyRegistersBuffer } from "../utils.js";
|
|
13
12
|
import { Pages } from "./pages.js";
|
|
14
13
|
const gas = gasCounter(tryAsGas(0));
|
|
15
14
|
const RESULT_REG = 7;
|
|
16
15
|
function prepareRegsAndMemory(machineId, pageStart, pageCount, requestType) {
|
|
17
|
-
const registers =
|
|
16
|
+
const registers = HostCallRegisters.empty();
|
|
18
17
|
registers.set(7, machineId);
|
|
19
18
|
registers.set(8, pageStart);
|
|
20
19
|
registers.set(9, pageCount);
|
|
21
20
|
registers.set(10, requestType);
|
|
22
21
|
const builder = new MemoryBuilder();
|
|
23
|
-
const memory = new
|
|
22
|
+
const memory = HostCallMemory.new(builder.finalize(tryAsMemoryIndex(0), tryAsSbrkIndex(0)));
|
|
24
23
|
return {
|
|
25
24
|
registers,
|
|
26
25
|
memory,
|
|
@@ -28,7 +27,7 @@ function prepareRegsAndMemory(machineId, pageStart, pageCount, requestType) {
|
|
|
28
27
|
}
|
|
29
28
|
function prepareTest(result, machineId, pageStart, pageCount, requestType) {
|
|
30
29
|
const refine = new TestRefineExt();
|
|
31
|
-
const pages = new
|
|
30
|
+
const pages = Pages.new(refine);
|
|
32
31
|
pages.currentServiceId = tryAsServiceId(10_000);
|
|
33
32
|
const machineIndex = tryAsMachineId(machineId);
|
|
34
33
|
const start = tryAsU64(pageStart);
|
|
@@ -12,7 +12,8 @@ export declare class Peek implements HostCallHandler {
|
|
|
12
12
|
basicGasCost: number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"SmallGas[U32]">;
|
|
13
13
|
currentServiceId: number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"ServiceId[u32]">;
|
|
14
14
|
tracedRegisters: (number & import("@typeberry/utils").WithOpaque<"register index">)[];
|
|
15
|
-
|
|
15
|
+
static new(refine: RefineExternalities): Peek;
|
|
16
|
+
private constructor();
|
|
16
17
|
execute(_gas: IGasCounter, regs: HostCallRegisters, memory: HostCallMemory): Promise<PvmExecution | undefined>;
|
|
17
18
|
}
|
|
18
19
|
//# sourceMappingURL=peek.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"peek.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jam-host-calls/refine/peek.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,eAAe,EACpB,KAAK,cAAc,EACnB,KAAK,iBAAiB,EACtB,YAAY,EAGb,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,KAAK,WAAW,EAAiB,MAAM,0BAA0B,CAAC;AAE3E,OAAO,EAAiB,KAAK,mBAAmB,EAAkB,MAAM,0CAA0C,CAAC;AAOnH;;;;GAIG;AACH,qBAAa,IAAK,YAAW,eAAe;
|
|
1
|
+
{"version":3,"file":"peek.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jam-host-calls/refine/peek.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,eAAe,EACpB,KAAK,cAAc,EACnB,KAAK,iBAAiB,EACtB,YAAY,EAGb,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,KAAK,WAAW,EAAiB,MAAM,0BAA0B,CAAC;AAE3E,OAAO,EAAiB,KAAK,mBAAmB,EAAkB,MAAM,0CAA0C,CAAC;AAOnH;;;;GAIG;AACH,qBAAa,IAAK,YAAW,eAAe;IAUtB,OAAO,CAAC,QAAQ,CAAC,MAAM;IAT3C,KAAK,iIAAyB;IAC9B,YAAY,4HAAqB;IACjC,gBAAgB,6HAAsB;IACtC,eAAe,uEAAwC;IAEvD,MAAM,CAAC,GAAG,CAAC,MAAM,EAAE,mBAAmB;IAItC,OAAO;IAED,OAAO,CAAC,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,iBAAiB,EAAE,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,YAAY,GAAG,SAAS,CAAC;CAoCrH"}
|
|
@@ -17,6 +17,9 @@ export class Peek {
|
|
|
17
17
|
basicGasCost = tryAsSmallGas(10);
|
|
18
18
|
currentServiceId = CURRENT_SERVICE_ID;
|
|
19
19
|
tracedRegisters = traceRegisters(IN_OUT_REG, 8, 9, 10);
|
|
20
|
+
static new(refine) {
|
|
21
|
+
return new Peek(refine);
|
|
22
|
+
}
|
|
20
23
|
constructor(refine) {
|
|
21
24
|
this.refine = refine;
|
|
22
25
|
}
|
|
@@ -9,18 +9,17 @@ import { OK, Result } from "#@typeberry/utils";
|
|
|
9
9
|
import { PeekPokeError, tryAsMachineId } from "../externalities/refine-externalities.js";
|
|
10
10
|
import { TestRefineExt } from "../externalities/refine-externalities.test.js";
|
|
11
11
|
import { HostCallResult } from "../general/results.js";
|
|
12
|
-
import { emptyRegistersBuffer } from "../utils.js";
|
|
13
12
|
import { Peek } from "./peek.js";
|
|
14
13
|
const gas = gasCounter(tryAsGas(0));
|
|
15
14
|
const RESULT_REG = 7;
|
|
16
15
|
function prepareRegsAndMemory(machineId, destinationStart, sourceStart, length) {
|
|
17
|
-
const registers =
|
|
16
|
+
const registers = HostCallRegisters.empty();
|
|
18
17
|
registers.set(7, machineId);
|
|
19
18
|
registers.set(8, tryAsU64(destinationStart));
|
|
20
19
|
registers.set(9, tryAsU64(sourceStart));
|
|
21
20
|
registers.set(10, tryAsU64(length));
|
|
22
21
|
const builder = new MemoryBuilder();
|
|
23
|
-
const memory = new
|
|
22
|
+
const memory = HostCallMemory.new(builder.finalize(tryAsMemoryIndex(0), tryAsSbrkIndex(0)));
|
|
24
23
|
return {
|
|
25
24
|
registers,
|
|
26
25
|
memory,
|
|
@@ -28,7 +27,7 @@ function prepareRegsAndMemory(machineId, destinationStart, sourceStart, length)
|
|
|
28
27
|
}
|
|
29
28
|
function prepareTest(result) {
|
|
30
29
|
const refine = new TestRefineExt();
|
|
31
|
-
const peek = new
|
|
30
|
+
const peek = Peek.new(refine);
|
|
32
31
|
peek.currentServiceId = tryAsServiceId(10_000);
|
|
33
32
|
const machineId = tryAsMachineId(10_000);
|
|
34
33
|
const destinationStart = 2 ** 16;
|
|
@@ -12,7 +12,8 @@ export declare class Poke implements HostCallHandler {
|
|
|
12
12
|
basicGasCost: number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"SmallGas[U32]">;
|
|
13
13
|
currentServiceId: number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"ServiceId[u32]">;
|
|
14
14
|
tracedRegisters: (number & import("@typeberry/utils").WithOpaque<"register index">)[];
|
|
15
|
-
|
|
15
|
+
static new(refine: RefineExternalities): Poke;
|
|
16
|
+
private constructor();
|
|
16
17
|
execute(_gas: IGasCounter, regs: HostCallRegisters, memory: HostCallMemory): Promise<PvmExecution | undefined>;
|
|
17
18
|
}
|
|
18
19
|
//# sourceMappingURL=poke.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"poke.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jam-host-calls/refine/poke.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,eAAe,EACpB,KAAK,cAAc,EACnB,KAAK,iBAAiB,EACtB,YAAY,EAGb,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,KAAK,WAAW,EAAiB,MAAM,0BAA0B,CAAC;AAE3E,OAAO,EAAiB,KAAK,mBAAmB,EAAkB,MAAM,0CAA0C,CAAC;AAOnH;;;;GAIG;AACH,qBAAa,IAAK,YAAW,eAAe;
|
|
1
|
+
{"version":3,"file":"poke.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jam-host-calls/refine/poke.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,eAAe,EACpB,KAAK,cAAc,EACnB,KAAK,iBAAiB,EACtB,YAAY,EAGb,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,KAAK,WAAW,EAAiB,MAAM,0BAA0B,CAAC;AAE3E,OAAO,EAAiB,KAAK,mBAAmB,EAAkB,MAAM,0CAA0C,CAAC;AAOnH;;;;GAIG;AACH,qBAAa,IAAK,YAAW,eAAe;IAUtB,OAAO,CAAC,QAAQ,CAAC,MAAM;IAT3C,KAAK,iIAA0B;IAC/B,YAAY,4HAAqB;IACjC,gBAAgB,6HAAsB;IACtC,eAAe,uEAAwC;IAEvD,MAAM,CAAC,GAAG,CAAC,MAAM,EAAE,mBAAmB;IAItC,OAAO;IAED,OAAO,CAAC,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,iBAAiB,EAAE,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,YAAY,GAAG,SAAS,CAAC;CAoCrH"}
|
|
@@ -17,6 +17,9 @@ export class Poke {
|
|
|
17
17
|
basicGasCost = tryAsSmallGas(10);
|
|
18
18
|
currentServiceId = CURRENT_SERVICE_ID;
|
|
19
19
|
tracedRegisters = traceRegisters(IN_OUT_REG, 8, 9, 10);
|
|
20
|
+
static new(refine) {
|
|
21
|
+
return new Poke(refine);
|
|
22
|
+
}
|
|
20
23
|
constructor(refine) {
|
|
21
24
|
this.refine = refine;
|
|
22
25
|
}
|
|
@@ -9,18 +9,17 @@ import { OK, Result } from "#@typeberry/utils";
|
|
|
9
9
|
import { PeekPokeError, tryAsMachineId } from "../externalities/refine-externalities.js";
|
|
10
10
|
import { TestRefineExt } from "../externalities/refine-externalities.test.js";
|
|
11
11
|
import { HostCallResult } from "../general/results.js";
|
|
12
|
-
import { emptyRegistersBuffer } from "../utils.js";
|
|
13
12
|
import { Poke } from "./poke.js";
|
|
14
13
|
const gas = gasCounter(tryAsGas(0));
|
|
15
14
|
const RESULT_REG = 7;
|
|
16
15
|
function prepareRegsAndMemory(machineId, sourceStart, destinationStart, length) {
|
|
17
|
-
const registers =
|
|
16
|
+
const registers = HostCallRegisters.empty();
|
|
18
17
|
registers.set(7, machineId);
|
|
19
18
|
registers.set(8, tryAsU64(sourceStart));
|
|
20
19
|
registers.set(9, tryAsU64(destinationStart));
|
|
21
20
|
registers.set(10, tryAsU64(length));
|
|
22
21
|
const builder = new MemoryBuilder();
|
|
23
|
-
const memory = new
|
|
22
|
+
const memory = HostCallMemory.new(builder.finalize(tryAsMemoryIndex(0), tryAsSbrkIndex(0)));
|
|
24
23
|
return {
|
|
25
24
|
registers,
|
|
26
25
|
memory,
|
|
@@ -28,7 +27,7 @@ function prepareRegsAndMemory(machineId, sourceStart, destinationStart, length)
|
|
|
28
27
|
}
|
|
29
28
|
function prepareTest(result) {
|
|
30
29
|
const refine = new TestRefineExt();
|
|
31
|
-
const poke = new
|
|
30
|
+
const poke = Poke.new(refine);
|
|
32
31
|
poke.currentServiceId = tryAsServiceId(10_000);
|
|
33
32
|
const machineId = tryAsMachineId(10_000);
|
|
34
33
|
const memoryStart = 2 ** 20;
|
|
@@ -20,7 +20,7 @@ onNewBlocks) {
|
|
|
20
20
|
key,
|
|
21
21
|
protocols: [`jamnp-s/0/${genesisFirstBytes}`],
|
|
22
22
|
});
|
|
23
|
-
const connections = new
|
|
23
|
+
const connections = Connections.new(network);
|
|
24
24
|
connections.addPersistentRetry(bootnodes);
|
|
25
25
|
const streamManager = new StreamManager();
|
|
26
26
|
// start the networking tasks
|
|
@@ -28,7 +28,8 @@ export declare class Connections {
|
|
|
28
28
|
private readonly network;
|
|
29
29
|
/** Info about peers that are currently connected or where connected in the past. */
|
|
30
30
|
private readonly peerInfo;
|
|
31
|
-
|
|
31
|
+
static new(network: Network<Peer>): Connections;
|
|
32
|
+
private constructor();
|
|
32
33
|
/** Attach some external typed data to given peer. */
|
|
33
34
|
setAuxData<T>(peer: PeerId, id: AuxData<T>, data: T): void;
|
|
34
35
|
/** Read some externally-attached data about the peer. */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"peers.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/jamnp-s/peers.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAElD,OAAO,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAGhF,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE7C,KAAK,QAAQ,GAAG;IACd,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,WAAW,CAAC;IAErB,iDAAiD;IACjD,OAAO,EAAE,IAAI,GAAG,IAAI,CAAC;IACrB,aAAa,EAAE,MAAM,CAAC;IACtB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IAErB,cAAc,EAAE,eAAe,CAAC;IAEhC,GAAG,EAAE,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,CAAC,CAAC;CAC3C,CAAC;AAEF,MAAM,MAAM,OAAO,CAAC,CAAC,IAAI;IACvB,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,CAAC,EAAE,CAAC,CAAC;CACZ,CAAC;AAWF;;;;;;;GAOG;AACH,qBAAa,WAAW;
|
|
1
|
+
{"version":3,"file":"peers.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/jamnp-s/peers.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAElD,OAAO,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAGhF,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE7C,KAAK,QAAQ,GAAG;IACd,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,WAAW,CAAC;IAErB,iDAAiD;IACjD,OAAO,EAAE,IAAI,GAAG,IAAI,CAAC;IACrB,aAAa,EAAE,MAAM,CAAC;IACtB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IAErB,cAAc,EAAE,eAAe,CAAC;IAEhC,GAAG,EAAE,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,CAAC,CAAC;CAC3C,CAAC;AAEF,MAAM,MAAM,OAAO,CAAC,CAAC,IAAI;IACvB,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,CAAC,EAAE,CAAC,CAAC;CACZ,CAAC;AAWF;;;;;;;GAOG;AACH,qBAAa,WAAW;IAQF,OAAO,CAAC,QAAQ,CAAC,OAAO;IAP5C,oFAAoF;IACpF,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAoC;IAE7D,MAAM,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,CAAC,IAAI,CAAC;IAIjC,OAAO;IAWP,qDAAqD;IACrD,UAAU,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,OAAO,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC;IAInD,yDAAyD;IACzD,UAAU,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,SAAS;IAI1D,sDAAsD;IACtD,WAAW,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,OAAO,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,SAAS,KAAK,CAAC;IAM7E,sDAAsD;IACtD,YAAY;IAIZ,iDAAiD;IAChD,iBAAiB;IAQlB,oDAAoD;IACpD,OAAO,CAAC,UAAU;IAyBlB,8EAA8E;YAChE,iBAAiB;IAqE/B;;;;;OAKG;IACH,kBAAkB,CAAC,SAAS,EAAE,QAAQ,EAAE;CAezC"}
|
|
@@ -21,6 +21,9 @@ export class Connections {
|
|
|
21
21
|
network;
|
|
22
22
|
/** Info about peers that are currently connected or where connected in the past. */
|
|
23
23
|
peerInfo = new Map();
|
|
24
|
+
static new(network) {
|
|
25
|
+
return new Connections(network);
|
|
26
|
+
}
|
|
24
27
|
constructor(network) {
|
|
25
28
|
this.network = network;
|
|
26
29
|
network.peers.onPeerConnected((peer) => {
|
|
@@ -42,7 +42,8 @@ export declare class ServerHandler implements StreamHandler<typeof STREAM_KIND>
|
|
|
42
42
|
private readonly chainSpec;
|
|
43
43
|
private readonly getBlockSequence;
|
|
44
44
|
kind: 128 & import("@typeberry/numbers").WithBytesRepresentation<1>;
|
|
45
|
-
|
|
45
|
+
static new(chainSpec: ChainSpec, getBlockSequence: (streamId: StreamId, hash: HeaderHash, direction: Direction, maxBlocks: U32) => BlockView[]): ServerHandler;
|
|
46
|
+
private constructor();
|
|
46
47
|
onStreamMessage(sender: StreamMessageSender, message: BytesBlob): void;
|
|
47
48
|
onClose(_streamId: StreamId): void;
|
|
48
49
|
}
|
|
@@ -51,7 +52,8 @@ export declare class ClientHandler implements StreamHandler<typeof STREAM_KIND>
|
|
|
51
52
|
kind: 128 & import("@typeberry/numbers").WithBytesRepresentation<1>;
|
|
52
53
|
private promiseResolvers;
|
|
53
54
|
private promiseRejectors;
|
|
54
|
-
|
|
55
|
+
static new(chainSpec: ChainSpec): ClientHandler;
|
|
56
|
+
private constructor();
|
|
55
57
|
onStreamMessage(sender: StreamMessageSender, message: BytesBlob): void;
|
|
56
58
|
onClose(streamId: StreamId): void;
|
|
57
59
|
requestBlockSequence(sender: StreamMessageSender, headerHash: HeaderHash, direction: Direction, maxBlocks: U32): Promise<BlockView[]>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ce-128-block-request.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jamnp-s/protocol/ce-128-block-request.ts"],"names":[],"mappings":"AAAA,OAAO,EAAS,KAAK,SAAS,EAAE,KAAK,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC1E,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,KAAK,WAAW,EAA2B,MAAM,kBAAkB,CAAC;AAC7E,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAGpD,OAAO,EAAW,KAAK,GAAG,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,KAAK,aAAa,EAAE,KAAK,QAAQ,EAAE,KAAK,mBAAmB,EAAmB,MAAM,aAAa,CAAC;AAE3G;;;;GAIG;AAEH,eAAO,MAAM,WAAW,+DAAuB,CAAC;AAEhD,oBAAY,SAAS;IACnB;;;;OAIG;IACH,OAAO,IAAI;IACX;;;;OAIG;IACH,QAAQ,IAAI;CACb;AAED,qBAAa,YAAa,SAAQ,SAAS;aAwBvB,UAAU,EAAE,UAAU;aACtB,SAAS,EAAE,SAAS;aACpB,SAAS,EAAE,GAAG;IAzBhC,MAAM,CAAC,KAAK;;;;QAgBT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,EAAE,EAAE,WAAW,CAAC,YAAY,CAAC;IAI7E,OAAO;CAOR;AAID,qBAAa,aAAc,YAAW,aAAa,CAAC,OAAO,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"ce-128-block-request.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jamnp-s/protocol/ce-128-block-request.ts"],"names":[],"mappings":"AAAA,OAAO,EAAS,KAAK,SAAS,EAAE,KAAK,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC1E,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,KAAK,WAAW,EAA2B,MAAM,kBAAkB,CAAC;AAC7E,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAGpD,OAAO,EAAW,KAAK,GAAG,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,KAAK,aAAa,EAAE,KAAK,QAAQ,EAAE,KAAK,mBAAmB,EAAmB,MAAM,aAAa,CAAC;AAE3G;;;;GAIG;AAEH,eAAO,MAAM,WAAW,+DAAuB,CAAC;AAEhD,oBAAY,SAAS;IACnB;;;;OAIG;IACH,OAAO,IAAI;IACX;;;;OAIG;IACH,QAAQ,IAAI;CACb;AAED,qBAAa,YAAa,SAAQ,SAAS;aAwBvB,UAAU,EAAE,UAAU;aACtB,SAAS,EAAE,SAAS;aACpB,SAAS,EAAE,GAAG;IAzBhC,MAAM,CAAC,KAAK;;;;QAgBT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,EAAE,EAAE,WAAW,CAAC,YAAY,CAAC;IAI7E,OAAO;CAOR;AAID,qBAAa,aAAc,YAAW,aAAa,CAAC,OAAO,WAAW,CAAC;IAWnE,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,gBAAgB;IAXnC,IAAI,gEAAe;IAEnB,MAAM,CAAC,GAAG,CACR,SAAS,EAAE,SAAS,EACpB,gBAAgB,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,KAAK,SAAS,EAAE;IAK/G,OAAO;IAUP,eAAe,CAAC,MAAM,EAAE,mBAAmB,EAAE,OAAO,EAAE,SAAS,GAAG,IAAI;IAYtE,OAAO,CAAC,SAAS,EAAE,QAAQ;CAC5B;AAED,qBAAa,aAAc,YAAW,aAAa,CAAC,OAAO,WAAW,CAAC;IAUjD,OAAO,CAAC,QAAQ,CAAC,SAAS;IAT9C,IAAI,gEAAe;IAEnB,OAAO,CAAC,gBAAgB,CAA0D;IAClF,OAAO,CAAC,gBAAgB,CAAwD;IAEhF,MAAM,CAAC,GAAG,CAAC,SAAS,EAAE,SAAS;IAI/B,OAAO;IAEP,eAAe,CAAC,MAAM,EAAE,mBAAmB,EAAE,OAAO,EAAE,SAAS,GAAG,IAAI;IAWtE,OAAO,CAAC,QAAQ,EAAE,QAAQ;IAOpB,oBAAoB,CACxB,MAAM,EAAE,mBAAmB,EAC3B,UAAU,EAAE,UAAU,EACtB,SAAS,EAAE,SAAS,EACpB,SAAS,EAAE,GAAG,GACb,OAAO,CAAC,SAAS,EAAE,CAAC;CAgBxB;AAED,0CAA0C;AAC1C,oBAAY,kBAAkB;IAC5B,+CAA+C;IAC/C,YAAY,IAAI;IAChB,iFAAiF;IACjF,WAAW,IAAI;CAChB;AAED,sEAAsE;AACtE,wBAAgB,sBAAsB,CACpC,SAAS,EAAE,SAAS,EACpB,MAAM,EAAE,QAAQ,EAChB,SAAS,EAAE,UAAU,EACrB,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,GAAG,GACT,MAAM,CAAC,SAAS,EAAE,EAAE,kBAAkB,CAAC,CAmEzC"}
|
|
@@ -60,6 +60,9 @@ export class ServerHandler {
|
|
|
60
60
|
chainSpec;
|
|
61
61
|
getBlockSequence;
|
|
62
62
|
kind = STREAM_KIND;
|
|
63
|
+
static new(chainSpec, getBlockSequence) {
|
|
64
|
+
return new ServerHandler(chainSpec, getBlockSequence);
|
|
65
|
+
}
|
|
63
66
|
constructor(chainSpec, getBlockSequence) {
|
|
64
67
|
this.chainSpec = chainSpec;
|
|
65
68
|
this.getBlockSequence = getBlockSequence;
|
|
@@ -78,6 +81,9 @@ export class ClientHandler {
|
|
|
78
81
|
kind = STREAM_KIND;
|
|
79
82
|
promiseResolvers = new Map();
|
|
80
83
|
promiseRejectors = new Map();
|
|
84
|
+
static new(chainSpec) {
|
|
85
|
+
return new ClientHandler(chainSpec);
|
|
86
|
+
}
|
|
81
87
|
constructor(chainSpec) {
|
|
82
88
|
this.chainSpec = chainSpec;
|
|
83
89
|
}
|
|
@@ -17,8 +17,8 @@ const TEST_BLOCK_VIEW = testBlockView();
|
|
|
17
17
|
describe("CE 128: Block Request", () => {
|
|
18
18
|
it("sends a block request and receives a sequence of blocks", async () => {
|
|
19
19
|
const handlers = testClientServer();
|
|
20
|
-
handlers.server.registerHandlers(new
|
|
21
|
-
handlers.client.registerHandlers(new
|
|
20
|
+
handlers.server.registerHandlers(ServerHandler.new(tinyChainSpec, getBlockSequence));
|
|
21
|
+
handlers.client.registerHandlers(ClientHandler.new(tinyChainSpec));
|
|
22
22
|
const receivedData = await new Promise((resolve) => {
|
|
23
23
|
handlers.client.withNewStream(STREAM_KIND, (handler, sender) => {
|
|
24
24
|
(async () => {
|
|
@@ -20,7 +20,8 @@ export declare class KeyValuePair extends WithDebug {
|
|
|
20
20
|
value: import("@typeberry/codec").Descriptor<BytesBlob, BytesBlob>;
|
|
21
21
|
}>>;
|
|
22
22
|
static create({ key, value }: CodecRecord<KeyValuePair>): KeyValuePair;
|
|
23
|
-
|
|
23
|
+
static new(key: Key, value: BytesBlob): KeyValuePair;
|
|
24
|
+
private constructor();
|
|
24
25
|
}
|
|
25
26
|
export declare class StateResponse extends WithDebug {
|
|
26
27
|
readonly keyValuePairs: KeyValuePair[];
|
|
@@ -54,7 +55,8 @@ export declare class Handler implements StreamHandler<typeof STREAM_KIND> {
|
|
|
54
55
|
kind: 129 & import("@typeberry/numbers").WithBytesRepresentation<1>;
|
|
55
56
|
private readonly boundaryNodes;
|
|
56
57
|
private readonly onResponse;
|
|
57
|
-
|
|
58
|
+
static new(isServer?: boolean, getBoundaryNodes?: (hash: HeaderHash, startKey: Key, endKey: Key) => TrieNode[], getKeyValuePairs?: (hash: HeaderHash, startKey: Key, endKey: Key) => KeyValuePair[]): Handler;
|
|
59
|
+
private constructor();
|
|
58
60
|
onStreamMessage(sender: StreamMessageSender, message: BytesBlob): void;
|
|
59
61
|
onClose(streamId: StreamId): void;
|
|
60
62
|
getStateByKey(sender: StreamMessageSender, headerHash: HeaderHash, startKey: StateRequest["startKey"], onResponse: (state: StateResponse) => void): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ce-129-state-request.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jamnp-s/protocol/ce-129-state-request.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AACnD,OAAO,EAAE,KAAK,EAAE,KAAK,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACzD,OAAO,EAAE,KAAK,WAAW,EAA2B,MAAM,kBAAkB,CAAC;AAG7E,OAAO,EAAY,KAAK,GAAG,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,mBAAmB,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AACzE,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,KAAK,aAAa,EAAE,KAAK,QAAQ,EAAE,KAAK,mBAAmB,EAAmB,MAAM,aAAa,CAAC;AAE3G;;;;GAIG;AAEH,eAAO,MAAM,WAAW,+DAAuB,CAAC;AAGhD,MAAM,MAAM,GAAG,GAAG,KAAK,CAAC,mBAAmB,CAAC,CAAC;AAO7C,qBAAa,YAAa,SAAQ,SAAS;
|
|
1
|
+
{"version":3,"file":"ce-129-state-request.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jamnp-s/protocol/ce-129-state-request.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AACnD,OAAO,EAAE,KAAK,EAAE,KAAK,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACzD,OAAO,EAAE,KAAK,WAAW,EAA2B,MAAM,kBAAkB,CAAC;AAG7E,OAAO,EAAY,KAAK,GAAG,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,mBAAmB,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AACzE,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,KAAK,aAAa,EAAE,KAAK,QAAQ,EAAE,KAAK,mBAAmB,EAAmB,MAAM,aAAa,CAAC;AAE3G;;;;GAIG;AAEH,eAAO,MAAM,WAAW,+DAAuB,CAAC;AAGhD,MAAM,MAAM,GAAG,GAAG,KAAK,CAAC,mBAAmB,CAAC,CAAC;AAO7C,qBAAa,YAAa,SAAQ,SAAS;aAevB,GAAG,EAAE,GAAG;aACR,KAAK,EAAE,SAAS;IAflC,MAAM,CAAC,KAAK;;;QAGT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,EAAE,WAAW,CAAC,YAAY,CAAC;IAIvD,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,SAAS;IAIrC,OAAO;CAMR;AAED,qBAAa,aAAc,SAAQ,SAAS;aASN,aAAa,EAAE,YAAY,EAAE;IARjE,MAAM,CAAC,KAAK;;;;;QAET;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,aAAa,EAAE,EAAE,WAAW,CAAC,aAAa,CAAC;IAI3D,OAAO;CAGR;AAED,qBAAa,YAAa,SAAQ,SAAS;aAavB,UAAU,EAAE,UAAU;aACtB,QAAQ,EAAE,GAAG;aACb,MAAM,EAAE,GAAG;aACX,WAAW,EAAE,GAAG;IAflC,MAAM,CAAC,KAAK;;;;;QAKT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,WAAW,EAAE,EAAE,WAAW,CAAC,YAAY,CAAC;IAItF,OAAO;CAQR;AAID,qBAAa,OAAQ,YAAW,aAAa,CAAC,OAAO,WAAW,CAAC;IAe7D,OAAO,CAAC,QAAQ,CAAC,QAAQ;IACzB,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAC;IAClC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAC;IAhBpC,IAAI,gEAAe;IAEnB,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAwC;IACtE,OAAO,CAAC,QAAQ,CAAC,UAAU,CAA4D;IAEvF,MAAM,CAAC,GAAG,CACR,QAAQ,UAAQ,EAChB,gBAAgB,CAAC,EAAE,CAAC,IAAI,EAAE,UAAU,EAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,KAAK,QAAQ,EAAE,EAC/E,gBAAgB,CAAC,EAAE,CAAC,IAAI,EAAE,UAAU,EAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,KAAK,YAAY,EAAE;IAKrF,OAAO;IAUP,eAAe,CAAC,MAAM,EAAE,mBAAmB,EAAE,OAAO,EAAE,SAAS,GAAG,IAAI;IAgCtE,OAAO,CAAC,QAAQ,EAAE,QAAQ;IAK1B,aAAa,CACX,MAAM,EAAE,mBAAmB,EAC3B,UAAU,EAAE,UAAU,EACtB,QAAQ,EAAE,YAAY,CAAC,UAAU,CAAC,EAClC,UAAU,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,IAAI;CAe7C"}
|
|
@@ -24,6 +24,9 @@ export class KeyValuePair extends WithDebug {
|
|
|
24
24
|
static create({ key, value }) {
|
|
25
25
|
return new KeyValuePair(key, value);
|
|
26
26
|
}
|
|
27
|
+
static new(key, value) {
|
|
28
|
+
return new KeyValuePair(key, value);
|
|
29
|
+
}
|
|
27
30
|
constructor(key, value) {
|
|
28
31
|
super();
|
|
29
32
|
this.key = key;
|
|
@@ -73,6 +76,9 @@ export class Handler {
|
|
|
73
76
|
kind = STREAM_KIND;
|
|
74
77
|
boundaryNodes = new Map();
|
|
75
78
|
onResponse = new Map();
|
|
79
|
+
static new(isServer = false, getBoundaryNodes, getKeyValuePairs) {
|
|
80
|
+
return new Handler(isServer, getBoundaryNodes, getKeyValuePairs);
|
|
81
|
+
}
|
|
76
82
|
constructor(isServer = false, getBoundaryNodes, getKeyValuePairs) {
|
|
77
83
|
this.isServer = isServer;
|
|
78
84
|
this.getBoundaryNodes = getBoundaryNodes;
|
|
@@ -17,8 +17,8 @@ const EXPECTED_VALUE = BytesBlob.blobFromNumbers([255, 255, 255, 0]);
|
|
|
17
17
|
describe("CE 129: State Request", () => {
|
|
18
18
|
it("sends a state request and receives a response", async () => {
|
|
19
19
|
const handlers = testClientServer();
|
|
20
|
-
handlers.server.registerHandlers(new
|
|
21
|
-
handlers.client.registerHandlers(new
|
|
20
|
+
handlers.server.registerHandlers(Handler.new(true, getBoundaryNodes, getKeyValuePairs));
|
|
21
|
+
handlers.client.registerHandlers(Handler.new());
|
|
22
22
|
const receivedData = await new Promise((resolve) => {
|
|
23
23
|
handlers.client.withNewStream(STREAM_KIND, (handler, sender) => {
|
|
24
24
|
handler.getStateByKey(sender, HEADER_HASH, KEY, (response) => {
|
|
@@ -27,7 +27,7 @@ describe("CE 129: State Request", () => {
|
|
|
27
27
|
return OK;
|
|
28
28
|
});
|
|
29
29
|
});
|
|
30
|
-
assert.deepStrictEqual(receivedData, [new
|
|
30
|
+
assert.deepStrictEqual(receivedData, [KeyValuePair.new(KEY, EXPECTED_VALUE)]);
|
|
31
31
|
});
|
|
32
32
|
});
|
|
33
33
|
const getBoundaryNodes = () => {
|
|
@@ -38,5 +38,5 @@ const getKeyValuePairs = (_hash, startKey) => {
|
|
|
38
38
|
if (KEY.isEqualTo(startKey)) {
|
|
39
39
|
value = EXPECTED_VALUE;
|
|
40
40
|
}
|
|
41
|
-
return [new
|
|
41
|
+
return [KeyValuePair.new(startKey, value)];
|
|
42
42
|
};
|
|
@@ -36,14 +36,16 @@ export declare class ServerHandler<T extends STREAM_KIND> implements StreamHandl
|
|
|
36
36
|
private readonly chainSpec;
|
|
37
37
|
readonly kind: T;
|
|
38
38
|
private readonly onTicketReceived;
|
|
39
|
-
|
|
39
|
+
static new<T extends STREAM_KIND>(chainSpec: ChainSpec, kind: T, onTicketReceived: (epochIndex: Epoch, ticket: SignedTicket) => void): ServerHandler<T>;
|
|
40
|
+
private constructor();
|
|
40
41
|
onStreamMessage(sender: StreamMessageSender, message: BytesBlob): void;
|
|
41
42
|
onClose(_streamId: StreamId): void;
|
|
42
43
|
}
|
|
43
44
|
export declare class ClientHandler<T extends STREAM_KIND> implements StreamHandler<T> {
|
|
44
45
|
private readonly chainSpec;
|
|
45
46
|
readonly kind: T;
|
|
46
|
-
|
|
47
|
+
static new<T extends STREAM_KIND>(chainSpec: ChainSpec, kind: T): ClientHandler<T>;
|
|
48
|
+
private constructor();
|
|
47
49
|
onStreamMessage(sender: StreamMessageSender): void;
|
|
48
50
|
onClose(_streamId: StreamId): void;
|
|
49
51
|
sendTicket(sender: StreamMessageSender, epochIndex: Epoch, ticket: SignedTicket): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ce-131-ce-132-safrole-ticket-distribution.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jamnp-s/protocol/ce-131-ce-132-safrole-ticket-distribution.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAC3D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,KAAK,WAAW,EAA2B,MAAM,kBAAkB,CAAC;AAC7E,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAEnD,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,KAAK,aAAa,EAAE,KAAK,QAAQ,EAAE,KAAK,mBAAmB,EAAmB,MAAM,aAAa,CAAC;AAE3G;;;;;;GAMG;AAEH,eAAO,MAAM,8BAA8B,+DAAuB,CAAC;AACnE,eAAO,MAAM,wBAAwB,+DAAuB,CAAC;AAE7D,KAAK,WAAW,GAAG,OAAO,8BAA8B,GAAG,OAAO,wBAAwB,CAAC;AAE3F;;;GAGG;AACH,qBAAa,yBAA0B,SAAQ,SAAS;aAWpC,UAAU,EAAE,KAAK;aACjB,MAAM,EAAE,YAAY;IAXtC,MAAM,CAAC,KAAK;;;;;;QAGT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,MAAM,EAAE,EAAE,WAAW,CAAC,yBAAyB,CAAC;IAI5E,OAAO;CAMR;AAID,qBAAa,aAAa,CAAC,CAAC,SAAS,WAAW,CAAE,YAAW,aAAa,CAAC,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"ce-131-ce-132-safrole-ticket-distribution.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jamnp-s/protocol/ce-131-ce-132-safrole-ticket-distribution.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAC3D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,KAAK,WAAW,EAA2B,MAAM,kBAAkB,CAAC;AAC7E,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAEnD,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,KAAK,aAAa,EAAE,KAAK,QAAQ,EAAE,KAAK,mBAAmB,EAAmB,MAAM,aAAa,CAAC;AAE3G;;;;;;GAMG;AAEH,eAAO,MAAM,8BAA8B,+DAAuB,CAAC;AACnE,eAAO,MAAM,wBAAwB,+DAAuB,CAAC;AAE7D,KAAK,WAAW,GAAG,OAAO,8BAA8B,GAAG,OAAO,wBAAwB,CAAC;AAE3F;;;GAGG;AACH,qBAAa,yBAA0B,SAAQ,SAAS;aAWpC,UAAU,EAAE,KAAK;aACjB,MAAM,EAAE,YAAY;IAXtC,MAAM,CAAC,KAAK;;;;;;QAGT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,MAAM,EAAE,EAAE,WAAW,CAAC,yBAAyB,CAAC;IAI5E,OAAO;CAMR;AAID,qBAAa,aAAa,CAAC,CAAC,SAAS,WAAW,CAAE,YAAW,aAAa,CAAC,CAAC,CAAC;IAUzE,OAAO,CAAC,QAAQ,CAAC,SAAS;aACV,IAAI,EAAE,CAAC;IACvB,OAAO,CAAC,QAAQ,CAAC,gBAAgB;IAXnC,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,WAAW,EAC9B,SAAS,EAAE,SAAS,EACpB,IAAI,EAAE,CAAC,EACP,gBAAgB,EAAE,CAAC,UAAU,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,KAAK,IAAI;IAKrE,OAAO;IAMP,eAAe,CAAC,MAAM,EAAE,mBAAmB,EAAE,OAAO,EAAE,SAAS,GAAG,IAAI;IAOtE,OAAO,CAAC,SAAS,EAAE,QAAQ;CAC5B;AAED,qBAAa,aAAa,CAAC,CAAC,SAAS,WAAW,CAAE,YAAW,aAAa,CAAC,CAAC,CAAC;IAMzE,OAAO,CAAC,QAAQ,CAAC,SAAS;aACV,IAAI,EAAE,CAAC;IANzB,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,WAAW,EAAE,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;IAI/D,OAAO;IAKP,eAAe,CAAC,MAAM,EAAE,mBAAmB,GAAG,IAAI;IAKlD,OAAO,CAAC,SAAS,EAAE,QAAQ;IAE3B,UAAU,CAAC,MAAM,EAAE,mBAAmB,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY;CAKhF"}
|
|
@@ -37,6 +37,9 @@ export class ServerHandler {
|
|
|
37
37
|
chainSpec;
|
|
38
38
|
kind;
|
|
39
39
|
onTicketReceived;
|
|
40
|
+
static new(chainSpec, kind, onTicketReceived) {
|
|
41
|
+
return new ServerHandler(chainSpec, kind, onTicketReceived);
|
|
42
|
+
}
|
|
40
43
|
constructor(chainSpec, kind, onTicketReceived) {
|
|
41
44
|
this.chainSpec = chainSpec;
|
|
42
45
|
this.kind = kind;
|
|
@@ -53,6 +56,9 @@ export class ServerHandler {
|
|
|
53
56
|
export class ClientHandler {
|
|
54
57
|
chainSpec;
|
|
55
58
|
kind;
|
|
59
|
+
static new(chainSpec, kind) {
|
|
60
|
+
return new ClientHandler(chainSpec, kind);
|
|
61
|
+
}
|
|
56
62
|
constructor(chainSpec, kind) {
|
|
57
63
|
this.chainSpec = chainSpec;
|
|
58
64
|
this.kind = kind;
|
|
@@ -17,12 +17,12 @@ describe("CE 131 and CE 132: Safrole Ticket Distribution", () => {
|
|
|
17
17
|
it("Client sends a ticket distribution request and the server receives it", async () => {
|
|
18
18
|
const handlers = testClientServer();
|
|
19
19
|
await new Promise((resolve) => {
|
|
20
|
-
handlers.server.registerHandlers(new
|
|
20
|
+
handlers.server.registerHandlers(ServerHandler.new(tinyChainSpec, STREAM_KIND_GENERATOR_TO_PROXY, (epochIndex, ticket) => {
|
|
21
21
|
assert.strictEqual(epochIndex, TEST_EPOCH);
|
|
22
22
|
assert.deepStrictEqual(ticket, TEST_TICKET);
|
|
23
23
|
resolve(undefined);
|
|
24
24
|
}));
|
|
25
|
-
handlers.client.registerHandlers(new
|
|
25
|
+
handlers.client.registerHandlers(ClientHandler.new(tinyChainSpec, STREAM_KIND_GENERATOR_TO_PROXY));
|
|
26
26
|
handlers.client.withNewStream(STREAM_KIND_GENERATOR_TO_PROXY, (handler, sender) => {
|
|
27
27
|
handler.sendTicket(sender, TEST_EPOCH, TEST_TICKET);
|
|
28
28
|
return OK;
|
|
@@ -29,8 +29,8 @@ export declare class CoreWorkPackage extends WithDebug {
|
|
|
29
29
|
lookupAnchorSlot: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"TimeSlot[u32]">, import("@typeberry/bytes").Bytes<4>>;
|
|
30
30
|
prerequisites: import("@typeberry/codec").Descriptor<(import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"WorkPackageHash">)[], import("@typeberry/codec").SequenceView<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"WorkPackageHash">, import("@typeberry/bytes").Bytes<32>>>;
|
|
31
31
|
}>>;
|
|
32
|
-
|
|
33
|
-
|
|
32
|
+
authToken: import("@typeberry/codec").Descriptor<BytesBlob, BytesBlob>;
|
|
33
|
+
authConfiguration: import("@typeberry/codec").Descriptor<BytesBlob, BytesBlob>;
|
|
34
34
|
items: import("@typeberry/codec").Descriptor<import("@typeberry/collections").FixedSizeArray<import("@typeberry/block").WorkItem, import("@typeberry/numbers").U8>, import("@typeberry/codec").SequenceView<import("@typeberry/block").WorkItem, import("@typeberry/codec").ViewOf<import("@typeberry/block").WorkItem, {
|
|
35
35
|
service: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"ServiceId[u32]">, import("@typeberry/bytes").Bytes<4>>;
|
|
36
36
|
codeHash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"CodeHash">, import("@typeberry/bytes").Bytes<32>>;
|
|
@@ -55,13 +55,16 @@ export declare class CoreWorkPackage extends WithDebug {
|
|
|
55
55
|
export declare class ServerHandler implements StreamHandler<typeof STREAM_KIND> {
|
|
56
56
|
private readonly onWorkPackage;
|
|
57
57
|
kind: 133 & import("@typeberry/numbers").WithBytesRepresentation<1>;
|
|
58
|
-
|
|
58
|
+
static new(onWorkPackage: (i: CoreIndex, w: WorkPackage, e: WorkPackageExtrinsics) => void): ServerHandler;
|
|
59
|
+
private constructor();
|
|
59
60
|
readonly workPackages: Map<string & import("@typeberry/utils").WithOpaque<"streamId">, CoreWorkPackage>;
|
|
60
61
|
onStreamMessage(sender: StreamMessageSender, message: BytesBlob): void;
|
|
61
62
|
onClose(streamId: StreamId): void;
|
|
62
63
|
}
|
|
63
64
|
export declare class ClientHandler implements StreamHandler<typeof STREAM_KIND> {
|
|
64
65
|
kind: 133 & import("@typeberry/numbers").WithBytesRepresentation<1>;
|
|
66
|
+
static new(): ClientHandler;
|
|
67
|
+
private constructor();
|
|
65
68
|
onStreamMessage(sender: StreamMessageSender): void;
|
|
66
69
|
onClose(_streamId: StreamId): void;
|
|
67
70
|
sendWorkPackage(sender: StreamMessageSender, coreIndex: CoreIndex, workPackage: WorkPackage, extrinsic: WorkPackageExtrinsics): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ce-133-work-package-submission.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jamnp-s/protocol/ce-133-work-package-submission.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,KAAK,qBAAqB,EAA2B,MAAM,+BAA+B,CAAC;AACpG,OAAO,EAAE,WAAW,EAAE,MAAM,kCAAkC,CAAC;AAC/D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,KAAK,WAAW,EAA2B,MAAM,kBAAkB,CAAC;AAE7E,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,KAAK,aAAa,EAAE,KAAK,QAAQ,EAAE,KAAK,mBAAmB,EAAmB,MAAM,aAAa,CAAC;AAE3G;;;;;;GAMG;AACH,eAAO,MAAM,WAAW,+DAAuB,CAAC;AAEhD,qBAAa,eAAgB,SAAQ,SAAS;aAW1B,SAAS,EAAE,SAAS;aACpB,WAAW,EAAE,WAAW;IAX1C,MAAM,CAAC,KAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QAGT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,SAAS,EAAE,WAAW,EAAE,EAAE,WAAW,CAAC,eAAe,CAAC;IAItE,OAAO;CAMR;AAID,qBAAa,aAAc,YAAW,aAAa,CAAC,OAAO,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"ce-133-work-package-submission.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jamnp-s/protocol/ce-133-work-package-submission.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,KAAK,qBAAqB,EAA2B,MAAM,+BAA+B,CAAC;AACpG,OAAO,EAAE,WAAW,EAAE,MAAM,kCAAkC,CAAC;AAC/D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,KAAK,WAAW,EAA2B,MAAM,kBAAkB,CAAC;AAE7E,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,KAAK,aAAa,EAAE,KAAK,QAAQ,EAAE,KAAK,mBAAmB,EAAmB,MAAM,aAAa,CAAC;AAE3G;;;;;;GAMG;AACH,eAAO,MAAM,WAAW,+DAAuB,CAAC;AAEhD,qBAAa,eAAgB,SAAQ,SAAS;aAW1B,SAAS,EAAE,SAAS;aACpB,WAAW,EAAE,WAAW;IAX1C,MAAM,CAAC,KAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QAGT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,SAAS,EAAE,WAAW,EAAE,EAAE,WAAW,CAAC,eAAe,CAAC;IAItE,OAAO;CAMR;AAID,qBAAa,aAAc,YAAW,aAAa,CAAC,OAAO,WAAW,CAAC;IAQnE,OAAO,CAAC,QAAQ,CAAC,aAAa;IAPhC,IAAI,gEAAe;IAEnB,MAAM,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC,CAAC,EAAE,SAAS,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,qBAAqB,KAAK,IAAI;IAI1F,OAAO;IAIP,SAAgB,YAAY,mFAAwC;IAEpE,eAAe,CAAC,MAAM,EAAE,mBAAmB,EAAE,OAAO,EAAE,SAAS,GAAG,IAAI;IAiBtE,OAAO,CAAC,QAAQ,EAAE,QAAQ,GAAG,IAAI;CAGlC;AAED,qBAAa,aAAc,YAAW,aAAa,CAAC,OAAO,WAAW,CAAC;IACrE,IAAI,gEAAe;IAEnB,MAAM,CAAC,GAAG;IAIV,OAAO;IAEP,eAAe,CAAC,MAAM,EAAE,mBAAmB,GAAG,IAAI;IAKlD,OAAO,CAAC,SAAS,EAAE,QAAQ,GAAG,IAAI;IAElC,eAAe,CACb,MAAM,EAAE,mBAAmB,EAC3B,SAAS,EAAE,SAAS,EACpB,WAAW,EAAE,WAAW,EACxB,SAAS,EAAE,qBAAqB;CAUnC"}
|
|
@@ -32,6 +32,9 @@ const logger = Logger.new(import.meta.filename, "protocol/ce-133");
|
|
|
32
32
|
export class ServerHandler {
|
|
33
33
|
onWorkPackage;
|
|
34
34
|
kind = STREAM_KIND;
|
|
35
|
+
static new(onWorkPackage) {
|
|
36
|
+
return new ServerHandler(onWorkPackage);
|
|
37
|
+
}
|
|
35
38
|
constructor(onWorkPackage) {
|
|
36
39
|
this.onWorkPackage = onWorkPackage;
|
|
37
40
|
}
|
|
@@ -58,6 +61,10 @@ export class ServerHandler {
|
|
|
58
61
|
}
|
|
59
62
|
export class ClientHandler {
|
|
60
63
|
kind = STREAM_KIND;
|
|
64
|
+
static new() {
|
|
65
|
+
return new ClientHandler();
|
|
66
|
+
}
|
|
67
|
+
constructor() { }
|
|
61
68
|
onStreamMessage(sender) {
|
|
62
69
|
logger.warn `[${sender.streamId}] Got unexpected message on CE-133 stream. Closing.`;
|
|
63
70
|
sender.close();
|
|
@@ -13,10 +13,10 @@ describe("CE133", () => {
|
|
|
13
13
|
it("should send a work package", async () => {
|
|
14
14
|
const handlers = testClientServer();
|
|
15
15
|
let receivedData = {};
|
|
16
|
-
const server = new
|
|
16
|
+
const server = ServerHandler.new((coreIndex, workPackage, extrinsic) => {
|
|
17
17
|
receivedData = { coreIndex, workPackage, extrinsic };
|
|
18
18
|
});
|
|
19
|
-
const client = new
|
|
19
|
+
const client = ClientHandler.new();
|
|
20
20
|
handlers.server.registerHandlers(server);
|
|
21
21
|
handlers.client.registerHandlers(client);
|
|
22
22
|
// when
|