@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
|
@@ -40,10 +40,11 @@ export declare class WorkPackageSharingResponse extends WithDebug {
|
|
|
40
40
|
export declare class ServerHandler implements StreamHandler<typeof STREAM_KIND> {
|
|
41
41
|
private readonly onWorkPackage;
|
|
42
42
|
kind: 134 & import("@typeberry/numbers").WithBytesRepresentation<1>;
|
|
43
|
-
|
|
43
|
+
static new(onWorkPackage: (coreIndex: CoreIndex, segmentsRootMappings: WorkPackageInfo[], workPackageBundle: WorkPackageBundle) => Promise<{
|
|
44
44
|
workReportHash: WorkReportHash;
|
|
45
45
|
signature: Ed25519Signature;
|
|
46
|
-
}>);
|
|
46
|
+
}>): ServerHandler;
|
|
47
|
+
private constructor();
|
|
47
48
|
private readonly requestsMap;
|
|
48
49
|
private static sendWorkReport;
|
|
49
50
|
onStreamMessage(sender: StreamMessageSender, message: BytesBlob): void;
|
|
@@ -51,6 +52,8 @@ export declare class ServerHandler implements StreamHandler<typeof STREAM_KIND>
|
|
|
51
52
|
}
|
|
52
53
|
export declare class ClientHandler implements StreamHandler<typeof STREAM_KIND> {
|
|
53
54
|
kind: 134 & import("@typeberry/numbers").WithBytesRepresentation<1>;
|
|
55
|
+
static new(): ClientHandler;
|
|
56
|
+
private constructor();
|
|
54
57
|
private readonly pendingRequests;
|
|
55
58
|
onStreamMessage(sender: StreamMessageSender, message: BytesBlob): void;
|
|
56
59
|
onClose(streamId: StreamId): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ce-134-work-package-sharing.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jamnp-s/protocol/ce-134-work-package-sharing.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClE,OAAO,EAAE,eAAe,EAAE,MAAM,oCAAoC,CAAC;AACrE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,KAAK,WAAW,EAA2B,MAAM,kBAAkB,CAAC;AAC7E,OAAO,EAA2B,KAAK,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAGnF,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,KAAK,aAAa,EAAE,KAAK,QAAQ,EAAE,KAAK,mBAAmB,EAAmB,MAAM,aAAa,CAAC;AAE3G;;;;;;GAMG;AAIH,KAAK,iBAAiB,GAAG,SAAS,CAAC;AAGnC,eAAO,MAAM,WAAW,+DAAuB,CAAC;AAEhD,qBAAa,yBAA0B,SAAQ,SAAS;aAWpC,SAAS,EAAE,SAAS;aACpB,oBAAoB,EAAE,eAAe,EAAE;IAXzD,MAAM,CAAC,KAAK;;;;;;QAGT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,SAAS,EAAE,oBAAoB,EAAE,EAAE,WAAW,CAAC,yBAAyB,CAAC;IAIzF,OAAO;CAMR;AAED,qBAAa,0BAA2B,SAAQ,SAAS;aAWrC,cAAc,EAAE,cAAc;aAC9B,SAAS,EAAE,gBAAgB;IAX7C,MAAM,CAAC,KAAK;;;QAGT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,cAAc,EAAE,SAAS,EAAE,EAAE,WAAW,CAAC,0BAA0B,CAAC;IAIpF,OAAO;CAMR;AAID,qBAAa,aAAc,YAAW,aAAa,CAAC,OAAO,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"ce-134-work-package-sharing.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jamnp-s/protocol/ce-134-work-package-sharing.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClE,OAAO,EAAE,eAAe,EAAE,MAAM,oCAAoC,CAAC;AACrE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,KAAK,WAAW,EAA2B,MAAM,kBAAkB,CAAC;AAC7E,OAAO,EAA2B,KAAK,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAGnF,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,KAAK,aAAa,EAAE,KAAK,QAAQ,EAAE,KAAK,mBAAmB,EAAmB,MAAM,aAAa,CAAC;AAE3G;;;;;;GAMG;AAIH,KAAK,iBAAiB,GAAG,SAAS,CAAC;AAGnC,eAAO,MAAM,WAAW,+DAAuB,CAAC;AAEhD,qBAAa,yBAA0B,SAAQ,SAAS;aAWpC,SAAS,EAAE,SAAS;aACpB,oBAAoB,EAAE,eAAe,EAAE;IAXzD,MAAM,CAAC,KAAK;;;;;;QAGT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,SAAS,EAAE,oBAAoB,EAAE,EAAE,WAAW,CAAC,yBAAyB,CAAC;IAIzF,OAAO;CAMR;AAED,qBAAa,0BAA2B,SAAQ,SAAS;aAWrC,cAAc,EAAE,cAAc;aAC9B,SAAS,EAAE,gBAAgB;IAX7C,MAAM,CAAC,KAAK;;;QAGT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,cAAc,EAAE,SAAS,EAAE,EAAE,WAAW,CAAC,0BAA0B,CAAC;IAIpF,OAAO;CAMR;AAID,qBAAa,aAAc,YAAW,aAAa,CAAC,OAAO,WAAW,CAAC;IAcnE,OAAO,CAAC,QAAQ,CAAC,aAAa;IAbhC,IAAI,gEAAe;IAEnB,MAAM,CAAC,GAAG,CACR,aAAa,EAAE,CACb,SAAS,EAAE,SAAS,EACpB,oBAAoB,EAAE,eAAe,EAAE,EACvC,iBAAiB,EAAE,iBAAiB,KACjC,OAAO,CAAC;QAAE,cAAc,EAAE,cAAc,CAAC;QAAC,SAAS,EAAE,gBAAgB,CAAA;KAAE,CAAC;IAK/E,OAAO;IAQP,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAkD;IAE9E,OAAO,CAAC,MAAM,CAAC,cAAc;IAU7B,eAAe,CAAC,MAAM,EAAE,mBAAmB,EAAE,OAAO,EAAE,SAAS,GAAG,IAAI;IAsBtE,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,OAAO,CAAC,QAAQ,CAAC,eAAe,CAM5B;IAEJ,eAAe,CAAC,MAAM,EAAE,mBAAmB,EAAE,OAAO,EAAE,SAAS,GAAG,IAAI;IAatE,OAAO,CAAC,QAAQ,EAAE,QAAQ,GAAG,IAAI;IAQ3B,eAAe,CACnB,MAAM,EAAE,mBAAmB,EAC3B,SAAS,EAAE,SAAS,EACpB,oBAAoB,EAAE,eAAe,EAAE,EACvC,iBAAiB,EAAE,iBAAiB,GACnC,OAAO,CAAC;QAAE,cAAc,EAAE,cAAc,CAAC;QAAC,SAAS,EAAE,gBAAgB,CAAA;KAAE,CAAC;CAY5E"}
|
|
@@ -43,6 +43,9 @@ const logger = Logger.new(import.meta.filename, "protocol/ce-134");
|
|
|
43
43
|
export class ServerHandler {
|
|
44
44
|
onWorkPackage;
|
|
45
45
|
kind = STREAM_KIND;
|
|
46
|
+
static new(onWorkPackage) {
|
|
47
|
+
return new ServerHandler(onWorkPackage);
|
|
48
|
+
}
|
|
46
49
|
constructor(onWorkPackage) {
|
|
47
50
|
this.onWorkPackage = onWorkPackage;
|
|
48
51
|
}
|
|
@@ -76,6 +79,10 @@ export class ServerHandler {
|
|
|
76
79
|
}
|
|
77
80
|
export class ClientHandler {
|
|
78
81
|
kind = STREAM_KIND;
|
|
82
|
+
static new() {
|
|
83
|
+
return new ClientHandler();
|
|
84
|
+
}
|
|
85
|
+
constructor() { }
|
|
79
86
|
pendingRequests = new Map();
|
|
80
87
|
onStreamMessage(sender, message) {
|
|
81
88
|
const { streamId } = sender;
|
|
@@ -22,7 +22,7 @@ describe("CE 134: Work Package Sharing", () => {
|
|
|
22
22
|
it("Client sends a work package and the server returns a work report hash", async () => {
|
|
23
23
|
const handlers = testClientServer();
|
|
24
24
|
await new Promise((resolve) => {
|
|
25
|
-
const serverHandler = new
|
|
25
|
+
const serverHandler = ServerHandler.new((coreIndex, segmentsRootMappings, workPackageBundle) => {
|
|
26
26
|
assert.deepStrictEqual(coreIndex, MOCK_CORE_INDEX);
|
|
27
27
|
assert.deepStrictEqual(segmentsRootMappings, MOCK_SEGMENTS_ROOT_MAPPINGS);
|
|
28
28
|
assert.deepStrictEqual(workPackageBundle, MOCK_WORK_PACKAGE_BUNDLE);
|
|
@@ -32,7 +32,7 @@ describe("CE 134: Work Package Sharing", () => {
|
|
|
32
32
|
});
|
|
33
33
|
});
|
|
34
34
|
handlers.server.registerHandlers(serverHandler);
|
|
35
|
-
handlers.client.registerHandlers(new
|
|
35
|
+
handlers.client.registerHandlers(ClientHandler.new());
|
|
36
36
|
handlers.client.withNewStream(STREAM_KIND, (handler, sender) => {
|
|
37
37
|
handler
|
|
38
38
|
.sendWorkPackage(sender, MOCK_CORE_INDEX, MOCK_SEGMENTS_ROOT_MAPPINGS, MOCK_WORK_PACKAGE_BUNDLE)
|
|
@@ -87,14 +87,16 @@ export declare class ServerHandler implements StreamHandler<typeof STREAM_KIND>
|
|
|
87
87
|
private readonly chainSpec;
|
|
88
88
|
private readonly onWorkReport;
|
|
89
89
|
kind: 135 & import("@typeberry/numbers").WithBytesRepresentation<1>;
|
|
90
|
-
|
|
90
|
+
static new(chainSpec: ChainSpec, onWorkReport: (workReport: GuaranteedWorkReport) => void): ServerHandler;
|
|
91
|
+
private constructor();
|
|
91
92
|
onStreamMessage(sender: StreamMessageSender, message: BytesBlob): void;
|
|
92
93
|
onClose(_streamId: StreamId): void;
|
|
93
94
|
}
|
|
94
95
|
export declare class ClientHandler implements StreamHandler<typeof STREAM_KIND> {
|
|
95
96
|
private readonly chainSpec;
|
|
96
97
|
kind: 135 & import("@typeberry/numbers").WithBytesRepresentation<1>;
|
|
97
|
-
|
|
98
|
+
static new(chainSpec: ChainSpec): ClientHandler;
|
|
99
|
+
private constructor();
|
|
98
100
|
onStreamMessage(sender: StreamMessageSender): void;
|
|
99
101
|
onClose(_streamId: StreamId): void;
|
|
100
102
|
sendWorkReport(sender: StreamMessageSender, workReport: GuaranteedWorkReport): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ce-135-work-report-distribution.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jamnp-s/protocol/ce-135-work-report-distribution.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAEjD,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAC7D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,KAAK,WAAW,EAA2B,MAAM,kBAAkB,CAAC;AAC7E,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAC7D,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,WAAW,+DAAuB,CAAC;AAEhD,qBAAa,oBAAqB,SAAQ,SAAS;aAkB/B,MAAM,EAAE,UAAU;aAClB,IAAI,EAAE,QAAQ;aACd,UAAU,EAAE,cAAc,CAAC,UAAU,EAAE,sBAAsB,CAAC;IAnBhF,MAAM,CAAC,KAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QAUT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,EAAE,WAAW,CAAC,oBAAoB,CAAC;IAI7E,OAAO;CAOR;AAID,qBAAa,aAAc,YAAW,aAAa,CAAC,OAAO,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"ce-135-work-report-distribution.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jamnp-s/protocol/ce-135-work-report-distribution.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAEjD,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAC7D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,KAAK,WAAW,EAA2B,MAAM,kBAAkB,CAAC;AAC7E,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAC7D,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,WAAW,+DAAuB,CAAC;AAEhD,qBAAa,oBAAqB,SAAQ,SAAS;aAkB/B,MAAM,EAAE,UAAU;aAClB,IAAI,EAAE,QAAQ;aACd,UAAU,EAAE,cAAc,CAAC,UAAU,EAAE,sBAAsB,CAAC;IAnBhF,MAAM,CAAC,KAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QAUT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,EAAE,WAAW,CAAC,oBAAoB,CAAC;IAI7E,OAAO;CAOR;AAID,qBAAa,aAAc,YAAW,aAAa,CAAC,OAAO,WAAW,CAAC;IAQnE,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,YAAY;IAR/B,IAAI,gEAAe;IAEnB,MAAM,CAAC,GAAG,CAAC,SAAS,EAAE,SAAS,EAAE,YAAY,EAAE,CAAC,UAAU,EAAE,oBAAoB,KAAK,IAAI;IAIzF,OAAO;IAKP,eAAe,CAAC,MAAM,EAAE,mBAAmB,EAAE,OAAO,EAAE,SAAS,GAAG,IAAI;IAOtE,OAAO,CAAC,SAAS,EAAE,QAAQ;CAC5B;AAED,qBAAa,aAAc,YAAW,aAAa,CAAC,OAAO,WAAW,CAAC;IAOjD,OAAO,CAAC,QAAQ,CAAC,SAAS;IAN9C,IAAI,gEAAe;IAEnB,MAAM,CAAC,GAAG,CAAC,SAAS,EAAE,SAAS;IAI/B,OAAO;IAEP,eAAe,CAAC,MAAM,EAAE,mBAAmB,GAAG,IAAI;IAKlD,OAAO,CAAC,SAAS,EAAE,QAAQ,GAAG,IAAI;IAElC,cAAc,CAAC,MAAM,EAAE,mBAAmB,EAAE,UAAU,EAAE,oBAAoB;CAK7E"}
|
|
@@ -43,6 +43,9 @@ export class ServerHandler {
|
|
|
43
43
|
chainSpec;
|
|
44
44
|
onWorkReport;
|
|
45
45
|
kind = STREAM_KIND;
|
|
46
|
+
static new(chainSpec, onWorkReport) {
|
|
47
|
+
return new ServerHandler(chainSpec, onWorkReport);
|
|
48
|
+
}
|
|
46
49
|
constructor(chainSpec, onWorkReport) {
|
|
47
50
|
this.chainSpec = chainSpec;
|
|
48
51
|
this.onWorkReport = onWorkReport;
|
|
@@ -58,6 +61,9 @@ export class ServerHandler {
|
|
|
58
61
|
export class ClientHandler {
|
|
59
62
|
chainSpec;
|
|
60
63
|
kind = STREAM_KIND;
|
|
64
|
+
static new(chainSpec) {
|
|
65
|
+
return new ClientHandler(chainSpec);
|
|
66
|
+
}
|
|
61
67
|
constructor(chainSpec) {
|
|
62
68
|
this.chainSpec = chainSpec;
|
|
63
69
|
}
|
|
@@ -74,12 +74,12 @@ describe("CE 135: Work Report Distribution", () => {
|
|
|
74
74
|
it("Guarantor sends a work report and validator receives it", async () => {
|
|
75
75
|
const handlers = testClientServer();
|
|
76
76
|
await new Promise((resolve) => {
|
|
77
|
-
const serverHandler = new
|
|
77
|
+
const serverHandler = ServerHandler.new(tinyChainSpec, (workReport) => {
|
|
78
78
|
assert.deepStrictEqual(workReport, MOCK_GUARANTEED_WORK_REPORT);
|
|
79
79
|
resolve(undefined);
|
|
80
80
|
});
|
|
81
81
|
handlers.server.registerHandlers(serverHandler);
|
|
82
|
-
handlers.client.registerHandlers(new
|
|
82
|
+
handlers.client.registerHandlers(ClientHandler.new(tinyChainSpec));
|
|
83
83
|
handlers.client.withNewStream(STREAM_KIND, (handler, sender) => {
|
|
84
84
|
handler.sendWorkReport(sender, MOCK_GUARANTEED_WORK_REPORT);
|
|
85
85
|
return OK;
|
|
@@ -93,7 +93,8 @@ export declare class Handler implements StreamHandler<typeof STREAM_KIND> {
|
|
|
93
93
|
kind: 0 & import("@typeberry/numbers").WithBytesRepresentation<1>;
|
|
94
94
|
private readonly handshakes;
|
|
95
95
|
private readonly pendingHandshakes;
|
|
96
|
-
|
|
96
|
+
static new(spec: ChainSpec, getHandshake: () => Handshake, onAnnouncement: (streamId: StreamId, ann: Announcement) => void, onHandshake: (streamId: StreamId, handshake: Handshake) => void): Handler;
|
|
97
|
+
private constructor();
|
|
97
98
|
onStreamMessage(sender: StreamMessageSender, message: BytesBlob): void;
|
|
98
99
|
onClose(streamId: StreamId): void;
|
|
99
100
|
sendHandshake(sender: StreamMessageSender): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"up-0-block-announcement.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jamnp-s/protocol/up-0-block-announcement.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,KAAK,UAAU,EAAE,KAAK,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC1E,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;AAGnD,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,6DAAqB,CAAC;AAE9C,qBAAa,WAAY,SAAQ,SAAS;aAWtB,IAAI,EAAE,UAAU;aAChB,IAAI,EAAE,QAAQ;IAXhC,MAAM,CAAC,KAAK;;;QAGT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,WAAW,CAAC,WAAW,CAAC;IAItD,OAAO;CAMR;AAED;;GAEG;AACH,qBAAa,SAAS;IAWlB,4BAA4B;aACZ,KAAK,EAAE,WAAW;IAClC,sEAAsE;aACtD,KAAK,EAAE,WAAW,EAAE;IAbtC,MAAM,CAAC,KAAK;;;;;;;;;QAGT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,WAAW,CAAC,SAAS,CAAC;IAItD,OAAO;CAMR;AAED;;;GAGG;AACH,qBAAa,YAAa,SAAQ,SAAS;IAWvC,sDAAsD;aACtC,MAAM,EAAE,MAAM;IAC9B,4BAA4B;aACZ,KAAK,EAAE,WAAW;IAbpC,MAAM,CAAC,KAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QAGT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,WAAW,CAAC,YAAY,CAAC;IAI1D,OAAO;CAQR;AAID,qBAAa,OAAQ,YAAW,aAAa,CAAC,OAAO,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"up-0-block-announcement.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jamnp-s/protocol/up-0-block-announcement.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,KAAK,UAAU,EAAE,KAAK,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC1E,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;AAGnD,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,6DAAqB,CAAC;AAE9C,qBAAa,WAAY,SAAQ,SAAS;aAWtB,IAAI,EAAE,UAAU;aAChB,IAAI,EAAE,QAAQ;IAXhC,MAAM,CAAC,KAAK;;;QAGT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,WAAW,CAAC,WAAW,CAAC;IAItD,OAAO;CAMR;AAED;;GAEG;AACH,qBAAa,SAAS;IAWlB,4BAA4B;aACZ,KAAK,EAAE,WAAW;IAClC,sEAAsE;aACtD,KAAK,EAAE,WAAW,EAAE;IAbtC,MAAM,CAAC,KAAK;;;;;;;;;QAGT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,WAAW,CAAC,SAAS,CAAC;IAItD,OAAO;CAMR;AAED;;;GAGG;AACH,qBAAa,YAAa,SAAQ,SAAS;IAWvC,sDAAsD;aACtC,MAAM,EAAE,MAAM;IAC9B,4BAA4B;aACZ,KAAK,EAAE,WAAW;IAbpC,MAAM,CAAC,KAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QAGT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,WAAW,CAAC,YAAY,CAAC;IAI1D,OAAO;CAQR;AAID,qBAAa,OAAQ,YAAW,aAAa,CAAC,OAAO,WAAW,CAAC;IAgB7D,OAAO,CAAC,QAAQ,CAAC,IAAI;IACrB,OAAO,CAAC,QAAQ,CAAC,YAAY;IAC7B,OAAO,CAAC,QAAQ,CAAC,cAAc;IAC/B,OAAO,CAAC,QAAQ,CAAC,WAAW;IAlB9B,IAAI,8DAAe;IAEnB,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAuC;IAClE,OAAO,CAAC,QAAQ,CAAC,iBAAiB,CAAqC;IAEvE,MAAM,CAAC,GAAG,CACR,IAAI,EAAE,SAAS,EACf,YAAY,EAAE,MAAM,SAAS,EAC7B,cAAc,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,GAAG,EAAE,YAAY,KAAK,IAAI,EAC/D,WAAW,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,KAAK,IAAI;IAKjE,OAAO;IAOP,eAAe,CAAC,MAAM,EAAE,mBAAmB,EAAE,OAAO,EAAE,SAAS,GAAG,IAAI;IAqBtE,OAAO,CAAC,QAAQ,EAAE,QAAQ,GAAG,IAAI;IAKjC,aAAa,CAAC,MAAM,EAAE,mBAAmB;IAWzC,gBAAgB,CAAC,MAAM,EAAE,mBAAmB,EAAE,WAAW,EAAE,YAAY;CAUxE"}
|
|
@@ -83,6 +83,9 @@ export class Handler {
|
|
|
83
83
|
kind = STREAM_KIND;
|
|
84
84
|
handshakes = new Map();
|
|
85
85
|
pendingHandshakes = new Map();
|
|
86
|
+
static new(spec, getHandshake, onAnnouncement, onHandshake) {
|
|
87
|
+
return new Handler(spec, getHandshake, onAnnouncement, onHandshake);
|
|
88
|
+
}
|
|
86
89
|
constructor(spec, getHandshake, onAnnouncement, onHandshake) {
|
|
87
90
|
this.spec = spec;
|
|
88
91
|
this.getHandshake = getHandshake;
|
|
@@ -34,7 +34,8 @@ declare class QuicStreamSender implements StreamMessageSender {
|
|
|
34
34
|
private bufferedLength;
|
|
35
35
|
private bufferedData;
|
|
36
36
|
private currentWriterPromise;
|
|
37
|
-
|
|
37
|
+
static new(streamId: StreamId, internal: Stream, onError: StreamErrorCallback): QuicStreamSender;
|
|
38
|
+
private constructor();
|
|
38
39
|
/** Send given piece of data to the other end. */
|
|
39
40
|
bufferAndSend(data: BytesBlob, prefixWithLength?: boolean): boolean;
|
|
40
41
|
close(): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"stream-manager.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/jamnp-s/stream-manager.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAE7C,OAAO,EAGL,KAAK,IAAI,EACT,KAAK,MAAM,EACX,KAAK,MAAM,EACX,KAAK,mBAAmB,EAEzB,MAAM,uBAAuB,CAAC;AAE/B,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,kBAAkB,CAAC;AAC3C,OAAO,EACL,KAAK,aAAa,EAClB,KAAK,QAAQ,EAEb,KAAK,YAAY,EACjB,KAAK,mBAAmB,EAGzB,MAAM,sBAAsB,CAAC;AAK9B,qBAAa,aAAa;IACxB,mDAAmD;IACnD,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAA6C;IAC9E,mDAAmD;IACnD,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAA6C;IAE9E,8DAA8D;IAC9D,OAAO,CAAC,QAAQ,CAAC,OAAO,CAOV;IAEd,2DAA2D;IAC3D,OAAO,CAAC,QAAQ,CAAC,eAAe,CAA2C;IAE3E,uCAAuC;IACvC,wBAAwB,CAAC,GAAG,QAAQ,EAAE,aAAa,EAAE;IAMrD,uCAAuC;IACvC,wBAAwB,CAAC,GAAG,QAAQ,EAAE,aAAa,EAAE;IAMrD,yCAAyC;IACzC,OAAO,CAAC,QAAQ,EAAE,QAAQ,GAAG,IAAI,GAAG,IAAI;IAIxC,gDAAgD;IAC1C,aAAa;IAMnB,4DAA4D;IAC5D,gBAAgB,CAAC,QAAQ,SAAS,aAAa,EAC7C,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,YAAY,CAAC,QAAQ,CAAC,EAC5B,IAAI,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,gBAAgB,KAAK,EAAE,GACxD,IAAI;IAWP,4DAA4D;IAC5D,aAAa,CAAC,QAAQ,SAAS,aAAa,EAC1C,IAAI,EAAE,IAAI,EACV,IAAI,EAAE,YAAY,CAAC,QAAQ,CAAC,EAC5B,IAAI,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,gBAAgB,KAAK,EAAE,GACxD,IAAI;IAcP,iCAAiC;IAC3B,gBAAgB,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM;IA8BjD,OAAO,CAAC,cAAc;CA8CvB;AA4CD,cAAM,gBAAiB,YAAW,mBAAmB;
|
|
1
|
+
{"version":3,"file":"stream-manager.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/jamnp-s/stream-manager.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAE7C,OAAO,EAGL,KAAK,IAAI,EACT,KAAK,MAAM,EACX,KAAK,MAAM,EACX,KAAK,mBAAmB,EAEzB,MAAM,uBAAuB,CAAC;AAE/B,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,kBAAkB,CAAC;AAC3C,OAAO,EACL,KAAK,aAAa,EAClB,KAAK,QAAQ,EAEb,KAAK,YAAY,EACjB,KAAK,mBAAmB,EAGzB,MAAM,sBAAsB,CAAC;AAK9B,qBAAa,aAAa;IACxB,mDAAmD;IACnD,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAA6C;IAC9E,mDAAmD;IACnD,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAA6C;IAE9E,8DAA8D;IAC9D,OAAO,CAAC,QAAQ,CAAC,OAAO,CAOV;IAEd,2DAA2D;IAC3D,OAAO,CAAC,QAAQ,CAAC,eAAe,CAA2C;IAE3E,uCAAuC;IACvC,wBAAwB,CAAC,GAAG,QAAQ,EAAE,aAAa,EAAE;IAMrD,uCAAuC;IACvC,wBAAwB,CAAC,GAAG,QAAQ,EAAE,aAAa,EAAE;IAMrD,yCAAyC;IACzC,OAAO,CAAC,QAAQ,EAAE,QAAQ,GAAG,IAAI,GAAG,IAAI;IAIxC,gDAAgD;IAC1C,aAAa;IAMnB,4DAA4D;IAC5D,gBAAgB,CAAC,QAAQ,SAAS,aAAa,EAC7C,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,YAAY,CAAC,QAAQ,CAAC,EAC5B,IAAI,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,gBAAgB,KAAK,EAAE,GACxD,IAAI;IAWP,4DAA4D;IAC5D,aAAa,CAAC,QAAQ,SAAS,aAAa,EAC1C,IAAI,EAAE,IAAI,EACV,IAAI,EAAE,YAAY,CAAC,QAAQ,CAAC,EAC5B,IAAI,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,gBAAgB,KAAK,EAAE,GACxD,IAAI;IAcP,iCAAiC;IAC3B,gBAAgB,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM;IA8BjD,OAAO,CAAC,cAAc;CA8CvB;AA4CD,cAAM,gBAAiB,YAAW,mBAAmB;aAUjC,QAAQ,EAAE,QAAQ;IAClC,OAAO,CAAC,QAAQ,CAAC,QAAQ;IACzB,OAAO,CAAC,QAAQ,CAAC,OAAO;IAX1B,OAAO,CAAC,cAAc,CAAK;IAC3B,OAAO,CAAC,YAAY,CAAiD;IACrE,OAAO,CAAC,oBAAoB,CAA8B;IAE1D,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,mBAAmB;IAI7E,OAAO;IAMP,iDAAiD;IACjD,aAAa,CAAC,IAAI,EAAE,SAAS,EAAE,gBAAgB,UAAO,GAAG,OAAO;IAsChE,KAAK,IAAI,IAAI;IAab;;;;OAIG;IACH,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAGvB"}
|
|
@@ -104,7 +104,7 @@ export class StreamManager {
|
|
|
104
104
|
}
|
|
105
105
|
};
|
|
106
106
|
stream.addOnError(onError);
|
|
107
|
-
const quicStream = new
|
|
107
|
+
const quicStream = QuicStreamSender.new(streamId, stream, onError);
|
|
108
108
|
this.streams.set(streamId, {
|
|
109
109
|
handler,
|
|
110
110
|
streamSender: quicStream,
|
|
@@ -156,6 +156,9 @@ class QuicStreamSender {
|
|
|
156
156
|
bufferedLength = 0;
|
|
157
157
|
bufferedData = [];
|
|
158
158
|
currentWriterPromise = null;
|
|
159
|
+
static new(streamId, internal, onError) {
|
|
160
|
+
return new QuicStreamSender(streamId, internal, onError);
|
|
161
|
+
}
|
|
159
162
|
constructor(streamId, internal, onError) {
|
|
160
163
|
this.streamId = streamId;
|
|
161
164
|
this.internal = internal;
|
|
@@ -34,7 +34,7 @@ export class SyncTask {
|
|
|
34
34
|
// retrieve a peer for that stream
|
|
35
35
|
return streamManager.getPeer(streamId);
|
|
36
36
|
};
|
|
37
|
-
const up0Handler =
|
|
37
|
+
const up0Handler = up0.Handler.new(spec, () => syncTask.getUp0Handshake(), (streamId, ann) => {
|
|
38
38
|
const peer = getPeerForStream(streamId);
|
|
39
39
|
if (peer !== null) {
|
|
40
40
|
syncTask.onUp0Annoucement(peer, ann);
|
|
@@ -47,7 +47,7 @@ export class SyncTask {
|
|
|
47
47
|
});
|
|
48
48
|
// server mode
|
|
49
49
|
streamManager.registerIncomingHandlers(up0Handler);
|
|
50
|
-
streamManager.registerIncomingHandlers(
|
|
50
|
+
streamManager.registerIncomingHandlers(ce128.ServerHandler.new(spec, (streamId, hash, direction, maxBlocks) => {
|
|
51
51
|
const peer = streamManager.getPeer(streamId);
|
|
52
52
|
if (peer !== null) {
|
|
53
53
|
return syncTask.handleGetBlockSequence(peer, hash, direction, maxBlocks);
|
|
@@ -56,7 +56,7 @@ export class SyncTask {
|
|
|
56
56
|
}));
|
|
57
57
|
// client mode
|
|
58
58
|
streamManager.registerOutgoingHandlers(up0Handler);
|
|
59
|
-
streamManager.registerOutgoingHandlers(
|
|
59
|
+
streamManager.registerOutgoingHandlers(ce128.ClientHandler.new(spec));
|
|
60
60
|
return syncTask;
|
|
61
61
|
}
|
|
62
62
|
// Other's best header hash with timeslot
|
|
@@ -283,5 +283,5 @@ export var SyncResult;
|
|
|
283
283
|
})(SyncResult || (SyncResult = {}));
|
|
284
284
|
function hashHeader(blake2b, header, spec) {
|
|
285
285
|
const encoded = Encoder.encodeObject(Header.Codec, header, spec);
|
|
286
|
-
return new
|
|
286
|
+
return WithHash.new(blake2b.hashBytes(encoded).asOpaque(), header);
|
|
287
287
|
}
|
|
@@ -34,7 +34,7 @@ describe("SyncTask", () => {
|
|
|
34
34
|
async function init(name, ourBlocks = []) {
|
|
35
35
|
const network = new MockNetwork(name);
|
|
36
36
|
const streamManager = new StreamManager();
|
|
37
|
-
const connections = new
|
|
37
|
+
const connections = Connections.new(network);
|
|
38
38
|
const blocksDb = await setupTestDatabase(ourBlocks);
|
|
39
39
|
const receivedBlocks = [];
|
|
40
40
|
const onNewBlocks = (blocks) => {
|
|
@@ -160,7 +160,7 @@ describe("SyncTask", () => {
|
|
|
160
160
|
deepEqual(p.syncTask.maintainSync().kind, SyncResult.NoNewBlocks);
|
|
161
161
|
}
|
|
162
162
|
// Send broadcast
|
|
163
|
-
self.syncTask.broadcastHeader(new
|
|
163
|
+
self.syncTask.broadcastHeader(WithHash.new(newBlock.hash, toHeaderView(newBlock.data.header)));
|
|
164
164
|
await tick();
|
|
165
165
|
for (const p of peers) {
|
|
166
166
|
deepEqual(p.syncTask.maintainSync(), {
|
|
@@ -203,7 +203,7 @@ function createTestBlock(options = {}) {
|
|
|
203
203
|
const block = Block.create({ ...baseBlock, header });
|
|
204
204
|
const view = toBlockView(block);
|
|
205
205
|
const headerHash = blake2b.hashBytes(view.header.encoded());
|
|
206
|
-
return new
|
|
206
|
+
return WithHash.new(headerHash.asOpaque(), block);
|
|
207
207
|
}
|
|
208
208
|
async function setupTestDatabase(inBlocks = []) {
|
|
209
209
|
const db = InMemoryBlocks.new();
|
|
@@ -217,7 +217,7 @@ async function setupTestDatabase(inBlocks = []) {
|
|
|
217
217
|
for (let i = 0; i < blocks.length; i++) {
|
|
218
218
|
const block = blocks[i];
|
|
219
219
|
const blockView = toBlockView(block.data);
|
|
220
|
-
await db.insertBlock(new
|
|
220
|
+
await db.insertBlock(WithHash.new(block.hash, blockView));
|
|
221
221
|
}
|
|
222
222
|
// Set the last block as best
|
|
223
223
|
if (blocks.length > 0) {
|
|
@@ -19,11 +19,11 @@ export class TicketDistributionTask {
|
|
|
19
19
|
static start(streamManager, connections, chainSpec) {
|
|
20
20
|
const task = new TicketDistributionTask(streamManager, connections);
|
|
21
21
|
// server mode: receive tickets from peers
|
|
22
|
-
streamManager.registerIncomingHandlers(
|
|
22
|
+
streamManager.registerIncomingHandlers(ce131.ServerHandler.new(chainSpec, ce131.STREAM_KIND_PROXY_TO_ALL, (epochIndex, ticket) => {
|
|
23
23
|
task.onTicketReceived(epochIndex, ticket);
|
|
24
24
|
}));
|
|
25
25
|
// client mode: send tickets to peers
|
|
26
|
-
streamManager.registerOutgoingHandlers(
|
|
26
|
+
streamManager.registerOutgoingHandlers(ce131.ClientHandler.new(chainSpec, ce131.STREAM_KIND_PROXY_TO_ALL));
|
|
27
27
|
return task;
|
|
28
28
|
}
|
|
29
29
|
/** Pending tickets waiting to be distributed to peers */
|
|
@@ -29,7 +29,7 @@ describe("TicketDistributionTask", () => {
|
|
|
29
29
|
async function init(name) {
|
|
30
30
|
const network = new MockNetwork(name);
|
|
31
31
|
const streamManager = new StreamManager();
|
|
32
|
-
const connections = new
|
|
32
|
+
const connections = Connections.new(network);
|
|
33
33
|
// Track received tickets for verification
|
|
34
34
|
const receivedTickets = [];
|
|
35
35
|
// Use real TicketDistributionTask
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"common.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/node/common.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"common.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/node/common.ts"],"names":[],"mappings":"AAAA,OAAO,EAA6B,KAAK,UAAU,EAAkB,KAAK,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC7G,OAAO,EAAE,KAAK,EAAE,KAAK,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAEzD,OAAO,EAAE,KAAK,SAAS,EAAgC,MAAM,mBAAmB,CAAC;AACjF,OAAO,EAAE,KAAK,YAAY,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAC3E,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAChF,OAAO,EAAE,KAAK,OAAO,EAAuB,MAAM,iBAAiB,CAAC;AACpE,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAG3C,eAAO,MAAM,MAAM,QAA0C,CAAC;AAE9D,wBAAgB,YAAY,CAAC,IAAI,EAAE,cAAc,aAUhD;AAED,wBAAgB,eAAe,CAC7B,OAAO,EAAE,OAAO,EAChB,QAAQ,EAAE,MAAM,EAChB,aAAa,EAAE,SAAS,EACxB,gBAAgB,EAAE,MAAM;;;EAWzB;AAED;;;;GAIG;AACH,MAAM,MAAM,aAAa,GAAG;IAC1B,uBAAuB,CAAC,EAAE,OAAO,CAAC;CACnC,CAAC;AAEF,wBAAsB,kBAAkB,CACtC,IAAI,EAAE,SAAS,EACf,OAAO,EAAE,OAAO,EAChB,iBAAiB,EAAE,UAAU,EAC7B,MAAM,EAAE,MAAM,CAAC,QAAQ,EAAE,kBAAkB,CAAC,EAC5C,MAAM,EAAE,YAAY,EACpB,QAAQ,EAAE,CAAC,UAAU,EAAE,QAAQ,CAAC,EAAE,EAClC,OAAO,GAAE,aAAkB,GAC1B,OAAO,CAAC,IAAI,CAAC,CAuCf"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Block, emptyBlock, Header, reencodeAsView
|
|
1
|
+
import { Block, emptyBlock, Header, reencodeAsView } from "#@typeberry/block";
|
|
2
2
|
import { Bytes } from "#@typeberry/bytes";
|
|
3
3
|
import { Decoder } from "#@typeberry/codec";
|
|
4
4
|
import { fullChainSpec, tinyChainSpec } from "#@typeberry/config";
|
|
@@ -49,10 +49,10 @@ export async function initializeDatabase(spec, blake2b, genesisHeaderHash, rootD
|
|
|
49
49
|
// write to db
|
|
50
50
|
// When initGenesisFromAncestry is set, use ancestry[0][0] as the initial block hash (for fuzz-target mode)
|
|
51
51
|
const initialBlockHash = (options.initGenesisFromAncestry ?? false) && ancestry.length > 0 ? ancestry[0][0] : genesisHeaderHash;
|
|
52
|
-
await blocks.insertBlock(new
|
|
52
|
+
await blocks.insertBlock(WithHash.new(initialBlockHash, blockView));
|
|
53
53
|
// insert fake blocks for ancestry data
|
|
54
54
|
for (const [hash, slot] of ancestry) {
|
|
55
|
-
await blocks.insertBlock(new
|
|
55
|
+
await blocks.insertBlock(WithHash.new(hash, reencodeAsView(Block.Codec, emptyBlock(slot), spec)));
|
|
56
56
|
}
|
|
57
57
|
await states.insertInitialState(initialBlockHash, genesisStateSerialized);
|
|
58
58
|
await blocks.setPostStateRoot(initialBlockHash, genesisStateRootHash);
|
|
@@ -13,7 +13,8 @@ type SubscriptionEventMap = {
|
|
|
13
13
|
};
|
|
14
14
|
declare class SubscriptionEventEmitter extends EventEmitter<SubscriptionEventMap> {
|
|
15
15
|
readonly unsubscribe: () => Promise<void>;
|
|
16
|
-
|
|
16
|
+
static new(unsubscribe: () => Promise<void>): SubscriptionEventEmitter;
|
|
17
|
+
private constructor();
|
|
17
18
|
}
|
|
18
19
|
export declare class RpcClient {
|
|
19
20
|
private ws;
|
|
@@ -21,7 +22,8 @@ export declare class RpcClient {
|
|
|
21
22
|
private subscriptions;
|
|
22
23
|
private nextId;
|
|
23
24
|
private connectionPromise;
|
|
24
|
-
|
|
25
|
+
static new(url: string): RpcClient;
|
|
26
|
+
private constructor();
|
|
25
27
|
private setupWebSocket;
|
|
26
28
|
waitForConnection(): Promise<void>;
|
|
27
29
|
call<M extends MethodWithNoArgsName>(method: M, params?: InputOf<M>): Promise<OutputOf<M>>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/rpc-client/index.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,OAAO,EAKZ,KAAK,UAAU,EACf,KAAK,oBAAoB,EACzB,KAAK,QAAQ,EAGb,KAAK,sBAAsB,EAE5B,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC7C,OAAO,SAAS,MAAM,IAAI,CAAC;AAE3B,MAAM,WAAW,YAAY,CAAC,CAAC,SAAS,sBAAsB;IAC5D,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,CAAC,CAAC;IACV,YAAY,EAAE,wBAAwB,CAAC;CACxC;AAED,KAAK,oBAAoB,GAAG;IAC1B,IAAI,EAAE,CAAC,OAAO,CAAC,CAAC;IAChB,KAAK,EAAE,CAAC,OAAO,CAAC,CAAC;IACjB,GAAG,EAAE,EAAE,CAAC;CACT,CAAC;AAEF,cAAM,wBAAyB,SAAQ,YAAY,CAAC,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/rpc-client/index.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,OAAO,EAKZ,KAAK,UAAU,EACf,KAAK,oBAAoB,EACzB,KAAK,QAAQ,EAGb,KAAK,sBAAsB,EAE5B,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC7C,OAAO,SAAS,MAAM,IAAI,CAAC;AAE3B,MAAM,WAAW,YAAY,CAAC,CAAC,SAAS,sBAAsB;IAC5D,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,CAAC,CAAC;IACV,YAAY,EAAE,wBAAwB,CAAC;CACxC;AAED,KAAK,oBAAoB,GAAG;IAC1B,IAAI,EAAE,CAAC,OAAO,CAAC,CAAC;IAChB,KAAK,EAAE,CAAC,OAAO,CAAC,CAAC;IACjB,GAAG,EAAE,EAAE,CAAC;CACT,CAAC;AAEF,cAAM,wBAAyB,SAAQ,YAAY,CAAC,oBAAoB,CAAC;IAKnD,QAAQ,CAAC,WAAW,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC;IAJ7D,MAAM,CAAC,GAAG,CAAC,WAAW,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC;IAI3C,OAAO;CAGR;AAID,qBAAa,SAAS;IACpB,OAAO,CAAC,EAAE,CAAY;IACtB,OAAO,CAAC,YAAY,CAA+D;IACnF,OAAO,CAAC,aAAa,CAAgE;IACrF,OAAO,CAAC,MAAM,CAAK;IACnB,OAAO,CAAC,iBAAiB,CAAgB;IAEzC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM;IAItB,OAAO;IAWP,OAAO,CAAC,cAAc;IAgDhB,iBAAiB,IAAI,OAAO,CAAC,IAAI,CAAC;IAIlC,IAAI,CAAC,CAAC,SAAS,oBAAoB,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;IAC1F,IAAI,CAAC,CAAC,SAAS,UAAU,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;IAqC/E,SAAS,CAAC,CAAC,SAAS,sBAAsB,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,wBAAwB,CAAC;YAOrG,WAAW;IAqBzB,KAAK,IAAI,IAAI;IAIb,SAAS,IAAI,SAAS;CAGvB"}
|
|
@@ -4,6 +4,9 @@ import { EventEmitter } from "eventemitter3";
|
|
|
4
4
|
import WebSocket from "ws";
|
|
5
5
|
class SubscriptionEventEmitter extends EventEmitter {
|
|
6
6
|
unsubscribe;
|
|
7
|
+
static new(unsubscribe) {
|
|
8
|
+
return new SubscriptionEventEmitter(unsubscribe);
|
|
9
|
+
}
|
|
7
10
|
constructor(unsubscribe) {
|
|
8
11
|
super();
|
|
9
12
|
this.unsubscribe = unsubscribe;
|
|
@@ -16,6 +19,9 @@ export class RpcClient {
|
|
|
16
19
|
subscriptions = new Map();
|
|
17
20
|
nextId = 1;
|
|
18
21
|
connectionPromise;
|
|
22
|
+
static new(url) {
|
|
23
|
+
return new RpcClient(url);
|
|
24
|
+
}
|
|
19
25
|
constructor(url) {
|
|
20
26
|
this.ws = new WebSocket(url);
|
|
21
27
|
this.connectionPromise = new Promise((resolve) => {
|
|
@@ -100,7 +106,7 @@ export class RpcClient {
|
|
|
100
106
|
}
|
|
101
107
|
async subscribe(method, params) {
|
|
102
108
|
const subscriptionId = await this.call(method, params);
|
|
103
|
-
const eventEmitter = new
|
|
109
|
+
const eventEmitter = SubscriptionEventEmitter.new(() => this.unsubscribe(subscriptionId));
|
|
104
110
|
this.subscriptions.set(subscriptionId, { id: subscriptionId, method, eventEmitter });
|
|
105
111
|
return eventEmitter;
|
|
106
112
|
}
|
|
@@ -16,7 +16,8 @@ import { type ValidatorData, type ValidatorDataView } from "./validator-data.js"
|
|
|
16
16
|
export declare class InMemoryStateView implements StateView {
|
|
17
17
|
private readonly chainSpec;
|
|
18
18
|
private readonly state;
|
|
19
|
-
|
|
19
|
+
static new(chainSpec: ChainSpec, state: State): InMemoryStateView;
|
|
20
|
+
private constructor();
|
|
20
21
|
availabilityAssignmentView(): AvailabilityAssignmentsView;
|
|
21
22
|
designatedValidatorDataView(): SequenceView<ValidatorData, ValidatorDataView>;
|
|
22
23
|
currentValidatorDataView(): SequenceView<ValidatorData, ValidatorDataView>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"in-memory-state-view.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/state/in-memory-state-view.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,KAAK,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,KAAK,qBAAqB,EAA0B,MAAM,yBAAyB,CAAC;AAC7F,OAAO,EAAE,KAAK,2BAA2B,EAAgC,MAAM,iBAAiB,CAAC;AACjG,OAAO,EAAE,KAAK,iBAAiB,EAAE,KAAK,kBAAkB,EAAmC,MAAM,WAAW,CAAC;AAC7G,OAAO,EAAgB,KAAK,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACzE,OAAO,EAAE,KAAK,uBAAuB,EAA4B,MAAM,2BAA2B,CAAC;AACnG,OAAO,EAAe,KAAK,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACtE,OAAO,EAAsB,KAAK,sBAAsB,EAAE,MAAM,cAAc,CAAC;AAC/E,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AACxC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAkB,KAAK,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAC1E,OAAO,EAAE,KAAK,aAAa,EAAE,KAAK,iBAAiB,EAAuB,MAAM,qBAAqB,CAAC;AAEtG,qBAAa,iBAAkB,YAAW,SAAS;
|
|
1
|
+
{"version":3,"file":"in-memory-state-view.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/state/in-memory-state-view.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,KAAK,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,KAAK,qBAAqB,EAA0B,MAAM,yBAAyB,CAAC;AAC7F,OAAO,EAAE,KAAK,2BAA2B,EAAgC,MAAM,iBAAiB,CAAC;AACjG,OAAO,EAAE,KAAK,iBAAiB,EAAE,KAAK,kBAAkB,EAAmC,MAAM,WAAW,CAAC;AAC7G,OAAO,EAAgB,KAAK,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACzE,OAAO,EAAE,KAAK,uBAAuB,EAA4B,MAAM,2BAA2B,CAAC;AACnG,OAAO,EAAe,KAAK,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACtE,OAAO,EAAsB,KAAK,sBAAsB,EAAE,MAAM,cAAc,CAAC;AAC/E,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AACxC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAkB,KAAK,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAC1E,OAAO,EAAE,KAAK,aAAa,EAAE,KAAK,iBAAiB,EAAuB,MAAM,qBAAqB,CAAC;AAEtG,qBAAa,iBAAkB,YAAW,SAAS;IAM/C,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,KAAK;IANxB,MAAM,CAAC,GAAG,CAAC,SAAS,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK;IAI7C,OAAO;IAKP,0BAA0B,IAAI,2BAA2B;IAIzD,2BAA2B,IAAI,YAAY,CAAC,aAAa,EAAE,iBAAiB,CAAC;IAI7E,wBAAwB,IAAI,YAAY,CAAC,aAAa,EAAE,iBAAiB,CAAC;IAI1E,yBAAyB,IAAI,YAAY,CAAC,aAAa,EAAE,iBAAiB,CAAC;IAI3E,aAAa,IAAI,YAAY,CAAC,iBAAiB,EAAE,YAAY,CAAC,cAAc,CAAC,CAAC;IAI9E,cAAc,IAAI,YAAY,CAAC,kBAAkB,EAAE,YAAY,CAAC,cAAc,CAAC,CAAC;IAIhF,gBAAgB,IAAI,gBAAgB;IAIpC,cAAc,IAAI,kBAAkB;IAIpC,qBAAqB,IAAI,qBAAqB;IAI9C,uBAAuB,IAAI,uBAAuB;IAIlD,eAAe,IAAI,eAAe;IAYlC,kBAAkB,CAAC,EAAE,EAAE,SAAS,GAAG,sBAAsB,GAAG,IAAI;CAQjE"}
|
|
@@ -11,6 +11,9 @@ import { validatorsDataCodec } from "./validator-data.js";
|
|
|
11
11
|
export class InMemoryStateView {
|
|
12
12
|
chainSpec;
|
|
13
13
|
state;
|
|
14
|
+
static new(chainSpec, state) {
|
|
15
|
+
return new InMemoryStateView(chainSpec, state);
|
|
16
|
+
}
|
|
14
17
|
constructor(chainSpec, state) {
|
|
15
18
|
this.chainSpec = chainSpec;
|
|
16
19
|
this.state = state;
|
|
@@ -31,6 +31,17 @@ export declare enum UpdateError {
|
|
|
31
31
|
/** Attempting to provide an existing preimage. */
|
|
32
32
|
PreimageExists = 2
|
|
33
33
|
}
|
|
34
|
+
/** Data backing an {@link InMemoryService}. */
|
|
35
|
+
export type InMemoryServiceData = {
|
|
36
|
+
/** https://graypaper.fluffylabs.dev/#/85129da/383303383303?v=0.6.3 */
|
|
37
|
+
info: ServiceAccountInfo;
|
|
38
|
+
/** https://graypaper.fluffylabs.dev/#/85129da/10f90010f900?v=0.6.3 */
|
|
39
|
+
readonly preimages: HashDictionary<PreimageHash, PreimageItem>;
|
|
40
|
+
/** https://graypaper.fluffylabs.dev/#/85129da/115400115800?v=0.6.3 */
|
|
41
|
+
readonly lookupHistory: HashDictionary<PreimageHash, LookupHistoryItem[]>;
|
|
42
|
+
/** https://graypaper.fluffylabs.dev/#/85129da/10f80010f800?v=0.6.3 */
|
|
43
|
+
readonly storage: Map<string, StorageItem>;
|
|
44
|
+
};
|
|
34
45
|
/**
|
|
35
46
|
* In-memory representation of the service.
|
|
36
47
|
*/
|
|
@@ -38,30 +49,14 @@ export declare class InMemoryService extends WithDebug implements Service {
|
|
|
38
49
|
/** Service id. */
|
|
39
50
|
readonly serviceId: ServiceId;
|
|
40
51
|
/** Service details. */
|
|
41
|
-
readonly data:
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
readonly preimages: HashDictionary<PreimageHash, PreimageItem>;
|
|
46
|
-
/** https://graypaper.fluffylabs.dev/#/85129da/115400115800?v=0.6.3 */
|
|
47
|
-
readonly lookupHistory: HashDictionary<PreimageHash, LookupHistoryItem[]>;
|
|
48
|
-
/** https://graypaper.fluffylabs.dev/#/85129da/10f80010f800?v=0.6.3 */
|
|
49
|
-
readonly storage: Map<string, StorageItem>;
|
|
50
|
-
};
|
|
51
|
-
constructor(
|
|
52
|
+
readonly data: InMemoryServiceData;
|
|
53
|
+
/** Create a new in-memory service wrapping the given id and data. */
|
|
54
|
+
static new(serviceId: ServiceId, data: InMemoryServiceData): InMemoryService;
|
|
55
|
+
protected constructor(
|
|
52
56
|
/** Service id. */
|
|
53
57
|
serviceId: ServiceId,
|
|
54
58
|
/** Service details. */
|
|
55
|
-
data:
|
|
56
|
-
/** https://graypaper.fluffylabs.dev/#/85129da/383303383303?v=0.6.3 */
|
|
57
|
-
info: ServiceAccountInfo;
|
|
58
|
-
/** https://graypaper.fluffylabs.dev/#/85129da/10f90010f900?v=0.6.3 */
|
|
59
|
-
readonly preimages: HashDictionary<PreimageHash, PreimageItem>;
|
|
60
|
-
/** https://graypaper.fluffylabs.dev/#/85129da/115400115800?v=0.6.3 */
|
|
61
|
-
readonly lookupHistory: HashDictionary<PreimageHash, LookupHistoryItem[]>;
|
|
62
|
-
/** https://graypaper.fluffylabs.dev/#/85129da/10f80010f800?v=0.6.3 */
|
|
63
|
-
readonly storage: Map<string, StorageItem>;
|
|
64
|
-
});
|
|
59
|
+
data: InMemoryServiceData);
|
|
65
60
|
getInfo(): ServiceAccountInfo;
|
|
66
61
|
getStorage(rawKey: StorageKey): BytesBlob | null;
|
|
67
62
|
hasPreimage(hash: PreimageHash): boolean;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"in-memory-state.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/state/in-memory-state.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,WAAW,EAChB,KAAK,YAAY,EACjB,KAAK,SAAS,EACd,KAAK,QAAQ,EAMd,MAAM,kBAAkB,CAAC;AAC1B,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAEjE,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,6BAA6B,CAAC;AAC1D,OAAO,EAAS,KAAK,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAEzD,OAAO,EAEL,cAAc,EACd,cAAc,EAEd,KAAK,cAAc,EACnB,WAAW,EAEZ,MAAM,wBAAwB,CAAC;AAChC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAEnD,OAAO,EAAgC,KAAK,oBAAoB,EAAE,MAAM,mCAAmC,CAAC;AAE5G,OAAO,EAA2B,KAAK,GAAG,EAAE,MAAM,oBAAoB,CAAC;AACvE,OAAO,EAAoC,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC3F,OAAO,EAAE,KAAK,kBAAkB,EAAgC,MAAM,0BAA0B,CAAC;AACjG,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AACjE,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EAA4B,KAAK,iBAAiB,EAAE,KAAK,kBAAkB,EAAE,MAAM,WAAW,CAAC;AACtG,OAAO,EAAE,KAAK,OAAO,EAAgB,MAAM,aAAa,CAAC;AACzD,OAAO,EAAE,eAAe,EAAkB,MAAM,eAAe,CAAC;AAEhE,OAAO,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAC9D,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AACrE,OAAO,EAAE,KAAK,kBAAkB,EAA0B,MAAM,mBAAmB,CAAC;AACpF,OAAO,EACL,iBAAiB,EACjB,KAAK,kBAAkB,EACvB,YAAY,EACZ,kBAAkB,EAClB,WAAW,EACX,KAAK,UAAU,EAEhB,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,eAAe,EAAE,KAAK,eAAe,EAAE,KAAK,OAAO,EAAE,KAAK,KAAK,EAAE,MAAM,YAAY,CAAC;AAC7F,OAAO,EACL,KAAK,cAAc,EAOpB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,KAAK,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChE,OAAO,EAAkB,cAAc,EAAuB,MAAM,iBAAiB,CAAC;AACtF,OAAO,EAAwB,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAE1E,oBAAY,WAAW;IACrB,0DAA0D;IAC1D,gBAAgB,IAAI;IACpB,mDAAmD;IACnD,SAAS,IAAI;IACb,kDAAkD;IAClD,cAAc,IAAI;CACnB;AAED
|
|
1
|
+
{"version":3,"file":"in-memory-state.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/state/in-memory-state.ts"],"names":[],"mappings":"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"}
|
|
@@ -35,6 +35,10 @@ export var UpdateError;
|
|
|
35
35
|
export class InMemoryService extends WithDebug {
|
|
36
36
|
serviceId;
|
|
37
37
|
data;
|
|
38
|
+
/** Create a new in-memory service wrapping the given id and data. */
|
|
39
|
+
static new(serviceId, data) {
|
|
40
|
+
return new InMemoryService(serviceId, data);
|
|
41
|
+
}
|
|
38
42
|
constructor(
|
|
39
43
|
/** Service id. */
|
|
40
44
|
serviceId,
|
|
@@ -74,7 +78,7 @@ export class InMemoryService extends WithDebug {
|
|
|
74
78
|
}
|
|
75
79
|
/** Return identical `InMemoryService` which does not share any references. */
|
|
76
80
|
clone() {
|
|
77
|
-
return new
|
|
81
|
+
return InMemoryService.new(this.serviceId, {
|
|
78
82
|
info: ServiceAccountInfo.create(this.data.info),
|
|
79
83
|
preimages: HashDictionary.fromEntries(Array.from(this.data.preimages.entries())),
|
|
80
84
|
lookupHistory: HashDictionary.fromEntries(Array.from(this.data.lookupHistory.entries()).map(([k, v]) => [k, v.slice()])),
|
|
@@ -105,7 +109,7 @@ export class InMemoryService extends WithDebug {
|
|
|
105
109
|
throw new Error(`Service ${service.serviceId} is missing expected lookupHistory: ${hash}, ${length}`);
|
|
106
110
|
}
|
|
107
111
|
const items = lookupHistory.get(hash) ?? [];
|
|
108
|
-
items.push(new
|
|
112
|
+
items.push(LookupHistoryItem.new(hash, length, slots));
|
|
109
113
|
lookupHistory.set(hash, items);
|
|
110
114
|
}
|
|
111
115
|
// copy storage
|
|
@@ -116,7 +120,7 @@ export class InMemoryService extends WithDebug {
|
|
|
116
120
|
}
|
|
117
121
|
storage.set(key.toString(), StorageItem.create({ key, value }));
|
|
118
122
|
}
|
|
119
|
-
return new
|
|
123
|
+
return InMemoryService.new(service.serviceId, {
|
|
120
124
|
info,
|
|
121
125
|
preimages,
|
|
122
126
|
storage,
|
|
@@ -274,7 +278,7 @@ export class InMemoryState extends WithDebug {
|
|
|
274
278
|
if (slot !== null) {
|
|
275
279
|
const lookupHistory = service.data.lookupHistory.get(preimage.hash);
|
|
276
280
|
const length = tryAsU32(preimage.blob.length);
|
|
277
|
-
const lookup = new
|
|
281
|
+
const lookup = LookupHistoryItem.new(preimage.hash, length, tryAsLookupHistorySlots([slot]));
|
|
278
282
|
if (lookupHistory === undefined) {
|
|
279
283
|
// no lookup history for that preimage at all (edge case, should be requested)
|
|
280
284
|
service.data.lookupHistory.set(preimage.hash, [lookup]);
|
|
@@ -321,7 +325,7 @@ export class InMemoryState extends WithDebug {
|
|
|
321
325
|
if (this.services.has(serviceId)) {
|
|
322
326
|
return Result.error(UpdateError.DuplicateService, () => `${serviceId} already exists!`);
|
|
323
327
|
}
|
|
324
|
-
this.services.set(serviceId, new
|
|
328
|
+
this.services.set(serviceId, InMemoryService.new(serviceId, {
|
|
325
329
|
info: account,
|
|
326
330
|
preimages: HashDictionary.new(),
|
|
327
331
|
storage: new Map(),
|
|
@@ -392,7 +396,7 @@ export class InMemoryState extends WithDebug {
|
|
|
392
396
|
this.services = s.services;
|
|
393
397
|
}
|
|
394
398
|
view() {
|
|
395
|
-
return new
|
|
399
|
+
return InMemoryStateView.new(this.chainSpec, this);
|
|
396
400
|
}
|
|
397
401
|
/**
|
|
398
402
|
* Create an empty and possibly incoherent `InMemoryState`.
|
|
@@ -322,7 +322,7 @@ describe("InMemoryState", () => {
|
|
|
322
322
|
assert.deepEqual(result, Result.ok(OK));
|
|
323
323
|
// Now UpdateOrAdd with different slot but same length
|
|
324
324
|
const slot2 = tryAsTimeSlot(2);
|
|
325
|
-
const newItem = new
|
|
325
|
+
const newItem = LookupHistoryItem.new(hash, tryAsU32(blob.length), tryAsLookupHistorySlots([slot2]));
|
|
326
326
|
result = state.applyUpdate({
|
|
327
327
|
preimages: new Map([
|
|
328
328
|
[
|
|
@@ -511,7 +511,7 @@ describe("InMemoryState", () => {
|
|
|
511
511
|
const slot2 = tryAsTimeSlot(2);
|
|
512
512
|
const length1 = tryAsU32(blob.length);
|
|
513
513
|
const length2 = tryAsU32(blob.length + 1); // simulate different-length record
|
|
514
|
-
const secondItem = new
|
|
514
|
+
const secondItem = LookupHistoryItem.new(hash, length2, tryAsLookupHistorySlots([slot2]));
|
|
515
515
|
result = state.applyUpdate({
|
|
516
516
|
preimages: new Map([
|
|
517
517
|
[
|
|
@@ -107,12 +107,8 @@ export declare class LookupHistoryItem {
|
|
|
107
107
|
* See PreimageStatus and the following GP fragment for more details.
|
|
108
108
|
* https://graypaper.fluffylabs.dev/#/5f542d7/11780011a500 */
|
|
109
109
|
readonly slots: LookupHistorySlots;
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
* Preimage availability history as a sequence of time slots.
|
|
113
|
-
* See PreimageStatus and the following GP fragment for more details.
|
|
114
|
-
* https://graypaper.fluffylabs.dev/#/5f542d7/11780011a500 */
|
|
115
|
-
slots: LookupHistorySlots);
|
|
110
|
+
static new(hash: PreimageHash, length: U32, slots: LookupHistorySlots): LookupHistoryItem;
|
|
111
|
+
private constructor();
|
|
116
112
|
static isRequested(item: LookupHistoryItem | LookupHistorySlots): boolean;
|
|
117
113
|
}
|
|
118
114
|
export {};
|