@aztec/blob-lib 4.0.0-nightly.20250907 → 4.0.0-nightly.20260107

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 (106) hide show
  1. package/dest/batched_blob.d.ts +26 -0
  2. package/dest/batched_blob.d.ts.map +1 -0
  3. package/dest/batched_blob.js +20 -0
  4. package/dest/blob.d.ts +50 -99
  5. package/dest/blob.d.ts.map +1 -1
  6. package/dest/blob.js +78 -169
  7. package/dest/blob_batching.d.ts +41 -123
  8. package/dest/blob_batching.d.ts.map +1 -1
  9. package/dest/blob_batching.js +129 -203
  10. package/dest/blob_utils.d.ts +40 -0
  11. package/dest/blob_utils.d.ts.map +1 -0
  12. package/dest/blob_utils.js +69 -0
  13. package/dest/circuit_types/blob_accumulator.d.ts +23 -0
  14. package/dest/circuit_types/blob_accumulator.d.ts.map +1 -0
  15. package/dest/circuit_types/blob_accumulator.js +62 -0
  16. package/dest/circuit_types/final_blob_accumulator.d.ts +23 -0
  17. package/dest/circuit_types/final_blob_accumulator.d.ts.map +1 -0
  18. package/dest/circuit_types/final_blob_accumulator.js +66 -0
  19. package/dest/circuit_types/final_blob_batching_challenges.d.ts +16 -0
  20. package/dest/circuit_types/final_blob_batching_challenges.d.ts.map +1 -0
  21. package/dest/circuit_types/final_blob_batching_challenges.js +26 -0
  22. package/dest/circuit_types/index.d.ts +4 -0
  23. package/dest/circuit_types/index.d.ts.map +1 -0
  24. package/dest/circuit_types/index.js +4 -0
  25. package/dest/encoding/block_blob_data.d.ts +22 -0
  26. package/dest/encoding/block_blob_data.d.ts.map +1 -0
  27. package/dest/encoding/block_blob_data.js +65 -0
  28. package/dest/encoding/block_end_marker.d.ts +11 -0
  29. package/dest/encoding/block_end_marker.d.ts.map +1 -0
  30. package/dest/encoding/block_end_marker.js +41 -0
  31. package/dest/encoding/block_end_state_field.d.ts +12 -0
  32. package/dest/encoding/block_end_state_field.d.ts.map +1 -0
  33. package/dest/encoding/block_end_state_field.js +39 -0
  34. package/dest/encoding/checkpoint_blob_data.d.ts +15 -0
  35. package/dest/encoding/checkpoint_blob_data.d.ts.map +1 -0
  36. package/dest/encoding/checkpoint_blob_data.js +67 -0
  37. package/dest/encoding/checkpoint_end_marker.d.ts +8 -0
  38. package/dest/encoding/checkpoint_end_marker.d.ts.map +1 -0
  39. package/dest/encoding/checkpoint_end_marker.js +28 -0
  40. package/dest/encoding/fixtures.d.ts +41 -0
  41. package/dest/encoding/fixtures.d.ts.map +1 -0
  42. package/dest/encoding/fixtures.js +140 -0
  43. package/dest/encoding/index.d.ts +10 -0
  44. package/dest/encoding/index.d.ts.map +1 -0
  45. package/dest/encoding/index.js +9 -0
  46. package/dest/encoding/tx_blob_data.d.ts +19 -0
  47. package/dest/encoding/tx_blob_data.d.ts.map +1 -0
  48. package/dest/encoding/tx_blob_data.js +79 -0
  49. package/dest/encoding/tx_start_marker.d.ts +16 -0
  50. package/dest/encoding/tx_start_marker.d.ts.map +1 -0
  51. package/dest/encoding/tx_start_marker.js +77 -0
  52. package/dest/errors.d.ts +1 -1
  53. package/dest/errors.d.ts.map +1 -1
  54. package/dest/hash.d.ts +43 -0
  55. package/dest/hash.d.ts.map +1 -0
  56. package/dest/hash.js +80 -0
  57. package/dest/index.d.ts +7 -4
  58. package/dest/index.d.ts.map +1 -1
  59. package/dest/index.js +6 -16
  60. package/dest/interface.d.ts +1 -2
  61. package/dest/interface.d.ts.map +1 -1
  62. package/dest/kzg_context.d.ts +8 -0
  63. package/dest/kzg_context.d.ts.map +1 -0
  64. package/dest/kzg_context.js +14 -0
  65. package/dest/sponge_blob.d.ts +12 -14
  66. package/dest/sponge_blob.d.ts.map +1 -1
  67. package/dest/sponge_blob.js +26 -30
  68. package/dest/testing.d.ts +10 -23
  69. package/dest/testing.d.ts.map +1 -1
  70. package/dest/testing.js +37 -53
  71. package/dest/types.d.ts +17 -0
  72. package/dest/types.d.ts.map +1 -0
  73. package/dest/types.js +4 -0
  74. package/package.json +10 -7
  75. package/src/batched_blob.ts +26 -0
  76. package/src/blob.ts +81 -195
  77. package/src/blob_batching.ts +168 -231
  78. package/src/blob_utils.ts +82 -0
  79. package/src/circuit_types/blob_accumulator.ts +96 -0
  80. package/src/circuit_types/final_blob_accumulator.ts +76 -0
  81. package/src/circuit_types/final_blob_batching_challenges.ts +30 -0
  82. package/src/circuit_types/index.ts +4 -0
  83. package/src/encoding/block_blob_data.ts +102 -0
  84. package/src/encoding/block_end_marker.ts +55 -0
  85. package/src/encoding/block_end_state_field.ts +59 -0
  86. package/src/encoding/checkpoint_blob_data.ts +95 -0
  87. package/src/encoding/checkpoint_end_marker.ts +40 -0
  88. package/src/encoding/fixtures.ts +210 -0
  89. package/src/encoding/index.ts +9 -0
  90. package/src/encoding/tx_blob_data.ts +116 -0
  91. package/src/encoding/tx_start_marker.ts +97 -0
  92. package/src/hash.ts +89 -0
  93. package/src/index.ts +6 -19
  94. package/src/interface.ts +0 -1
  95. package/src/kzg_context.ts +16 -0
  96. package/src/sponge_blob.ts +28 -31
  97. package/src/testing.ts +48 -59
  98. package/src/types.ts +17 -0
  99. package/dest/blob_batching_public_inputs.d.ts +0 -71
  100. package/dest/blob_batching_public_inputs.d.ts.map +0 -1
  101. package/dest/blob_batching_public_inputs.js +0 -168
  102. package/dest/encoding.d.ts +0 -66
  103. package/dest/encoding.d.ts.map +0 -1
  104. package/dest/encoding.js +0 -113
  105. package/src/blob_batching_public_inputs.ts +0 -252
  106. package/src/encoding.ts +0 -138
@@ -0,0 +1,40 @@
1
+ import { BLS12Point } from '@aztec/foundation/curves/bls12';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
+ import type { BatchedBlob } from './batched_blob.js';
4
+ import { Blob } from './blob.js';
5
+ import { type CheckpointBlobData } from './encoding/index.js';
6
+ /**
7
+ * @param blobs - The blobs to emit.
8
+ * @returns The blobs' compressed commitments in hex prefixed by the number of blobs. 1 byte for the prefix, 48 bytes
9
+ * per blob commitment.
10
+ * @dev Used for proposing blocks to validate injected blob commitments match real broadcast blobs.
11
+ */
12
+ export declare function getPrefixedEthBlobCommitments(blobs: Blob[]): `0x${string}`;
13
+ /**
14
+ * @param fields - Fields to broadcast in the blob(s)
15
+ * @returns As many blobs as required to broadcast the given fields to an L1 block.
16
+ *
17
+ * @throws If the number of fields does not match what's indicated by the checkpoint prefix.
18
+ */
19
+ export declare function getBlobsPerL1Block(fields: Fr[]): Blob[];
20
+ /**
21
+ * Get the encoded data from all blobs in the checkpoint.
22
+ * @param blobs - The blobs to read data from. Should be all the blobs for the L1 block proposing the checkpoint.
23
+ * @returns The encoded data of the checkpoint.
24
+ */
25
+ export declare function decodeCheckpointBlobDataFromBlobs(blobs: Blob[]): CheckpointBlobData;
26
+ export declare function computeBlobsHashFromBlobs(blobs: Blob[]): Fr;
27
+ export declare function getBlobCommitmentsFromBlobs(blobs: Blob[]): BLS12Point[];
28
+ /**
29
+ * Returns a proof of opening of the blobs to verify on L1 using the point evaluation precompile:
30
+ *
31
+ * input[:32] - versioned_hash
32
+ * input[32:64] - z
33
+ * input[64:96] - y
34
+ * input[96:144] - commitment C
35
+ * input[144:192] - commitment Q (a 'proof' committing to the quotient polynomial q(X))
36
+ *
37
+ * See https://eips.ethereum.org/EIPS/eip-4844#point-evaluation-precompile
38
+ */
39
+ export declare function getEthBlobEvaluationInputs(batchedBlob: BatchedBlob): `0x${string}`;
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxvYl91dGlscy5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2Jsb2JfdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQzVELE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUVwRCxPQUFPLEtBQUssRUFBRSxXQUFXLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNyRCxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQ2pDLE9BQU8sRUFBRSxLQUFLLGtCQUFrQixFQUFzQyxNQUFNLHFCQUFxQixDQUFDO0FBR2xHOzs7OztHQUtHO0FBQ0gsd0JBQWdCLDZCQUE2QixDQUFDLEtBQUssRUFBRSxJQUFJLEVBQUUsR0FBRyxLQUFLLE1BQU0sRUFBRSxDQVMxRTtBQUVEOzs7OztHQUtHO0FBQ0gsd0JBQWdCLGtCQUFrQixDQUFDLE1BQU0sRUFBRSxFQUFFLEVBQUUsR0FBRyxJQUFJLEVBQUUsQ0FTdkQ7QUFFRDs7OztHQUlHO0FBQ0gsd0JBQWdCLGlDQUFpQyxDQUFDLEtBQUssRUFBRSxJQUFJLEVBQUUsR0FBRyxrQkFBa0IsQ0FHbkY7QUFFRCx3QkFBZ0IseUJBQXlCLENBQUMsS0FBSyxFQUFFLElBQUksRUFBRSxHQUFHLEVBQUUsQ0FFM0Q7QUFFRCx3QkFBZ0IsMkJBQTJCLENBQUMsS0FBSyxFQUFFLElBQUksRUFBRSxHQUFHLFVBQVUsRUFBRSxDQUV2RTtBQUVEOzs7Ozs7Ozs7O0dBVUc7QUFDSCx3QkFBZ0IsMEJBQTBCLENBQUMsV0FBVyxFQUFFLFdBQVcsR0FBRyxLQUFLLE1BQU0sRUFBRSxDQVNsRiJ9
@@ -0,0 +1 @@
1
+ {"version":3,"file":"blob_utils.d.ts","sourceRoot":"","sources":["../src/blob_utils.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAC5D,OAAO,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AAEpD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,KAAK,kBAAkB,EAAsC,MAAM,qBAAqB,CAAC;AAGlG;;;;;GAKG;AACH,wBAAgB,6BAA6B,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,KAAK,MAAM,EAAE,CAS1E;AAED;;;;;GAKG;AACH,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,EAAE,EAAE,GAAG,IAAI,EAAE,CASvD;AAED;;;;GAIG;AACH,wBAAgB,iCAAiC,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,kBAAkB,CAGnF;AAED,wBAAgB,yBAAyB,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,CAE3D;AAED,wBAAgB,2BAA2B,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,UAAU,EAAE,CAEvE;AAED;;;;;;;;;;GAUG;AACH,wBAAgB,0BAA0B,CAAC,WAAW,EAAE,WAAW,GAAG,KAAK,MAAM,EAAE,CASlF"}
@@ -0,0 +1,69 @@
1
+ import { FIELDS_PER_BLOB } from '@aztec/constants';
2
+ import { BLS12Point } from '@aztec/foundation/curves/bls12';
3
+ import { Blob } from './blob.js';
4
+ import { decodeCheckpointBlobDataFromBuffer } from './encoding/index.js';
5
+ import { computeBlobsHash, computeEthVersionedBlobHash } from './hash.js';
6
+ /**
7
+ * @param blobs - The blobs to emit.
8
+ * @returns The blobs' compressed commitments in hex prefixed by the number of blobs. 1 byte for the prefix, 48 bytes
9
+ * per blob commitment.
10
+ * @dev Used for proposing blocks to validate injected blob commitments match real broadcast blobs.
11
+ */ export function getPrefixedEthBlobCommitments(blobs) {
12
+ // Prefix the number of blobs.
13
+ const lenBuf = Buffer.alloc(1);
14
+ lenBuf.writeUint8(blobs.length);
15
+ const blobBuf = Buffer.concat(blobs.map((blob)=>blob.commitment));
16
+ const buf = Buffer.concat([
17
+ lenBuf,
18
+ blobBuf
19
+ ]);
20
+ return `0x${buf.toString('hex')}`;
21
+ }
22
+ /**
23
+ * @param fields - Fields to broadcast in the blob(s)
24
+ * @returns As many blobs as required to broadcast the given fields to an L1 block.
25
+ *
26
+ * @throws If the number of fields does not match what's indicated by the checkpoint prefix.
27
+ */ export function getBlobsPerL1Block(fields) {
28
+ if (!fields.length) {
29
+ throw new Error('Cannot create blobs from empty fields.');
30
+ }
31
+ const numBlobs = Math.ceil(fields.length / FIELDS_PER_BLOB);
32
+ return Array.from({
33
+ length: numBlobs
34
+ }, (_, i)=>Blob.fromFields(fields.slice(i * FIELDS_PER_BLOB, (i + 1) * FIELDS_PER_BLOB)));
35
+ }
36
+ /**
37
+ * Get the encoded data from all blobs in the checkpoint.
38
+ * @param blobs - The blobs to read data from. Should be all the blobs for the L1 block proposing the checkpoint.
39
+ * @returns The encoded data of the checkpoint.
40
+ */ export function decodeCheckpointBlobDataFromBlobs(blobs) {
41
+ const buf = Buffer.concat(blobs.map((b)=>b.data));
42
+ return decodeCheckpointBlobDataFromBuffer(buf);
43
+ }
44
+ export function computeBlobsHashFromBlobs(blobs) {
45
+ return computeBlobsHash(blobs.map((b)=>b.getEthVersionedBlobHash()));
46
+ }
47
+ export function getBlobCommitmentsFromBlobs(blobs) {
48
+ return blobs.map((b)=>BLS12Point.decompress(b.commitment));
49
+ }
50
+ /**
51
+ * Returns a proof of opening of the blobs to verify on L1 using the point evaluation precompile:
52
+ *
53
+ * input[:32] - versioned_hash
54
+ * input[32:64] - z
55
+ * input[64:96] - y
56
+ * input[96:144] - commitment C
57
+ * input[144:192] - commitment Q (a 'proof' committing to the quotient polynomial q(X))
58
+ *
59
+ * See https://eips.ethereum.org/EIPS/eip-4844#point-evaluation-precompile
60
+ */ export function getEthBlobEvaluationInputs(batchedBlob) {
61
+ const buf = Buffer.concat([
62
+ computeEthVersionedBlobHash(batchedBlob.commitment.compress()),
63
+ batchedBlob.z.toBuffer(),
64
+ batchedBlob.y.toBuffer(),
65
+ batchedBlob.commitment.compress(),
66
+ batchedBlob.q.compress()
67
+ ]);
68
+ return `0x${buf.toString('hex')}`;
69
+ }
@@ -0,0 +1,23 @@
1
+ import { BLS12Fr, BLS12Point } from '@aztec/foundation/curves/bls12';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
+ import { BufferReader, FieldReader } from '@aztec/foundation/serialize';
4
+ /**
5
+ * See `noir-projects/noir-protocol-circuits/crates/blob/src/abis/blob_accumulator.nr` for documentation.
6
+ */
7
+ export declare class BlobAccumulator {
8
+ blobCommitmentsHashAcc: Fr;
9
+ zAcc: Fr;
10
+ yAcc: BLS12Fr;
11
+ cAcc: BLS12Point;
12
+ gammaAcc: Fr;
13
+ gammaPowAcc: BLS12Fr;
14
+ constructor(blobCommitmentsHashAcc: Fr, zAcc: Fr, yAcc: BLS12Fr, cAcc: BLS12Point, gammaAcc: Fr, gammaPowAcc: BLS12Fr);
15
+ static empty(): BlobAccumulator;
16
+ equals(other: BlobAccumulator): boolean;
17
+ static fromBuffer(buffer: Buffer | BufferReader): BlobAccumulator;
18
+ toBuffer(): Buffer<ArrayBufferLike>;
19
+ toFields(): Fr[];
20
+ static fromFields(fields: Fr[] | FieldReader): BlobAccumulator;
21
+ static random(): BlobAccumulator;
22
+ }
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxvYl9hY2N1bXVsYXRvci5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NpcmN1aXRfdHlwZXMvYmxvYl9hY2N1bXVsYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQVcsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNwRCxPQUFPLEVBQUUsWUFBWSxFQUFFLFdBQVcsRUFBcUIsTUFBTSw2QkFBNkIsQ0FBQztBQUUzRjs7R0FFRztBQUNILHFCQUFhLGVBQWU7SUFFakIsc0JBQXNCLEVBQUUsRUFBRTtJQUMxQixJQUFJLEVBQUUsRUFBRTtJQUNSLElBQUksRUFBRSxPQUFPO0lBQ2IsSUFBSSxFQUFFLFVBQVU7SUFDaEIsUUFBUSxFQUFFLEVBQUU7SUFDWixXQUFXLEVBQUUsT0FBTztJQU43QixZQUNTLHNCQUFzQixFQUFFLEVBQUUsRUFDMUIsSUFBSSxFQUFFLEVBQUUsRUFDUixJQUFJLEVBQUUsT0FBTyxFQUNiLElBQUksRUFBRSxVQUFVLEVBQ2hCLFFBQVEsRUFBRSxFQUFFLEVBQ1osV0FBVyxFQUFFLE9BQU8sRUFDekI7SUFFSixNQUFNLENBQUMsS0FBSyxJQUFJLGVBQWUsQ0FFOUI7SUFFRCxNQUFNLENBQUMsS0FBSyxFQUFFLGVBQWUsV0FTNUI7SUFFRCxNQUFNLENBQUMsVUFBVSxDQUFDLE1BQU0sRUFBRSxNQUFNLEdBQUcsWUFBWSxHQUFHLGVBQWUsQ0FVaEU7SUFFRCxRQUFRLDRCQVNQO0lBRUQsUUFBUSxTQVdQO0lBRUQsTUFBTSxDQUFDLFVBQVUsQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLEdBQUcsV0FBVyxHQUFHLGVBQWUsQ0FjN0Q7SUFFRCxNQUFNLENBQUMsTUFBTSxvQkFTWjtDQUNGIn0=
@@ -0,0 +1 @@
1
+ {"version":3,"file":"blob_accumulator.d.ts","sourceRoot":"","sources":["../../src/circuit_types/blob_accumulator.ts"],"names":[],"mappings":"AACA,OAAO,EAAW,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAC9E,OAAO,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AACpD,OAAO,EAAE,YAAY,EAAE,WAAW,EAAqB,MAAM,6BAA6B,CAAC;AAE3F;;GAEG;AACH,qBAAa,eAAe;IAEjB,sBAAsB,EAAE,EAAE;IAC1B,IAAI,EAAE,EAAE;IACR,IAAI,EAAE,OAAO;IACb,IAAI,EAAE,UAAU;IAChB,QAAQ,EAAE,EAAE;IACZ,WAAW,EAAE,OAAO;IAN7B,YACS,sBAAsB,EAAE,EAAE,EAC1B,IAAI,EAAE,EAAE,EACR,IAAI,EAAE,OAAO,EACb,IAAI,EAAE,UAAU,EAChB,QAAQ,EAAE,EAAE,EACZ,WAAW,EAAE,OAAO,EACzB;IAEJ,MAAM,CAAC,KAAK,IAAI,eAAe,CAE9B;IAED,MAAM,CAAC,KAAK,EAAE,eAAe,WAS5B;IAED,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,YAAY,GAAG,eAAe,CAUhE;IAED,QAAQ,4BASP;IAED,QAAQ,SAWP;IAED,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,EAAE,EAAE,GAAG,WAAW,GAAG,eAAe,CAc7D;IAED,MAAM,CAAC,MAAM,oBASZ;CACF"}
@@ -0,0 +1,62 @@
1
+ import { BLS12_FQ_LIMBS, BLS12_FR_LIMBS } from '@aztec/constants';
2
+ import { BLS12Fq, BLS12Fr, BLS12Point } from '@aztec/foundation/curves/bls12';
3
+ import { Fr } from '@aztec/foundation/curves/bn254';
4
+ import { BufferReader, FieldReader, serializeToBuffer } from '@aztec/foundation/serialize';
5
+ /**
6
+ * See `noir-projects/noir-protocol-circuits/crates/blob/src/abis/blob_accumulator.nr` for documentation.
7
+ */ export class BlobAccumulator {
8
+ blobCommitmentsHashAcc;
9
+ zAcc;
10
+ yAcc;
11
+ cAcc;
12
+ gammaAcc;
13
+ gammaPowAcc;
14
+ constructor(blobCommitmentsHashAcc, zAcc, yAcc, cAcc, gammaAcc, gammaPowAcc){
15
+ this.blobCommitmentsHashAcc = blobCommitmentsHashAcc;
16
+ this.zAcc = zAcc;
17
+ this.yAcc = yAcc;
18
+ this.cAcc = cAcc;
19
+ this.gammaAcc = gammaAcc;
20
+ this.gammaPowAcc = gammaPowAcc;
21
+ }
22
+ static empty() {
23
+ return new BlobAccumulator(Fr.ZERO, Fr.ZERO, BLS12Fr.ZERO, BLS12Point.ZERO, Fr.ZERO, BLS12Fr.ZERO);
24
+ }
25
+ equals(other) {
26
+ return this.blobCommitmentsHashAcc.equals(other.blobCommitmentsHashAcc) && this.zAcc.equals(other.zAcc) && this.yAcc.equals(other.yAcc) && this.cAcc.equals(other.cAcc) && this.gammaAcc.equals(other.gammaAcc) && this.gammaPowAcc.equals(other.gammaPowAcc);
27
+ }
28
+ static fromBuffer(buffer) {
29
+ const reader = BufferReader.asReader(buffer);
30
+ return new BlobAccumulator(Fr.fromBuffer(reader), Fr.fromBuffer(reader), BLS12Fr.fromBuffer(reader), BLS12Point.fromBuffer(reader), Fr.fromBuffer(reader), BLS12Fr.fromBuffer(reader));
31
+ }
32
+ toBuffer() {
33
+ return serializeToBuffer(this.blobCommitmentsHashAcc, this.zAcc, this.yAcc, this.cAcc, this.gammaAcc, this.gammaPowAcc);
34
+ }
35
+ toFields() {
36
+ return [
37
+ this.blobCommitmentsHashAcc,
38
+ this.zAcc,
39
+ ...this.yAcc.toNoirBigNum().limbs.map(Fr.fromString),
40
+ ...this.cAcc.x.toNoirBigNum().limbs.map(Fr.fromString),
41
+ ...this.cAcc.y.toNoirBigNum().limbs.map(Fr.fromString),
42
+ new Fr(this.cAcc.isInfinite),
43
+ this.gammaAcc,
44
+ ...this.gammaPowAcc.toNoirBigNum().limbs.map(Fr.fromString)
45
+ ];
46
+ }
47
+ static fromFields(fields) {
48
+ const reader = FieldReader.asReader(fields);
49
+ return new BlobAccumulator(reader.readField(), reader.readField(), BLS12Fr.fromNoirBigNum({
50
+ limbs: reader.readFieldArray(BLS12_FR_LIMBS).map((f)=>f.toString())
51
+ }), new BLS12Point(BLS12Fq.fromNoirBigNum({
52
+ limbs: reader.readFieldArray(BLS12_FQ_LIMBS).map((f)=>f.toString())
53
+ }), BLS12Fq.fromNoirBigNum({
54
+ limbs: reader.readFieldArray(BLS12_FQ_LIMBS).map((f)=>f.toString())
55
+ }), reader.readBoolean()), reader.readField(), BLS12Fr.fromNoirBigNum({
56
+ limbs: reader.readFieldArray(BLS12_FR_LIMBS).map((f)=>f.toString())
57
+ }));
58
+ }
59
+ static random() {
60
+ return new BlobAccumulator(Fr.random(), Fr.random(), BLS12Fr.random(), BLS12Point.random(), Fr.random(), BLS12Fr.random());
61
+ }
62
+ }
@@ -0,0 +1,23 @@
1
+ import { BLS12Fr, BLS12Point } from '@aztec/foundation/curves/bls12';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
+ import { BufferReader } from '@aztec/foundation/serialize';
4
+ import { inspect } from 'util';
5
+ /**
6
+ * See `noir-projects/noir-protocol-circuits/crates/blob/src/abis/final_blob_accumulator.nr` for documentation.
7
+ */
8
+ export declare class FinalBlobAccumulator {
9
+ blobCommitmentsHash: Fr;
10
+ z: Fr;
11
+ y: BLS12Fr;
12
+ c: BLS12Point;
13
+ constructor(blobCommitmentsHash: Fr, z: Fr, y: BLS12Fr, c: BLS12Point);
14
+ static empty(): FinalBlobAccumulator;
15
+ static fromBuffer(buffer: Buffer | BufferReader): FinalBlobAccumulator;
16
+ toBuffer(): Buffer<ArrayBufferLike>;
17
+ toFields(): Fr[];
18
+ toString(): string;
19
+ equals(other: FinalBlobAccumulator): boolean;
20
+ static random(): FinalBlobAccumulator;
21
+ [inspect.custom](): string;
22
+ }
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmluYWxfYmxvYl9hY2N1bXVsYXRvci5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NpcmN1aXRfdHlwZXMvZmluYWxfYmxvYl9hY2N1bXVsYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ3JFLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNwRCxPQUFPLEVBQUUsWUFBWSxFQUFxQixNQUFNLDZCQUE2QixDQUFDO0FBRTlFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFL0I7O0dBRUc7QUFDSCxxQkFBYSxvQkFBb0I7SUFFdEIsbUJBQW1CLEVBQUUsRUFBRTtJQUN2QixDQUFDLEVBQUUsRUFBRTtJQUNMLENBQUMsRUFBRSxPQUFPO0lBQ1YsQ0FBQyxFQUFFLFVBQVU7SUFKdEIsWUFDUyxtQkFBbUIsRUFBRSxFQUFFLEVBQ3ZCLENBQUMsRUFBRSxFQUFFLEVBQ0wsQ0FBQyxFQUFFLE9BQU8sRUFDVixDQUFDLEVBQUUsVUFBVSxFQUNsQjtJQUVKLE1BQU0sQ0FBQyxLQUFLLElBQUksb0JBQW9CLENBRW5DO0lBRUQsTUFBTSxDQUFDLFVBQVUsQ0FBQyxNQUFNLEVBQUUsTUFBTSxHQUFHLFlBQVksR0FBRyxvQkFBb0IsQ0FRckU7SUFFRCxRQUFRLDRCQUVQO0lBRUQsUUFBUSxTQU9QO0lBR0QsUUFBUSxXQU1QO0lBRUQsTUFBTSxDQUFDLEtBQUssRUFBRSxvQkFBb0IsV0FPakM7SUFHRCxNQUFNLENBQUMsTUFBTSx5QkFFWjtJQUVELENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxXQU9mO0NBQ0YifQ==
@@ -0,0 +1 @@
1
+ {"version":3,"file":"final_blob_accumulator.d.ts","sourceRoot":"","sources":["../../src/circuit_types/final_blob_accumulator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AACrE,OAAO,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AACpD,OAAO,EAAE,YAAY,EAAqB,MAAM,6BAA6B,CAAC;AAE9E,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAE/B;;GAEG;AACH,qBAAa,oBAAoB;IAEtB,mBAAmB,EAAE,EAAE;IACvB,CAAC,EAAE,EAAE;IACL,CAAC,EAAE,OAAO;IACV,CAAC,EAAE,UAAU;IAJtB,YACS,mBAAmB,EAAE,EAAE,EACvB,CAAC,EAAE,EAAE,EACL,CAAC,EAAE,OAAO,EACV,CAAC,EAAE,UAAU,EAClB;IAEJ,MAAM,CAAC,KAAK,IAAI,oBAAoB,CAEnC;IAED,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,YAAY,GAAG,oBAAoB,CAQrE;IAED,QAAQ,4BAEP;IAED,QAAQ,SAOP;IAGD,QAAQ,WAMP;IAED,MAAM,CAAC,KAAK,EAAE,oBAAoB,WAOjC;IAGD,MAAM,CAAC,MAAM,yBAEZ;IAED,CAAC,OAAO,CAAC,MAAM,CAAC,WAOf;CACF"}
@@ -0,0 +1,66 @@
1
+ var _computedKey;
2
+ import { BLS12Fr, BLS12Point } from '@aztec/foundation/curves/bls12';
3
+ import { Fr } from '@aztec/foundation/curves/bn254';
4
+ import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
5
+ import { inspect } from 'util';
6
+ _computedKey = inspect.custom;
7
+ /**
8
+ * See `noir-projects/noir-protocol-circuits/crates/blob/src/abis/final_blob_accumulator.nr` for documentation.
9
+ */ export class FinalBlobAccumulator {
10
+ blobCommitmentsHash;
11
+ z;
12
+ y;
13
+ c;
14
+ constructor(blobCommitmentsHash, z, y, c){
15
+ this.blobCommitmentsHash = blobCommitmentsHash;
16
+ this.z = z;
17
+ this.y = y;
18
+ this.c = c;
19
+ }
20
+ static empty() {
21
+ return new FinalBlobAccumulator(Fr.ZERO, Fr.ZERO, BLS12Fr.ZERO, BLS12Point.ZERO);
22
+ }
23
+ static fromBuffer(buffer) {
24
+ const reader = BufferReader.asReader(buffer);
25
+ return new FinalBlobAccumulator(Fr.fromBuffer(reader), Fr.fromBuffer(reader), BLS12Fr.fromBuffer(reader), BLS12Point.fromBuffer(reader));
26
+ }
27
+ toBuffer() {
28
+ return serializeToBuffer(this.blobCommitmentsHash, this.z, this.y, this.c);
29
+ }
30
+ toFields() {
31
+ return [
32
+ this.blobCommitmentsHash,
33
+ this.z,
34
+ ...this.y.toNoirBigNum().limbs.map(Fr.fromString),
35
+ ...this.c.toBN254Fields()
36
+ ];
37
+ }
38
+ // The below is used to send to L1 for proof verification
39
+ toString() {
40
+ // We prepend 32 bytes for the (unused) 'blobHash' slot. This is not read or required by getEpochProofPublicInputs() on L1, but
41
+ // is expected since we usually pass the full precompile inputs via verifyEpochRootProof() to getEpochProofPublicInputs() to ensure
42
+ // we use calldata rather than a slice in memory:
43
+ const buf = Buffer.concat([
44
+ Buffer.alloc(32),
45
+ this.z.toBuffer(),
46
+ this.y.toBuffer(),
47
+ this.c.compress()
48
+ ]);
49
+ return buf.toString('hex');
50
+ }
51
+ equals(other) {
52
+ return this.blobCommitmentsHash.equals(other.blobCommitmentsHash) && this.z.equals(other.z) && this.y.equals(other.y) && this.c.equals(other.c);
53
+ }
54
+ // Creates a random instance. Used for testing only - will not prove/verify.
55
+ static random() {
56
+ return new FinalBlobAccumulator(Fr.random(), Fr.random(), BLS12Fr.random(), BLS12Point.random());
57
+ }
58
+ [_computedKey]() {
59
+ return `FinalBlobAccumulator {
60
+ blobCommitmentsHash: ${inspect(this.blobCommitmentsHash)},
61
+ z: ${inspect(this.z)},
62
+ y: ${inspect(this.y)},
63
+ c: ${inspect(this.c)},
64
+ }`;
65
+ }
66
+ }
@@ -0,0 +1,16 @@
1
+ import { BLS12Fr } from '@aztec/foundation/curves/bls12';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
+ import { BufferReader } from '@aztec/foundation/serialize';
4
+ /**
5
+ * See `noir-projects/noir-protocol-circuits/crates/blob/src/abis/final_blob_batching_challenges.nr` for documentation.
6
+ */
7
+ export declare class FinalBlobBatchingChallenges {
8
+ readonly z: Fr;
9
+ readonly gamma: BLS12Fr;
10
+ constructor(z: Fr, gamma: BLS12Fr);
11
+ equals(other: FinalBlobBatchingChallenges): boolean;
12
+ static empty(): FinalBlobBatchingChallenges;
13
+ static fromBuffer(buffer: Buffer | BufferReader): FinalBlobBatchingChallenges;
14
+ toBuffer(): Buffer<ArrayBufferLike>;
15
+ }
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmluYWxfYmxvYl9iYXRjaGluZ19jaGFsbGVuZ2VzLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY2lyY3VpdF90eXBlcy9maW5hbF9ibG9iX2JhdGNoaW5nX2NoYWxsZW5nZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ3pELE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNwRCxPQUFPLEVBQUUsWUFBWSxFQUFxQixNQUFNLDZCQUE2QixDQUFDO0FBRTlFOztHQUVHO0FBQ0gscUJBQWEsMkJBQTJCO2FBRXBCLENBQUMsRUFBRSxFQUFFO2FBQ0wsS0FBSyxFQUFFLE9BQU87SUFGaEMsWUFDa0IsQ0FBQyxFQUFFLEVBQUUsRUFDTCxLQUFLLEVBQUUsT0FBTyxFQUM1QjtJQUVKLE1BQU0sQ0FBQyxLQUFLLEVBQUUsMkJBQTJCLFdBRXhDO0lBRUQsTUFBTSxDQUFDLEtBQUssSUFBSSwyQkFBMkIsQ0FFMUM7SUFFRCxNQUFNLENBQUMsVUFBVSxDQUFDLE1BQU0sRUFBRSxNQUFNLEdBQUcsWUFBWSxHQUFHLDJCQUEyQixDQUc1RTtJQUVELFFBQVEsNEJBRVA7Q0FDRiJ9
@@ -0,0 +1 @@
1
+ {"version":3,"file":"final_blob_batching_challenges.d.ts","sourceRoot":"","sources":["../../src/circuit_types/final_blob_batching_challenges.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,gCAAgC,CAAC;AACzD,OAAO,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AACpD,OAAO,EAAE,YAAY,EAAqB,MAAM,6BAA6B,CAAC;AAE9E;;GAEG;AACH,qBAAa,2BAA2B;aAEpB,CAAC,EAAE,EAAE;aACL,KAAK,EAAE,OAAO;IAFhC,YACkB,CAAC,EAAE,EAAE,EACL,KAAK,EAAE,OAAO,EAC5B;IAEJ,MAAM,CAAC,KAAK,EAAE,2BAA2B,WAExC;IAED,MAAM,CAAC,KAAK,IAAI,2BAA2B,CAE1C;IAED,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,YAAY,GAAG,2BAA2B,CAG5E;IAED,QAAQ,4BAEP;CACF"}
@@ -0,0 +1,26 @@
1
+ import { BLS12Fr } from '@aztec/foundation/curves/bls12';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
+ import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
4
+ /**
5
+ * See `noir-projects/noir-protocol-circuits/crates/blob/src/abis/final_blob_batching_challenges.nr` for documentation.
6
+ */ export class FinalBlobBatchingChallenges {
7
+ z;
8
+ gamma;
9
+ constructor(z, gamma){
10
+ this.z = z;
11
+ this.gamma = gamma;
12
+ }
13
+ equals(other) {
14
+ return this.z.equals(other.z) && this.gamma.equals(other.gamma);
15
+ }
16
+ static empty() {
17
+ return new FinalBlobBatchingChallenges(Fr.ZERO, BLS12Fr.ZERO);
18
+ }
19
+ static fromBuffer(buffer) {
20
+ const reader = BufferReader.asReader(buffer);
21
+ return new FinalBlobBatchingChallenges(Fr.fromBuffer(reader), reader.readObject(BLS12Fr));
22
+ }
23
+ toBuffer() {
24
+ return serializeToBuffer(this.z, this.gamma);
25
+ }
26
+ }
@@ -0,0 +1,4 @@
1
+ export * from './blob_accumulator.js';
2
+ export * from './final_blob_accumulator.js';
3
+ export * from './final_blob_batching_challenges.js';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jaXJjdWl0X3R5cGVzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLHFDQUFxQyxDQUFDIn0=
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/circuit_types/index.ts"],"names":[],"mappings":"AACA,cAAc,uBAAuB,CAAC;AACtC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,qCAAqC,CAAC"}
@@ -0,0 +1,4 @@
1
+ /// Types used in the protocol circuits.
2
+ export * from './blob_accumulator.js';
3
+ export * from './final_blob_accumulator.js';
4
+ export * from './final_blob_batching_challenges.js';
@@ -0,0 +1,22 @@
1
+ import { Fr } from '@aztec/foundation/curves/bn254';
2
+ import { FieldReader } from '@aztec/foundation/serialize';
3
+ import { type BlockEndMarker } from './block_end_marker.js';
4
+ import { type BlockEndStateField } from './block_end_state_field.js';
5
+ import { type TxBlobData } from './tx_blob_data.js';
6
+ export interface BlockEndBlobData {
7
+ blockEndMarker: BlockEndMarker;
8
+ blockEndStateField: BlockEndStateField;
9
+ lastArchiveRoot: Fr;
10
+ noteHashRoot: Fr;
11
+ nullifierRoot: Fr;
12
+ publicDataRoot: Fr;
13
+ l1ToL2MessageRoot: Fr | undefined;
14
+ }
15
+ export interface BlockBlobData extends BlockEndBlobData {
16
+ txs: TxBlobData[];
17
+ }
18
+ export declare function encodeBlockEndBlobData(blockEndBlobData: BlockEndBlobData): Fr[];
19
+ export declare function decodeBlockEndBlobData(fields: Fr[] | FieldReader, isFirstBlock: boolean): BlockEndBlobData;
20
+ export declare function encodeBlockBlobData(blockBlobData: BlockBlobData): Fr[];
21
+ export declare function decodeBlockBlobData(fields: Fr[] | FieldReader, isFirstBlock: boolean): BlockBlobData;
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxvY2tfYmxvYl9kYXRhLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZW5jb2RpbmcvYmxvY2tfYmxvYl9kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNwRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFHMUQsT0FBTyxFQUNMLEtBQUssY0FBYyxFQUlwQixNQUFNLHVCQUF1QixDQUFDO0FBQy9CLE9BQU8sRUFDTCxLQUFLLGtCQUFrQixFQUd4QixNQUFNLDRCQUE0QixDQUFDO0FBQ3BDLE9BQU8sRUFBRSxLQUFLLFVBQVUsRUFBc0MsTUFBTSxtQkFBbUIsQ0FBQztBQUl4RixNQUFNLFdBQVcsZ0JBQWdCO0lBQy9CLGNBQWMsRUFBRSxjQUFjLENBQUM7SUFDL0Isa0JBQWtCLEVBQUUsa0JBQWtCLENBQUM7SUFDdkMsZUFBZSxFQUFFLEVBQUUsQ0FBQztJQUNwQixZQUFZLEVBQUUsRUFBRSxDQUFDO0lBQ2pCLGFBQWEsRUFBRSxFQUFFLENBQUM7SUFDbEIsY0FBYyxFQUFFLEVBQUUsQ0FBQztJQUNuQixpQkFBaUIsRUFBRSxFQUFFLEdBQUcsU0FBUyxDQUFDO0NBQ25DO0FBRUQsTUFBTSxXQUFXLGFBQWMsU0FBUSxnQkFBZ0I7SUFDckQsR0FBRyxFQUFFLFVBQVUsRUFBRSxDQUFDO0NBQ25CO0FBRUQsd0JBQWdCLHNCQUFzQixDQUFDLGdCQUFnQixFQUFFLGdCQUFnQixHQUFHLEVBQUUsRUFBRSxDQVUvRTtBQUVELHdCQUFnQixzQkFBc0IsQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLEdBQUcsV0FBVyxFQUFFLFlBQVksRUFBRSxPQUFPLEdBQUcsZ0JBQWdCLENBbUIxRztBQUVELHdCQUFnQixtQkFBbUIsQ0FBQyxhQUFhLEVBQUUsYUFBYSxHQUFHLEVBQUUsRUFBRSxDQUV0RTtBQUVELHdCQUFnQixtQkFBbUIsQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLEdBQUcsV0FBVyxFQUFFLFlBQVksRUFBRSxPQUFPLEdBQUcsYUFBYSxDQStCcEcifQ==
@@ -0,0 +1 @@
1
+ {"version":3,"file":"block_blob_data.d.ts","sourceRoot":"","sources":["../../src/encoding/block_blob_data.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAG1D,OAAO,EACL,KAAK,cAAc,EAIpB,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EACL,KAAK,kBAAkB,EAGxB,MAAM,4BAA4B,CAAC;AACpC,OAAO,EAAE,KAAK,UAAU,EAAsC,MAAM,mBAAmB,CAAC;AAIxF,MAAM,WAAW,gBAAgB;IAC/B,cAAc,EAAE,cAAc,CAAC;IAC/B,kBAAkB,EAAE,kBAAkB,CAAC;IACvC,eAAe,EAAE,EAAE,CAAC;IACpB,YAAY,EAAE,EAAE,CAAC;IACjB,aAAa,EAAE,EAAE,CAAC;IAClB,cAAc,EAAE,EAAE,CAAC;IACnB,iBAAiB,EAAE,EAAE,GAAG,SAAS,CAAC;CACnC;AAED,MAAM,WAAW,aAAc,SAAQ,gBAAgB;IACrD,GAAG,EAAE,UAAU,EAAE,CAAC;CACnB;AAED,wBAAgB,sBAAsB,CAAC,gBAAgB,EAAE,gBAAgB,GAAG,EAAE,EAAE,CAU/E;AAED,wBAAgB,sBAAsB,CAAC,MAAM,EAAE,EAAE,EAAE,GAAG,WAAW,EAAE,YAAY,EAAE,OAAO,GAAG,gBAAgB,CAmB1G;AAED,wBAAgB,mBAAmB,CAAC,aAAa,EAAE,aAAa,GAAG,EAAE,EAAE,CAEtE;AAED,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,EAAE,EAAE,GAAG,WAAW,EAAE,YAAY,EAAE,OAAO,GAAG,aAAa,CA+BpG"}
@@ -0,0 +1,65 @@
1
+ import { FieldReader } from '@aztec/foundation/serialize';
2
+ import { BlobDeserializationError } from '../errors.js';
3
+ import { decodeBlockEndMarker, encodeBlockEndMarker, isBlockEndMarker } from './block_end_marker.js';
4
+ import { decodeBlockEndStateField, encodeBlockEndStateField } from './block_end_state_field.js';
5
+ import { decodeTxBlobData, encodeTxBlobData } from './tx_blob_data.js';
6
+ export function encodeBlockEndBlobData(blockEndBlobData) {
7
+ return [
8
+ encodeBlockEndMarker(blockEndBlobData.blockEndMarker),
9
+ encodeBlockEndStateField(blockEndBlobData.blockEndStateField),
10
+ blockEndBlobData.lastArchiveRoot,
11
+ blockEndBlobData.noteHashRoot,
12
+ blockEndBlobData.nullifierRoot,
13
+ blockEndBlobData.publicDataRoot,
14
+ ...blockEndBlobData.l1ToL2MessageRoot ? [
15
+ blockEndBlobData.l1ToL2MessageRoot
16
+ ] : []
17
+ ];
18
+ }
19
+ export function decodeBlockEndBlobData(fields, isFirstBlock) {
20
+ const reader = FieldReader.asReader(fields);
21
+ const numBlockEndData = isFirstBlock ? 7 : 6;
22
+ if (numBlockEndData > reader.remainingFields()) {
23
+ throw new BlobDeserializationError(`Incorrect encoding of blob fields: not enough fields for block end data. Expected ${numBlockEndData} fields, only ${reader.remainingFields()} remaining.`);
24
+ }
25
+ return {
26
+ blockEndMarker: decodeBlockEndMarker(reader.readField()),
27
+ blockEndStateField: decodeBlockEndStateField(reader.readField()),
28
+ lastArchiveRoot: reader.readField(),
29
+ noteHashRoot: reader.readField(),
30
+ nullifierRoot: reader.readField(),
31
+ publicDataRoot: reader.readField(),
32
+ l1ToL2MessageRoot: isFirstBlock ? reader.readField() : undefined
33
+ };
34
+ }
35
+ export function encodeBlockBlobData(blockBlobData) {
36
+ return [
37
+ ...blockBlobData.txs.map((tx)=>encodeTxBlobData(tx)).flat(),
38
+ ...encodeBlockEndBlobData(blockBlobData)
39
+ ];
40
+ }
41
+ export function decodeBlockBlobData(fields, isFirstBlock) {
42
+ const reader = FieldReader.asReader(fields);
43
+ const txs = [];
44
+ let hasReachedBlockEnd = false;
45
+ while(!hasReachedBlockEnd){
46
+ if (reader.isFinished()) {
47
+ throw new BlobDeserializationError(`Incorrect encoding of blob fields: not enough fields for block end marker.`);
48
+ }
49
+ const currentField = reader.peekField();
50
+ if (isBlockEndMarker(currentField)) {
51
+ hasReachedBlockEnd = true;
52
+ } else {
53
+ txs.push(decodeTxBlobData(reader));
54
+ }
55
+ }
56
+ const blockEndBlobData = decodeBlockEndBlobData(reader, isFirstBlock);
57
+ const blockEndMarker = blockEndBlobData.blockEndMarker;
58
+ if (blockEndMarker.numTxs !== txs.length) {
59
+ throw new BlobDeserializationError(`Incorrect encoding of blob fields: expected ${blockEndMarker.numTxs} txs, but got ${txs.length}.`);
60
+ }
61
+ return {
62
+ txs,
63
+ ...blockEndBlobData
64
+ };
65
+ }
@@ -0,0 +1,11 @@
1
+ import { BlockNumber } from '@aztec/foundation/branded-types';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
+ export interface BlockEndMarker {
4
+ timestamp: bigint;
5
+ blockNumber: BlockNumber;
6
+ numTxs: number;
7
+ }
8
+ export declare function encodeBlockEndMarker(blockEndMarker: BlockEndMarker): Fr;
9
+ export declare function decodeBlockEndMarker(field: Fr): BlockEndMarker;
10
+ export declare function isBlockEndMarker(field: Fr): boolean;
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxvY2tfZW5kX21hcmtlci5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2VuY29kaW5nL2Jsb2NrX2VuZF9tYXJrZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQzlELE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQVVwRCxNQUFNLFdBQVcsY0FBYztJQUM3QixTQUFTLEVBQUUsTUFBTSxDQUFDO0lBQ2xCLFdBQVcsRUFBRSxXQUFXLENBQUM7SUFDekIsTUFBTSxFQUFFLE1BQU0sQ0FBQztDQUNoQjtBQUVELHdCQUFnQixvQkFBb0IsQ0FBQyxjQUFjLEVBQUUsY0FBYyxNQVNsRTtBQUVELHdCQUFnQixvQkFBb0IsQ0FBQyxLQUFLLEVBQUUsRUFBRSxHQUFHLGNBQWMsQ0FtQjlEO0FBR0Qsd0JBQWdCLGdCQUFnQixDQUFDLEtBQUssRUFBRSxFQUFFLEdBQUcsT0FBTyxDQUduRCJ9
@@ -0,0 +1 @@
1
+ {"version":3,"file":"block_end_marker.d.ts","sourceRoot":"","sources":["../../src/encoding/block_end_marker.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,iCAAiC,CAAC;AAC9D,OAAO,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AAUpD,MAAM,WAAW,cAAc;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,WAAW,CAAC;IACzB,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,wBAAgB,oBAAoB,CAAC,cAAc,EAAE,cAAc,MASlE;AAED,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,EAAE,GAAG,cAAc,CAmB9D;AAGD,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,EAAE,GAAG,OAAO,CAGnD"}
@@ -0,0 +1,41 @@
1
+ import { BLOCK_END_PREFIX } from '@aztec/constants';
2
+ import { BlockNumber } from '@aztec/foundation/branded-types';
3
+ import { Fr } from '@aztec/foundation/curves/bn254';
4
+ import { BlobDeserializationError } from '../errors.js';
5
+ // Must match the implementation in `noir-protocol-circuits/crates/types/src/blob_data/block_blob_data.nr`.
6
+ const BLOCK_NUMBER_BIT_SIZE = 32n;
7
+ const TIMESTAMP_BIT_SIZE = 64n;
8
+ const NUM_TXS_BIT_SIZE = 16n;
9
+ export function encodeBlockEndMarker(blockEndMarker) {
10
+ let value = BLOCK_END_PREFIX;
11
+ value <<= TIMESTAMP_BIT_SIZE;
12
+ value += blockEndMarker.timestamp;
13
+ value <<= BLOCK_NUMBER_BIT_SIZE;
14
+ value += BigInt(blockEndMarker.blockNumber);
15
+ value <<= NUM_TXS_BIT_SIZE;
16
+ value += BigInt(blockEndMarker.numTxs);
17
+ return new Fr(value);
18
+ }
19
+ export function decodeBlockEndMarker(field) {
20
+ let value = field.toBigInt();
21
+ const numTxs = Number(value & 2n ** NUM_TXS_BIT_SIZE - 1n);
22
+ value >>= NUM_TXS_BIT_SIZE;
23
+ const blockNumber = BlockNumber(Number(value & 2n ** BLOCK_NUMBER_BIT_SIZE - 1n));
24
+ value >>= BLOCK_NUMBER_BIT_SIZE;
25
+ const timestamp = value & 2n ** TIMESTAMP_BIT_SIZE - 1n;
26
+ value >>= TIMESTAMP_BIT_SIZE;
27
+ const prefix = value;
28
+ if (prefix !== BLOCK_END_PREFIX) {
29
+ throw new BlobDeserializationError(`Incorrect encoding of blob fields: invalid block end marker.`);
30
+ }
31
+ return {
32
+ blockNumber,
33
+ timestamp,
34
+ numTxs
35
+ };
36
+ }
37
+ // Check if a field is a block end marker. Used before decoding to check if it has reached the end of the block.
38
+ export function isBlockEndMarker(field) {
39
+ const prefix = field.toBigInt() >> NUM_TXS_BIT_SIZE + BLOCK_NUMBER_BIT_SIZE + TIMESTAMP_BIT_SIZE;
40
+ return prefix === BLOCK_END_PREFIX;
41
+ }
@@ -0,0 +1,12 @@
1
+ import { Fr } from '@aztec/foundation/curves/bn254';
2
+ export declare const TOTAL_MANA_USED_BIT_SIZE = 48n;
3
+ export interface BlockEndStateField {
4
+ l1ToL2MessageNextAvailableLeafIndex: number;
5
+ noteHashNextAvailableLeafIndex: number;
6
+ nullifierNextAvailableLeafIndex: number;
7
+ publicDataNextAvailableLeafIndex: number;
8
+ totalManaUsed: bigint;
9
+ }
10
+ export declare function encodeBlockEndStateField(blockEndStateField: BlockEndStateField): Fr;
11
+ export declare function decodeBlockEndStateField(field: Fr): BlockEndStateField;
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxvY2tfZW5kX3N0YXRlX2ZpZWxkLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZW5jb2RpbmcvYmxvY2tfZW5kX3N0YXRlX2ZpZWxkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU1BLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQU1wRCxlQUFPLE1BQU0sd0JBQXdCLE1BQU0sQ0FBQztBQUU1QyxNQUFNLFdBQVcsa0JBQWtCO0lBQ2pDLG1DQUFtQyxFQUFFLE1BQU0sQ0FBQztJQUM1Qyw4QkFBOEIsRUFBRSxNQUFNLENBQUM7SUFDdkMsK0JBQStCLEVBQUUsTUFBTSxDQUFDO0lBQ3hDLGdDQUFnQyxFQUFFLE1BQU0sQ0FBQztJQUN6QyxhQUFhLEVBQUUsTUFBTSxDQUFDO0NBQ3ZCO0FBRUQsd0JBQWdCLHdCQUF3QixDQUFDLGtCQUFrQixFQUFFLGtCQUFrQixNQVc5RTtBQUVELHdCQUFnQix3QkFBd0IsQ0FBQyxLQUFLLEVBQUUsRUFBRSxHQUFHLGtCQUFrQixDQXVCdEUifQ==
@@ -0,0 +1 @@
1
+ {"version":3,"file":"block_end_state_field.d.ts","sourceRoot":"","sources":["../../src/encoding/block_end_state_field.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AAMpD,eAAO,MAAM,wBAAwB,MAAM,CAAC;AAE5C,MAAM,WAAW,kBAAkB;IACjC,mCAAmC,EAAE,MAAM,CAAC;IAC5C,8BAA8B,EAAE,MAAM,CAAC;IACvC,+BAA+B,EAAE,MAAM,CAAC;IACxC,gCAAgC,EAAE,MAAM,CAAC;IACzC,aAAa,EAAE,MAAM,CAAC;CACvB;AAED,wBAAgB,wBAAwB,CAAC,kBAAkB,EAAE,kBAAkB,MAW9E;AAED,wBAAgB,wBAAwB,CAAC,KAAK,EAAE,EAAE,GAAG,kBAAkB,CAuBtE"}
@@ -0,0 +1,39 @@
1
+ import { L1_TO_L2_MSG_TREE_HEIGHT, NOTE_HASH_TREE_HEIGHT, NULLIFIER_TREE_HEIGHT, PUBLIC_DATA_TREE_HEIGHT } from '@aztec/constants';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
+ import { BlobDeserializationError } from '../errors.js';
4
+ // Must match the implementation in `noir-protocol-circuits/crates/types/src/blob_data/block_blob_data.nr`.
5
+ export const TOTAL_MANA_USED_BIT_SIZE = 48n;
6
+ export function encodeBlockEndStateField(blockEndStateField) {
7
+ let value = BigInt(blockEndStateField.l1ToL2MessageNextAvailableLeafIndex);
8
+ value <<= BigInt(NOTE_HASH_TREE_HEIGHT);
9
+ value += BigInt(blockEndStateField.noteHashNextAvailableLeafIndex);
10
+ value <<= BigInt(NULLIFIER_TREE_HEIGHT);
11
+ value += BigInt(blockEndStateField.nullifierNextAvailableLeafIndex);
12
+ value <<= BigInt(PUBLIC_DATA_TREE_HEIGHT);
13
+ value += BigInt(blockEndStateField.publicDataNextAvailableLeafIndex);
14
+ value <<= BigInt(TOTAL_MANA_USED_BIT_SIZE);
15
+ value += BigInt(blockEndStateField.totalManaUsed);
16
+ return new Fr(value);
17
+ }
18
+ export function decodeBlockEndStateField(field) {
19
+ let value = field.toBigInt();
20
+ const totalManaUsed = value & 2n ** TOTAL_MANA_USED_BIT_SIZE - 1n;
21
+ value >>= TOTAL_MANA_USED_BIT_SIZE;
22
+ const publicDataNextAvailableLeafIndex = Number(value & 2n ** BigInt(PUBLIC_DATA_TREE_HEIGHT) - 1n);
23
+ value >>= BigInt(PUBLIC_DATA_TREE_HEIGHT);
24
+ const nullifierNextAvailableLeafIndex = Number(value & 2n ** BigInt(NULLIFIER_TREE_HEIGHT) - 1n);
25
+ value >>= BigInt(NULLIFIER_TREE_HEIGHT);
26
+ const noteHashNextAvailableLeafIndex = Number(value & 2n ** BigInt(NOTE_HASH_TREE_HEIGHT) - 1n);
27
+ value >>= BigInt(NOTE_HASH_TREE_HEIGHT);
28
+ if (value > 2n ** BigInt(L1_TO_L2_MSG_TREE_HEIGHT) - 1n) {
29
+ throw new BlobDeserializationError(`Incorrect encoding of blob fields: invalid block end state field.`);
30
+ }
31
+ const l1ToL2MessageNextAvailableLeafIndex = Number(value);
32
+ return {
33
+ l1ToL2MessageNextAvailableLeafIndex,
34
+ noteHashNextAvailableLeafIndex,
35
+ nullifierNextAvailableLeafIndex,
36
+ publicDataNextAvailableLeafIndex,
37
+ totalManaUsed
38
+ };
39
+ }
@@ -0,0 +1,15 @@
1
+ import { Fr } from '@aztec/foundation/curves/bn254';
2
+ import { FieldReader } from '@aztec/foundation/serialize';
3
+ import { type BlockBlobData } from './block_blob_data.js';
4
+ import { type CheckpointEndMarker } from './checkpoint_end_marker.js';
5
+ import type { TxStartMarker } from './tx_start_marker.js';
6
+ export interface CheckpointBlobData {
7
+ checkpointEndMarker: CheckpointEndMarker;
8
+ blocks: BlockBlobData[];
9
+ }
10
+ export declare function encodeCheckpointBlobData(checkpointBlobData: CheckpointBlobData): Fr[];
11
+ export declare function encodeCheckpointBlobDataFromBlocks(blocks: BlockBlobData[]): Fr[];
12
+ export declare function decodeCheckpointBlobData(fields: Fr[] | FieldReader): CheckpointBlobData;
13
+ export declare function decodeCheckpointBlobDataFromBuffer(buf: Buffer): CheckpointBlobData;
14
+ export declare function getTotalNumBlobFieldsFromTxs(txsPerBlock: TxStartMarker[][]): number;
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2twb2ludF9ibG9iX2RhdGEuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9lbmNvZGluZy9jaGVja3BvaW50X2Jsb2JfZGF0YS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsRUFBRSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDcEQsT0FBTyxFQUFnQixXQUFXLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUd4RSxPQUFPLEVBQUUsS0FBSyxhQUFhLEVBQTRDLE1BQU0sc0JBQXNCLENBQUM7QUFDcEcsT0FBTyxFQUNMLEtBQUssbUJBQW1CLEVBSXpCLE1BQU0sNEJBQTRCLENBQUM7QUFDcEMsT0FBTyxLQUFLLEVBQUUsYUFBYSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFMUQsTUFBTSxXQUFXLGtCQUFrQjtJQUNqQyxtQkFBbUIsRUFBRSxtQkFBbUIsQ0FBQztJQUN6QyxNQUFNLEVBQUUsYUFBYSxFQUFFLENBQUM7Q0FDekI7QUFFRCx3QkFBZ0Isd0JBQXdCLENBQUMsa0JBQWtCLEVBQUUsa0JBQWtCLEdBQUcsRUFBRSxFQUFFLENBS3JGO0FBRUQsd0JBQWdCLGtDQUFrQyxDQUFDLE1BQU0sRUFBRSxhQUFhLEVBQUUsR0FBRyxFQUFFLEVBQUUsQ0FJaEY7QUFFRCx3QkFBZ0Isd0JBQXdCLENBQUMsTUFBTSxFQUFFLEVBQUUsRUFBRSxHQUFHLFdBQVcsR0FBRyxrQkFBa0IsQ0EwQ3ZGO0FBRUQsd0JBQWdCLGtDQUFrQyxDQUFDLEdBQUcsRUFBRSxNQUFNLEdBQUcsa0JBQWtCLENBS2xGO0FBRUQsd0JBQWdCLDRCQUE0QixDQUFDLFdBQVcsRUFBRSxhQUFhLEVBQUUsRUFBRSxHQUFHLE1BQU0sQ0FZbkYifQ==
@@ -0,0 +1 @@
1
+ {"version":3,"file":"checkpoint_blob_data.d.ts","sourceRoot":"","sources":["../../src/encoding/checkpoint_blob_data.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AACpD,OAAO,EAAgB,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAGxE,OAAO,EAAE,KAAK,aAAa,EAA4C,MAAM,sBAAsB,CAAC;AACpG,OAAO,EACL,KAAK,mBAAmB,EAIzB,MAAM,4BAA4B,CAAC;AACpC,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAE1D,MAAM,WAAW,kBAAkB;IACjC,mBAAmB,EAAE,mBAAmB,CAAC;IACzC,MAAM,EAAE,aAAa,EAAE,CAAC;CACzB;AAED,wBAAgB,wBAAwB,CAAC,kBAAkB,EAAE,kBAAkB,GAAG,EAAE,EAAE,CAKrF;AAED,wBAAgB,kCAAkC,CAAC,MAAM,EAAE,aAAa,EAAE,GAAG,EAAE,EAAE,CAIhF;AAED,wBAAgB,wBAAwB,CAAC,MAAM,EAAE,EAAE,EAAE,GAAG,WAAW,GAAG,kBAAkB,CA0CvF;AAED,wBAAgB,kCAAkC,CAAC,GAAG,EAAE,MAAM,GAAG,kBAAkB,CAKlF;AAED,wBAAgB,4BAA4B,CAAC,WAAW,EAAE,aAAa,EAAE,EAAE,GAAG,MAAM,CAYnF"}