@aztec/blob-lib 3.0.0-devnet.2 → 3.0.0-devnet.20251212

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 (99) 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 +6 -11
  5. package/dest/blob.d.ts.map +1 -1
  6. package/dest/blob.js +5 -2
  7. package/dest/blob_batching.d.ts +35 -84
  8. package/dest/blob_batching.d.ts.map +1 -1
  9. package/dest/blob_batching.js +73 -108
  10. package/dest/blob_utils.d.ts +21 -11
  11. package/dest/blob_utils.d.ts.map +1 -1
  12. package/dest/blob_utils.js +29 -20
  13. package/dest/circuit_types/blob_accumulator.d.ts +4 -2
  14. package/dest/circuit_types/blob_accumulator.d.ts.map +1 -1
  15. package/dest/circuit_types/blob_accumulator.js +5 -1
  16. package/dest/circuit_types/final_blob_accumulator.d.ts +3 -2
  17. package/dest/circuit_types/final_blob_accumulator.d.ts.map +1 -1
  18. package/dest/circuit_types/final_blob_accumulator.js +2 -1
  19. package/dest/circuit_types/final_blob_batching_challenges.d.ts +3 -2
  20. package/dest/circuit_types/final_blob_batching_challenges.d.ts.map +1 -1
  21. package/dest/circuit_types/final_blob_batching_challenges.js +2 -1
  22. package/dest/circuit_types/index.d.ts +1 -1
  23. package/dest/encoding/block_blob_data.d.ts +22 -0
  24. package/dest/encoding/block_blob_data.d.ts.map +1 -0
  25. package/dest/encoding/block_blob_data.js +65 -0
  26. package/dest/encoding/block_end_marker.d.ts +11 -0
  27. package/dest/encoding/block_end_marker.d.ts.map +1 -0
  28. package/dest/encoding/block_end_marker.js +41 -0
  29. package/dest/encoding/block_end_state_field.d.ts +12 -0
  30. package/dest/encoding/block_end_state_field.d.ts.map +1 -0
  31. package/dest/encoding/block_end_state_field.js +39 -0
  32. package/dest/encoding/checkpoint_blob_data.d.ts +15 -0
  33. package/dest/encoding/checkpoint_blob_data.d.ts.map +1 -0
  34. package/dest/encoding/checkpoint_blob_data.js +67 -0
  35. package/dest/encoding/checkpoint_end_marker.d.ts +8 -0
  36. package/dest/encoding/checkpoint_end_marker.d.ts.map +1 -0
  37. package/dest/encoding/checkpoint_end_marker.js +28 -0
  38. package/dest/encoding/fixtures.d.ts +41 -0
  39. package/dest/encoding/fixtures.d.ts.map +1 -0
  40. package/dest/encoding/fixtures.js +140 -0
  41. package/dest/encoding/index.d.ts +10 -0
  42. package/dest/encoding/index.d.ts.map +1 -0
  43. package/dest/encoding/index.js +9 -0
  44. package/dest/encoding/tx_blob_data.d.ts +19 -0
  45. package/dest/encoding/tx_blob_data.d.ts.map +1 -0
  46. package/dest/encoding/tx_blob_data.js +79 -0
  47. package/dest/encoding/tx_start_marker.d.ts +16 -0
  48. package/dest/encoding/tx_start_marker.d.ts.map +1 -0
  49. package/dest/{encoding.js → encoding/tx_start_marker.js} +13 -59
  50. package/dest/errors.d.ts +1 -1
  51. package/dest/errors.d.ts.map +1 -1
  52. package/dest/hash.d.ts +13 -5
  53. package/dest/hash.d.ts.map +1 -1
  54. package/dest/hash.js +19 -8
  55. package/dest/index.d.ts +4 -4
  56. package/dest/index.d.ts.map +1 -1
  57. package/dest/index.js +3 -3
  58. package/dest/interface.d.ts +1 -1
  59. package/dest/kzg_context.d.ts +6 -2
  60. package/dest/kzg_context.d.ts.map +1 -1
  61. package/dest/kzg_context.js +12 -3
  62. package/dest/sponge_blob.d.ts +9 -15
  63. package/dest/sponge_blob.d.ts.map +1 -1
  64. package/dest/sponge_blob.js +21 -36
  65. package/dest/testing.d.ts +8 -16
  66. package/dest/testing.d.ts.map +1 -1
  67. package/dest/testing.js +35 -64
  68. package/dest/types.d.ts +2 -1
  69. package/dest/types.d.ts.map +1 -1
  70. package/dest/types.js +1 -0
  71. package/package.json +8 -7
  72. package/src/batched_blob.ts +26 -0
  73. package/src/blob.ts +5 -2
  74. package/src/blob_batching.ts +91 -126
  75. package/src/blob_utils.ts +33 -22
  76. package/src/circuit_types/blob_accumulator.ts +13 -1
  77. package/src/circuit_types/final_blob_accumulator.ts +2 -1
  78. package/src/circuit_types/final_blob_batching_challenges.ts +2 -1
  79. package/src/encoding/block_blob_data.ts +102 -0
  80. package/src/encoding/block_end_marker.ts +55 -0
  81. package/src/encoding/block_end_state_field.ts +59 -0
  82. package/src/encoding/checkpoint_blob_data.ts +95 -0
  83. package/src/encoding/checkpoint_end_marker.ts +40 -0
  84. package/src/encoding/fixtures.ts +210 -0
  85. package/src/encoding/index.ts +9 -0
  86. package/src/encoding/tx_blob_data.ts +116 -0
  87. package/src/{encoding.ts → encoding/tx_start_marker.ts} +19 -76
  88. package/src/hash.ts +20 -8
  89. package/src/index.ts +3 -3
  90. package/src/kzg_context.ts +12 -1
  91. package/src/sponge_blob.ts +23 -36
  92. package/src/testing.ts +47 -73
  93. package/src/types.ts +1 -0
  94. package/dest/deserialize.d.ts +0 -14
  95. package/dest/deserialize.d.ts.map +0 -1
  96. package/dest/deserialize.js +0 -33
  97. package/dest/encoding.d.ts +0 -26
  98. package/dest/encoding.d.ts.map +0 -1
  99. package/src/deserialize.ts +0 -38
@@ -1,24 +1,23 @@
1
1
  import { type FieldsOf } from '@aztec/foundation/array';
2
- import { Fr } from '@aztec/foundation/fields';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
3
  import { BufferReader, FieldReader, type Tuple } from '@aztec/foundation/serialize';
4
4
  /**
5
5
  * A Poseidon2 sponge used to accumulate data that will be added to blobs.
6
6
  * See noir-projects/noir-protocol-circuits/crates/types/src/abis/sponge_blob.nr.
7
7
  */
8
8
  export declare class SpongeBlob {
9
- /** Sponge with absorbed fields that will go into one or more blobs. */
10
9
  readonly sponge: Poseidon2Sponge;
11
- /** Number of effects absorbed so far. */
12
10
  numAbsorbedFields: number;
13
- /** Number of effects that will be absorbed. */
14
- readonly numExpectedFields: number;
11
+ static MAX_FIELDS: number;
15
12
  constructor(
16
13
  /** Sponge with absorbed fields that will go into one or more blobs. */
17
14
  sponge: Poseidon2Sponge,
18
15
  /** Number of effects absorbed so far. */
19
- numAbsorbedFields: number,
20
- /** Number of effects that will be absorbed. */
21
- numExpectedFields: number);
16
+ numAbsorbedFields: number);
17
+ /**
18
+ * Initialize the sponge blob to absorb data for a checkpoint.
19
+ */
20
+ static init(): SpongeBlob;
22
21
  static fromBuffer(buffer: Buffer | BufferReader): SpongeBlob;
23
22
  toBuffer(): Buffer<ArrayBufferLike>;
24
23
  static getFields(fields: FieldsOf<SpongeBlob>): (number | Poseidon2Sponge)[];
@@ -28,11 +27,6 @@ export declare class SpongeBlob {
28
27
  absorb(fields: Fr[]): Promise<void>;
29
28
  squeeze(): Promise<Fr>;
30
29
  static empty(): SpongeBlob;
31
- /**
32
- * Initialize the sponge blob with the number of expected fields in the checkpoint and absorb it as the first field.
33
- * Note: `numExpectedFields` includes the first field absorbed in this method.
34
- */
35
- static init(numExpectedFields: number): Promise<SpongeBlob>;
36
30
  }
37
31
  export declare class Poseidon2Sponge {
38
32
  cache: Tuple<Fr, 3>;
@@ -46,9 +40,9 @@ export declare class Poseidon2Sponge {
46
40
  toFields(): Fr[];
47
41
  static fromFields(fields: Fr[] | FieldReader): Poseidon2Sponge;
48
42
  static empty(): Poseidon2Sponge;
49
- static init(numExpectedFields: number): Poseidon2Sponge;
43
+ static init(iv: Fr): Poseidon2Sponge;
50
44
  performDuplex(): Promise<void>;
51
45
  absorb(fields: Fr[]): Promise<void>;
52
46
  squeeze(): Promise<Fr>;
53
47
  }
54
- //# sourceMappingURL=sponge_blob.d.ts.map
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BvbmdlX2Jsb2IuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9zcG9uZ2VfYmxvYi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsS0FBSyxRQUFRLEVBQWEsTUFBTSx5QkFBeUIsQ0FBQztBQUVuRSxPQUFPLEVBQUUsRUFBRSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDcEQsT0FBTyxFQUNMLFlBQVksRUFDWixXQUFXLEVBQ1gsS0FBSyxLQUFLLEVBR1gsTUFBTSw2QkFBNkIsQ0FBQztBQUVyQzs7O0dBR0c7QUFDSCxxQkFBYSxVQUFVO2FBS0gsTUFBTSxFQUFFLGVBQWU7SUFFaEMsaUJBQWlCLEVBQUUsTUFBTTtJQU5sQyxNQUFNLENBQUMsVUFBVSxTQUEwQztJQUUzRDtJQUNFLHVFQUF1RTtJQUN2RCxNQUFNLEVBQUUsZUFBZTtJQUN2Qyx5Q0FBeUM7SUFDbEMsaUJBQWlCLEVBQUUsTUFBTSxFQUM5QjtJQUVKOztPQUVHO0lBQ0gsTUFBTSxDQUFDLElBQUksSUFBSSxVQUFVLENBS3hCO0lBRUQsTUFBTSxDQUFDLFVBQVUsQ0FBQyxNQUFNLEVBQUUsTUFBTSxHQUFHLFlBQVksR0FBRyxVQUFVLENBRzNEO0lBRUQsUUFBUSw0QkFFUDtJQUVELE1BQU0sQ0FBQyxTQUFTLENBQUMsTUFBTSxFQUFFLFFBQVEsQ0FBQyxVQUFVLENBQUMsZ0NBRTVDO0lBRUQsUUFBUSxJQUFJLEVBQUUsRUFBRSxDQUVmO0lBRUQsTUFBTSxDQUFDLFVBQVUsQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLEdBQUcsV0FBVyxHQUFHLFVBQVUsQ0FHeEQ7SUFFRCxLQUFLLGVBRUo7SUFFSyxNQUFNLENBQUMsTUFBTSxFQUFFLEVBQUUsRUFBRSxpQkFReEI7SUFFSyxPQUFPLElBQUksT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQUUzQjtJQUVELE1BQU0sQ0FBQyxLQUFLLElBQUksVUFBVSxDQUV6QjtDQUNGO0FBR0QscUJBQWEsZUFBZTtJQUVqQixLQUFLLEVBQUUsS0FBSyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDbkIsS0FBSyxFQUFFLEtBQUssQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ25CLFNBQVMsRUFBRSxNQUFNO0lBQ2pCLFdBQVcsRUFBRSxPQUFPO0lBSjdCLFlBQ1MsS0FBSyxFQUFFLEtBQUssQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEVBQ25CLEtBQUssRUFBRSxLQUFLLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUNuQixTQUFTLEVBQUUsTUFBTSxFQUNqQixXQUFXLEVBQUUsT0FBTyxFQUN6QjtJQUVKLE1BQU0sQ0FBQyxVQUFVLENBQUMsTUFBTSxFQUFFLE1BQU0sR0FBRyxZQUFZLEdBQUcsZUFBZSxDQVFoRTtJQUVELFFBQVEsNEJBRVA7SUFFRCxNQUFNLENBQUMsU0FBUyxDQUFDLE1BQU0sRUFBRSxRQUFRLENBQUMsZUFBZSxDQUFDLDBEQUVqRDtJQUVELFFBQVEsSUFBSSxFQUFFLEVBQUUsQ0FFZjtJQUVELE1BQU0sQ0FBQyxVQUFVLENBQUMsTUFBTSxFQUFFLEVBQUUsRUFBRSxHQUFHLFdBQVcsR0FBRyxlQUFlLENBUTdEO0lBRUQsTUFBTSxDQUFDLEtBQUssSUFBSSxlQUFlLENBTzlCO0lBRUQsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLEVBQUUsRUFBRSxHQUFHLGVBQWUsQ0FJbkM7SUFLSyxhQUFhLGtCQVNsQjtJQUVLLE1BQU0sQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLGlCQWF4QjtJQUVLLE9BQU8sSUFBSSxPQUFPLENBQUMsRUFBRSxDQUFDLENBTzNCO0NBQ0YifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"sponge_blob.d.ts","sourceRoot":"","sources":["../src/sponge_blob.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,QAAQ,EAAa,MAAM,yBAAyB,CAAC;AAEnE,OAAO,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAC9C,OAAO,EACL,YAAY,EACZ,WAAW,EACX,KAAK,KAAK,EAGX,MAAM,6BAA6B,CAAC;AAErC;;;GAGG;AACH,qBAAa,UAAU;IAEnB,uEAAuE;aACvD,MAAM,EAAE,eAAe;IACvC,yCAAyC;IAClC,iBAAiB,EAAE,MAAM;IAChC,+CAA+C;aAC/B,iBAAiB,EAAE,MAAM;;IALzC,uEAAuE;IACvD,MAAM,EAAE,eAAe;IACvC,yCAAyC;IAClC,iBAAiB,EAAE,MAAM;IAChC,+CAA+C;IAC/B,iBAAiB,EAAE,MAAM;IAG3C,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,YAAY,GAAG,UAAU;IAK5D,QAAQ;IAIR,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,UAAU,CAAC;IAI7C,QAAQ,IAAI,EAAE,EAAE;IAIhB,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,EAAE,EAAE,GAAG,WAAW,GAAG,UAAU;IASzD,KAAK;IAIC,MAAM,CAAC,MAAM,EAAE,EAAE,EAAE;IAUnB,OAAO,IAAI,OAAO,CAAC,EAAE,CAAC;IAS5B,MAAM,CAAC,KAAK,IAAI,UAAU;IAI1B;;;OAGG;WACU,IAAI,CAAC,iBAAiB,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC;CAQlE;AAGD,qBAAa,eAAe;IAEjB,KAAK,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;IACnB,KAAK,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;IACnB,SAAS,EAAE,MAAM;IACjB,WAAW,EAAE,OAAO;gBAHpB,KAAK,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,EACnB,KAAK,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,EACnB,SAAS,EAAE,MAAM,EACjB,WAAW,EAAE,OAAO;IAG7B,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,YAAY,GAAG,eAAe;IAUjE,QAAQ;IAIR,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,eAAe,CAAC;IAIlD,QAAQ,IAAI,EAAE,EAAE;IAIhB,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,EAAE,EAAE,GAAG,WAAW,GAAG,eAAe;IAU9D,MAAM,CAAC,KAAK,IAAI,eAAe;IAS/B,MAAM,CAAC,IAAI,CAAC,iBAAiB,EAAE,MAAM,GAAG,eAAe;IAUjD,aAAa;IAWb,MAAM,CAAC,MAAM,EAAE,EAAE,EAAE;IAenB,OAAO,IAAI,OAAO,CAAC,EAAE,CAAC;CAQ7B"}
1
+ {"version":3,"file":"sponge_blob.d.ts","sourceRoot":"","sources":["../src/sponge_blob.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,QAAQ,EAAa,MAAM,yBAAyB,CAAC;AAEnE,OAAO,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AACpD,OAAO,EACL,YAAY,EACZ,WAAW,EACX,KAAK,KAAK,EAGX,MAAM,6BAA6B,CAAC;AAErC;;;GAGG;AACH,qBAAa,UAAU;aAKH,MAAM,EAAE,eAAe;IAEhC,iBAAiB,EAAE,MAAM;IANlC,MAAM,CAAC,UAAU,SAA0C;IAE3D;IACE,uEAAuE;IACvD,MAAM,EAAE,eAAe;IACvC,yCAAyC;IAClC,iBAAiB,EAAE,MAAM,EAC9B;IAEJ;;OAEG;IACH,MAAM,CAAC,IAAI,IAAI,UAAU,CAKxB;IAED,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,YAAY,GAAG,UAAU,CAG3D;IAED,QAAQ,4BAEP;IAED,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,UAAU,CAAC,gCAE5C;IAED,QAAQ,IAAI,EAAE,EAAE,CAEf;IAED,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,EAAE,EAAE,GAAG,WAAW,GAAG,UAAU,CAGxD;IAED,KAAK,eAEJ;IAEK,MAAM,CAAC,MAAM,EAAE,EAAE,EAAE,iBAQxB;IAEK,OAAO,IAAI,OAAO,CAAC,EAAE,CAAC,CAE3B;IAED,MAAM,CAAC,KAAK,IAAI,UAAU,CAEzB;CACF;AAGD,qBAAa,eAAe;IAEjB,KAAK,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;IACnB,KAAK,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;IACnB,SAAS,EAAE,MAAM;IACjB,WAAW,EAAE,OAAO;IAJ7B,YACS,KAAK,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,EACnB,KAAK,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,EACnB,SAAS,EAAE,MAAM,EACjB,WAAW,EAAE,OAAO,EACzB;IAEJ,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,YAAY,GAAG,eAAe,CAQhE;IAED,QAAQ,4BAEP;IAED,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,eAAe,CAAC,0DAEjD;IAED,QAAQ,IAAI,EAAE,EAAE,CAEf;IAED,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,EAAE,EAAE,GAAG,WAAW,GAAG,eAAe,CAQ7D;IAED,MAAM,CAAC,KAAK,IAAI,eAAe,CAO9B;IAED,MAAM,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,GAAG,eAAe,CAInC;IAKK,aAAa,kBASlB;IAEK,MAAM,CAAC,MAAM,EAAE,EAAE,EAAE,iBAaxB;IAEK,OAAO,IAAI,OAAO,CAAC,EAAE,CAAC,CAO3B;CACF"}
@@ -1,7 +1,7 @@
1
- import { TWO_POW_64 } from '@aztec/constants';
1
+ import { BLOBS_PER_CHECKPOINT, FIELDS_PER_BLOB, TWO_POW_64 } from '@aztec/constants';
2
2
  import { makeTuple } from '@aztec/foundation/array';
3
- import { poseidon2Permutation } from '@aztec/foundation/crypto';
4
- import { Fr } from '@aztec/foundation/fields';
3
+ import { poseidon2Permutation } from '@aztec/foundation/crypto/poseidon';
4
+ import { Fr } from '@aztec/foundation/curves/bn254';
5
5
  import { BufferReader, FieldReader, serializeToBuffer, serializeToFields } from '@aztec/foundation/serialize';
6
6
  /**
7
7
  * A Poseidon2 sponge used to accumulate data that will be added to blobs.
@@ -9,15 +9,22 @@ import { BufferReader, FieldReader, serializeToBuffer, serializeToFields } from
9
9
  */ export class SpongeBlob {
10
10
  sponge;
11
11
  numAbsorbedFields;
12
- numExpectedFields;
13
- constructor(/** Sponge with absorbed fields that will go into one or more blobs. */ sponge, /** Number of effects absorbed so far. */ numAbsorbedFields, /** Number of effects that will be absorbed. */ numExpectedFields){
12
+ static MAX_FIELDS = BLOBS_PER_CHECKPOINT * FIELDS_PER_BLOB;
13
+ constructor(/** Sponge with absorbed fields that will go into one or more blobs. */ sponge, /** Number of effects absorbed so far. */ numAbsorbedFields){
14
14
  this.sponge = sponge;
15
15
  this.numAbsorbedFields = numAbsorbedFields;
16
- this.numExpectedFields = numExpectedFields;
16
+ }
17
+ /**
18
+ * Initialize the sponge blob to absorb data for a checkpoint.
19
+ */ static init() {
20
+ // This must match the implementation in noir-projects/noir-protocol-circuits/types/src/abis/sponge_blob.nr
21
+ const iv = new Fr(BigInt(SpongeBlob.MAX_FIELDS) * TWO_POW_64);
22
+ const sponge = Poseidon2Sponge.init(iv);
23
+ return new SpongeBlob(sponge, 0);
17
24
  }
18
25
  static fromBuffer(buffer) {
19
26
  const reader = BufferReader.asReader(buffer);
20
- return new SpongeBlob(reader.readObject(Poseidon2Sponge), reader.readNumber(), reader.readNumber());
27
+ return new SpongeBlob(reader.readObject(Poseidon2Sponge), reader.readNumber());
21
28
  }
22
29
  toBuffer() {
23
30
  return serializeToBuffer(...SpongeBlob.getFields(this));
@@ -25,8 +32,7 @@ import { BufferReader, FieldReader, serializeToBuffer, serializeToFields } from
25
32
  static getFields(fields) {
26
33
  return [
27
34
  fields.sponge,
28
- fields.numAbsorbedFields,
29
- fields.numExpectedFields
35
+ fields.numAbsorbedFields
30
36
  ];
31
37
  }
32
38
  toFields() {
@@ -34,43 +40,23 @@ import { BufferReader, FieldReader, serializeToBuffer, serializeToFields } from
34
40
  }
35
41
  static fromFields(fields) {
36
42
  const reader = FieldReader.asReader(fields);
37
- return new SpongeBlob(reader.readObject(Poseidon2Sponge), reader.readField().toNumber(), reader.readField().toNumber());
43
+ return new SpongeBlob(reader.readObject(Poseidon2Sponge), reader.readField().toNumber());
38
44
  }
39
45
  clone() {
40
46
  return SpongeBlob.fromBuffer(this.toBuffer());
41
47
  }
42
48
  async absorb(fields) {
43
- if (this.numAbsorbedFields + fields.length > this.numExpectedFields) {
44
- throw new Error(`Attempted to fill spongeBlob with ${this.numAbsorbedFields + fields.length}, but it has a max of ${this.numExpectedFields}`);
49
+ if (this.numAbsorbedFields + fields.length > SpongeBlob.MAX_FIELDS) {
50
+ throw new Error(`Attempted to fill spongeBlob with ${this.numAbsorbedFields + fields.length}, but it has a max of ${SpongeBlob.MAX_FIELDS}`);
45
51
  }
46
52
  await this.sponge.absorb(fields);
47
53
  this.numAbsorbedFields += fields.length;
48
54
  }
49
55
  async squeeze() {
50
- // If the blob sponge is not 'full', we append 1 to match Poseidon2::hash_internal()
51
- // NB: There is currently no use case in which we don't 'fill' a blob sponge, but adding for completeness
52
- if (this.numAbsorbedFields != this.numExpectedFields) {
53
- await this.sponge.absorb([
54
- Fr.ONE
55
- ]);
56
- }
57
- return this.sponge.squeeze();
56
+ return await this.sponge.squeeze();
58
57
  }
59
58
  static empty() {
60
- return new SpongeBlob(Poseidon2Sponge.empty(), 0, 0);
61
- }
62
- /**
63
- * Initialize the sponge blob with the number of expected fields in the checkpoint and absorb it as the first field.
64
- * Note: `numExpectedFields` includes the first field absorbed in this method.
65
- */ static async init(numExpectedFields) {
66
- // This must match what the checkpoint root rollup circuit expects.
67
- // See noir-projects/noir-protocol-circuits/types/src/abis/sponge_blob.nr -> init_for_checkpoint.
68
- const sponge = Poseidon2Sponge.init(numExpectedFields);
69
- await sponge.absorb([
70
- new Fr(numExpectedFields)
71
- ]);
72
- const numAbsorbedFields = 1;
73
- return new SpongeBlob(sponge, numAbsorbedFields, numExpectedFields);
59
+ return new SpongeBlob(Poseidon2Sponge.empty(), 0);
74
60
  }
75
61
  }
76
62
  // This is just noir's stdlib version of the poseidon2 sponge. We use it for a blob-specific implmentation of the hasher.
@@ -110,8 +96,7 @@ export class Poseidon2Sponge {
110
96
  static empty() {
111
97
  return new Poseidon2Sponge(makeTuple(3, ()=>Fr.ZERO), makeTuple(4, ()=>Fr.ZERO), 0, false);
112
98
  }
113
- static init(numExpectedFields) {
114
- const iv = new Fr(numExpectedFields).mul(new Fr(TWO_POW_64));
99
+ static init(iv) {
115
100
  const sponge = Poseidon2Sponge.empty();
116
101
  sponge.state[3] = iv;
117
102
  return sponge;
package/dest/testing.d.ts CHANGED
@@ -1,7 +1,9 @@
1
- import { Fr } from '@aztec/foundation/fields';
2
1
  import { Blob } from './blob.js';
3
- import { BatchedBlobAccumulator } from './blob_batching.js';
2
+ import { BlobAccumulator } from './circuit_types/blob_accumulator.js';
3
+ import { FinalBlobAccumulator } from './circuit_types/final_blob_accumulator.js';
4
+ import { FinalBlobBatchingChallenges } from './circuit_types/final_blob_batching_challenges.js';
4
5
  import { SpongeBlob } from './sponge_blob.js';
6
+ export * from './encoding/fixtures.js';
5
7
  /**
6
8
  * Makes arbitrary poseidon sponge for blob inputs.
7
9
  * Note: will not verify inside the circuit.
@@ -15,19 +17,9 @@ export declare function makeSpongeBlob(seed?: number): SpongeBlob;
15
17
  * @param seed - The seed to use for generating the blob accumulator.
16
18
  * @returns A blob accumulator instance.
17
19
  */
18
- export declare function makeBatchedBlobAccumulator(seed?: number): BatchedBlobAccumulator;
19
- export declare function makeEncodedTxBlobFields(length: number): Fr[];
20
- export declare function makeEncodedBlockBlobFields(...lengths: number[]): Fr[];
21
- export declare function makeEncodedBlobFields(length: number): Fr[];
22
- /**
23
- * Make an encoded blob with the given length
24
- *
25
- * This will deserialise correctly in the archiver
26
- * @param length
27
- * @returns
28
- */
29
- export declare function makeEncodedBlob(length: number): Blob;
30
- export declare function makeEncodedBlobs(length: number): Blob[];
20
+ export declare function makeBlobAccumulator(seed?: number): BlobAccumulator;
21
+ export declare function makeFinalBlobAccumulator(seed?: number): FinalBlobAccumulator;
22
+ export declare function makeFinalBlobBatchingChallenges(seed?: number): FinalBlobBatchingChallenges;
31
23
  /**
32
24
  * Make a blob with random fields.
33
25
  *
@@ -36,4 +28,4 @@ export declare function makeEncodedBlobs(length: number): Blob[];
36
28
  * @returns
37
29
  */
38
30
  export declare function makeRandomBlob(length: number): Blob;
39
- //# sourceMappingURL=testing.d.ts.map
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdGluZy5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3Rlc3RpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBSUEsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUNqQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDdEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDakYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sbURBQW1ELENBQUM7QUFDaEcsT0FBTyxFQUFtQixVQUFVLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUUvRCxjQUFjLHdCQUF3QixDQUFDO0FBRXZDOzs7OztHQUtHO0FBQ0gsd0JBQWdCLGNBQWMsQ0FBQyxJQUFJLFNBQUksR0FBRyxVQUFVLENBVW5EO0FBMEJEOzs7OztHQUtHO0FBQ0gsd0JBQWdCLG1CQUFtQixDQUFDLElBQUksU0FBSSxHQUFHLGVBQWUsQ0FTN0Q7QUFFRCx3QkFBZ0Isd0JBQXdCLENBQUMsSUFBSSxTQUFJLHdCQU9oRDtBQUVELHdCQUFnQiwrQkFBK0IsQ0FBQyxJQUFJLFNBQUksK0JBRXZEO0FBRUQ7Ozs7OztHQU1HO0FBQ0gsd0JBQWdCLGNBQWMsQ0FBQyxNQUFNLEVBQUUsTUFBTSxHQUFHLElBQUksQ0FFbkQifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"testing.d.ts","sourceRoot":"","sources":["../src/testing.ts"],"names":[],"mappings":"AAGA,OAAO,EAAuB,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAEnE,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,sBAAsB,EAAE,MAAM,oBAAoB,CAAC;AAI5D,OAAO,EAAmB,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE/D;;;;;GAKG;AACH,wBAAgB,cAAc,CAAC,IAAI,SAAI,GAAG,UAAU,CAWnD;AAED;;;;;GAKG;AACH,wBAAgB,0BAA0B,CAAC,IAAI,SAAI,GAAG,sBAAsB,CAW3E;AAED,wBAAgB,uBAAuB,CAAC,MAAM,EAAE,MAAM,GAAG,EAAE,EAAE,CAoB5D;AAED,wBAAgB,0BAA0B,CAAC,GAAG,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,EAAE,CAMrE;AAGD,wBAAgB,qBAAqB,CAAC,MAAM,EAAE,MAAM,GAAG,EAAE,EAAE,CAO1D;AAED;;;;;;GAMG;AACH,wBAAgB,eAAe,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI,CAMpD;AAED,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI,EAAE,CAGvD;AAED;;;;;;GAMG;AACH,wBAAgB,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI,CAEnD"}
1
+ {"version":3,"file":"testing.d.ts","sourceRoot":"","sources":["../src/testing.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;AACtE,OAAO,EAAE,oBAAoB,EAAE,MAAM,2CAA2C,CAAC;AACjF,OAAO,EAAE,2BAA2B,EAAE,MAAM,mDAAmD,CAAC;AAChG,OAAO,EAAmB,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE/D,cAAc,wBAAwB,CAAC;AAEvC;;;;;GAKG;AACH,wBAAgB,cAAc,CAAC,IAAI,SAAI,GAAG,UAAU,CAUnD;AA0BD;;;;;GAKG;AACH,wBAAgB,mBAAmB,CAAC,IAAI,SAAI,GAAG,eAAe,CAS7D;AAED,wBAAgB,wBAAwB,CAAC,IAAI,SAAI,wBAOhD;AAED,wBAAgB,+BAA+B,CAAC,IAAI,SAAI,+BAEvD;AAED;;;;;;GAMG;AACH,wBAAgB,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI,CAEnD"}
package/dest/testing.js CHANGED
@@ -1,84 +1,55 @@
1
- import { FIELDS_PER_BLOB } from '@aztec/constants';
2
1
  import { makeTuple } from '@aztec/foundation/array';
3
- import { randomInt } from '@aztec/foundation/crypto';
4
- import { BLS12Fr, BLS12Point, Fr } from '@aztec/foundation/fields';
2
+ import { BLS12Fq, BLS12Fr, BLS12Point, BLSPointNotOnCurveError } from '@aztec/foundation/curves/bls12';
3
+ import { Fr } from '@aztec/foundation/curves/bn254';
5
4
  import { Blob } from './blob.js';
6
- import { BatchedBlobAccumulator } from './blob_batching.js';
7
- import { getBlobsPerL1Block } from './blob_utils.js';
8
- import { FinalBlobBatchingChallenges } from './circuit_types/index.js';
9
- import { createBlockEndMarker, encodeTxStartMarker } from './encoding.js';
5
+ import { BlobAccumulator } from './circuit_types/blob_accumulator.js';
6
+ import { FinalBlobAccumulator } from './circuit_types/final_blob_accumulator.js';
7
+ import { FinalBlobBatchingChallenges } from './circuit_types/final_blob_batching_challenges.js';
10
8
  import { Poseidon2Sponge, SpongeBlob } from './sponge_blob.js';
9
+ export * from './encoding/fixtures.js';
11
10
  /**
12
11
  * Makes arbitrary poseidon sponge for blob inputs.
13
12
  * Note: will not verify inside the circuit.
14
13
  * @param seed - The seed to use for generating the sponge.
15
14
  * @returns A sponge blob instance.
16
15
  */ export function makeSpongeBlob(seed = 1) {
17
- return new SpongeBlob(new Poseidon2Sponge(makeTuple(3, (i)=>new Fr(i)), makeTuple(4, (i)=>new Fr(i)), 1, false), seed, seed + 1);
16
+ return new SpongeBlob(new Poseidon2Sponge(makeTuple(3, (i)=>new Fr(i)), makeTuple(4, (i)=>new Fr(i)), 1, false), seed);
17
+ }
18
+ /**
19
+ * Makes an arbitrary but valid BLS12 point. The value is deterministic for a given seed.
20
+ * @param seed - The seed to use for generating the point.
21
+ * @returns A BLS12 point instance.
22
+ */ function makeBLS12Point(seed = 1) {
23
+ let accum = 0;
24
+ while(true){
25
+ try {
26
+ const x = new BLS12Fq(seed + accum);
27
+ const y = BLS12Point.YFromX(x);
28
+ if (y) {
29
+ return new BLS12Point(x, y, false);
30
+ }
31
+ accum++;
32
+ } catch (e) {
33
+ if (!(e instanceof BLSPointNotOnCurveError)) {
34
+ throw e;
35
+ }
36
+ // The point is not on the curve - try again
37
+ }
38
+ }
18
39
  }
19
40
  /**
20
41
  * Makes arbitrary blob public accumulator.
21
42
  * Note: will not verify inside the circuit.
22
43
  * @param seed - The seed to use for generating the blob accumulator.
23
44
  * @returns A blob accumulator instance.
24
- */ export function makeBatchedBlobAccumulator(seed = 1) {
25
- return new BatchedBlobAccumulator(new Fr(seed), new Fr(seed + 1), new BLS12Fr(seed + 2), BLS12Point.random(), BLS12Point.random(), new Fr(seed + 3), new BLS12Fr(seed + 4), new FinalBlobBatchingChallenges(new Fr(seed + 5), new BLS12Fr(seed + 6)));
45
+ */ export function makeBlobAccumulator(seed = 1) {
46
+ return new BlobAccumulator(new Fr(seed), new Fr(seed + 0x10), new BLS12Fr(seed + 0x20), makeBLS12Point(seed + 0x30), new Fr(seed + 0x50), new BLS12Fr(seed + 0x60));
26
47
  }
27
- export function makeEncodedTxBlobFields(length) {
28
- const txStartMarker = {
29
- numBlobFields: length,
30
- // The rest of the values don't matter. The test components using it do not try to deserialize everything.
31
- // Only `checkBlobFieldsEncoding` is used and it only looks at `numBlobFields`. This might change in the future
32
- // when we add more thorough checks to `checkBlobFieldsEncoding`.
33
- revertCode: 0,
34
- numNoteHashes: 0,
35
- numNullifiers: 0,
36
- numL2ToL1Msgs: 0,
37
- numPublicDataWrites: 0,
38
- numPrivateLogs: 0,
39
- publicLogsLength: 0,
40
- contractClassLogLength: 0
41
- };
42
- return [
43
- encodeTxStartMarker(txStartMarker),
44
- ...Array.from({
45
- length: length - 1
46
- }, ()=>new Fr(randomInt(Number.MAX_SAFE_INTEGER)))
47
- ];
48
- }
49
- export function makeEncodedBlockBlobFields(...lengths) {
50
- return [
51
- ...lengths.length > 0 ? makeEncodedTxBlobFields(lengths[0] - 1) : [],
52
- ...lengths.slice(1).flatMap((length)=>makeEncodedTxBlobFields(length)),
53
- createBlockEndMarker(lengths.length)
54
- ];
55
- }
56
- // Create blob fields for a checkpoint with a single block.
57
- export function makeEncodedBlobFields(length) {
58
- if (length <= 2) {
59
- throw new Error('Encoded blob fields length must be greater than 2');
60
- }
61
- const checkpointPrefix = new Fr(length);
62
- return [
63
- checkpointPrefix,
64
- ...makeEncodedBlockBlobFields(length - 1)
65
- ]; // -1 to account for the checkpoint prefix.
66
- }
67
- /**
68
- * Make an encoded blob with the given length
69
- *
70
- * This will deserialise correctly in the archiver
71
- * @param length
72
- * @returns
73
- */ export function makeEncodedBlob(length) {
74
- if (length > FIELDS_PER_BLOB) {
75
- throw new Error(`A single encoded blob must be less than ${FIELDS_PER_BLOB} fields`);
76
- }
77
- return Blob.fromFields(makeEncodedBlobFields(length));
48
+ export function makeFinalBlobAccumulator(seed = 1) {
49
+ return new FinalBlobAccumulator(new Fr(seed), new Fr(seed + 0x10), new BLS12Fr(seed + 0x20), makeBLS12Point(seed + 0x30));
78
50
  }
79
- export function makeEncodedBlobs(length) {
80
- const fields = makeEncodedBlobFields(length);
81
- return getBlobsPerL1Block(fields);
51
+ export function makeFinalBlobBatchingChallenges(seed = 1) {
52
+ return new FinalBlobBatchingChallenges(new Fr(seed), new BLS12Fr(seed + 0x10));
82
53
  }
83
54
  /**
84
55
  * Make a blob with random fields.
package/dest/types.d.ts CHANGED
@@ -1,3 +1,4 @@
1
+ export * from './batched_blob.js';
1
2
  export * from './circuit_types/index.js';
2
3
  export * from './interface.js';
3
4
  export * from './sponge_blob.js';
@@ -13,4 +14,4 @@ export interface BlobKzgInstance {
13
14
  /** Function to compute both blob data cells and their corresponding KZG proofs for EIP7594 */
14
15
  computeCellsAndKzgProofs(blob: Uint8Array): [Uint8Array[], Uint8Array[]];
15
16
  }
16
- //# sourceMappingURL=types.d.ts.map
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGtCQUFrQixDQUFDO0FBRWpDOzs7R0FHRztBQUNILE1BQU0sV0FBVyxlQUFlO0lBQzlCLHdEQUF3RDtJQUN4RCxtQkFBbUIsQ0FBQyxJQUFJLEVBQUUsVUFBVSxHQUFHLFVBQVUsQ0FBQztJQUNsRCxrREFBa0Q7SUFDbEQsbUJBQW1CLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRSxVQUFVLEVBQUUsVUFBVSxHQUFHLFVBQVUsQ0FBQztJQUMxRSw4RkFBOEY7SUFDOUYsd0JBQXdCLENBQUMsSUFBSSxFQUFFLFVBQVUsR0FBRyxDQUFDLFVBQVUsRUFBRSxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQUM7Q0FDMUUifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAC;AACzC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,kBAAkB,CAAC;AAEjC;;;GAGG;AACH,MAAM,WAAW,eAAe;IAC9B,wDAAwD;IACxD,mBAAmB,CAAC,IAAI,EAAE,UAAU,GAAG,UAAU,CAAC;IAClD,kDAAkD;IAClD,mBAAmB,CAAC,IAAI,EAAE,UAAU,EAAE,UAAU,EAAE,UAAU,GAAG,UAAU,CAAC;IAC1E,8FAA8F;IAC9F,wBAAwB,CAAC,IAAI,EAAE,UAAU,GAAG,CAAC,UAAU,EAAE,EAAE,UAAU,EAAE,CAAC,CAAC;CAC1E"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,0BAA0B,CAAC;AACzC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,kBAAkB,CAAC;AAEjC;;;GAGG;AACH,MAAM,WAAW,eAAe;IAC9B,wDAAwD;IACxD,mBAAmB,CAAC,IAAI,EAAE,UAAU,GAAG,UAAU,CAAC;IAClD,kDAAkD;IAClD,mBAAmB,CAAC,IAAI,EAAE,UAAU,EAAE,UAAU,EAAE,UAAU,GAAG,UAAU,CAAC;IAC1E,8FAA8F;IAC9F,wBAAwB,CAAC,IAAI,EAAE,UAAU,GAAG,CAAC,UAAU,EAAE,EAAE,UAAU,EAAE,CAAC,CAAC;CAC1E"}
package/dest/types.js CHANGED
@@ -1,3 +1,4 @@
1
+ export * from './batched_blob.js';
1
2
  export * from './circuit_types/index.js';
2
3
  export * from './interface.js';
3
4
  export * from './sponge_blob.js';
package/package.json CHANGED
@@ -1,10 +1,10 @@
1
1
  {
2
2
  "name": "@aztec/blob-lib",
3
- "version": "3.0.0-devnet.2",
3
+ "version": "3.0.0-devnet.20251212",
4
4
  "type": "module",
5
5
  "exports": {
6
6
  ".": "./dest/index.js",
7
- "./encoding": "./dest/encoding.js",
7
+ "./encoding": "./dest/encoding/index.js",
8
8
  "./types": "./dest/types.js",
9
9
  "./testing": "./dest/testing.js"
10
10
  },
@@ -16,10 +16,10 @@
16
16
  "tsconfig": "./tsconfig.json"
17
17
  },
18
18
  "scripts": {
19
- "build": "yarn clean && tsc -b",
20
- "build:dev": "tsc -b --watch",
19
+ "build": "yarn clean && ../scripts/tsc.sh",
20
+ "build:dev": "../scripts/tsc.sh --watch",
21
21
  "clean": "rm -rf ./dest .tsbuildinfo",
22
- "start:dev": "tsc-watch -p tsconfig.json --onSuccess 'yarn start'",
22
+ "start:dev": "concurrently -k \"tsgo -b -w\" \"nodemon --watch dest --exec yarn start\"",
23
23
  "start": "node ./dest/index.js",
24
24
  "test": "NODE_NO_WARNINGS=1 node --experimental-vm-modules ../node_modules/.bin/jest --passWithNoTests --maxWorkers=${JEST_MAX_WORKERS:-8}"
25
25
  },
@@ -27,8 +27,8 @@
27
27
  "../package.common.json"
28
28
  ],
29
29
  "dependencies": {
30
- "@aztec/constants": "3.0.0-devnet.2",
31
- "@aztec/foundation": "3.0.0-devnet.2",
30
+ "@aztec/constants": "3.0.0-devnet.20251212",
31
+ "@aztec/foundation": "3.0.0-devnet.20251212",
32
32
  "@crate-crypto/node-eth-kzg": "^0.10.0",
33
33
  "tslib": "^2.4.0"
34
34
  },
@@ -36,6 +36,7 @@
36
36
  "@jest/globals": "^30.0.0",
37
37
  "@types/jest": "^30.0.0",
38
38
  "@types/node": "^22.15.17",
39
+ "@typescript/native-preview": "7.0.0-dev.20251126.1",
39
40
  "get-port": "^7.1.0",
40
41
  "jest": "^30.0.0",
41
42
  "ts-node": "^10.9.1",
@@ -0,0 +1,26 @@
1
+ import { BLS12Fr, BLS12Point } from '@aztec/foundation/curves/bls12';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
+
4
+ import { FinalBlobAccumulator } from './circuit_types/index.js';
5
+
6
+ /**
7
+ * A class to represent the result from accumulating blobs in an epoch using BatchedBlobAccumulator.
8
+ */
9
+ export class BatchedBlob {
10
+ constructor(
11
+ /** Hash of Cs (to link to L1 blob hashes). */
12
+ public readonly blobCommitmentsHash: Fr,
13
+ /** Challenge point z such that p_i(z) = y_i. */
14
+ public readonly z: Fr,
15
+ /** Evaluation y, linear combination of all evaluations y_i = p_i(z) with gamma. */
16
+ public readonly y: BLS12Fr,
17
+ /** Commitment C, linear combination of all commitments C_i = [p_i] with gamma. */
18
+ public readonly commitment: BLS12Point,
19
+ /** KZG opening 'proof' Q (commitment to the quotient poly.), linear combination of all blob kzg 'proofs' Q_i with gamma. */
20
+ public readonly q: BLS12Point,
21
+ ) {}
22
+
23
+ toFinalBlobAccumulator() {
24
+ return new FinalBlobAccumulator(this.blobCommitmentsHash, this.z, this.y, this.commitment);
25
+ }
26
+ }
package/src/blob.ts CHANGED
@@ -1,10 +1,11 @@
1
1
  import { FIELDS_PER_BLOB } from '@aztec/constants';
2
- import { BLS12Fr, Fr } from '@aztec/foundation/fields';
2
+ import { BLS12Fr } from '@aztec/foundation/curves/bls12';
3
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
4
  import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
4
5
 
5
6
  import { computeBlobCommitment, computeChallengeZ, computeEthVersionedBlobHash } from './hash.js';
6
7
  import type { BlobJson } from './interface.js';
7
- import { BYTES_PER_BLOB, BYTES_PER_COMMITMENT, kzg } from './kzg_context.js';
8
+ import { BYTES_PER_BLOB, BYTES_PER_COMMITMENT, getKzg } from './kzg_context.js';
8
9
 
9
10
  export { FIELDS_PER_BLOB };
10
11
 
@@ -136,6 +137,7 @@ export class Blob {
136
137
  * proof: Buffer - KZG opening proof for y = p(z). The commitment to quotient polynomial Q, used in compressed BLS12 point format (48 bytes).
137
138
  */
138
139
  evaluate(challengeZ: Fr, verifyProof = false) {
140
+ const kzg = getKzg();
139
141
  const res = kzg.computeKzgProof(this.data, challengeZ.toBuffer());
140
142
  if (verifyProof && !kzg.verifyKzgProof(this.commitment, challengeZ.toBuffer(), res[1], res[0])) {
141
143
  throw new Error(`KZG proof did not verify.`);
@@ -178,6 +180,7 @@ export class Blob {
178
180
  }
179
181
 
180
182
  static getViemKzgInstance() {
183
+ const kzg = getKzg();
181
184
  return {
182
185
  blobToKzgCommitment: kzg.blobToKzgCommitment.bind(kzg),
183
186
  computeBlobKzgProof: kzg.computeBlobKzgProof.bind(kzg),