@typeberry/lib 0.5.3-fb6e98a → 0.5.4-472e282

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.
Files changed (162) hide show
  1. package/package.json +1 -1
  2. package/packages/core/networking/certificate.d.ts.map +1 -1
  3. package/packages/core/networking/certificate.js +1 -0
  4. package/packages/core/networking/package.json +1 -1
  5. package/packages/core/networking/setup.d.ts.map +1 -1
  6. package/packages/core/networking/setup.js +16 -12
  7. package/packages/core/telemetry/package.json +1 -1
  8. package/packages/core/utils/compatibility.d.ts +0 -1
  9. package/packages/core/utils/compatibility.d.ts.map +1 -1
  10. package/packages/core/utils/compatibility.js +1 -2
  11. package/packages/core/utils/compatibility.test.js +6 -10
  12. package/packages/extensions/ipc/jamnp/handler.d.ts +5 -4
  13. package/packages/extensions/ipc/jamnp/handler.d.ts.map +1 -1
  14. package/packages/extensions/ipc/jamnp/handler.js +59 -34
  15. package/packages/extensions/ipc/jamnp/stream.d.ts +6 -4
  16. package/packages/extensions/ipc/jamnp/stream.d.ts.map +1 -1
  17. package/packages/jam/block/index.d.ts +11 -11
  18. package/packages/jam/block/index.d.ts.map +1 -1
  19. package/packages/jam/block/index.js +11 -11
  20. package/packages/jam/block/work-package.d.ts +3 -1
  21. package/packages/jam/block/work-package.d.ts.map +1 -1
  22. package/packages/jam/block/work-package.js +6 -2
  23. package/packages/jam/block-json/block.d.ts +125 -0
  24. package/packages/jam/block-json/block.d.ts.map +1 -1
  25. package/packages/jam/block-json/block.js +9 -2
  26. package/packages/jam/database-lmdb/states.test.js +3 -5
  27. package/packages/jam/fuzz-proto/v1/handler.d.ts +1 -1
  28. package/packages/jam/fuzz-proto/v1/handler.d.ts.map +1 -1
  29. package/packages/jam/fuzz-proto/v1/handler.js +43 -19
  30. package/packages/jam/fuzz-proto/v1/types.d.ts +1 -1
  31. package/packages/jam/jam-host-calls/accumulate/bless.d.ts.map +1 -1
  32. package/packages/jam/jam-host-calls/accumulate/bless.js +6 -10
  33. package/packages/jam/jam-host-calls/accumulate/bless.test.js +32 -72
  34. package/packages/jam/jam-host-calls/accumulate/new.d.ts.map +1 -1
  35. package/packages/jam/jam-host-calls/accumulate/new.js +2 -4
  36. package/packages/jam/jam-host-calls/accumulate/new.test.js +4 -5
  37. package/packages/jam/jam-host-calls/general/fetch.d.ts +1 -57
  38. package/packages/jam/jam-host-calls/general/fetch.d.ts.map +1 -1
  39. package/packages/jam/jam-host-calls/general/fetch.js +6 -29
  40. package/packages/jam/jam-host-calls/general/fetch.test.js +2 -58
  41. package/packages/jam/jamnp-s/peers.d.ts.map +1 -1
  42. package/packages/jam/jamnp-s/peers.js +10 -0
  43. package/packages/jam/jamnp-s/protocol/ce-128-block-request.d.ts +1 -1
  44. package/packages/jam/jamnp-s/protocol/ce-128-block-request.d.ts.map +1 -1
  45. package/packages/jam/jamnp-s/protocol/ce-128-block-request.js +10 -8
  46. package/packages/jam/jamnp-s/protocol/ce-129-state-request.d.ts.map +1 -1
  47. package/packages/jam/jamnp-s/protocol/ce-129-state-request.js +11 -9
  48. package/packages/jam/jamnp-s/protocol/ce-131-ce-132-safrole-ticket-distribution.d.ts +3 -3
  49. package/packages/jam/jamnp-s/protocol/ce-131-ce-132-safrole-ticket-distribution.d.ts.map +1 -1
  50. package/packages/jam/jamnp-s/protocol/ce-131-ce-132-safrole-ticket-distribution.js +2 -2
  51. package/packages/jam/jamnp-s/protocol/ce-133-work-package-submission.d.ts +6 -6
  52. package/packages/jam/jamnp-s/protocol/ce-133-work-package-submission.d.ts.map +1 -1
  53. package/packages/jam/jamnp-s/protocol/ce-133-work-package-submission.js +2 -2
  54. package/packages/jam/jamnp-s/protocol/ce-134-work-package-sharing.d.ts.map +1 -1
  55. package/packages/jam/jamnp-s/protocol/ce-134-work-package-sharing.js +8 -6
  56. package/packages/jam/jamnp-s/protocol/ce-135-work-report-distribution.d.ts +16 -16
  57. package/packages/jam/jamnp-s/protocol/ce-135-work-report-distribution.d.ts.map +1 -1
  58. package/packages/jam/jamnp-s/protocol/ce-135-work-report-distribution.js +2 -2
  59. package/packages/jam/jamnp-s/protocol/stream.d.ts +13 -7
  60. package/packages/jam/jamnp-s/protocol/stream.d.ts.map +1 -1
  61. package/packages/jam/jamnp-s/protocol/stream.js +5 -4
  62. package/packages/jam/jamnp-s/protocol/test-utils.d.ts +1 -1
  63. package/packages/jam/jamnp-s/protocol/test-utils.d.ts.map +1 -1
  64. package/packages/jam/jamnp-s/protocol/test-utils.js +9 -12
  65. package/packages/jam/jamnp-s/protocol/up-0-block-announcement.d.ts +2 -2
  66. package/packages/jam/jamnp-s/protocol/up-0-block-announcement.d.ts.map +1 -1
  67. package/packages/jam/jamnp-s/protocol/up-0-block-announcement.js +1 -1
  68. package/packages/jam/jamnp-s/stream-manager.d.ts.map +1 -1
  69. package/packages/jam/jamnp-s/stream-manager.js +7 -5
  70. package/packages/jam/jamnp-s/stream-manager.test.js +8 -5
  71. package/packages/jam/jamnp-s/tasks/sync.js +1 -1
  72. package/packages/jam/node/jam-config.d.ts +4 -1
  73. package/packages/jam/node/jam-config.d.ts.map +1 -1
  74. package/packages/jam/node/jam-config.js +6 -2
  75. package/packages/jam/node/main.d.ts.map +1 -1
  76. package/packages/jam/node/main.js +5 -4
  77. package/packages/jam/node/package.json +1 -1
  78. package/packages/jam/node/reader.d.ts +25 -25
  79. package/packages/jam/node/workers.d.ts +183 -183
  80. package/packages/jam/state/accumulation-queue.d.ts +26 -26
  81. package/packages/jam/state/assurances.d.ts +26 -26
  82. package/packages/jam/state/privileged-services.d.ts +1 -1
  83. package/packages/jam/state/privileged-services.d.ts.map +1 -1
  84. package/packages/jam/state/privileged-services.js +1 -6
  85. package/packages/jam/state/service.d.ts +1 -1
  86. package/packages/jam/state/service.d.ts.map +1 -1
  87. package/packages/jam/state/statistics.d.ts +0 -8
  88. package/packages/jam/state/statistics.d.ts.map +1 -1
  89. package/packages/jam/state/statistics.js +14 -44
  90. package/packages/jam/state/statistics.test.js +1 -8
  91. package/packages/jam/state/test.utils.d.ts +1 -1
  92. package/packages/jam/state/test.utils.d.ts.map +1 -1
  93. package/packages/jam/state/test.utils.js +4 -22
  94. package/packages/jam/state-json/accounts.d.ts +10 -0
  95. package/packages/jam/state-json/accounts.d.ts.map +1 -1
  96. package/packages/jam/state-json/accounts.js +47 -19
  97. package/packages/jam/state-json/dump.d.ts.map +1 -1
  98. package/packages/jam/state-json/dump.js +5 -9
  99. package/packages/jam/state-json/dump.test.js +2 -10
  100. package/packages/jam/state-json/statistics.d.ts +1 -1
  101. package/packages/jam/state-json/statistics.d.ts.map +1 -1
  102. package/packages/jam/state-json/statistics.js +1 -13
  103. package/packages/jam/state-merkleization/in-memory-state-codec.d.ts +29 -31
  104. package/packages/jam/state-merkleization/in-memory-state-codec.d.ts.map +1 -1
  105. package/packages/jam/state-merkleization/serialize.d.ts +4 -4
  106. package/packages/jam/state-merkleization/serialize.d.ts.map +1 -1
  107. package/packages/jam/state-merkleization/serialize.js +5 -8
  108. package/packages/jam/state-merkleization/serialized-state-view.d.ts.map +1 -1
  109. package/packages/jam/state-merkleization/state-entries.test.js +1 -7
  110. package/packages/jam/state-vectors/index.d.ts +377 -5
  111. package/packages/jam/state-vectors/index.d.ts.map +1 -1
  112. package/packages/jam/state-vectors/index.js +3 -3
  113. package/packages/jam/transition/accumulate/accumulate-state.d.ts +1 -2
  114. package/packages/jam/transition/accumulate/accumulate-state.d.ts.map +1 -1
  115. package/packages/jam/transition/accumulate/accumulate-utils.d.ts.map +1 -1
  116. package/packages/jam/transition/accumulate/accumulate-utils.js +2 -6
  117. package/packages/jam/transition/accumulate/accumulate-utils.test.js +2 -4
  118. package/packages/jam/transition/accumulate/accumulate.d.ts.map +1 -1
  119. package/packages/jam/transition/accumulate/accumulate.js +11 -20
  120. package/packages/jam/transition/accumulate/index.d.ts +0 -1
  121. package/packages/jam/transition/accumulate/index.d.ts.map +1 -1
  122. package/packages/jam/transition/accumulate/index.js +0 -1
  123. package/packages/jam/transition/accumulate/operand.d.ts +7 -7
  124. package/packages/jam/transition/chain-stf.d.ts +3 -5
  125. package/packages/jam/transition/chain-stf.d.ts.map +1 -1
  126. package/packages/jam/transition/chain-stf.js +5 -29
  127. package/packages/jam/transition/disputes/disputes.test.data2.d.ts +3 -3
  128. package/packages/jam/transition/disputes/disputes.test.data2.d.ts.map +1 -1
  129. package/packages/jam/transition/externalities/accumulate-externalities.d.ts.map +1 -1
  130. package/packages/jam/transition/externalities/accumulate-externalities.js +22 -49
  131. package/packages/jam/transition/externalities/accumulate-externalities.test.js +8 -72
  132. package/packages/jam/transition/externalities/fetch-externalities.d.ts +3 -22
  133. package/packages/jam/transition/externalities/fetch-externalities.d.ts.map +1 -1
  134. package/packages/jam/transition/externalities/fetch-externalities.js +3 -55
  135. package/packages/jam/transition/externalities/fetch-externalities.test.js +199 -112
  136. package/packages/jam/transition/reports/error.d.ts +3 -1
  137. package/packages/jam/transition/reports/error.d.ts.map +1 -1
  138. package/packages/jam/transition/reports/error.js +2 -0
  139. package/packages/jam/transition/reports/verify-basic.d.ts.map +1 -1
  140. package/packages/jam/transition/reports/verify-basic.js +10 -0
  141. package/packages/jam/transition/reports/verify-basic.test.js +29 -0
  142. package/packages/jam/transition/statistics.d.ts +0 -7
  143. package/packages/jam/transition/statistics.d.ts.map +1 -1
  144. package/packages/jam/transition/statistics.js +2 -11
  145. package/packages/jam/transition/statistics.test.js +0 -40
  146. package/packages/workers/block-authorship/generator.test.d.ts +2 -0
  147. package/packages/workers/block-authorship/generator.test.d.ts.map +1 -0
  148. package/packages/workers/block-authorship/generator.test.js +200 -0
  149. package/packages/workers/block-authorship/main.d.ts.map +1 -1
  150. package/packages/workers/block-authorship/main.js +23 -4
  151. package/packages/workers/block-authorship/package.json +1 -1
  152. package/packages/workers/block-authorship/protocol.d.ts +53 -51
  153. package/packages/workers/block-authorship/protocol.d.ts.map +1 -1
  154. package/packages/workers/block-authorship/protocol.js +6 -3
  155. package/packages/workers/importer/importer.d.ts.map +1 -1
  156. package/packages/workers/importer/importer.js +0 -1
  157. package/packages/workers/importer/package.json +1 -1
  158. package/packages/workers/importer/protocol.d.ts +54 -54
  159. package/packages/workers/jam-network/protocol.d.ts +79 -79
  160. package/packages/jam/transition/accumulate/deferred-transfers.d.ts +0 -36
  161. package/packages/jam/transition/accumulate/deferred-transfers.d.ts.map +0 -1
  162. package/packages/jam/transition/accumulate/deferred-transfers.js +0 -94
@@ -1,4 +1,129 @@
1
1
  import { Block } from "#@typeberry/block";
2
2
  import type { ChainSpec } from "#@typeberry/config";
3
3
  export declare const blockFromJson: (spec: ChainSpec) => import("@typeberry/json-parser").FromJsonWithParser<unknown, Block>;
4
+ export declare const blockViewFromJson: (spec: ChainSpec) => import("@typeberry/json-parser").FromJsonWithParser<unknown, import("@typeberry/codec").ViewOf<Block, {
5
+ header: import("@typeberry/codec").Descriptor<import("@typeberry/block").Header & import("@typeberry/codec").CodecRecord<import("@typeberry/block").Header>, import("@typeberry/codec").ViewOf<import("@typeberry/block").Header & import("@typeberry/codec").CodecRecord<import("@typeberry/block").Header>, {
6
+ parentHeaderHash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"HeaderHash">, import("@typeberry/bytes").Bytes<32>>;
7
+ priorStateRoot: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"StateRootHash">, import("@typeberry/bytes").Bytes<32>>;
8
+ extrinsicHash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"ExtrinsicHash">, import("@typeberry/bytes").Bytes<32>>;
9
+ timeSlotIndex: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"TimeSlot[u32]">, import("@typeberry/bytes").Bytes<4>>;
10
+ epochMarker: import("@typeberry/codec").Descriptor<import("@typeberry/block").EpochMarker | null, import("@typeberry/codec").ViewOf<import("@typeberry/block").EpochMarker, {
11
+ entropy: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"EntropyHash">, import("@typeberry/bytes").Bytes<32>>;
12
+ ticketsEntropy: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"EntropyHash">, import("@typeberry/bytes").Bytes<32>>;
13
+ validators: import("@typeberry/codec").Descriptor<readonly import("@typeberry/block").ValidatorKeys[] & import("@typeberry/utils").WithOpaque<"ValidatorsCount">, import("@typeberry/codec").SequenceView<import("@typeberry/block").ValidatorKeys, import("@typeberry/codec").ViewOf<import("@typeberry/block").ValidatorKeys, {
14
+ bandersnatch: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"BandersnatchKey">, import("@typeberry/bytes").Bytes<32>>;
15
+ ed25519: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"Ed25519Key">, import("@typeberry/bytes").Bytes<32>>;
16
+ }>>>;
17
+ }> | null>;
18
+ ticketsMarker: import("@typeberry/codec").Descriptor<import("@typeberry/block").TicketsMarker | null, import("@typeberry/codec").ViewOf<import("@typeberry/block").TicketsMarker, {
19
+ tickets: import("@typeberry/codec").Descriptor<readonly import("@typeberry/block").Ticket[] & import("@typeberry/utils").WithOpaque<"EpochLength">, import("@typeberry/codec").SequenceView<import("@typeberry/block").Ticket, import("@typeberry/codec").ViewOf<import("@typeberry/block").Ticket, {
20
+ id: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32>, import("@typeberry/bytes").Bytes<32>>;
21
+ attempt: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<1> & import("@typeberry/utils").WithOpaque<"TicketAttempt[0|1|2]">, import("@typeberry/numbers").U8>;
22
+ }>>>;
23
+ }> | null>;
24
+ bandersnatchBlockAuthorIndex: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<2> & import("@typeberry/utils").WithOpaque<"ValidatorIndex[u16]">, import("@typeberry/bytes").Bytes<2>>;
25
+ entropySource: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<96> & import("@typeberry/utils").WithOpaque<"BandersnatchVrfSignature">, import("@typeberry/bytes").Bytes<96>>;
26
+ offendersMarker: import("@typeberry/codec").Descriptor<(import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"Ed25519Key">)[], import("@typeberry/codec").SequenceView<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"Ed25519Key">, import("@typeberry/bytes").Bytes<32>>>;
27
+ seal: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<96> & import("@typeberry/utils").WithOpaque<"BandersnatchVrfSignature">, import("@typeberry/bytes").Bytes<96>>;
28
+ }>>;
29
+ extrinsic: import("@typeberry/codec").Descriptor<import("@typeberry/block").Extrinsic, import("@typeberry/codec").ViewOf<import("@typeberry/block").Extrinsic, {
30
+ tickets: import("@typeberry/codec").Descriptor<readonly import("@typeberry/block").SignedTicket[] & import("@typeberry/utils").WithOpaque<"Size: [0..chainSpec.maxTicketsPerExtrinsic)">, import("@typeberry/codec").SequenceView<import("@typeberry/block").SignedTicket, import("@typeberry/codec").ViewOf<import("@typeberry/block").SignedTicket, {
31
+ attempt: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<1> & import("@typeberry/utils").WithOpaque<"TicketAttempt[0|1|2]">, import("@typeberry/numbers").U8>;
32
+ signature: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<784> & import("@typeberry/utils").WithOpaque<"BandersnatchRingSignature">, import("@typeberry/bytes").Bytes<784>>;
33
+ }>>>;
34
+ preimages: import("@typeberry/codec").Descriptor<import("@typeberry/block").Preimage[], import("@typeberry/codec").SequenceView<import("@typeberry/block").Preimage, import("@typeberry/codec").ViewOf<import("@typeberry/block").Preimage, {
35
+ requester: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"ServiceId[u32]">, import("@typeberry/bytes").Bytes<4>>;
36
+ blob: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").BytesBlob, import("@typeberry/bytes").BytesBlob>;
37
+ }>>>;
38
+ guarantees: import("@typeberry/codec").Descriptor<readonly import("@typeberry/block").ReportGuarantee[] & import("@typeberry/utils").WithOpaque<"[0..CoresCount)">, import("@typeberry/codec").SequenceView<import("@typeberry/block").ReportGuarantee, import("@typeberry/codec").ViewOf<import("@typeberry/block").ReportGuarantee, {
39
+ report: import("@typeberry/codec").Descriptor<import("@typeberry/block").WorkReport, import("@typeberry/codec").ViewOf<import("@typeberry/block").WorkReport, {
40
+ workPackageSpec: import("@typeberry/codec").Descriptor<import("@typeberry/block").WorkPackageSpec, import("@typeberry/codec").ViewOf<import("@typeberry/block").WorkPackageSpec, {
41
+ hash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"WorkPackageHash">, import("@typeberry/bytes").Bytes<32>>;
42
+ length: import("@typeberry/codec").Descriptor<import("@typeberry/numbers").U32, import("@typeberry/bytes").Bytes<4>>;
43
+ erasureRoot: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32>, import("@typeberry/bytes").Bytes<32>>;
44
+ exportsRoot: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"ExportsRootHash">, import("@typeberry/bytes").Bytes<32>>;
45
+ exportsCount: import("@typeberry/codec").Descriptor<import("@typeberry/numbers").U16, import("@typeberry/bytes").Bytes<2>>;
46
+ }>>;
47
+ context: import("@typeberry/codec").Descriptor<import("@typeberry/block").RefineContext, import("@typeberry/codec").ViewOf<import("@typeberry/block").RefineContext, {
48
+ anchor: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"HeaderHash">, import("@typeberry/bytes").Bytes<32>>;
49
+ stateRoot: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"StateRootHash">, import("@typeberry/bytes").Bytes<32>>;
50
+ beefyRoot: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"BeefyHash">, import("@typeberry/bytes").Bytes<32>>;
51
+ lookupAnchor: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"HeaderHash">, import("@typeberry/bytes").Bytes<32>>;
52
+ lookupAnchorSlot: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"TimeSlot[u32]">, import("@typeberry/bytes").Bytes<4>>;
53
+ 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>>>;
54
+ }>>;
55
+ coreIndex: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<2> & import("@typeberry/utils").WithOpaque<"CoreIndex[u16]">, import("@typeberry/numbers").U32>;
56
+ authorizerHash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"AuthorizerHash">, import("@typeberry/bytes").Bytes<32>>;
57
+ authorizationGasUsed: import("@typeberry/codec").Descriptor<bigint & import("@typeberry/numbers").WithBytesRepresentation<8> & import("@typeberry/utils").WithOpaque<"ServiceGas[u64]">, import("@typeberry/numbers").U64>;
58
+ authorizationOutput: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").BytesBlob, import("@typeberry/bytes").BytesBlob>;
59
+ segmentRootLookup: import("@typeberry/codec").Descriptor<readonly import("@typeberry/block").WorkPackageInfo[], import("@typeberry/codec").SequenceView<import("@typeberry/block").WorkPackageInfo, import("@typeberry/codec").ViewOf<import("@typeberry/block").WorkPackageInfo, {
60
+ workPackageHash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"WorkPackageHash">, import("@typeberry/bytes").Bytes<32>>;
61
+ segmentTreeRoot: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"ExportsRootHash">, import("@typeberry/bytes").Bytes<32>>;
62
+ }>>>;
63
+ results: import("@typeberry/codec").Descriptor<import("@typeberry/collections").FixedSizeArray<import("@typeberry/block").WorkResult, import("@typeberry/numbers").U8>, import("@typeberry/codec").SequenceView<import("@typeberry/block").WorkResult, import("@typeberry/codec").ViewOf<import("@typeberry/block").WorkResult, {
64
+ serviceId: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"ServiceId[u32]">, import("@typeberry/bytes").Bytes<4>>;
65
+ codeHash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"CodeHash">, import("@typeberry/bytes").Bytes<32>>;
66
+ payloadHash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32>, import("@typeberry/bytes").Bytes<32>>;
67
+ gas: import("@typeberry/codec").Descriptor<bigint & import("@typeberry/numbers").WithBytesRepresentation<8> & import("@typeberry/utils").WithOpaque<"ServiceGas[u64]">, import("@typeberry/bytes").Bytes<8>>;
68
+ result: import("@typeberry/codec").Descriptor<import("@typeberry/block").WorkExecResult, {
69
+ kind: import("@typeberry/block").WorkExecResultKind.ok;
70
+ okBlob: import("@typeberry/bytes").BytesBlob;
71
+ } | {
72
+ kind: import("@typeberry/block").WorkExecResultKind.outOfGas;
73
+ } | {
74
+ kind: import("@typeberry/block").WorkExecResultKind.panic;
75
+ } | {
76
+ kind: import("@typeberry/block").WorkExecResultKind.incorrectNumberOfExports;
77
+ } | {
78
+ kind: import("@typeberry/block").WorkExecResultKind.digestTooBig;
79
+ } | {
80
+ kind: import("@typeberry/block").WorkExecResultKind.badCode;
81
+ } | {
82
+ kind: import("@typeberry/block").WorkExecResultKind.codeOversize;
83
+ }>;
84
+ load: import("@typeberry/codec").Descriptor<import("@typeberry/block").WorkRefineLoad, import("@typeberry/codec").ViewOf<import("@typeberry/block").WorkRefineLoad, {
85
+ gasUsed: import("@typeberry/codec").Descriptor<bigint & import("@typeberry/numbers").WithBytesRepresentation<8> & import("@typeberry/utils").WithOpaque<"ServiceGas[u64]">, import("@typeberry/numbers").U64>;
86
+ importedSegments: import("@typeberry/codec").Descriptor<import("@typeberry/numbers").U32, import("@typeberry/numbers").U32>;
87
+ extrinsicCount: import("@typeberry/codec").Descriptor<import("@typeberry/numbers").U32, import("@typeberry/numbers").U32>;
88
+ extrinsicSize: import("@typeberry/codec").Descriptor<import("@typeberry/numbers").U32, import("@typeberry/numbers").U32>;
89
+ exportedSegments: import("@typeberry/codec").Descriptor<import("@typeberry/numbers").U32, import("@typeberry/numbers").U32>;
90
+ }>>;
91
+ }>>>;
92
+ }>>;
93
+ slot: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"TimeSlot[u32]">, import("@typeberry/bytes").Bytes<4>>;
94
+ credentials: import("@typeberry/codec").Descriptor<(readonly import("@typeberry/block").Credential[] & import("@typeberry/utils").WithOpaque<"2">) | (readonly import("@typeberry/block").Credential[] & import("@typeberry/utils").WithOpaque<"3">), import("@typeberry/codec").SequenceView<import("@typeberry/block").Credential, import("@typeberry/codec").ViewOf<import("@typeberry/block").Credential, {
95
+ validatorIndex: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<2> & import("@typeberry/utils").WithOpaque<"ValidatorIndex[u16]">, import("@typeberry/bytes").Bytes<2>>;
96
+ signature: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<64> & import("@typeberry/utils").WithOpaque<"Ed25519Signature">, import("@typeberry/bytes").Bytes<64>>;
97
+ }>>>;
98
+ }>>>;
99
+ assurances: import("@typeberry/codec").Descriptor<readonly import("@typeberry/block").AvailabilityAssurance[] & import("@typeberry/utils").WithOpaque<"[0 .. ValidatorsCount)">, import("@typeberry/codec").SequenceView<import("@typeberry/block").AvailabilityAssurance, import("@typeberry/codec").ViewOf<import("@typeberry/block").AvailabilityAssurance, {
100
+ anchor: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"HeaderHash">, import("@typeberry/bytes").Bytes<32>>;
101
+ bitfield: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").BitVec, import("@typeberry/bytes").BitVec>;
102
+ validatorIndex: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<2> & import("@typeberry/utils").WithOpaque<"ValidatorIndex[u16]">, import("@typeberry/bytes").Bytes<2>>;
103
+ signature: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<64> & import("@typeberry/utils").WithOpaque<"Ed25519Signature">, import("@typeberry/bytes").Bytes<64>>;
104
+ }>>>;
105
+ disputes: import("@typeberry/codec").Descriptor<import("@typeberry/block").DisputesExtrinsic, import("@typeberry/codec").ViewOf<import("@typeberry/block").DisputesExtrinsic, {
106
+ verdicts: import("@typeberry/codec").Descriptor<import("@typeberry/block").Verdict[], import("@typeberry/codec").SequenceView<import("@typeberry/block").Verdict, import("@typeberry/codec").ViewOf<import("@typeberry/block").Verdict, {
107
+ workReportHash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"WorkReportHash">, import("@typeberry/bytes").Bytes<32>>;
108
+ votesEpoch: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"Epoch">, import("@typeberry/bytes").Bytes<4>>;
109
+ votes: import("@typeberry/codec").Descriptor<readonly import("@typeberry/block").Judgement[] & import("@typeberry/utils").WithOpaque<"Validators super majority">, import("@typeberry/codec").SequenceView<import("@typeberry/block").Judgement, import("@typeberry/codec").ViewOf<import("@typeberry/block").Judgement, {
110
+ isWorkReportValid: import("@typeberry/codec").Descriptor<boolean, boolean>;
111
+ index: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<2> & import("@typeberry/utils").WithOpaque<"ValidatorIndex[u16]">, import("@typeberry/bytes").Bytes<2>>;
112
+ signature: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<64> & import("@typeberry/utils").WithOpaque<"Ed25519Signature">, import("@typeberry/bytes").Bytes<64>>;
113
+ }>>>;
114
+ }>>>;
115
+ culprits: import("@typeberry/codec").Descriptor<import("@typeberry/block").Culprit[], import("@typeberry/codec").SequenceView<import("@typeberry/block").Culprit, import("@typeberry/codec").ViewOf<import("@typeberry/block").Culprit, {
116
+ workReportHash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"WorkReportHash">, import("@typeberry/bytes").Bytes<32>>;
117
+ key: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"Ed25519Key">, import("@typeberry/bytes").Bytes<32>>;
118
+ signature: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<64> & import("@typeberry/utils").WithOpaque<"Ed25519Signature">, import("@typeberry/bytes").Bytes<64>>;
119
+ }>>>;
120
+ faults: import("@typeberry/codec").Descriptor<import("@typeberry/block").Fault[], import("@typeberry/codec").SequenceView<import("@typeberry/block").Fault, import("@typeberry/codec").ViewOf<import("@typeberry/block").Fault, {
121
+ workReportHash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"WorkReportHash">, import("@typeberry/bytes").Bytes<32>>;
122
+ wasConsideredValid: import("@typeberry/codec").Descriptor<boolean, boolean>;
123
+ key: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"Ed25519Key">, import("@typeberry/bytes").Bytes<32>>;
124
+ signature: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<64> & import("@typeberry/utils").WithOpaque<"Ed25519Signature">, import("@typeberry/bytes").Bytes<64>>;
125
+ }>>>;
126
+ }>>;
127
+ }>>;
128
+ }>>;
4
129
  //# sourceMappingURL=block.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"block.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/block-json/block.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AACzC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAKnD,eAAO,MAAM,aAAa,GAAI,MAAM,SAAS,wEAO1C,CAAC"}
1
+ {"version":3,"file":"block.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/block-json/block.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAkB,MAAM,kBAAkB,CAAC;AACzD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAKnD,eAAO,MAAM,aAAa,GAAI,MAAM,SAAS,wEAO1C,CAAC;AAEJ,eAAO,MAAM,iBAAiB,GAAI,MAAM,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAMhD,CAAC"}
@@ -1,8 +1,15 @@
1
- import { Block } from "#@typeberry/block";
2
- import { json } from "#@typeberry/json-parser";
1
+ import { Block, reencodeAsView } from "#@typeberry/block";
2
+ import { json, parseFromJson } from "#@typeberry/json-parser";
3
3
  import { getExtrinsicFromJson } from "./extrinsic.js";
4
4
  import { headerFromJson } from "./header.js";
5
5
  export const blockFromJson = (spec) => json.object({
6
6
  header: headerFromJson,
7
7
  extrinsic: getExtrinsicFromJson(spec),
8
8
  }, ({ header, extrinsic }) => Block.create({ header, extrinsic }));
9
+ export const blockViewFromJson = (spec) => {
10
+ const parseBlock = blockFromJson(spec);
11
+ return json.fromAny((p) => {
12
+ const block = parseFromJson(p, parseBlock);
13
+ return reencodeAsView(Block.Codec, block, spec);
14
+ });
15
+ };
@@ -6,13 +6,13 @@ import { Bytes, BytesBlob } from "#@typeberry/bytes";
6
6
  import { SortedSet } from "#@typeberry/collections";
7
7
  import { tinyChainSpec } from "#@typeberry/config";
8
8
  import { Blake2b, HASH_SIZE } from "#@typeberry/hash";
9
- import { MAX_VALUE_U32, tryAsU32, tryAsU64 } from "#@typeberry/numbers";
9
+ import { tryAsU32, tryAsU64 } from "#@typeberry/numbers";
10
10
  import { InMemoryState, LookupHistoryItem, PrivilegedServices, ServiceAccountInfo, tryAsLookupHistorySlots, tryAsPerCore, UpdateService, } from "#@typeberry/state";
11
11
  import { testState } from "#@typeberry/state/test.utils.js";
12
12
  import { StateEntries } from "#@typeberry/state-merkleization";
13
13
  import { InMemoryTrie, leafComparator } from "#@typeberry/trie";
14
14
  import { getBlake2bTrieHasher } from "#@typeberry/trie/hasher.js";
15
- import { Compatibility, deepEqual, GpVersion, OK, Result } from "#@typeberry/utils";
15
+ import { deepEqual, OK, Result } from "#@typeberry/utils";
16
16
  import { LmdbRoot } from "./root.js";
17
17
  import { LmdbStates } from "./states.js";
18
18
  let blake2bTrieHasher;
@@ -73,9 +73,7 @@ describe("LMDB States database", () => {
73
73
  manager: tryAsServiceId(1),
74
74
  assigners: tryAsPerCore(new Array(spec.coresCount).fill(tryAsServiceId(2)), spec),
75
75
  delegator: tryAsServiceId(3),
76
- registrar: Compatibility.isGreaterOrEqual(GpVersion.V0_7_1)
77
- ? tryAsServiceId(4)
78
- : tryAsServiceId(MAX_VALUE_U32),
76
+ registrar: tryAsServiceId(4),
79
77
  autoAccumulateServices: new Map(),
80
78
  }),
81
79
  updated: new Map([
@@ -2,7 +2,7 @@ import type { BlockView, HeaderHash, StateRootHash } from "#@typeberry/block";
2
2
  import type { ChainSpec } from "#@typeberry/config";
3
3
  import { type Result } from "#@typeberry/utils";
4
4
  import type { IpcHandler, IpcSender } from "../server.js";
5
- import { type ErrorMessage, type Initialize, type KeyValue, type PeerInfo } from "./types.js";
5
+ import { ErrorMessage, type Initialize, type KeyValue, type PeerInfo } from "./types.js";
6
6
  /**
7
7
  * Handler interface for v1 fuzzer protocol messages.
8
8
  * https://github.com/davxy/jam-conformance/blob/main/fuzz-proto/fuzz-v1.asn
@@ -1 +1 @@
1
- {"version":3,"file":"handler.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/fuzz-proto/v1/handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAE7E,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAEnD,OAAO,EAAe,KAAK,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAC5D,OAAO,KAAK,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAC1D,OAAO,EACL,KAAK,YAAY,EAEjB,KAAK,UAAU,EACf,KAAK,QAAQ,EAKb,KAAK,QAAQ,EACd,MAAM,YAAY,CAAC;AAIpB;;;GAGG;AACH,MAAM,WAAW,kBAAkB;IACjC;;;OAGG;IACH,WAAW,CAAC,KAAK,EAAE,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;IAEhD;;;OAGG;IACH,UAAU,CAAC,MAAM,EAAE,UAAU,GAAG,OAAO,CAAC,aAAa,CAAC,CAAC;IAEvD;;;OAGG;IACH,WAAW,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,MAAM,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC,CAAC;IAE5E,gEAAgE;IAChE,kBAAkB,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC;CAC5D;AAED,qBAAa,UAAW,YAAW,UAAU;aAIzB,UAAU,EAAE,kBAAkB;aAC9B,MAAM,EAAE,SAAS;aACjB,IAAI,EAAE,SAAS;IALjC,OAAO,CAAC,eAAe,CAAK;gBAGV,UAAU,EAAE,kBAAkB,EAC9B,MAAM,EAAE,SAAS,EACjB,IAAI,EAAE,SAAS;IAG3B,eAAe,CAAC,GAAG,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;YAiBvC,iBAAiB;IAsG/B,OAAO,CAAC,EAAE,KAAK,EAAE,EAAE;QAAE,KAAK,CAAC,EAAE,KAAK,CAAA;KAAE,GAAG,IAAI;IAI3C,4DAA4D;IAC5D,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;CAGrC"}
1
+ {"version":3,"file":"handler.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/fuzz-proto/v1/handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAE7E,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAEnD,OAAO,EAAe,KAAK,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAC5D,OAAO,KAAK,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAC1D,OAAO,EACL,YAAY,EAEZ,KAAK,UAAU,EACf,KAAK,QAAQ,EAKb,KAAK,QAAQ,EACd,MAAM,YAAY,CAAC;AAIpB;;;GAGG;AACH,MAAM,WAAW,kBAAkB;IACjC;;;OAGG;IACH,WAAW,CAAC,KAAK,EAAE,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;IAEhD;;;OAGG;IACH,UAAU,CAAC,MAAM,EAAE,UAAU,GAAG,OAAO,CAAC,aAAa,CAAC,CAAC;IAEvD;;;OAGG;IACH,WAAW,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,MAAM,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC,CAAC;IAE5E,gEAAgE;IAChE,kBAAkB,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC;CAC5D;AAED,qBAAa,UAAW,YAAW,UAAU;aAIzB,UAAU,EAAE,kBAAkB;aAC9B,MAAM,EAAE,SAAS;aACjB,IAAI,EAAE,SAAS;IALjC,OAAO,CAAC,eAAe,CAAK;gBAGV,UAAU,EAAE,kBAAkB,EAC9B,MAAM,EAAE,SAAS,EACjB,IAAI,EAAE,SAAS;IAG3B,eAAe,CAAC,GAAG,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;YAiBvC,iBAAiB;IA2H/B,OAAO,CAAC,EAAE,KAAK,EAAE,EAAE;QAAE,KAAK,CAAC,EAAE,KAAK,CAAA;KAAE,GAAG,IAAI;IAI3C,4DAA4D;IAC5D,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;CAGrC"}
@@ -1,7 +1,7 @@
1
1
  import { Decoder, Encoder } from "#@typeberry/codec";
2
2
  import { Logger } from "#@typeberry/logger";
3
3
  import { assertNever } from "#@typeberry/utils";
4
- import { Features, MessageType, messageCodec, } from "./types.js";
4
+ import { ErrorMessage, Features, MessageType, messageCodec, } from "./types.js";
5
5
  const logger = Logger.new(import.meta.filename, "ext-ipc-fuzz-v1");
6
6
  export class FuzzTarget {
7
7
  msgHandler;
@@ -53,35 +53,59 @@ export class FuzzTarget {
53
53
  break;
54
54
  }
55
55
  case MessageType.Initialize: {
56
- const stateRoot = await this.msgHandler.initialize(message.value);
57
- response = {
58
- type: MessageType.StateRoot,
59
- value: stateRoot,
60
- };
61
- break;
62
- }
63
- case MessageType.ImportBlock: {
64
- const result = await this.msgHandler.importBlock(message.value);
65
- if (result.isOk) {
56
+ try {
57
+ const stateRoot = await this.msgHandler.initialize(message.value);
66
58
  response = {
67
59
  type: MessageType.StateRoot,
68
- value: result.ok,
60
+ value: stateRoot,
69
61
  };
70
62
  }
71
- else {
63
+ catch (e) {
72
64
  response = {
73
65
  type: MessageType.Error,
74
- value: result.error,
66
+ value: ErrorMessage.create({ message: `initialize error: ${e}` }),
67
+ };
68
+ }
69
+ break;
70
+ }
71
+ case MessageType.ImportBlock: {
72
+ try {
73
+ const result = await this.msgHandler.importBlock(message.value);
74
+ if (result.isOk) {
75
+ response = {
76
+ type: MessageType.StateRoot,
77
+ value: result.ok,
78
+ };
79
+ }
80
+ else {
81
+ response = {
82
+ type: MessageType.Error,
83
+ value: result.error,
84
+ };
85
+ }
86
+ }
87
+ catch (e) {
88
+ response = {
89
+ type: MessageType.Error,
90
+ value: ErrorMessage.create({ message: `importBlock error: ${e}` }),
75
91
  };
76
92
  }
77
93
  break;
78
94
  }
79
95
  case MessageType.GetState: {
80
- const state = await this.msgHandler.getSerializedState(message.value);
81
- response = {
82
- type: MessageType.State,
83
- value: state,
84
- };
96
+ try {
97
+ const state = await this.msgHandler.getSerializedState(message.value);
98
+ response = {
99
+ type: MessageType.State,
100
+ value: state,
101
+ };
102
+ }
103
+ catch (e) {
104
+ response = {
105
+ type: MessageType.Error,
106
+ value: ErrorMessage.create({ message: `getState error: ${e}` }),
107
+ };
108
+ }
85
109
  break;
86
110
  }
87
111
  case MessageType.StateRoot: {
@@ -138,7 +138,7 @@ export declare class Initialize extends WithDebug {
138
138
  }>>>;
139
139
  }> | null>;
140
140
  ticketsMarker: import("@typeberry/codec").Descriptor<import("@typeberry/block").TicketsMarker | null, import("@typeberry/codec").ViewOf<import("@typeberry/block").TicketsMarker, {
141
- tickets: import("@typeberry/codec").Descriptor<readonly import("@typeberry/block/tickets.js").Ticket[] & import("@typeberry/utils").WithOpaque<"EpochLength">, import("@typeberry/codec").SequenceView<import("@typeberry/block/tickets.js").Ticket, import("@typeberry/codec").ViewOf<import("@typeberry/block/tickets.js").Ticket, {
141
+ tickets: import("@typeberry/codec").Descriptor<readonly import("@typeberry/block").Ticket[] & import("@typeberry/utils").WithOpaque<"EpochLength">, import("@typeberry/codec").SequenceView<import("@typeberry/block").Ticket, import("@typeberry/codec").ViewOf<import("@typeberry/block").Ticket, {
142
142
  id: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32>, import("@typeberry/bytes").Bytes<32>>;
143
143
  attempt: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<1> & import("@typeberry/utils").WithOpaque<"TicketAttempt[0|1|2]">, U8>;
144
144
  }>>>;
@@ -1 +1 @@
1
- {"version":3,"file":"bless.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jam-host-calls/accumulate/bless.ts"],"names":[],"mappings":"AAAA,OAAO,EAAmB,KAAK,SAAS,EAAmC,MAAM,kBAAkB,CAAC;AAEpG,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAEnD,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AACpG,OAAO,EAAE,YAAY,EAAsC,MAAM,2BAA2B,CAAC;AAC7F,OAAO,EAAE,KAAK,WAAW,EAAiB,MAAM,0BAA0B,CAAC;AAU3E,OAAO,EAAE,KAAK,YAAY,EAAyB,MAAM,mCAAmC,CAAC;AAkB7F;;;;GAIG;AACH,qBAAa,KAAM,YAAW,eAAe;aAQzB,gBAAgB,EAAE,SAAS;IAC3C,OAAO,CAAC,QAAQ,CAAC,YAAY;IAC7B,OAAO,CAAC,QAAQ,CAAC,SAAS;IAT5B,KAAK,iIAA0B;IAC/B,YAAY,4HAAqB;IACjC,eAAe,uEAE8B;gBAG3B,gBAAgB,EAAE,SAAS,EAC1B,YAAY,EAAE,YAAY,EAC1B,SAAS,EAAE,SAAS;IAGjC,OAAO,CAAC,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,iBAAiB,EAAE,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,SAAS,GAAG,YAAY,CAAC;CAoFrH"}
1
+ {"version":3,"file":"bless.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jam-host-calls/accumulate/bless.ts"],"names":[],"mappings":"AAAA,OAAO,EAAmB,KAAK,SAAS,EAAmB,MAAM,kBAAkB,CAAC;AAEpF,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAEnD,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AACpG,OAAO,EAAE,YAAY,EAAsC,MAAM,2BAA2B,CAAC;AAC7F,OAAO,EAAE,KAAK,WAAW,EAAiB,MAAM,0BAA0B,CAAC;AAG3E,OAAO,EAAE,KAAK,YAAY,EAAyB,MAAM,mCAAmC,CAAC;AAkB7F;;;;GAIG;AACH,qBAAa,KAAM,YAAW,eAAe;aAMzB,gBAAgB,EAAE,SAAS;IAC3C,OAAO,CAAC,QAAQ,CAAC,YAAY;IAC7B,OAAO,CAAC,QAAQ,CAAC,SAAS;IAP5B,KAAK,iIAA0B;IAC/B,YAAY,4HAAqB;IACjC,eAAe,uEAAgD;gBAG7C,gBAAgB,EAAE,SAAS,EAC1B,YAAY,EAAE,YAAY,EAC1B,SAAS,EAAE,SAAS;IAGjC,OAAO,CAAC,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,iBAAiB,EAAE,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,SAAS,GAAG,YAAY,CAAC;CAkFrH"}
@@ -1,10 +1,10 @@
1
- import { tryAsServiceGas, tryAsServiceId } from "#@typeberry/block";
1
+ import { tryAsServiceGas } from "#@typeberry/block";
2
2
  import { codec, Decoder, tryAsExactBytes } from "#@typeberry/codec";
3
3
  import { tryAsU64 } from "#@typeberry/numbers";
4
4
  import { PvmExecution, traceRegisters, tryAsHostCallIndex } from "#@typeberry/pvm-host-calls";
5
5
  import { tryAsSmallGas } from "#@typeberry/pvm-interface";
6
6
  import { tryAsPerCore } from "#@typeberry/state";
7
- import { asOpaqueType, assertNever, Compatibility, GpVersion, lazyInspect, safeAllocUint8Array, } from "#@typeberry/utils";
7
+ import { asOpaqueType, assertNever, lazyInspect, safeAllocUint8Array } from "#@typeberry/utils";
8
8
  import { UpdatePrivilegesError } from "../externalities/partial-state.js";
9
9
  import { HostCallResult } from "../general/results.js";
10
10
  import { logger } from "../logger.js";
@@ -25,9 +25,7 @@ export class Bless {
25
25
  chainSpec;
26
26
  index = tryAsHostCallIndex(14);
27
27
  basicGasCost = tryAsSmallGas(10);
28
- tracedRegisters = Compatibility.isGreaterOrEqual(GpVersion.V0_7_1)
29
- ? traceRegisters(IN_OUT_REG, 8, 9, 10, 11, 12)
30
- : traceRegisters(IN_OUT_REG, 8, 9, 10, 11);
28
+ tracedRegisters = traceRegisters(IN_OUT_REG, 8, 9, 10, 11, 12);
31
29
  constructor(currentServiceId, partialState, chainSpec) {
32
30
  this.currentServiceId = currentServiceId;
33
31
  this.partialState = partialState;
@@ -41,13 +39,11 @@ export class Bless {
41
39
  // `v`: manages validator keys
42
40
  const delegator = getServiceId(regs.get(9));
43
41
  // `r`: manages creation of new services with id within protected range
44
- const registrar = Compatibility.isGreaterOrEqual(GpVersion.V0_7_1)
45
- ? getServiceId(regs.get(10))
46
- : tryAsServiceId(2 ** 32 - 1);
42
+ const registrar = getServiceId(regs.get(10));
47
43
  // `o`: memory offset
48
- const sourceStart = Compatibility.isGreaterOrEqual(GpVersion.V0_7_1) ? regs.get(11) : regs.get(10);
44
+ const sourceStart = regs.get(11);
49
45
  // `n`: number of items in the auto-accumulate dictionary
50
- const numberOfItems = Compatibility.isGreaterOrEqual(GpVersion.V0_7_1) ? regs.get(12) : regs.get(11);
46
+ const numberOfItems = regs.get(12);
51
47
  /*
52
48
  * `z`: array of key-value pairs serviceId -> gas that auto-accumulate every block
53
49
  * https://graypaper.fluffylabs.dev/#/7e6ff6a/368100368100?v=0.6.7
@@ -3,7 +3,7 @@ import { describe, it } from "node:test";
3
3
  import { tryAsServiceGas, tryAsServiceId } from "#@typeberry/block";
4
4
  import { codec, Encoder } from "#@typeberry/codec";
5
5
  import { tinyChainSpec } from "#@typeberry/config";
6
- import { MAX_VALUE_U32, MAX_VALUE_U64, tryAsU64 } from "#@typeberry/numbers";
6
+ import { MAX_VALUE_U64, tryAsU64 } from "#@typeberry/numbers";
7
7
  import { HostCallMemory, HostCallRegisters, PvmExecution } from "#@typeberry/pvm-host-calls";
8
8
  import { tryAsGas } from "#@typeberry/pvm-interface";
9
9
  import { gasCounter } from "#@typeberry/pvm-interpreter/gas.js";
@@ -11,7 +11,7 @@ import { MemoryBuilder, tryAsMemoryIndex } from "#@typeberry/pvm-interpreter/mem
11
11
  import { PAGE_SIZE } from "#@typeberry/pvm-interpreter/memory/memory-consts.js";
12
12
  import { tryAsSbrkIndex } from "#@typeberry/pvm-interpreter/memory/memory-index.js";
13
13
  import { codecPerCore, tryAsPerCore } from "#@typeberry/state";
14
- import { Compatibility, deepEqual, GpVersion, Result } from "#@typeberry/utils";
14
+ import { deepEqual, Result } from "#@typeberry/utils";
15
15
  import { UpdatePrivilegesError } from "../externalities/partial-state.js";
16
16
  import { PartialStateMock } from "../externalities/partial-state-mock.js";
17
17
  import { HostCallResult } from "../general/results.js";
@@ -23,8 +23,8 @@ const MANAGER_REG = 7;
23
23
  const AUTHORIZATION_REG = 8;
24
24
  const VALIDATOR_REG = 9;
25
25
  const REGISTRAR_REG = 10;
26
- const DICTIONARY_START = Compatibility.isGreaterOrEqual(GpVersion.V0_7_1) ? 11 : 10;
27
- const DICTIONARY_COUNT = Compatibility.isGreaterOrEqual(GpVersion.V0_7_1) ? 12 : 11;
26
+ const DICTIONARY_START = 11;
27
+ const DICTIONARY_COUNT = 12;
28
28
  function prepareServiceGasMap() {
29
29
  const entries = [];
30
30
  entries.push([tryAsServiceId(10_000), tryAsServiceGas(15_000)]);
@@ -68,7 +68,6 @@ function prepareRegsAndMemory(entries, authorizerData, { skipDictionary = false,
68
68
  };
69
69
  }
70
70
  describe("HostCalls: Bless", () => {
71
- const itPost071 = Compatibility.isGreaterOrEqual(GpVersion.V0_7_1) ? it : it.skip;
72
71
  it("should set new privileged services and auto-accumulate services", async () => {
73
72
  const accumulate = new PartialStateMock();
74
73
  const serviceId = tryAsServiceId(10_000);
@@ -81,28 +80,15 @@ describe("HostCalls: Bless", () => {
81
80
  // then
82
81
  assert.deepStrictEqual(result, undefined);
83
82
  assert.deepStrictEqual(registers.get(RESULT_REG), HostCallResult.OK);
84
- if (Compatibility.isGreaterOrEqual(GpVersion.V0_7_1)) {
85
- deepEqual(accumulate.privilegedServices, [
86
- [
87
- tryAsServiceId(5),
88
- tryAsPerCore([tryAsServiceId(10), tryAsServiceId(15)], tinyChainSpec),
89
- tryAsServiceId(20),
90
- tryAsServiceId(42),
91
- new Map(entries),
92
- ],
93
- ]);
94
- }
95
- else {
96
- deepEqual(accumulate.privilegedServices, [
97
- [
98
- tryAsServiceId(5),
99
- tryAsPerCore([tryAsServiceId(10), tryAsServiceId(15)], tinyChainSpec),
100
- tryAsServiceId(20),
101
- tryAsServiceId(MAX_VALUE_U32),
102
- new Map(entries),
103
- ],
104
- ]);
105
- }
83
+ deepEqual(accumulate.privilegedServices, [
84
+ [
85
+ tryAsServiceId(5),
86
+ tryAsPerCore([tryAsServiceId(10), tryAsServiceId(15)], tinyChainSpec),
87
+ tryAsServiceId(20),
88
+ tryAsServiceId(42),
89
+ new Map(entries),
90
+ ],
91
+ ]);
106
92
  });
107
93
  it("should return panic when dictionary is not readable", async () => {
108
94
  const accumulate = new PartialStateMock();
@@ -143,28 +129,15 @@ describe("HostCalls: Bless", () => {
143
129
  // then
144
130
  assert.deepStrictEqual(result, undefined);
145
131
  assert.deepStrictEqual(registers.get(RESULT_REG), HostCallResult.OK);
146
- if (Compatibility.isGreaterOrEqual(GpVersion.V0_7_1)) {
147
- deepEqual(accumulate.privilegedServices, [
148
- [
149
- tryAsServiceId(5),
150
- tryAsPerCore([tryAsServiceId(10), tryAsServiceId(15)], tinyChainSpec),
151
- tryAsServiceId(20),
152
- tryAsServiceId(42),
153
- new Map(entries),
154
- ],
155
- ]);
156
- }
157
- else {
158
- deepEqual(accumulate.privilegedServices, [
159
- [
160
- tryAsServiceId(5),
161
- tryAsPerCore([tryAsServiceId(10), tryAsServiceId(15)], tinyChainSpec),
162
- tryAsServiceId(20),
163
- tryAsServiceId(MAX_VALUE_U32),
164
- new Map(entries),
165
- ],
166
- ]);
167
- }
132
+ deepEqual(accumulate.privilegedServices, [
133
+ [
134
+ tryAsServiceId(5),
135
+ tryAsPerCore([tryAsServiceId(10), tryAsServiceId(15)], tinyChainSpec),
136
+ tryAsServiceId(20),
137
+ tryAsServiceId(42),
138
+ new Map(entries),
139
+ ],
140
+ ]);
168
141
  });
169
142
  it("should auto-accumulate services when dictionary contains duplicates", async () => {
170
143
  const accumulate = new PartialStateMock();
@@ -179,28 +152,15 @@ describe("HostCalls: Bless", () => {
179
152
  // then
180
153
  assert.deepStrictEqual(result, undefined);
181
154
  assert.deepStrictEqual(registers.get(RESULT_REG), HostCallResult.OK);
182
- if (Compatibility.isGreaterOrEqual(GpVersion.V0_7_1)) {
183
- deepEqual(accumulate.privilegedServices, [
184
- [
185
- tryAsServiceId(5),
186
- tryAsPerCore([tryAsServiceId(10), tryAsServiceId(15)], tinyChainSpec),
187
- tryAsServiceId(20),
188
- tryAsServiceId(42),
189
- new Map(entries),
190
- ],
191
- ]);
192
- }
193
- else {
194
- deepEqual(accumulate.privilegedServices, [
195
- [
196
- tryAsServiceId(5),
197
- tryAsPerCore([tryAsServiceId(10), tryAsServiceId(15)], tinyChainSpec),
198
- tryAsServiceId(20),
199
- tryAsServiceId(MAX_VALUE_U32),
200
- new Map(entries),
201
- ],
202
- ]);
203
- }
155
+ deepEqual(accumulate.privilegedServices, [
156
+ [
157
+ tryAsServiceId(5),
158
+ tryAsPerCore([tryAsServiceId(10), tryAsServiceId(15)], tinyChainSpec),
159
+ tryAsServiceId(20),
160
+ tryAsServiceId(42),
161
+ new Map(entries),
162
+ ],
163
+ ]);
204
164
  });
205
165
  it("should return HUH when service is unprivileged", async () => {
206
166
  const accumulate = new PartialStateMock();
@@ -247,7 +207,7 @@ describe("HostCalls: Bless", () => {
247
207
  assert.deepStrictEqual(registers.get(RESULT_REG), HostCallResult.WHO);
248
208
  assert.deepStrictEqual(accumulate.privilegedServices, []);
249
209
  });
250
- itPost071("should return WHO if given registrar is invalid", async () => {
210
+ it("should return WHO if given registrar is invalid", async () => {
251
211
  const accumulate = new PartialStateMock();
252
212
  accumulate.privilegedServicesResponse = Result.error(UpdatePrivilegesError.InvalidServiceId, () => "Test: invalid registrar service ID for bless");
253
213
  const serviceId = tryAsServiceId(11_000);
@@ -1 +1 @@
1
- {"version":3,"file":"new.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jam-host-calls/accumulate/new.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAmB,MAAM,kBAAkB,CAAC;AAInE,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AACpG,OAAO,EAAE,YAAY,EAAsC,MAAM,2BAA2B,CAAC;AAC7F,OAAO,EAAE,KAAK,WAAW,EAAiB,MAAM,0BAA0B,CAAC;AAE3E,OAAO,EAAmB,KAAK,YAAY,EAAE,MAAM,mCAAmC,CAAC;AAMvF;;;;GAIG;AACH,qBAAa,GAAI,YAAW,eAAe;aAQvB,gBAAgB,EAAE,SAAS;IAC3C,OAAO,CAAC,QAAQ,CAAC,YAAY;IAR/B,KAAK,iIAA0B;IAC/B,YAAY,4HAAqB;IACjC,eAAe,uEAE8B;gBAG3B,gBAAgB,EAAE,SAAS,EAC1B,YAAY,EAAE,YAAY;IAGvC,OAAO,CAAC,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,iBAAiB,EAAE,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,SAAS,GAAG,YAAY,CAAC;CA0DrH"}
1
+ {"version":3,"file":"new.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/jam-host-calls/accumulate/new.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAmB,MAAM,kBAAkB,CAAC;AAInE,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AACpG,OAAO,EAAE,YAAY,EAAsC,MAAM,2BAA2B,CAAC;AAC7F,OAAO,EAAE,KAAK,WAAW,EAAiB,MAAM,0BAA0B,CAAC;AAE3E,OAAO,EAAmB,KAAK,YAAY,EAAE,MAAM,mCAAmC,CAAC;AAMvF;;;;GAIG;AACH,qBAAa,GAAI,YAAW,eAAe;aAMvB,gBAAgB,EAAE,SAAS;IAC3C,OAAO,CAAC,QAAQ,CAAC,YAAY;IAN/B,KAAK,iIAA0B;IAC/B,YAAY,4HAAqB;IACjC,eAAe,uEAAgD;gBAG7C,gBAAgB,EAAE,SAAS,EAC1B,YAAY,EAAE,YAAY;IAGvC,OAAO,CAAC,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,iBAAiB,EAAE,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,SAAS,GAAG,YAAY,CAAC;CA0DrH"}
@@ -4,7 +4,7 @@ import { HASH_SIZE } from "#@typeberry/hash";
4
4
  import { tryAsU64 } from "#@typeberry/numbers";
5
5
  import { PvmExecution, traceRegisters, tryAsHostCallIndex } from "#@typeberry/pvm-host-calls";
6
6
  import { tryAsSmallGas } from "#@typeberry/pvm-interface";
7
- import { assertNever, Compatibility, GpVersion, resultToString } from "#@typeberry/utils";
7
+ import { assertNever, resultToString } from "#@typeberry/utils";
8
8
  import { NewServiceError } from "../externalities/partial-state.js";
9
9
  import { HostCallResult } from "../general/results.js";
10
10
  import { logger } from "../logger.js";
@@ -19,9 +19,7 @@ export class New {
19
19
  partialState;
20
20
  index = tryAsHostCallIndex(18);
21
21
  basicGasCost = tryAsSmallGas(10);
22
- tracedRegisters = Compatibility.isGreaterOrEqual(GpVersion.V0_7_1)
23
- ? traceRegisters(IN_OUT_REG, 8, 9, 10, 11, 12)
24
- : traceRegisters(IN_OUT_REG, 8, 9, 10, 11);
22
+ tracedRegisters = traceRegisters(IN_OUT_REG, 8, 9, 10, 11, 12);
25
23
  constructor(currentServiceId, partialState) {
26
24
  this.currentServiceId = currentServiceId;
27
25
  this.partialState = partialState;
@@ -10,7 +10,7 @@ import { gasCounter } from "#@typeberry/pvm-interpreter/gas.js";
10
10
  import { MemoryBuilder, tryAsMemoryIndex } from "#@typeberry/pvm-interpreter/memory/index.js";
11
11
  import { tryAsSbrkIndex } from "#@typeberry/pvm-interpreter/memory/memory-index.js";
12
12
  import { PAGE_SIZE } from "#@typeberry/pvm-interpreter/spi-decoder/memory-conts.js";
13
- import { Compatibility, GpVersion, Result } from "#@typeberry/utils";
13
+ import { Result } from "#@typeberry/utils";
14
14
  import { NewServiceError } from "../externalities/partial-state.js";
15
15
  import { PartialStateMock } from "../externalities/partial-state-mock.js";
16
16
  import { HostCallResult } from "../general/results.js";
@@ -46,7 +46,6 @@ wantedServiceId = tryAsU64(2 ** 32 - 1), { skipCodeHash = false } = {}) {
46
46
  };
47
47
  }
48
48
  describe("HostCalls: New", () => {
49
- const itPost071 = Compatibility.isGreaterOrEqual(GpVersion.V0_7_1) ? it : it.skip;
50
49
  it("should create a new service", async () => {
51
50
  const accumulate = new PartialStateMock();
52
51
  const serviceId = tryAsServiceId(10_000);
@@ -98,7 +97,7 @@ describe("HostCalls: New", () => {
98
97
  assert.deepStrictEqual(registers.get(RESULT_REG), HostCallResult.HUH);
99
98
  assert.deepStrictEqual(accumulate.newServiceCalled.length, 1);
100
99
  });
101
- itPost071("should create a new service with selected id", async () => {
100
+ it("should create a new service with selected id", async () => {
102
101
  const accumulate = new PartialStateMock();
103
102
  const serviceId = tryAsServiceId(10); // service has registrar privilege
104
103
  const n = new New(serviceId, accumulate);
@@ -113,7 +112,7 @@ describe("HostCalls: New", () => {
113
112
  [Bytes.fill(HASH_SIZE, 0x69), 4096n, 2n ** 40n, 2n ** 50n, gratisStorage, 42n],
114
113
  ]);
115
114
  });
116
- itPost071("should create a new service with random id", async () => {
115
+ it("should create a new service with random id", async () => {
117
116
  const accumulate = new PartialStateMock();
118
117
  const serviceId = tryAsServiceId(10_000); // service does not have registrar privilege
119
118
  const n = new New(serviceId, accumulate);
@@ -128,7 +127,7 @@ describe("HostCalls: New", () => {
128
127
  [Bytes.fill(HASH_SIZE, 0x69), 4096n, 2n ** 40n, 2n ** 50n, gratisStorage, 42n],
129
128
  ]);
130
129
  });
131
- itPost071("should fail when trying to set selected id, but service already exists", async () => {
130
+ it("should fail when trying to set selected id, but service already exists", async () => {
132
131
  const accumulate = new PartialStateMock();
133
132
  const serviceId = tryAsServiceId(10);
134
133
  const n = new New(serviceId, accumulate);