@typeberry/lib 0.5.2 → 0.5.3-5a6cfcc

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 (179) hide show
  1. package/package.json +9 -5
  2. package/packages/core/collections/blob-dictionary.d.ts.map +1 -1
  3. package/packages/core/collections/blob-dictionary.js +3 -3
  4. package/packages/core/crypto/bandersnatch.d.ts +2 -1
  5. package/packages/core/crypto/bandersnatch.d.ts.map +1 -1
  6. package/packages/core/crypto/bandersnatch.js +9 -2
  7. package/packages/core/crypto/key-derivation.test.js +8 -7
  8. package/packages/core/hash/hash.d.ts.map +1 -1
  9. package/packages/core/hash/hash.js +1 -0
  10. package/packages/core/networking/certificate.d.ts.map +1 -1
  11. package/packages/core/networking/certificate.js +1 -0
  12. package/packages/core/networking/package.json +1 -1
  13. package/packages/core/networking/setup.d.ts.map +1 -1
  14. package/packages/core/networking/setup.js +16 -12
  15. package/packages/core/numbers/index.d.ts +4 -0
  16. package/packages/core/numbers/index.d.ts.map +1 -1
  17. package/packages/core/numbers/index.js +4 -4
  18. package/packages/core/pvm-host-calls/bin.js +6 -6
  19. package/packages/core/pvm-host-calls/ecalli-io-tracker.d.ts +32 -0
  20. package/packages/core/pvm-host-calls/ecalli-io-tracker.d.ts.map +1 -0
  21. package/packages/core/pvm-host-calls/ecalli-io-tracker.js +14 -0
  22. package/packages/core/pvm-host-calls/ecalli-trace-logger.d.ts +139 -0
  23. package/packages/core/pvm-host-calls/ecalli-trace-logger.d.ts.map +1 -0
  24. package/packages/core/pvm-host-calls/ecalli-trace-logger.js +209 -0
  25. package/packages/core/pvm-host-calls/ecalli-trace-logger.test.d.ts +2 -0
  26. package/packages/core/pvm-host-calls/ecalli-trace-logger.test.d.ts.map +1 -0
  27. package/packages/core/pvm-host-calls/ecalli-trace-logger.test.js +231 -0
  28. package/packages/core/pvm-host-calls/host-call-memory.d.ts +2 -0
  29. package/packages/core/pvm-host-calls/host-call-memory.d.ts.map +1 -1
  30. package/packages/core/pvm-host-calls/host-call-memory.js +12 -2
  31. package/packages/core/pvm-host-calls/host-call-registers.d.ts +6 -0
  32. package/packages/core/pvm-host-calls/host-call-registers.d.ts.map +1 -1
  33. package/packages/core/pvm-host-calls/host-call-registers.js +24 -0
  34. package/packages/core/pvm-host-calls/host-calls-executor.d.ts +37 -0
  35. package/packages/core/pvm-host-calls/host-calls-executor.d.ts.map +1 -0
  36. package/packages/core/pvm-host-calls/host-calls-executor.js +129 -0
  37. package/packages/core/pvm-host-calls/host-calls.d.ts +20 -26
  38. package/packages/core/pvm-host-calls/host-calls.d.ts.map +1 -1
  39. package/packages/core/pvm-host-calls/host-calls.js +40 -112
  40. package/packages/core/pvm-host-calls/index.d.ts +7 -6
  41. package/packages/core/pvm-host-calls/index.d.ts.map +1 -1
  42. package/packages/core/pvm-host-calls/index.js +7 -6
  43. package/packages/core/pvm-host-calls/{interpreter-instance-manager.d.ts → pvm-instance-manager.d.ts} +3 -3
  44. package/packages/core/pvm-host-calls/pvm-instance-manager.d.ts.map +1 -0
  45. package/packages/core/pvm-host-calls/{interpreter-instance-manager.js → pvm-instance-manager.js} +2 -2
  46. package/packages/core/pvm-interpreter/ops/math-consts.d.ts +2 -3
  47. package/packages/core/pvm-interpreter/ops/math-consts.d.ts.map +1 -1
  48. package/packages/core/pvm-interpreter/ops/math-consts.js +2 -3
  49. package/packages/core/pvm-interpreter/ops/math-ops.js +3 -3
  50. package/packages/core/pvm-interpreter/ops/math-utils.js +13 -13
  51. package/packages/core/pvm-interpreter/ops/math-utils.test.js +17 -16
  52. package/packages/core/telemetry/package.json +1 -1
  53. package/packages/extensions/ipc/jamnp/handler.d.ts +5 -4
  54. package/packages/extensions/ipc/jamnp/handler.d.ts.map +1 -1
  55. package/packages/extensions/ipc/jamnp/handler.js +59 -34
  56. package/packages/extensions/ipc/jamnp/stream.d.ts +6 -4
  57. package/packages/extensions/ipc/jamnp/stream.d.ts.map +1 -1
  58. package/packages/jam/block/work-item.d.ts +13 -4
  59. package/packages/jam/block/work-item.d.ts.map +1 -1
  60. package/packages/jam/block/work-result.d.ts +3 -5
  61. package/packages/jam/block/work-result.d.ts.map +1 -1
  62. package/packages/jam/block/work-result.js +6 -0
  63. package/packages/jam/block-json/work-result.d.ts.map +1 -1
  64. package/packages/jam/block-json/work-result.js +6 -6
  65. package/packages/jam/database-lmdb/states.test.js +4 -3
  66. package/packages/jam/executor/index.d.ts +4 -0
  67. package/packages/jam/executor/index.d.ts.map +1 -0
  68. package/packages/jam/executor/index.js +2 -0
  69. package/packages/jam/{transition/accumulate → executor}/pvm-executor.d.ts +19 -16
  70. package/packages/jam/executor/pvm-executor.d.ts.map +1 -0
  71. package/packages/jam/{transition/accumulate → executor}/pvm-executor.js +48 -5
  72. package/packages/jam/in-core/externalities/refine.d.ts +24 -0
  73. package/packages/jam/in-core/externalities/refine.d.ts.map +1 -0
  74. package/packages/jam/in-core/externalities/refine.js +36 -0
  75. package/packages/jam/in-core/in-core.d.ts +60 -0
  76. package/packages/jam/in-core/in-core.d.ts.map +1 -0
  77. package/packages/jam/in-core/in-core.js +294 -0
  78. package/packages/jam/in-core/in-core.test.d.ts +2 -0
  79. package/packages/jam/in-core/in-core.test.d.ts.map +1 -0
  80. package/packages/jam/in-core/in-core.test.js +81 -0
  81. package/packages/jam/in-core/index.d.ts +2 -0
  82. package/packages/jam/in-core/index.d.ts.map +1 -0
  83. package/packages/jam/in-core/index.js +1 -0
  84. package/packages/jam/jam-host-calls/accumulate/bless.test.js +4 -5
  85. package/packages/jam/jamnp-s/peers.d.ts.map +1 -1
  86. package/packages/jam/jamnp-s/peers.js +10 -0
  87. package/packages/jam/jamnp-s/protocol/ce-128-block-request.d.ts +1 -1
  88. package/packages/jam/jamnp-s/protocol/ce-128-block-request.d.ts.map +1 -1
  89. package/packages/jam/jamnp-s/protocol/ce-128-block-request.js +10 -8
  90. package/packages/jam/jamnp-s/protocol/ce-129-state-request.d.ts.map +1 -1
  91. package/packages/jam/jamnp-s/protocol/ce-129-state-request.js +11 -9
  92. package/packages/jam/jamnp-s/protocol/ce-131-ce-132-safrole-ticket-distribution.d.ts +3 -3
  93. package/packages/jam/jamnp-s/protocol/ce-131-ce-132-safrole-ticket-distribution.d.ts.map +1 -1
  94. package/packages/jam/jamnp-s/protocol/ce-131-ce-132-safrole-ticket-distribution.js +2 -2
  95. package/packages/jam/jamnp-s/protocol/ce-133-work-package-submission.d.ts +5 -5
  96. package/packages/jam/jamnp-s/protocol/ce-133-work-package-submission.d.ts.map +1 -1
  97. package/packages/jam/jamnp-s/protocol/ce-133-work-package-submission.js +2 -2
  98. package/packages/jam/jamnp-s/protocol/ce-134-work-package-sharing.d.ts.map +1 -1
  99. package/packages/jam/jamnp-s/protocol/ce-134-work-package-sharing.js +8 -6
  100. package/packages/jam/jamnp-s/protocol/ce-135-work-report-distribution.d.ts +3 -3
  101. package/packages/jam/jamnp-s/protocol/ce-135-work-report-distribution.d.ts.map +1 -1
  102. package/packages/jam/jamnp-s/protocol/ce-135-work-report-distribution.js +2 -2
  103. package/packages/jam/jamnp-s/protocol/ce-135-work-report-distribution.test.js +2 -2
  104. package/packages/jam/jamnp-s/protocol/stream.d.ts +13 -7
  105. package/packages/jam/jamnp-s/protocol/stream.d.ts.map +1 -1
  106. package/packages/jam/jamnp-s/protocol/stream.js +5 -4
  107. package/packages/jam/jamnp-s/protocol/test-utils.d.ts +1 -1
  108. package/packages/jam/jamnp-s/protocol/test-utils.d.ts.map +1 -1
  109. package/packages/jam/jamnp-s/protocol/test-utils.js +9 -12
  110. package/packages/jam/jamnp-s/protocol/up-0-block-announcement.d.ts +1 -1
  111. package/packages/jam/jamnp-s/protocol/up-0-block-announcement.d.ts.map +1 -1
  112. package/packages/jam/jamnp-s/protocol/up-0-block-announcement.js +1 -1
  113. package/packages/jam/jamnp-s/stream-manager.d.ts.map +1 -1
  114. package/packages/jam/jamnp-s/stream-manager.js +7 -5
  115. package/packages/jam/jamnp-s/stream-manager.test.js +8 -5
  116. package/packages/jam/jamnp-s/tasks/sync.js +1 -1
  117. package/packages/jam/node/jam-config.d.ts +4 -1
  118. package/packages/jam/node/jam-config.d.ts.map +1 -1
  119. package/packages/jam/node/jam-config.js +6 -2
  120. package/packages/jam/node/main-importer.d.ts.map +1 -1
  121. package/packages/jam/node/main-importer.js +3 -1
  122. package/packages/jam/node/main.d.ts.map +1 -1
  123. package/packages/jam/node/main.js +5 -4
  124. package/packages/jam/node/package.json +1 -1
  125. package/packages/jam/rpc-validation/types.d.ts +7 -3
  126. package/packages/jam/rpc-validation/types.d.ts.map +1 -1
  127. package/packages/jam/rpc-validation/validation.d.ts +254 -36
  128. package/packages/jam/rpc-validation/validation.d.ts.map +1 -1
  129. package/packages/jam/rpc-validation/validation.js +20 -2
  130. package/packages/jam/safrole/bandersnatch-vrf.d.ts +2 -0
  131. package/packages/jam/safrole/bandersnatch-vrf.d.ts.map +1 -1
  132. package/packages/jam/safrole/bandersnatch-vrf.js +11 -0
  133. package/packages/jam/safrole/bandersnatch-vrf.test.js +3 -3
  134. package/packages/jam/safrole/bandersnatch-wasm.d.ts +1 -0
  135. package/packages/jam/safrole/bandersnatch-wasm.d.ts.map +1 -1
  136. package/packages/jam/safrole/bandersnatch-wasm.js +8 -5
  137. package/packages/jam/safrole/safrole-seal.d.ts +1 -3
  138. package/packages/jam/safrole/safrole-seal.d.ts.map +1 -1
  139. package/packages/jam/safrole/safrole-seal.js +14 -25
  140. package/packages/jam/safrole/safrole-seal.test.js +4 -10
  141. package/packages/jam/state/in-memory-state.d.ts.map +1 -1
  142. package/packages/jam/state/in-memory-state.js +2 -3
  143. package/packages/jam/state/test.utils.d.ts.map +1 -1
  144. package/packages/jam/state/test.utils.js +2 -3
  145. package/packages/jam/transition/accumulate/accumulate-data.d.ts.map +1 -1
  146. package/packages/jam/transition/accumulate/accumulate-data.js +1 -2
  147. package/packages/jam/transition/accumulate/accumulate-queue.test.js +2 -2
  148. package/packages/jam/transition/accumulate/accumulate-utils.test.js +2 -2
  149. package/packages/jam/transition/accumulate/accumulate.d.ts.map +1 -1
  150. package/packages/jam/transition/accumulate/accumulate.js +8 -13
  151. package/packages/jam/transition/accumulate/accumulate.test.js +2 -2
  152. package/packages/jam/transition/accumulate/accumulation-result-merge-utils.d.ts.map +1 -1
  153. package/packages/jam/transition/accumulate/accumulation-result-merge-utils.js +1 -2
  154. package/packages/jam/transition/accumulate/accumulation-result-merge-utils.test.js +1 -2
  155. package/packages/jam/transition/accumulate/deferred-transfers.d.ts +1 -1
  156. package/packages/jam/transition/accumulate/deferred-transfers.d.ts.map +1 -1
  157. package/packages/jam/transition/accumulate/deferred-transfers.js +6 -7
  158. package/packages/jam/transition/disputes/disputes.d.ts.map +1 -1
  159. package/packages/jam/transition/disputes/disputes.js +5 -4
  160. package/packages/jam/transition/disputes/disputes.test.data2.js +2 -2
  161. package/packages/jam/transition/externalities/fetch-externalities.d.ts +7 -1
  162. package/packages/jam/transition/externalities/fetch-externalities.d.ts.map +1 -1
  163. package/packages/jam/transition/externalities/fetch-externalities.js +4 -0
  164. package/packages/jam/transition/externalities/fetch-externalities.test.js +2 -2
  165. package/packages/jam/transition/hasher.test.js +2 -2
  166. package/packages/jam/transition/reports/test.utils.d.ts.map +1 -1
  167. package/packages/jam/transition/reports/test.utils.js +2 -2
  168. package/packages/workers/block-authorship/main.d.ts.map +1 -1
  169. package/packages/workers/block-authorship/main.js +23 -4
  170. package/packages/workers/block-authorship/package.json +1 -1
  171. package/packages/workers/block-authorship/protocol.d.ts +3 -1
  172. package/packages/workers/block-authorship/protocol.d.ts.map +1 -1
  173. package/packages/workers/block-authorship/protocol.js +6 -3
  174. package/packages/workers/importer/package.json +1 -1
  175. package/packages/core/pvm-host-calls/host-calls-manager.d.ts +0 -23
  176. package/packages/core/pvm-host-calls/host-calls-manager.d.ts.map +0 -1
  177. package/packages/core/pvm-host-calls/host-calls-manager.js +0 -44
  178. package/packages/core/pvm-host-calls/interpreter-instance-manager.d.ts.map +0 -1
  179. package/packages/jam/transition/accumulate/pvm-executor.d.ts.map +0 -1
@@ -20,6 +20,7 @@ var ResultValues;
20
20
  const ringCommitmentCache = [];
21
21
  const FUNCTIONS = {
22
22
  verifySeal,
23
+ verifyHeaderSeals,
23
24
  verifyTickets,
24
25
  getRingCommitment,
25
26
  generateSeal,
@@ -29,6 +30,16 @@ const FUNCTIONS = {
29
30
  // Ideally we would just export functions and figure out how to mock
30
31
  // properly in ESM.
31
32
  export default FUNCTIONS;
33
+ async function verifyHeaderSeals(bandersnatch, authorKey, signature, payload, encodedUnsealedHeader, entropySignature, entropyPayloadPrefix) {
34
+ const sealResult = await bandersnatch.verifyHeaderSeals(authorKey.raw, signature.raw, payload.raw, encodedUnsealedHeader.raw, entropySignature.raw, entropyPayloadPrefix.raw);
35
+ if (sealResult[RESULT_INDEX] === ResultValues.Error) {
36
+ return Result.error(null, () => "Bandersnatch VRF seal verification failed");
37
+ }
38
+ return Result.ok([
39
+ Bytes.fromBlob(sealResult.subarray(1, 33), HASH_SIZE).asOpaque(),
40
+ Bytes.fromBlob(sealResult.subarray(33), HASH_SIZE).asOpaque(),
41
+ ]);
42
+ }
32
43
  async function verifySeal(bandersnatch, authorKey, signature, payload, encodedUnsealedHeader) {
33
44
  const sealResult = await bandersnatch.verifySeal(authorKey.raw, signature.raw, payload.raw, encodedUnsealedHeader.raw);
34
45
  if (sealResult[RESULT_INDEX] === ResultValues.Error) {
@@ -27,7 +27,7 @@ describe("Bandersnatch verification", () => {
27
27
  const result = await bandersnatchVrf.getRingCommitment(await bandersnatchWasm, bandersnatchKeys);
28
28
  const expectedCommitment = Bytes.parseBytes("0x8387a131593447e4e1c3d4e220c322e42d33207fa77cd0fedb39fc3491479ca47a2d82295252e278fa3eec78185982ed82ae0c8fd691335e703d663fb5be02b3def15380789320636b2479beab5a03ccb3f0909ffea59d859fcdc7e187e45a8c92e630ae2b14e758ab0960e372172203f4c9a41777dadd529971d7ab9d23ab29fe0e9c85ec450505dde7f5ac038274cf", BANDERSNATCH_RING_ROOT_BYTES);
29
29
  assert.strictEqual(result.isOk, true);
30
- assert.deepStrictEqual(result.ok, expectedCommitment);
30
+ assert.strictEqual(result.ok.toString(), expectedCommitment.toString());
31
31
  });
32
32
  });
33
33
  describe("verifyTickets", () => {
@@ -72,7 +72,7 @@ describe("Bandersnatch verification", () => {
72
72
  ].map((x) => Bytes.parseBytes(x, HASH_SIZE));
73
73
  const result = await bandersnatchVrf.verifyTickets(await bandersnatchWasm, bandersnatchKeys.length, commitment, tickets, entropy);
74
74
  assert.strictEqual(result.every((x) => x.isValid), true);
75
- assert.deepStrictEqual(result.map((x) => x.entropyHash), expectedIds);
75
+ assert.deepStrictEqual(result.map((x) => x.entropyHash.toString()), expectedIds.map((x) => x.toString()));
76
76
  });
77
77
  it("should detect that one signature is incorrect", async () => {
78
78
  const tickets = [
@@ -97,7 +97,7 @@ describe("Bandersnatch verification", () => {
97
97
  ].map((x) => Bytes.parseBytes(x, HASH_SIZE));
98
98
  const result = await bandersnatchVrf.verifyTickets(await bandersnatchWasm, bandersnatchKeys.length, commitment, tickets, entropy);
99
99
  assert.deepStrictEqual(result.map((x) => x.isValid), [false, true, true]);
100
- assert.deepStrictEqual(result.map((x) => x.entropyHash), expectedIds);
100
+ assert.deepStrictEqual(result.map((x) => x.entropyHash.toString()), expectedIds.map((x) => x.toString()));
101
101
  });
102
102
  });
103
103
  describe("verifySeal", () => {
@@ -2,6 +2,7 @@ export declare class BandernsatchWasm {
2
2
  private constructor();
3
3
  static new(): Promise<BandernsatchWasm>;
4
4
  verifySeal(authorKey: Uint8Array, signature: Uint8Array, payload: Uint8Array, auxData: Uint8Array): Promise<Uint8Array<ArrayBufferLike>>;
5
+ verifyHeaderSeals(authorKey: Uint8Array, headerSeal: Uint8Array, headerSealPayload: Uint8Array, unsealedHeader: Uint8Array, entropySeal: Uint8Array, entropyPayloadPrefix: Uint8Array): Promise<Uint8Array<ArrayBufferLike>>;
5
6
  getRingCommitment(keys: Uint8Array): Promise<Uint8Array<ArrayBufferLike>>;
6
7
  batchVerifyTicket(ringSize: number, commitment: Uint8Array, ticketsData: Uint8Array, contextLength: number): Promise<Uint8Array<ArrayBufferLike>>;
7
8
  generateSeal(authorKey: Uint8Array, input: Uint8Array, auxData: Uint8Array): Promise<Uint8Array<ArrayBufferLike>>;
@@ -1 +1 @@
1
- {"version":3,"file":"bandersnatch-wasm.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/safrole/bandersnatch-wasm.ts"],"names":[],"mappings":"AAEA,qBAAa,gBAAgB;IAC3B,OAAO;WAEM,GAAG;IAKV,UAAU,CAAC,SAAS,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,EAAE,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,UAAU;IAIjG,iBAAiB,CAAC,IAAI,EAAE,UAAU;IAIlC,iBAAiB,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,WAAW,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM;IAI1G,YAAY,CAAC,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,UAAU;IAI1E,gBAAgB,CAAC,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU;CAGhE"}
1
+ {"version":3,"file":"bandersnatch-wasm.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/safrole/bandersnatch-wasm.ts"],"names":[],"mappings":"AAEA,qBAAa,gBAAgB;IAC3B,OAAO;WAEM,GAAG;IAKV,UAAU,CAAC,SAAS,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,EAAE,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,UAAU;IAIjG,iBAAiB,CACrB,SAAS,EAAE,UAAU,EACrB,UAAU,EAAE,UAAU,EACtB,iBAAiB,EAAE,UAAU,EAC7B,cAAc,EAAE,UAAU,EAC1B,WAAW,EAAE,UAAU,EACvB,oBAAoB,EAAE,UAAU;IAY5B,iBAAiB,CAAC,IAAI,EAAE,UAAU;IAIlC,iBAAiB,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,WAAW,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM;IAI1G,YAAY,CAAC,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,UAAU;IAI1E,gBAAgB,CAAC,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU;CAGhE"}
@@ -6,18 +6,21 @@ export class BandernsatchWasm {
6
6
  return new BandernsatchWasm();
7
7
  }
8
8
  async verifySeal(authorKey, signature, payload, auxData) {
9
- return bandersnatchWasm.verify_seal(authorKey, signature, payload, auxData);
9
+ return bandersnatchWasm.verifySeal(authorKey, signature, payload, auxData);
10
+ }
11
+ async verifyHeaderSeals(authorKey, headerSeal, headerSealPayload, unsealedHeader, entropySeal, entropyPayloadPrefix) {
12
+ return bandersnatchWasm.verifyHeaderSeals(authorKey, headerSeal, headerSealPayload, unsealedHeader, entropySeal, entropyPayloadPrefix);
10
13
  }
11
14
  async getRingCommitment(keys) {
12
- return bandersnatchWasm.ring_commitment(keys);
15
+ return bandersnatchWasm.ringCommitment(keys);
13
16
  }
14
17
  async batchVerifyTicket(ringSize, commitment, ticketsData, contextLength) {
15
- return bandersnatchWasm.batch_verify_tickets(ringSize, commitment, ticketsData, contextLength);
18
+ return bandersnatchWasm.batchVerifyTickets(ringSize, commitment, ticketsData, contextLength);
16
19
  }
17
20
  async generateSeal(authorKey, input, auxData) {
18
- return bandersnatchWasm.generate_seal(authorKey, input, auxData);
21
+ return bandersnatchWasm.generateSeal(authorKey, input, auxData);
19
22
  }
20
23
  async getVrfOutputHash(authorKey, input) {
21
- return bandersnatchWasm.vrf_output_hash(authorKey, input);
24
+ return bandersnatchWasm.vrfOutputHash(authorKey, input);
22
25
  }
23
26
  }
@@ -8,8 +8,7 @@ export declare enum SafroleSealError {
8
8
  InvalidValidatorIndex = 0,
9
9
  InvalidValidator = 1,
10
10
  InvalidTicket = 2,
11
- IncorrectSeal = 3,
12
- IncorrectEntropySource = 4
11
+ IncorrectSeal = 3
13
12
  }
14
13
  export type SafroleSealState = Pick<State, "currentValidatorData" | "sealingKeySeries"> & {
15
14
  currentEntropy: EntropyHash;
@@ -22,7 +21,6 @@ export declare class SafroleSeal {
22
21
  * hence the state is passed as an argument for more control.
23
22
  */
24
23
  verifyHeaderSeal(headerView: HeaderView, state: SafroleSealState): Promise<Result<EntropyHash, SafroleSealError>>;
25
- private verifySeal;
26
24
  /** Regular (non-fallback) mode of Safrole. */
27
25
  verifySealWithTicket(tickets: PerEpochBlock<Ticket>, timeSlot: TimeSlot, entropy: EntropyHash, validatorData: ValidatorData, headerView: HeaderView): Promise<Result<EntropyHash, SafroleSealError>>;
28
26
  /** Fallback mode of Safrole. */
@@ -1 +1 @@
1
- {"version":3,"file":"safrole-seal.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/safrole/safrole-seal.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,WAAW,EAEhB,KAAK,UAAU,EACf,KAAK,aAAa,EAClB,KAAK,QAAQ,EACd,MAAM,kBAAkB,CAAC;AAC1B,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,6BAA6B,CAAC;AAE1D,OAAO,EAA0B,KAAK,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACjF,OAAO,KAAK,EAAE,KAAK,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAE7D,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAE1C,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAG1D,oBAAY,gBAAgB;IAC1B,qBAAqB,IAAI;IACzB,gBAAgB,IAAI;IACpB,aAAa,IAAI;IACjB,aAAa,IAAI;IACjB,sBAAsB,IAAI;CAC3B;AAED,MAAM,MAAM,gBAAgB,GAAG,IAAI,CAAC,KAAK,EAAE,sBAAsB,GAAG,kBAAkB,CAAC,GAAG;IACxF,cAAc,EAAE,WAAW,CAAC;CAC7B,CAAC;AAIF,qBAAa,WAAW;IACV,OAAO,CAAC,QAAQ,CAAC,YAAY;gBAAZ,YAAY,GAAE,OAAO,CAAC,gBAAgB,CAA0B;IAC7F;;;OAGG;IACG,gBAAgB,CACpB,UAAU,EAAE,UAAU,EACtB,KAAK,EAAE,gBAAgB,GACtB,OAAO,CAAC,MAAM,CAAC,WAAW,EAAE,gBAAgB,CAAC,CAAC;YA6BnC,UAAU;IA0BxB,8CAA8C;IACxC,oBAAoB,CACxB,OAAO,EAAE,aAAa,CAAC,MAAM,CAAC,EAC9B,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,WAAW,EACpB,aAAa,EAAE,aAAa,EAC5B,UAAU,EAAE,UAAU,GACrB,OAAO,CAAC,MAAM,CAAC,WAAW,EAAE,gBAAgB,CAAC,CAAC;IA4BjD,gCAAgC;IAC1B,kBAAkB,CACtB,IAAI,EAAE,aAAa,CAAC,eAAe,CAAC,EACpC,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,WAAW,EACpB,SAAS,EAAE,aAAa,EACxB,UAAU,EAAE,UAAU,GACrB,OAAO,CAAC,MAAM,CAAC,WAAW,EAAE,gBAAgB,CAAC,CAAC;CA2BlD"}
1
+ {"version":3,"file":"safrole-seal.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/safrole/safrole-seal.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,WAAW,EAEhB,KAAK,UAAU,EACf,KAAK,aAAa,EAClB,KAAK,QAAQ,EACd,MAAM,kBAAkB,CAAC;AAC1B,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,6BAA6B,CAAC;AAE1D,OAAO,EAA0B,KAAK,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACjF,OAAO,KAAK,EAAE,KAAK,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAE7D,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAE1C,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAG1D,oBAAY,gBAAgB;IAC1B,qBAAqB,IAAI;IACzB,gBAAgB,IAAI;IACpB,aAAa,IAAI;IACjB,aAAa,IAAI;CAClB;AAED,MAAM,MAAM,gBAAgB,GAAG,IAAI,CAAC,KAAK,EAAE,sBAAsB,GAAG,kBAAkB,CAAC,GAAG;IACxF,cAAc,EAAE,WAAW,CAAC;CAC7B,CAAC;AAIF,qBAAa,WAAW;IACV,OAAO,CAAC,QAAQ,CAAC,YAAY;gBAAZ,YAAY,GAAE,OAAO,CAAC,gBAAgB,CAA0B;IAC7F;;;OAGG;IACG,gBAAgB,CACpB,UAAU,EAAE,UAAU,EACtB,KAAK,EAAE,gBAAgB,GACtB,OAAO,CAAC,MAAM,CAAC,WAAW,EAAE,gBAAgB,CAAC,CAAC;IAuBjD,8CAA8C;IACxC,oBAAoB,CACxB,OAAO,EAAE,aAAa,CAAC,MAAM,CAAC,EAC9B,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,WAAW,EACpB,aAAa,EAAE,aAAa,EAC5B,UAAU,EAAE,UAAU,GACrB,OAAO,CAAC,MAAM,CAAC,WAAW,EAAE,gBAAgB,CAAC,CAAC;IAmCjD,gCAAgC;IAC1B,kBAAkB,CACtB,IAAI,EAAE,aAAa,CAAC,eAAe,CAAC,EACpC,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,WAAW,EACpB,SAAS,EAAE,aAAa,EACxB,UAAU,EAAE,UAAU,GACrB,OAAO,CAAC,MAAM,CAAC,WAAW,EAAE,gBAAgB,CAAC,CAAC;CA8BlD"}
@@ -12,7 +12,6 @@ export var SafroleSealError;
12
12
  SafroleSealError[SafroleSealError["InvalidValidator"] = 1] = "InvalidValidator";
13
13
  SafroleSealError[SafroleSealError["InvalidTicket"] = 2] = "InvalidTicket";
14
14
  SafroleSealError[SafroleSealError["IncorrectSeal"] = 3] = "IncorrectSeal";
15
- SafroleSealError[SafroleSealError["IncorrectEntropySource"] = 4] = "IncorrectEntropySource";
16
15
  })(SafroleSealError || (SafroleSealError = {}));
17
16
  const BANDERSNATCH_ZERO_KEY = Bytes.zero(BANDERSNATCH_KEY_BYTES).asOpaque();
18
17
  export class SafroleSeal {
@@ -25,21 +24,6 @@ export class SafroleSeal {
25
24
  * hence the state is passed as an argument for more control.
26
25
  */
27
26
  async verifyHeaderSeal(headerView, state) {
28
- const sealResult = await this.verifySeal(headerView, state);
29
- if (sealResult.isError) {
30
- return sealResult;
31
- }
32
- // verify entropySource
33
- const payload = BytesBlob.blobFromParts(JAM_ENTROPY, sealResult.ok.raw);
34
- const blockAuthorIndex = headerView.bandersnatchBlockAuthorIndex.materialize();
35
- const blockAuthorKey = state.currentValidatorData.at(blockAuthorIndex)?.bandersnatch;
36
- const entropySourceResult = await bandersnatchVrf.verifySeal(await this.bandersnatch, blockAuthorKey ?? BANDERSNATCH_ZERO_KEY, headerView.entropySource.materialize(), payload, BytesBlob.blobFromNumbers([]));
37
- if (entropySourceResult.isError) {
38
- return Result.error(SafroleSealError.IncorrectEntropySource, () => "Safrole: incorrect entropy source in header seal");
39
- }
40
- return Result.ok(entropySourceResult.ok);
41
- }
42
- async verifySeal(headerView, state) {
43
27
  // we use transitioned keys already
44
28
  const validatorIndex = headerView.bandersnatchBlockAuthorIndex.materialize();
45
29
  const authorKeys = state.currentValidatorData.at(validatorIndex);
@@ -58,17 +42,21 @@ export class SafroleSeal {
58
42
  async verifySealWithTicket(tickets, timeSlot, entropy, validatorData, headerView) {
59
43
  const index = timeSlot % tickets.length;
60
44
  const ticket = tickets.at(index);
61
- const payload = BytesBlob.blobFromParts(JAM_TICKET_SEAL, entropy.raw, new Uint8Array([ticket?.attempt ?? 0]));
62
- // verify seal correctness
45
+ if (ticket === undefined) {
46
+ return Result.error(SafroleSealError.IncorrectSeal, () => "Safrole: missing ticket");
47
+ }
48
+ const payload = BytesBlob.blobFromParts(JAM_TICKET_SEAL, entropy.raw, new Uint8Array([ticket.attempt]));
49
+ // verify seal and entropy source correctness
63
50
  const authorKey = validatorData.bandersnatch;
64
- const result = await bandersnatchVrf.verifySeal(await this.bandersnatch, authorKey ?? BANDERSNATCH_ZERO_KEY, headerView.seal.materialize(), payload, encodeUnsealedHeader(headerView));
51
+ const result = await bandersnatchVrf.verifyHeaderSeals(await this.bandersnatch, authorKey ?? BANDERSNATCH_ZERO_KEY, headerView.seal.materialize(), payload, encodeUnsealedHeader(headerView), headerView.entropySource.materialize(), BytesBlob.blobFrom(JAM_ENTROPY));
65
52
  if (result.isError) {
66
53
  return Result.error(SafroleSealError.IncorrectSeal, () => "Safrole: incorrect seal with ticket");
67
54
  }
68
- if (ticket === undefined || !ticket.id.isEqualTo(result.ok)) {
69
- return Result.error(SafroleSealError.InvalidTicket, () => `Safrole: invalid ticket, expected ${ticket?.id} got ${result.ok}`);
55
+ const [sealOutput, entropyOutput] = result.ok;
56
+ if (!ticket.id.isEqualTo(sealOutput)) {
57
+ return Result.error(SafroleSealError.InvalidTicket, () => `Safrole: invalid ticket, expected ${ticket.id} got ${sealOutput}`);
70
58
  }
71
- return Result.ok(result.ok);
59
+ return Result.ok(entropyOutput);
72
60
  }
73
61
  /** Fallback mode of Safrole. */
74
62
  async verifySealWithKeys(keys, timeSlot, entropy, authorKey, headerView) {
@@ -78,12 +66,13 @@ export class SafroleSeal {
78
66
  if (sealingKey === undefined || !sealingKey.isEqualTo(authorBandersnatchKey)) {
79
67
  return Result.error(SafroleSealError.InvalidValidator, () => `Invalid Validator. Expected: ${sealingKey}, got: ${authorKey.bandersnatch}`);
80
68
  }
81
- // verify seal correctness
69
+ // verify seal and entropy source correctness
82
70
  const payload = BytesBlob.blobFromParts(JAM_FALLBACK_SEAL, entropy.raw);
83
- const result = await bandersnatchVrf.verifySeal(await this.bandersnatch, authorBandersnatchKey, headerView.seal.materialize(), payload, encodeUnsealedHeader(headerView));
71
+ const result = await bandersnatchVrf.verifyHeaderSeals(await this.bandersnatch, authorBandersnatchKey, headerView.seal.materialize(), payload, encodeUnsealedHeader(headerView), headerView.entropySource.materialize(), BytesBlob.blobFrom(JAM_ENTROPY));
84
72
  if (result.isError) {
85
73
  return Result.error(SafroleSealError.IncorrectSeal, () => "Safrole: incorrect seal with keys");
86
74
  }
87
- return Result.ok(result.ok);
75
+ const [_, entropyOutput] = result.ok;
76
+ return Result.ok(entropyOutput);
88
77
  }
89
78
  }
@@ -35,11 +35,8 @@ describe("Safrole Seal verification", () => {
35
35
  sealingKeySeries: SEALING_KEYS,
36
36
  currentEntropy: Bytes.parseBytes("0x405c80c1f6a2d5a0f8dbc56996f04230221100d9500244648f02a795d7850eac", HASH_SIZE).asOpaque(),
37
37
  });
38
- assert.deepStrictEqual(result, {
39
- isError: false,
40
- isOk: true,
41
- ok: Bytes.parseBytes("0xc13af3d0cbdb7174590f34518e3beb05708935ceaee242e7ba11a94ca87bd007", HASH_SIZE).asOpaque(),
42
- });
38
+ assert.strictEqual(result.isOk, true);
39
+ assert.strictEqual(result.ok.toString(), "0xc13af3d0cbdb7174590f34518e3beb05708935ceaee242e7ba11a94ca87bd007");
43
40
  });
44
41
  it("should verify a valid ticket seal and entropySource", async () => {
45
42
  // based on test-vectors/w3f-davxy_070/traces/safrole/00000002.json
@@ -63,11 +60,8 @@ describe("Safrole Seal verification", () => {
63
60
  sealingKeySeries: SEALING_KEYS,
64
61
  currentEntropy: Bytes.parseBytes("0x405c80c1f6a2d5a0f8dbc56996f04230221100d9500244648f02a795d7850eac", HASH_SIZE).asOpaque(),
65
62
  });
66
- assert.deepStrictEqual(result, {
67
- isError: false,
68
- isOk: true,
69
- ok: Bytes.parseBytes("0xc13af3d0cbdb7174590f34518e3beb05708935ceaee242e7ba11a94ca87bd007", HASH_SIZE).asOpaque(),
70
- });
63
+ assert.strictEqual(result.isOk, true);
64
+ assert.strictEqual(result.ok.toString(), "0xc13af3d0cbdb7174590f34518e3beb05708935ceaee242e7ba11a94ca87bd007");
71
65
  });
72
66
  });
73
67
  const TEST_VALIDATOR_KEYS = tryAsPerValidator([
@@ -1 +1 @@
1
- {"version":3,"file":"in-memory-state.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/state/in-memory-state.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"in-memory-state.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/state/in-memory-state.ts"],"names":[],"mappings":"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"}
@@ -5,8 +5,7 @@ import { asKnownSize, FixedSizeArray, HashDictionary, HashSet, SortedArray, Sort
5
5
  import { BANDERSNATCH_KEY_BYTES, BLS_KEY_BYTES, ED25519_KEY_BYTES } from "#@typeberry/crypto";
6
6
  import { BANDERSNATCH_RING_ROOT_BYTES } from "#@typeberry/crypto/bandersnatch.js";
7
7
  import { HASH_SIZE } from "#@typeberry/hash";
8
- import { tryAsU32 } from "#@typeberry/numbers";
9
- import { MAX_VALUE } from "#@typeberry/pvm-interpreter/ops/math-consts.js";
8
+ import { MAX_VALUE_U32, tryAsU32 } from "#@typeberry/numbers";
10
9
  import { asOpaqueType, assertNever, check, OK, Result, WithDebug } from "#@typeberry/utils";
11
10
  import { accumulationOutputComparator } from "./accumulation-output.js";
12
11
  import { AUTHORIZATION_QUEUE_SIZE } from "./auth.js";
@@ -451,7 +450,7 @@ export class InMemoryState extends WithDebug {
451
450
  manager: tryAsServiceId(0),
452
451
  assigners: tryAsPerCore(new Array(spec.coresCount).fill(tryAsServiceId(0)), spec),
453
452
  delegator: tryAsServiceId(0),
454
- registrar: tryAsServiceId(MAX_VALUE),
453
+ registrar: tryAsServiceId(MAX_VALUE_U32),
455
454
  autoAccumulateServices: new Map(),
456
455
  }),
457
456
  accumulationOutputLog: SortedArray.fromArray(accumulationOutputComparator, []),
@@ -1 +1 @@
1
- {"version":3,"file":"test.utils.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/state/test.utils.ts"],"names":[],"mappings":"AAqBA,OAAO,EAUL,aAAa,EAYd,MAAM,YAAY,CAAC;AAKpB,eAAO,MAAM,SAAS,QAAO,aAyT5B,CAAC;AAqCF,eAAO,MAAM,eAAe,QAK1B,CAAC;AAEH,eAAO,MAAM,UAAU,YAkHtB,CAAC"}
1
+ {"version":3,"file":"test.utils.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/state/test.utils.ts"],"names":[],"mappings":"AAoBA,OAAO,EAUL,aAAa,EAYd,MAAM,YAAY,CAAC;AAKpB,eAAO,MAAM,SAAS,QAAO,aAyT5B,CAAC;AAqCF,eAAO,MAAM,eAAe,QAK1B,CAAC;AAEH,eAAO,MAAM,UAAU,YAkHtB,CAAC"}
@@ -6,8 +6,7 @@ import { asKnownSize, FixedSizeArray, HashDictionary, HashSet, SortedArray, Sort
6
6
  import { tinyChainSpec } from "#@typeberry/config";
7
7
  import { BANDERSNATCH_RING_ROOT_BYTES } from "#@typeberry/crypto/bandersnatch.js";
8
8
  import { HASH_SIZE } from "#@typeberry/hash";
9
- import { tryAsU16, tryAsU32, tryAsU64 } from "#@typeberry/numbers";
10
- import { MAX_VALUE } from "#@typeberry/pvm-interpreter/ops/math-consts.js";
9
+ import { MAX_VALUE_U32, tryAsU16, tryAsU32, tryAsU64 } from "#@typeberry/numbers";
11
10
  import { Compatibility, GpVersion } from "#@typeberry/utils";
12
11
  import { AUTHORIZATION_QUEUE_SIZE, AvailabilityAssignment, accumulationOutputComparator, BlockState, CoreStatistics, DisputesRecords, ENTROPY_ENTRIES, hashComparator, InMemoryService, InMemoryState, LookupHistoryItem, PreimageItem, PrivilegedServices, RecentBlocks, SafroleSealingKeysData, ServiceAccountInfo, ServiceStatistics, StatisticsData, tryAsPerCore, ValidatorData, ValidatorStatistics, } from "./index.js";
13
12
  const spec = tinyChainSpec;
@@ -271,7 +270,7 @@ export const testState = () => {
271
270
  manager: tryAsServiceId(0),
272
271
  assigners: tryAsPerCore(new Array(spec.coresCount).fill(tryAsServiceId(0)), spec),
273
272
  delegator: tryAsServiceId(0),
274
- registrar: tryAsServiceId(MAX_VALUE),
273
+ registrar: tryAsServiceId(MAX_VALUE_U32),
275
274
  autoAccumulateServices: new Map(),
276
275
  }),
277
276
  });
@@ -1 +1 @@
1
- {"version":3,"file":"accumulate-data.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/transition/accumulate/accumulate-data.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,UAAU,EAAE,KAAK,SAAS,EAAmB,MAAM,kBAAkB,CAAC;AACpF,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AACjE,OAAO,EAAoB,KAAK,GAAG,EAAE,MAAM,oBAAoB,CAAC;AAEhE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAavC;;;;;GAKG;AACH,qBAAa,cAAc;IACzB,OAAO,CAAC,QAAQ,CAAC,sBAAsB,CAAqC;IAC5E,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAoC;IACzE,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAc;IACzC,OAAO,CAAC,QAAQ,CAAC,mBAAmB,CAA6B;gBAG/D,OAAO,EAAE,SAAS,CAAC,UAAU,CAAC,EAC9B,SAAS,EAAE,eAAe,EAAE,EAC5B,iCAAiC,EAAE,GAAG,CAAC,SAAS,EAAE,UAAU,CAAC;IAwC/D;;;;OAIG;IACH,OAAO,CAAC,wBAAwB;IAahC,oCAAoC;IACpC,OAAO,CAAC,eAAe;IAYvB;;;;;OAKG;IACH,OAAO,CAAC,kBAAkB;IAmB1B;;OAEG;IAEH;;;;;OAKG;IACH,OAAO,CAAC,gBAAgB;IA8CxB,0DAA0D;IAC1D,WAAW,CAAC,SAAS,EAAE,SAAS,GAAG,OAAO,EAAE;IAI5C,2DAA2D;IAC3D,YAAY,CAAC,SAAS,EAAE,SAAS,GAAG,eAAe,EAAE;IAIrD,0EAA0E;IAC1E,gBAAgB,CAAC,SAAS,EAAE,SAAS,GAAG,GAAG;IAI3C,mDAAmD;IACnD,WAAW,CAAC,SAAS,EAAE,SAAS,GAAG,UAAU;IAI7C;;;;OAIG;IACH,aAAa,IAAI,SAAS,EAAE;CAG7B"}
1
+ {"version":3,"file":"accumulate-data.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/transition/accumulate/accumulate-data.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,UAAU,EAAE,KAAK,SAAS,EAAmB,MAAM,kBAAkB,CAAC;AACpF,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AACjE,OAAO,EAAmC,KAAK,GAAG,EAAE,MAAM,oBAAoB,CAAC;AAC/E,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAavC;;;;;GAKG;AACH,qBAAa,cAAc;IACzB,OAAO,CAAC,QAAQ,CAAC,sBAAsB,CAAqC;IAC5E,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAoC;IACzE,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAc;IACzC,OAAO,CAAC,QAAQ,CAAC,mBAAmB,CAA6B;gBAG/D,OAAO,EAAE,SAAS,CAAC,UAAU,CAAC,EAC9B,SAAS,EAAE,eAAe,EAAE,EAC5B,iCAAiC,EAAE,GAAG,CAAC,SAAS,EAAE,UAAU,CAAC;IAwC/D;;;;OAIG;IACH,OAAO,CAAC,wBAAwB;IAahC,oCAAoC;IACpC,OAAO,CAAC,eAAe;IAYvB;;;;;OAKG;IACH,OAAO,CAAC,kBAAkB;IAmB1B;;OAEG;IAEH;;;;;OAKG;IACH,OAAO,CAAC,gBAAgB;IA8CxB,0DAA0D;IAC1D,WAAW,CAAC,SAAS,EAAE,SAAS,GAAG,OAAO,EAAE;IAI5C,2DAA2D;IAC3D,YAAY,CAAC,SAAS,EAAE,SAAS,GAAG,eAAe,EAAE;IAIrD,0EAA0E;IAC1E,gBAAgB,CAAC,SAAS,EAAE,SAAS,GAAG,GAAG;IAI3C,mDAAmD;IACnD,WAAW,CAAC,SAAS,EAAE,SAAS,GAAG,UAAU;IAI7C;;;;OAIG;IACH,aAAa,IAAI,SAAS,EAAE;CAG7B"}
@@ -1,6 +1,5 @@
1
1
  import { tryAsServiceGas } from "#@typeberry/block";
2
- import { sumU64, tryAsU32 } from "#@typeberry/numbers";
3
- import { MAX_VALUE_U64 } from "#@typeberry/pvm-interpreter/ops/math-consts.js";
2
+ import { MAX_VALUE_U64, sumU64, tryAsU32 } from "#@typeberry/numbers";
4
3
  import { Operand } from "./operand.js";
5
4
  class AccumulateDataItem {
6
5
  operands;
@@ -3,7 +3,7 @@ import { tryAsCoreIndex, tryAsPerEpochBlock, tryAsServiceGas, tryAsServiceId, tr
3
3
  import { RefineContext, WorkPackageInfo } from "#@typeberry/block/refine-context.js";
4
4
  import { tryAsWorkItemsCount } from "#@typeberry/block/work-package.js";
5
5
  import { WorkPackageSpec, WorkReport } from "#@typeberry/block/work-report.js";
6
- import { WorkExecResult, WorkExecResultKind, WorkRefineLoad, WorkResult } from "#@typeberry/block/work-result.js";
6
+ import { WorkExecResult, WorkRefineLoad, WorkResult } from "#@typeberry/block/work-result.js";
7
7
  import { Bytes, BytesBlob } from "#@typeberry/bytes";
8
8
  import { asKnownSize, FixedSizeArray, HashSet } from "#@typeberry/collections";
9
9
  import { tinyChainSpec } from "#@typeberry/config";
@@ -43,7 +43,7 @@ describe("accumulate-queue", () => {
43
43
  importedSegments: tryAsU32(0),
44
44
  }),
45
45
  payloadHash: Bytes.zero(HASH_SIZE).asOpaque(),
46
- result: new WorkExecResult(WorkExecResultKind.ok, BytesBlob.empty()),
46
+ result: WorkExecResult.ok(BytesBlob.empty()),
47
47
  serviceId: tryAsServiceId(0),
48
48
  }),
49
49
  ], tryAsWorkItemsCount(1)),
@@ -4,7 +4,7 @@ import { tryAsCoreIndex, tryAsServiceGas, tryAsServiceId, tryAsTimeSlot } from "
4
4
  import { RefineContext } from "#@typeberry/block/refine-context.js";
5
5
  import { tryAsWorkItemsCount } from "#@typeberry/block/work-package.js";
6
6
  import { WorkPackageSpec, WorkReport } from "#@typeberry/block/work-report.js";
7
- import { WorkExecResult, WorkExecResultKind, WorkRefineLoad, WorkResult } from "#@typeberry/block/work-result.js";
7
+ import { WorkExecResult, WorkRefineLoad, WorkResult } from "#@typeberry/block/work-result.js";
8
8
  import { Bytes, BytesBlob } from "#@typeberry/bytes";
9
9
  import { FixedSizeArray, HashSet } from "#@typeberry/collections";
10
10
  import { tinyChainSpec } from "#@typeberry/config";
@@ -52,7 +52,7 @@ describe("accumulate-utils", () => {
52
52
  importedSegments: tryAsU32(0),
53
53
  }),
54
54
  payloadHash: Bytes.zero(HASH_SIZE).asOpaque(),
55
- result: new WorkExecResult(WorkExecResultKind.ok, BytesBlob.empty()),
55
+ result: WorkExecResult.ok(BytesBlob.empty()),
56
56
  serviceId: tryAsServiceId(0),
57
57
  }),
58
58
  ], tryAsWorkItemsCount(1)),
@@ -1 +1 @@
1
- {"version":3,"file":"accumulate.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/transition/accumulate/accumulate.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,KAAK,SAAS,EAIf,MAAM,kBAAkB,CAAC;AAM1B,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,KAAK,OAAO,EAA8B,MAAM,iBAAiB,CAAC;AAmB3E,OAAO,EAAyC,MAAM,EAAa,MAAM,kBAAkB,CAAC;AAM5F,OAAO,EACL,KAAK,eAAe,EACpB,KAAK,gBAAgB,EACrB,KAAK,eAAe,EAGrB,MAAM,uBAAuB,CAAC;AAO/B,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AAGtD,eAAO,MAAM,kBAAkB,8BAA8B,CAAC;AAC9D,MAAM,MAAM,kBAAkB,GAAG,OAAO,kBAAkB,CAAC;AA2B3D,qBAAa,UAAU;aAEH,SAAS,EAAE,SAAS;aACpB,OAAO,EAAE,OAAO;aAChB,KAAK,EAAE,eAAe;aACtB,OAAO,EAAE,iBAAiB;gBAH1B,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,eAAe,EACtB,OAAO,EAAE,iBAAiB;IAO5C;;;;OAIG;IACH,OAAO,CAAC,qBAAqB;IAkB7B;;;;OAIG;YACW,uBAAuB;IAyGrC;;;;OAIG;YACW,uBAAuB;IAoDrC;;;;;;;OAOG;YACW,4BAA4B;IA8D1C;;;;;;;OAOG;YACW,sBAAsB;IAsEpC,OAAO,CAAC,gBAAgB;IAuCxB,OAAO,CAAC,kBAAkB;IAsB1B;;;;;;;;;OASG;YACW,oBAAoB;IA6ClC;;OAEG;IACH,OAAO,CAAC,0BAA0B;IAkDlC;;;;;;OAMG;IACH,OAAO,CAAC,WAAW;IAcnB;;;;;;OAMG;IACI,6BAA6B,CAAC,UAAU,EAAE,SAAS,EAAE,GAAG,OAAO;IAKhE,UAAU,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,eAAe,GAAG,OAAO,CAAC,MAAM,CAAC,gBAAgB,EAAE,kBAAkB,CAAC,CAAC;CAwGrH"}
1
+ {"version":3,"file":"accumulate.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/transition/accumulate/accumulate.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,KAAK,SAAS,EAIf,MAAM,kBAAkB,CAAC;AAM1B,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAEnD,OAAO,EAAE,KAAK,OAAO,EAA8B,MAAM,iBAAiB,CAAC;AAiB3E,OAAO,EAAyC,MAAM,EAAa,MAAM,kBAAkB,CAAC;AAM5F,OAAO,EACL,KAAK,eAAe,EACpB,KAAK,gBAAgB,EACrB,KAAK,eAAe,EAGrB,MAAM,uBAAuB,CAAC;AAO/B,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AAEtD,eAAO,MAAM,kBAAkB,8BAA8B,CAAC;AAC9D,MAAM,MAAM,kBAAkB,GAAG,OAAO,kBAAkB,CAAC;AA2B3D,qBAAa,UAAU;aAEH,SAAS,EAAE,SAAS;aACpB,OAAO,EAAE,OAAO;aAChB,KAAK,EAAE,eAAe;aACtB,OAAO,EAAE,iBAAiB;gBAH1B,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,eAAe,EACtB,OAAO,EAAE,iBAAiB;IAO5C;;;;OAIG;IACH,OAAO,CAAC,qBAAqB;IAkB7B;;;;OAIG;YACW,uBAAuB;IAqGrC;;;;OAIG;YACW,uBAAuB;IAoDrC;;;;;;;OAOG;YACW,4BAA4B;IA8D1C;;;;;;;OAOG;YACW,sBAAsB;IAsEpC,OAAO,CAAC,gBAAgB;IAuCxB,OAAO,CAAC,kBAAkB;IAsB1B;;;;;;;;;OASG;YACW,oBAAoB;IA6ClC;;OAEG;IACH,OAAO,CAAC,0BAA0B;IAkDlC;;;;;;OAMG;IACH,OAAO,CAAC,WAAW;IAcnB;;;;;;OAMG;IACI,6BAA6B,CAAC,UAAU,EAAE,SAAS,EAAE,GAAG,OAAO;IAKhE,UAAU,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,eAAe,GAAG,OAAO,CAAC,MAAM,CAAC,gBAAgB,EAAE,kBAAkB,CAAC,CAAC;CAwGrH"}
@@ -3,12 +3,11 @@ import { W_C } from "#@typeberry/block/gp-constants.js";
3
3
  import { Bytes } from "#@typeberry/bytes";
4
4
  import { codec, Encoder } from "#@typeberry/codec";
5
5
  import { ArrayView, HashSet, SortedArray } from "#@typeberry/collections";
6
+ import { PvmExecutor, ReturnStatus } from "#@typeberry/executor";
6
7
  import { HASH_SIZE } from "#@typeberry/hash";
7
8
  import { AccumulationStateUpdate, PartiallyUpdatedState, } from "#@typeberry/jam-host-calls/externalities/state-update.js";
8
9
  import { Logger } from "#@typeberry/logger";
9
- import { sumU64, tryAsU32 } from "#@typeberry/numbers";
10
- import { Status, tryAsGas } from "#@typeberry/pvm-interface";
11
- import { MAX_VALUE_U64 } from "#@typeberry/pvm-interpreter/ops/math-consts.js";
10
+ import { MAX_VALUE_U64, sumU64, tryAsU32 } from "#@typeberry/numbers";
12
11
  import { accumulationOutputComparator, hashComparator, ServiceAccountInfo, tryAsPerCore, } from "#@typeberry/state";
13
12
  import { assertEmpty, Compatibility, GpVersion, Result, TestSuite } from "#@typeberry/utils";
14
13
  import { AccumulateExternalities } from "../externalities/accumulate-externalities.js";
@@ -18,7 +17,6 @@ import { AccumulateQueue, pruneQueue } from "./accumulate-queue.js";
18
17
  import { GAS_TO_INVOKE_WORK_REPORT, } from "./accumulate-state.js";
19
18
  import { generateNextServiceId, getWorkPackageHashes } from "./accumulate-utils.js";
20
19
  import { mergePerallelAccumulationResults, } from "./accumulation-result-merge-utils.js";
21
- import { PvmExecutor } from "./pvm-executor.js";
22
20
  export const ACCUMULATION_ERROR = "duplicate service created";
23
21
  var PvmInvocationError;
24
22
  (function (PvmInvocationError) {
@@ -102,28 +100,25 @@ export class Accumulate {
102
100
  serviceId,
103
101
  argsLength: tryAsU32(transfers.length + operands.length),
104
102
  });
105
- const result = await executor.run(invocationArgs, tryAsGas(gas));
103
+ const result = await executor.run(invocationArgs, gas);
106
104
  const [newState, checkpoint] = partialState.getStateUpdates();
107
105
  /**
108
106
  * PVM invocation returned and error so we return the checkpoint
109
107
  *
110
108
  * https://graypaper.fluffylabs.dev/#/7e6ff6a/300002300002?v=0.6.7
111
109
  */
112
- if (result.hasStatus()) {
113
- const status = result.status;
114
- if (status === Status.OOG || status === Status.PANIC) {
115
- logger.trace `[${serviceId}] accumulate finished with ${Status[status]} reverting to checkpoint.`;
116
- return Result.ok({ stateUpdate: checkpoint, consumedGas: tryAsServiceGas(result.consumedGas) });
117
- }
118
- logger.trace `[${serviceId}] accumulate finished with ${Status[status]}`;
110
+ if (result.status !== ReturnStatus.OK) {
111
+ logger.trace `[${serviceId}] accumulate finished with ${ReturnStatus[result.status]} reverting to checkpoint.`;
112
+ return Result.ok({ stateUpdate: checkpoint, consumedGas: tryAsServiceGas(result.consumedGas) });
119
113
  }
114
+ logger.trace `[${serviceId}] accumulate finished with ${ReturnStatus[result.status]}`;
120
115
  /**
121
116
  * PVM invocation returned a hash so we override whatever `yield` host call
122
117
  * provided.
123
118
  *
124
119
  * https://graypaper.fluffylabs.dev/#/7e6ff6a/301202301202?v=0.6.7
125
120
  */
126
- if (result.hasMemorySlice() && result.memorySlice.length === HASH_SIZE) {
121
+ if (result.memorySlice.length === HASH_SIZE) {
127
122
  const memorySlice = Bytes.fromBlob(result.memorySlice, HASH_SIZE);
128
123
  newState.yieldedRoot = memorySlice.asOpaque();
129
124
  }
@@ -5,7 +5,7 @@ import { MIN_PUBLIC_SERVICE_INDEX } from "#@typeberry/block/gp-constants.js";
5
5
  import { RefineContext } from "#@typeberry/block/refine-context.js";
6
6
  import { tryAsWorkItemsCount } from "#@typeberry/block/work-package.js";
7
7
  import { WorkPackageSpec, WorkReport } from "#@typeberry/block/work-report.js";
8
- import { WorkExecResult, WorkExecResultKind, WorkRefineLoad, WorkResult } from "#@typeberry/block/work-result.js";
8
+ import { WorkExecResult, WorkRefineLoad, WorkResult } from "#@typeberry/block/work-result.js";
9
9
  import { Bytes, BytesBlob } from "#@typeberry/bytes";
10
10
  import { asKnownSize, FixedSizeArray, HashDictionary, HashSet } from "#@typeberry/collections";
11
11
  import { PvmBackend, PvmBackendNames, tinyChainSpec } from "#@typeberry/config";
@@ -266,7 +266,7 @@ const createWorkReport = (workPackageHash, prerequisites = [], serviceId = tryAs
266
266
  importedSegments: tryAsU32(0),
267
267
  }),
268
268
  payloadHash: Bytes.zero(HASH_SIZE).asOpaque(),
269
- result: new WorkExecResult(WorkExecResultKind.ok, BytesBlob.empty()),
269
+ result: WorkExecResult.ok(BytesBlob.empty()),
270
270
  serviceId,
271
271
  }),
272
272
  ], tryAsWorkItemsCount(1)),
@@ -1 +1 @@
1
- {"version":3,"file":"accumulation-result-merge-utils.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/transition/accumulate/accumulation-result-merge-utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,UAAU,EAAE,KAAK,SAAS,EAAmB,MAAM,kBAAkB,CAAC;AACpF,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,uBAAuB,EAAE,KAAK,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAI1F,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAE7D,wBAAgB,gCAAgC,CAC9C,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,eAAe,EACtB,UAAU,EAAE,uBAAuB,EACnC,OAAO,EAAE,0BAA0B,GAClC,WAAW,CAab;AAED,KAAK,SAAS,GAAG,SAAS,CAAC;AAC3B,KAAK,WAAW,GAAG;IAAE,WAAW,EAAE,UAAU,CAAC;IAAC,WAAW,EAAE,uBAAuB,CAAA;CAAE,CAAC;AAGrF,MAAM,MAAM,0BAA0B,GAAG,GAAG,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;AAErE,MAAM,MAAM,WAAW,GAAG;IACxB,SAAS,EAAE,eAAe,EAAE,CAAC;IAC7B,YAAY,EAAE,UAAU,CAAC;IACzB,KAAK,EAAE,uBAAuB,CAAC;CAChC,CAAC"}
1
+ {"version":3,"file":"accumulation-result-merge-utils.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/transition/accumulate/accumulation-result-merge-utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,UAAU,EAAE,KAAK,SAAS,EAAmB,MAAM,kBAAkB,CAAC;AACpF,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,uBAAuB,EAAE,KAAK,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAG1F,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAE7D,wBAAgB,gCAAgC,CAC9C,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,eAAe,EACtB,UAAU,EAAE,uBAAuB,EACnC,OAAO,EAAE,0BAA0B,GAClC,WAAW,CAab;AAED,KAAK,SAAS,GAAG,SAAS,CAAC;AAC3B,KAAK,WAAW,GAAG;IAAE,WAAW,EAAE,UAAU,CAAC;IAAC,WAAW,EAAE,uBAAuB,CAAA;CAAE,CAAC;AAGrF,MAAM,MAAM,0BAA0B,GAAG,GAAG,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;AAErE,MAAM,MAAM,WAAW,GAAG;IACxB,SAAS,EAAE,eAAe,EAAE,CAAC;IAC7B,YAAY,EAAE,UAAU,CAAC;IACzB,KAAK,EAAE,uBAAuB,CAAC;CAChC,CAAC"}
@@ -1,7 +1,6 @@
1
1
  import { tryAsServiceGas } from "#@typeberry/block";
2
2
  import { AccumulationStateUpdate } from "#@typeberry/jam-host-calls";
3
- import { sumU64 } from "#@typeberry/numbers";
4
- import { MAX_VALUE_U64 } from "#@typeberry/pvm-interpreter/ops/math-consts.js";
3
+ import { MAX_VALUE_U64, sumU64 } from "#@typeberry/numbers";
5
4
  import { PrivilegedServices, tryAsPerCore, UpdatePreimageKind } from "#@typeberry/state";
6
5
  export function mergePerallelAccumulationResults(chainSpec, state, inputState, results) {
7
6
  const mergeContext = createMergeContext(chainSpec, state, inputState, results);
@@ -7,8 +7,7 @@ import { BANDERSNATCH_KEY_BYTES, BLS_KEY_BYTES, ED25519_KEY_BYTES } from "#@type
7
7
  import { HASH_SIZE } from "#@typeberry/hash";
8
8
  import { AccumulationStateUpdate, PendingTransfer } from "#@typeberry/jam-host-calls";
9
9
  import { TRANSFER_MEMO_BYTES } from "#@typeberry/jam-host-calls/externalities/partial-state.js";
10
- import { tryAsU32, tryAsU64 } from "#@typeberry/numbers";
11
- import { MAX_VALUE_U64 } from "#@typeberry/pvm-interpreter/ops/math-consts.js";
10
+ import { MAX_VALUE_U64, tryAsU32, tryAsU64 } from "#@typeberry/numbers";
12
11
  import { AUTHORIZATION_QUEUE_SIZE, InMemoryState, PreimageItem, PrivilegedServices, ServiceAccountInfo, StorageItem, tryAsPerCore, UpdatePreimage, UpdateService, UpdateStorage, VALIDATOR_META_BYTES, ValidatorData, } from "#@typeberry/state";
13
12
  import { deepEqual } from "#@typeberry/utils";
14
13
  import { mergePerallelAccumulationResults } from "./accumulation-result-merge-utils.js";
@@ -1,7 +1,7 @@
1
1
  import { type EntropyHash, type ServiceId, type TimeSlot } from "#@typeberry/block";
2
2
  import type { ChainSpec, PvmBackend } from "#@typeberry/config";
3
3
  import type { Blake2b } from "#@typeberry/hash";
4
- import type { PendingTransfer } from "#@typeberry/jam-host-calls/externalities/pending-transfer.js";
4
+ import type { PendingTransfer } from "#@typeberry/jam-host-calls";
5
5
  import { type ServicesUpdate, type State } from "#@typeberry/state";
6
6
  import { Result } from "#@typeberry/utils";
7
7
  import type { CountAndGasUsed } from "../statistics.js";
@@ -1 +1 @@
1
- {"version":3,"file":"deferred-transfers.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/transition/accumulate/deferred-transfers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,WAAW,EAAE,KAAK,SAAS,EAAE,KAAK,QAAQ,EAAmB,MAAM,kBAAkB,CAAC;AAGpG,OAAO,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC/D,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,6DAA6D,CAAC;AAQnG,OAAO,EAAsB,KAAK,cAAc,EAAE,KAAK,KAAK,EAAE,MAAM,kBAAkB,CAAC;AACvF,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAG1C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAIxD,KAAK,sBAAsB,GAAG;IAC5B,gBAAgB,EAAE,eAAe,EAAE,CAAC;IACpC,QAAQ,EAAE,QAAQ,CAAC;IACnB,cAAc,EAAE,cAAc,CAAC;IAC/B,6DAA6D;IAC7D,OAAO,EAAE,WAAW,CAAC;CACtB,CAAC;AAEF,MAAM,MAAM,sBAAsB,GAAG,IAAI,CAAC,KAAK,EAAE,UAAU,GAAG,YAAY,GAAG,oBAAoB,CAAC,CAAC;AAEnG,MAAM,MAAM,uBAAuB,GAAG;IACpC,cAAc,EAAE,cAAc,CAAC;IAC/B,kBAAkB,EAAE,GAAG,CAAC,SAAS,EAAE,eAAe,CAAC,CAAC;CACrD,CAAC;AAQF,oBAAY,0BAA0B;IACpC,sBAAsB,IAAI;IAC1B,mBAAmB,IAAI;CACxB;AAGD;;GAEG;AACH,qBAAa,iBAAiB;aAEV,SAAS,EAAE,SAAS;aACpB,OAAO,EAAE,OAAO;IAChC,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,GAAG;gBAHJ,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,OAAO,EACf,KAAK,EAAE,sBAAsB,EAC7B,GAAG,EAAE,UAAU;IAG5B,UAAU,CAAC,EACf,gBAAgB,EAChB,QAAQ,EACR,cAAc,EAAE,mBAAmB,EACnC,OAAO,GACR,EAAE,sBAAsB,GAAG,OAAO,CAAC,MAAM,CAAC,uBAAuB,EAAE,0BAA0B,CAAC,CAAC;CAuFjG"}
1
+ {"version":3,"file":"deferred-transfers.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/transition/accumulate/deferred-transfers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,WAAW,EAAE,KAAK,SAAS,EAAE,KAAK,QAAQ,EAAmB,MAAM,kBAAkB,CAAC;AAGpG,OAAO,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAE/D,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAIjE,OAAO,EAAsB,KAAK,cAAc,EAAE,KAAK,KAAK,EAAE,MAAM,kBAAkB,CAAC;AACvF,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAG1C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAGxD,KAAK,sBAAsB,GAAG;IAC5B,gBAAgB,EAAE,eAAe,EAAE,CAAC;IACpC,QAAQ,EAAE,QAAQ,CAAC;IACnB,cAAc,EAAE,cAAc,CAAC;IAC/B,6DAA6D;IAC7D,OAAO,EAAE,WAAW,CAAC;CACtB,CAAC;AAEF,MAAM,MAAM,sBAAsB,GAAG,IAAI,CAAC,KAAK,EAAE,UAAU,GAAG,YAAY,GAAG,oBAAoB,CAAC,CAAC;AAEnG,MAAM,MAAM,uBAAuB,GAAG;IACpC,cAAc,EAAE,cAAc,CAAC;IAC/B,kBAAkB,EAAE,GAAG,CAAC,SAAS,EAAE,eAAe,CAAC,CAAC;CACrD,CAAC;AAQF,oBAAY,0BAA0B;IACpC,sBAAsB,IAAI;IAC1B,mBAAmB,IAAI;CACxB;AAGD;;GAEG;AACH,qBAAa,iBAAiB;aAEV,SAAS,EAAE,SAAS;aACpB,OAAO,EAAE,OAAO;IAChC,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,GAAG;gBAHJ,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,OAAO,EACf,KAAK,EAAE,sBAAsB,EAC7B,GAAG,EAAE,UAAU;IAG5B,UAAU,CAAC,EACf,gBAAgB,EAChB,QAAQ,EACR,cAAc,EAAE,mBAAmB,EACnC,OAAO,GACR,EAAE,sBAAsB,GAAG,OAAO,CAAC,MAAM,CAAC,uBAAuB,EAAE,0BAA0B,CAAC,CAAC;CAuFjG"}
@@ -1,16 +1,15 @@
1
1
  import { tryAsServiceGas } from "#@typeberry/block";
2
2
  import { W_C } from "#@typeberry/block/gp-constants.js";
3
3
  import { codec, Encoder } from "#@typeberry/codec";
4
- import { AccumulationStateUpdate, PartiallyUpdatedState, } from "#@typeberry/jam-host-calls/externalities/state-update.js";
4
+ import { PvmExecutor } from "#@typeberry/executor";
5
+ import { AccumulationStateUpdate, PartiallyUpdatedState } from "#@typeberry/jam-host-calls";
5
6
  import { Logger } from "#@typeberry/logger";
6
7
  import { sumU64, tryAsU32 } from "#@typeberry/numbers";
7
- import { tryAsGas } from "#@typeberry/pvm-interface";
8
8
  import { ServiceAccountInfo } from "#@typeberry/state";
9
9
  import { Result } from "#@typeberry/utils";
10
10
  import { AccumulateExternalities } from "../externalities/accumulate-externalities.js";
11
11
  import { FetchExternalities } from "../externalities/fetch-externalities.js";
12
12
  import { uniquePreserveOrder } from "./accumulate-utils.js";
13
- import { PvmExecutor } from "./pvm-executor.js";
14
13
  const ARGS_CODEC = codec.object({
15
14
  timeslot: codec.varU32.asOpaque(),
16
15
  serviceId: codec.varU32.asOpaque(),
@@ -61,7 +60,7 @@ export class DeferredTransfers {
61
60
  partiallyUpdatedState.updateServiceInfo(serviceId, newInfo);
62
61
  const partialState = new AccumulateExternalities(this.chainSpec, this.blake2b, partiallyUpdatedState, serviceId, serviceId, timeslot);
63
62
  const fetchExternalities = FetchExternalities.createForOnTransfer({ entropy, transfers }, this.chainSpec);
64
- let consumedGas = tryAsGas(0);
63
+ let consumedGas = tryAsServiceGas(0);
65
64
  const hasTransfers = transfers.length > 0;
66
65
  const isCodeCorrect = code !== null && code.length <= W_C;
67
66
  if (!hasTransfers || !isCodeCorrect) {
@@ -78,10 +77,10 @@ export class DeferredTransfers {
78
77
  else {
79
78
  const executor = await PvmExecutor.createOnTransferExecutor(serviceId, code, { partialState, fetchExternalities }, this.pvm);
80
79
  const args = Encoder.encodeObject(ARGS_CODEC, { timeslot, serviceId, transfersLength: tryAsU32(transfers.length) }, this.chainSpec);
81
- const gas = transfers.reduce((acc, item) => acc + item.gas, 0n);
82
- consumedGas = (await executor.run(args, tryAsGas(gas))).consumedGas;
80
+ const gas = tryAsServiceGas(transfers.reduce((acc, item) => acc + item.gas, 0n));
81
+ consumedGas = (await executor.run(args, gas)).consumedGas;
83
82
  }
84
- transferStatistics.set(serviceId, { count: tryAsU32(transfers.length), gasUsed: tryAsServiceGas(consumedGas) });
83
+ transferStatistics.set(serviceId, { count: tryAsU32(transfers.length), gasUsed: consumedGas });
85
84
  const [updatedState] = partialState.getStateUpdates();
86
85
  currentStateUpdate = updatedState;
87
86
  }
@@ -1 +1 @@
1
- {"version":3,"file":"disputes.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/transition/disputes/disputes.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AAGtE,OAAO,EAAkB,OAAO,EAA0B,MAAM,wBAAwB,CAAC;AACzF,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAQ/C,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAC1C,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,KAAK,EAAE,aAAa,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAc9E,qBAAa,QAAQ;IAEjB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,OAAO;aACR,KAAK,EAAE,aAAa;gBAFnB,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,OAAO,EACjB,KAAK,EAAE,aAAa;IAGtC,OAAO,CAAC,cAAc;IAoDtB,OAAO,CAAC,YAAY;IA8DpB,OAAO,CAAC,cAAc;IA6DtB,OAAO,CAAC,qBAAqB;IAoB7B,OAAO,CAAC,4BAA4B;IAsBpC,OAAO,CAAC,yBAAyB;IAoCjC,OAAO,CAAC,0BAA0B;IA0BlC;;;;OAIG;IACH,OAAO,CAAC,wBAAwB;IAuBhC,OAAO,CAAC,YAAY;IAepB,OAAO,CAAC,yBAAyB;IAWjC,OAAO,CAAC,+BAA+B;IAoCvC,OAAO,CAAC,gBAAgB;IAWxB;;OAEG;IACG,UAAU,CAAC,QAAQ,EAAE,iBAAiB,GAAG,OAAO,CACpD,MAAM,CACJ;QACE,aAAa,EAAE,OAAO,CAAC,UAAU,CAAC,CAAC;QACnC,WAAW,EAAE,mBAAmB,CAAC;KAClC,EACD,iBAAiB,CAClB,CACF;CAwCF"}
1
+ {"version":3,"file":"disputes.d.ts","sourceRoot":"","sources":["../../../../../../packages/jam/transition/disputes/disputes.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AAGtE,OAAO,EAAkB,OAAO,EAA0B,MAAM,wBAAwB,CAAC;AACzF,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAQ/C,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAC1C,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,KAAK,EAAE,aAAa,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAc9E,qBAAa,QAAQ;IAEjB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,OAAO;aACR,KAAK,EAAE,aAAa;gBAFnB,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,OAAO,EACjB,KAAK,EAAE,aAAa;IAGtC,OAAO,CAAC,cAAc;IAoDtB,OAAO,CAAC,YAAY;IA8DpB,OAAO,CAAC,cAAc;IA6DtB,OAAO,CAAC,qBAAqB;IAoB7B,OAAO,CAAC,4BAA4B;IAsBpC,OAAO,CAAC,yBAAyB;IAoCjC,OAAO,CAAC,0BAA0B;IA0BlC;;;;OAIG;IACH,OAAO,CAAC,wBAAwB;IAuBhC,OAAO,CAAC,YAAY;IAepB,OAAO,CAAC,yBAAyB;IAWjC,OAAO,CAAC,+BAA+B;IAoCvC,OAAO,CAAC,gBAAgB;IAaxB;;OAEG;IACG,UAAU,CAAC,QAAQ,EAAE,iBAAiB,GAAG,OAAO,CACpD,MAAM,CACJ;QACE,aAAa,EAAE,OAAO,CAAC,UAAU,CAAC,CAAC;QACnC,WAAW,EAAE,mBAAmB,CAAC;KAClC,EACD,iBAAiB,CAClB,CACF;CAwCF"}
@@ -291,10 +291,11 @@ export class Disputes {
291
291
  const punishSetKeys = this.state.disputesRecords.punishSet;
292
292
  const currentValidatorKeys = this.state.currentValidatorData.map((v) => v.ed25519);
293
293
  const previousValidatorKeys = this.state.previousValidatorData.map((v) => v.ed25519);
294
- const allValidatorKeys = currentValidatorKeys
295
- .concat(previousValidatorKeys)
296
- .filter((key) => !punishSetKeys.has(key));
297
- return HashSet.from(allValidatorKeys);
294
+ const allValidatorKeysSet = HashSet.from(currentValidatorKeys.concat(previousValidatorKeys));
295
+ for (const key of punishSetKeys) {
296
+ allValidatorKeysSet.delete(key);
297
+ }
298
+ return allValidatorKeysSet;
298
299
  }
299
300
  /**
300
301
  * Transition the disputes and return a list of offenders.
@@ -2,7 +2,7 @@
2
2
  import { tryAsCoreIndex, tryAsPerValidator, tryAsServiceGas, tryAsServiceId, tryAsTimeSlot } from "#@typeberry/block";
3
3
  import { RefineContext } from "#@typeberry/block/refine-context.js";
4
4
  import { WorkPackageSpec, WorkReport } from "#@typeberry/block/work-report.js";
5
- import { WorkExecResult, WorkExecResultKind, WorkRefineLoad, WorkResult } from "#@typeberry/block/work-result.js";
5
+ import { WorkExecResult, WorkRefineLoad, WorkResult } from "#@typeberry/block/work-result.js";
6
6
  import { Bytes, BytesBlob } from "#@typeberry/bytes";
7
7
  import { FixedSizeArray } from "#@typeberry/collections";
8
8
  import { tinyChainSpec } from "#@typeberry/config";
@@ -174,7 +174,7 @@ export function workReport(packageHash, coreIndex) {
174
174
  codeHash: Bytes.zero(HASH_SIZE).asOpaque(),
175
175
  payloadHash: Bytes.zero(HASH_SIZE).asOpaque(),
176
176
  gas: tryAsServiceGas(42),
177
- result: new WorkExecResult(WorkExecResultKind.ok, BytesBlob.parseBlob("0x010203")),
177
+ result: WorkExecResult.ok(BytesBlob.parseBlob("0x010203")),
178
178
  load: WorkRefineLoad.create({
179
179
  gasUsed: tryAsServiceGas(0),
180
180
  importedSegments: tryAsU32(0),