@aztec/foundation 0.22.0 → 0.24.0

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 (121) hide show
  1. package/dest/abi/buffer.js +2 -2
  2. package/dest/fields/fields.d.ts +1 -0
  3. package/dest/fields/fields.d.ts.map +1 -1
  4. package/dest/fields/fields.js +6 -3
  5. package/package.json +2 -2
  6. package/src/abi/abi.ts +337 -0
  7. package/src/abi/buffer.ts +36 -0
  8. package/src/abi/decoder.ts +176 -0
  9. package/src/abi/encoder.ts +143 -0
  10. package/src/abi/index.ts +6 -0
  11. package/src/abi/selector.ts +243 -0
  12. package/src/abi/utils.ts +50 -0
  13. package/src/array/array.ts +86 -0
  14. package/src/array/index.ts +1 -0
  15. package/src/async-map/index.ts +18 -0
  16. package/src/aztec-address/index.ts +36 -0
  17. package/src/bigint-buffer/index.ts +87 -0
  18. package/src/collection/array.ts +64 -0
  19. package/src/collection/index.ts +1 -0
  20. package/src/committable/committable.ts +46 -0
  21. package/src/committable/index.ts +1 -0
  22. package/src/crypto/index.ts +16 -0
  23. package/src/crypto/keccak/index.ts +33 -0
  24. package/src/crypto/pedersen/index.ts +1 -0
  25. package/src/crypto/pedersen/pedersen.elliptic.ts +584 -0
  26. package/src/crypto/pedersen/pedersen.noble.ts +573 -0
  27. package/src/crypto/pedersen/pedersen.wasm.ts +42 -0
  28. package/src/crypto/random/index.ts +42 -0
  29. package/src/crypto/sha256/index.ts +3 -0
  30. package/src/errors/index.ts +6 -0
  31. package/src/eth-address/index.ts +234 -0
  32. package/src/fields/coordinate.ts +104 -0
  33. package/src/fields/fields.ts +328 -0
  34. package/src/fields/index.ts +3 -0
  35. package/src/fields/point.ts +145 -0
  36. package/src/fifo/bounded_serial_queue.ts +100 -0
  37. package/src/fifo/index.ts +4 -0
  38. package/src/fifo/memory_fifo.ts +118 -0
  39. package/src/fifo/semaphore.ts +33 -0
  40. package/src/fifo/serial_queue.ts +81 -0
  41. package/src/index.ts +29 -0
  42. package/src/json-rpc/README.md +55 -0
  43. package/src/json-rpc/class_converter.ts +213 -0
  44. package/src/json-rpc/client/index.ts +1 -0
  45. package/src/json-rpc/client/json_rpc_client.ts +147 -0
  46. package/src/json-rpc/convert.ts +163 -0
  47. package/src/json-rpc/fixtures/class_a.ts +15 -0
  48. package/src/json-rpc/fixtures/class_b.ts +15 -0
  49. package/src/json-rpc/fixtures/test_state.ts +59 -0
  50. package/src/json-rpc/index.ts +8 -0
  51. package/src/json-rpc/js_utils.ts +20 -0
  52. package/src/json-rpc/server/index.ts +2 -0
  53. package/src/json-rpc/server/json_proxy.ts +60 -0
  54. package/src/json-rpc/server/json_rpc_server.ts +269 -0
  55. package/src/log/console.ts +39 -0
  56. package/src/log/debug.ts +83 -0
  57. package/src/log/index.ts +5 -0
  58. package/src/log/log_fn.ts +5 -0
  59. package/src/log/log_history.ts +44 -0
  60. package/src/log/logger.ts +137 -0
  61. package/src/mutex/index.ts +83 -0
  62. package/src/mutex/mutex_database.ts +12 -0
  63. package/src/noir/index.ts +1 -0
  64. package/src/noir/noir_package_config.ts +54 -0
  65. package/src/retry/index.ts +99 -0
  66. package/src/running-promise/index.ts +60 -0
  67. package/src/serialize/buffer_reader.ts +286 -0
  68. package/src/serialize/field_reader.ts +143 -0
  69. package/src/serialize/free_funcs.ts +147 -0
  70. package/src/serialize/index.ts +5 -0
  71. package/src/serialize/serialize.ts +303 -0
  72. package/src/serialize/types.ts +40 -0
  73. package/src/sleep/index.ts +71 -0
  74. package/src/testing/index.ts +1 -0
  75. package/src/testing/test_data.ts +36 -0
  76. package/src/timer/elapsed.ts +23 -0
  77. package/src/timer/index.ts +3 -0
  78. package/src/timer/timeout.ts +64 -0
  79. package/src/timer/timer.ts +48 -0
  80. package/src/transport/browser/index.ts +4 -0
  81. package/src/transport/browser/message_port_socket.ts +48 -0
  82. package/src/transport/browser/shared_worker_connector.ts +21 -0
  83. package/src/transport/browser/shared_worker_listener.ts +53 -0
  84. package/src/transport/browser/worker_connector.ts +30 -0
  85. package/src/transport/browser/worker_listener.ts +54 -0
  86. package/src/transport/dispatch/create_dispatch_fn.ts +35 -0
  87. package/src/transport/dispatch/create_dispatch_proxy.ts +141 -0
  88. package/src/transport/dispatch/messages.ts +58 -0
  89. package/src/transport/index.ts +11 -0
  90. package/src/transport/interface/connector.ts +9 -0
  91. package/src/transport/interface/listener.ts +16 -0
  92. package/src/transport/interface/socket.ts +15 -0
  93. package/src/transport/interface/transferable.ts +125 -0
  94. package/src/transport/node/index.ts +2 -0
  95. package/src/transport/node/node_connector.ts +30 -0
  96. package/src/transport/node/node_connector_socket.ts +52 -0
  97. package/src/transport/node/node_listener.ts +34 -0
  98. package/src/transport/node/node_listener_socket.ts +48 -0
  99. package/src/transport/transport_client.ts +131 -0
  100. package/src/transport/transport_server.ts +108 -0
  101. package/src/trees/index.ts +54 -0
  102. package/src/types/index.ts +8 -0
  103. package/src/url/index.ts +73 -0
  104. package/src/wasm/README.md +6 -0
  105. package/src/wasm/empty_wasi_sdk.ts +166 -0
  106. package/src/wasm/fixtures/gcd.wasm +0 -0
  107. package/src/wasm/fixtures/gcd.wat +27 -0
  108. package/src/wasm/index.ts +1 -0
  109. package/src/wasm/wasm_module.ts +260 -0
  110. package/src/worker/browser/index.ts +2 -0
  111. package/src/worker/browser/start_web_module.ts +23 -0
  112. package/src/worker/browser/web_data_store.ts +38 -0
  113. package/src/worker/browser/web_worker.ts +24 -0
  114. package/src/worker/data_store.ts +19 -0
  115. package/src/worker/index.ts +2 -0
  116. package/src/worker/node/index.ts +2 -0
  117. package/src/worker/node/node_data_store.ts +27 -0
  118. package/src/worker/node/node_worker.ts +22 -0
  119. package/src/worker/node/start_node_module.ts +29 -0
  120. package/src/worker/wasm_worker.ts +7 -0
  121. package/src/worker/worker_pool.ts +73 -0
@@ -11,7 +11,7 @@ export function bufferAsFields(input, targetLength) {
11
11
  const encoded = [
12
12
  new Fr(input.length),
13
13
  ...chunk(input, Fr.SIZE_IN_BYTES - 1).map(c => {
14
- const fieldBytes = Buffer.alloc(32);
14
+ const fieldBytes = Buffer.alloc(Fr.SIZE_IN_BYTES);
15
15
  Buffer.from(c).copy(fieldBytes, 1);
16
16
  return Fr.fromBuffer(fieldBytes);
17
17
  }),
@@ -31,4 +31,4 @@ export function bufferFromFields(fields) {
31
31
  const [length, ...payload] = fields;
32
32
  return Buffer.concat(payload.map(f => f.toBuffer().subarray(1))).subarray(0, length.toNumber());
33
33
  }
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVmZmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FiaS9idWZmZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE1BQU0sY0FBYyxDQUFDO0FBRWpDLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUV6Qzs7Ozs7O0dBTUc7QUFDSCxNQUFNLFVBQVUsY0FBYyxDQUFDLEtBQWEsRUFBRSxZQUFvQjtJQUNoRSxNQUFNLE9BQU8sR0FBRztRQUNkLElBQUksRUFBRSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUM7UUFDcEIsR0FBRyxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxhQUFhLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFO1lBQzVDLE1BQU0sVUFBVSxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUM7WUFDcEMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQ25DLE9BQU8sRUFBRSxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUNuQyxDQUFDLENBQUM7S0FDSCxDQUFDO0lBQ0YsSUFBSSxPQUFPLENBQUMsTUFBTSxHQUFHLFlBQVksRUFBRSxDQUFDO1FBQ2xDLE1BQU0sSUFBSSxLQUFLLENBQUMsMENBQTBDLE9BQU8sQ0FBQyxNQUFNLGVBQWUsWUFBWSxFQUFFLENBQUMsQ0FBQztJQUN6RyxDQUFDO0lBQ0QsOEZBQThGO0lBQzlGLE9BQU8sQ0FBQyxHQUFHLE9BQU8sRUFBRSxHQUFHLEtBQUssQ0FBQyxZQUFZLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztBQUM3RSxDQUFDO0FBRUQ7Ozs7R0FJRztBQUNILE1BQU0sVUFBVSxnQkFBZ0IsQ0FBQyxNQUFZO0lBQzNDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsR0FBRyxPQUFPLENBQUMsR0FBRyxNQUFNLENBQUM7SUFDcEMsT0FBTyxNQUFNLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxFQUFFLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO0FBQ2xHLENBQUMifQ==
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVmZmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FiaS9idWZmZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE1BQU0sY0FBYyxDQUFDO0FBRWpDLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUV6Qzs7Ozs7O0dBTUc7QUFDSCxNQUFNLFVBQVUsY0FBYyxDQUFDLEtBQWEsRUFBRSxZQUFvQjtJQUNoRSxNQUFNLE9BQU8sR0FBRztRQUNkLElBQUksRUFBRSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUM7UUFDcEIsR0FBRyxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxhQUFhLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFO1lBQzVDLE1BQU0sVUFBVSxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1lBQ2xELE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDLENBQUMsQ0FBQztZQUNuQyxPQUFPLEVBQUUsQ0FBQyxVQUFVLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDbkMsQ0FBQyxDQUFDO0tBQ0gsQ0FBQztJQUNGLElBQUksT0FBTyxDQUFDLE1BQU0sR0FBRyxZQUFZLEVBQUUsQ0FBQztRQUNsQyxNQUFNLElBQUksS0FBSyxDQUFDLDBDQUEwQyxPQUFPLENBQUMsTUFBTSxlQUFlLFlBQVksRUFBRSxDQUFDLENBQUM7SUFDekcsQ0FBQztJQUNELDhGQUE4RjtJQUM5RixPQUFPLENBQUMsR0FBRyxPQUFPLEVBQUUsR0FBRyxLQUFLLENBQUMsWUFBWSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7QUFDN0UsQ0FBQztBQUVEOzs7O0dBSUc7QUFDSCxNQUFNLFVBQVUsZ0JBQWdCLENBQUMsTUFBWTtJQUMzQyxNQUFNLENBQUMsTUFBTSxFQUFFLEdBQUcsT0FBTyxDQUFDLEdBQUcsTUFBTSxDQUFDO0lBQ3BDLE9BQU8sTUFBTSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUMsRUFBRSxNQUFNLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQztBQUNsRyxDQUFDIn0=
@@ -26,6 +26,7 @@ declare abstract class BaseField {
26
26
  toBuffer(): Buffer;
27
27
  toString(): `0x${string}`;
28
28
  toBigInt(): bigint;
29
+ toBool(): boolean;
29
30
  toNumber(): number;
30
31
  toShortString(): string;
31
32
  equals(rhs: BaseField): boolean;
@@ -1 +1 @@
1
- {"version":3,"file":"fields.d.ts","sourceRoot":"","sources":["../../src/fields/fields.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAiB7D;;;;;;;;GAQG;AACH,uBAAe,SAAS;IACtB,MAAM,CAAC,aAAa,SAAM;IAC1B,OAAO,CAAC,QAAQ,CAAC,CAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,CAAS;IAE1B;;;SAGK;IACL,IAAI,KAAK,IAAI,MAAM,CAElB;IAED,SAAS,aAAa,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM;IA8B3E,SAAS,CAAC,QAAQ,CAAC,OAAO,IAAI,MAAM;IAEpC;;OAEG;IACH,QAAQ,IAAI,MAAM;IAOlB,QAAQ,IAAI,KAAK,MAAM,EAAE;IAIzB,QAAQ,IAAI,MAAM;IAUlB,QAAQ,IAAI,MAAM;IAQlB,aAAa,IAAI,MAAM;IAKvB,MAAM,CAAC,GAAG,EAAE,SAAS,GAAG,OAAO;IAI/B,EAAE,CAAC,GAAG,EAAE,SAAS,GAAG,OAAO;IAI3B,MAAM,IAAI,OAAO;IAIjB,cAAc,IAAI,MAAM;IAIxB,OAAO;CAGR;AAmCD;;GAEG;AACH,MAAM,WAAW,EAAE;IACjB,aAAa;IACb,SAAS,EAAE,IAAI,CAAC;CACjB;AAED;;GAEG;AACH,qBAAa,EAAG,SAAQ,SAAS;IAC/B,MAAM,CAAC,IAAI,KAAc;IACzB,MAAM,CAAC,OAAO,SAAuE;gBAEzE,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,EAAE,GAAG,MAAM;IAI1D,SAAS,CAAC,OAAO;IAIjB,MAAM,CAAC,MAAM;IAIb,MAAM,CAAC,IAAI;IAIX,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,YAAY;IAI/C,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,MAAM;IAItC,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE,MAAM;IAI7B,iBAAiB;IAEjB,GAAG,CAAC,GAAG,EAAE,EAAE;IAIX,GAAG,CAAC,GAAG,EAAE,EAAE;IAKX,GAAG,CAAC,GAAG,EAAE,EAAE;IAIX,GAAG,CAAC,GAAG,EAAE,EAAE;CAQZ;AAED;;GAEG;AACH,MAAM,WAAW,EAAE;IACjB,aAAa;IACb,SAAS,EAAE,IAAI,CAAC;CACjB;AAED;;GAEG;AACH,qBAAa,EAAG,SAAQ,SAAS;IAC/B,MAAM,CAAC,IAAI,KAAc;IACzB,MAAM,CAAC,OAAO,SAAuE;IACrF,OAAO,CAAC,MAAM,CAAC,UAAU,CAA6C;IACtE,OAAO,CAAC,MAAM,CAAC,QAAQ,CAA8B;IAErD,IAAI,GAAG,IAAI,EAAE,CAEZ;IAED,IAAI,IAAI,IAAI,EAAE,CAEb;gBAEW,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,EAAE,GAAG,MAAM;IAI1D,SAAS,CAAC,OAAO;IAIjB,MAAM,CAAC,MAAM;IAIb,MAAM,CAAC,IAAI;IAIX,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,YAAY;IAI/C,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,MAAM;IAItC,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE,MAAM;IAI7B,MAAM,CAAC,WAAW,CAAC,IAAI,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE;CAG1C;AA6BD;;;;GAIG;AACH,MAAM,MAAM,cAAc,GAAG,EAAE,CAAC;AAChC,eAAO,MAAM,cAAc,WAAK,CAAC"}
1
+ {"version":3,"file":"fields.d.ts","sourceRoot":"","sources":["../../src/fields/fields.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAiB7D;;;;;;;;GAQG;AACH,uBAAe,SAAS;IACtB,MAAM,CAAC,aAAa,SAAM;IAC1B,OAAO,CAAC,QAAQ,CAAC,CAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,CAAS;IAE1B;;;SAGK;IACL,IAAI,KAAK,IAAI,MAAM,CAElB;IAED,SAAS,aAAa,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM;IA8B3E,SAAS,CAAC,QAAQ,CAAC,OAAO,IAAI,MAAM;IAEpC;;OAEG;IACH,QAAQ,IAAI,MAAM;IAOlB,QAAQ,IAAI,KAAK,MAAM,EAAE;IAIzB,QAAQ,IAAI,MAAM;IAUlB,MAAM,IAAI,OAAO;IAIjB,QAAQ,IAAI,MAAM;IAQlB,aAAa,IAAI,MAAM;IAKvB,MAAM,CAAC,GAAG,EAAE,SAAS,GAAG,OAAO;IAI/B,EAAE,CAAC,GAAG,EAAE,SAAS,GAAG,OAAO;IAI3B,MAAM,IAAI,OAAO;IAIjB,cAAc,IAAI,MAAM;IAIxB,OAAO;CAGR;AAmCD;;GAEG;AACH,MAAM,WAAW,EAAE;IACjB,aAAa;IACb,SAAS,EAAE,IAAI,CAAC;CACjB;AAED;;GAEG;AACH,qBAAa,EAAG,SAAQ,SAAS;IAC/B,MAAM,CAAC,IAAI,KAAc;IACzB,MAAM,CAAC,OAAO,SAAuE;gBAEzE,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,EAAE,GAAG,MAAM;IAI1D,SAAS,CAAC,OAAO;IAIjB,MAAM,CAAC,MAAM;IAIb,MAAM,CAAC,IAAI;IAIX,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,YAAY;IAI/C,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,MAAM;IAItC,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE,MAAM;IAI7B,iBAAiB;IAEjB,GAAG,CAAC,GAAG,EAAE,EAAE;IAIX,GAAG,CAAC,GAAG,EAAE,EAAE;IAKX,GAAG,CAAC,GAAG,EAAE,EAAE;IAIX,GAAG,CAAC,GAAG,EAAE,EAAE;CAQZ;AAED;;GAEG;AACH,MAAM,WAAW,EAAE;IACjB,aAAa;IACb,SAAS,EAAE,IAAI,CAAC;CACjB;AAED;;GAEG;AACH,qBAAa,EAAG,SAAQ,SAAS;IAC/B,MAAM,CAAC,IAAI,KAAc;IACzB,MAAM,CAAC,OAAO,SAAuE;IACrF,OAAO,CAAC,MAAM,CAAC,UAAU,CAA6C;IACtE,OAAO,CAAC,MAAM,CAAC,QAAQ,CAA8B;IAErD,IAAI,GAAG,IAAI,EAAE,CAEZ;IAED,IAAI,IAAI,IAAI,EAAE,CAEb;gBAEW,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,EAAE,GAAG,MAAM;IAI1D,SAAS,CAAC,OAAO;IAIjB,MAAM,CAAC,MAAM;IAIb,MAAM,CAAC,IAAI;IAIX,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,YAAY;IAI/C,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,MAAM;IAItC,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE,MAAM;IAI7B,MAAM,CAAC,WAAW,CAAC,IAAI,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE;CAG1C;AA6BD;;;;GAIG;AACH,MAAM,MAAM,cAAc,GAAG,EAAE,CAAC;AAChC,eAAO,MAAM,cAAc,WAAK,CAAC"}
@@ -71,6 +71,9 @@ class BaseField {
71
71
  }
72
72
  return this.asBigInt;
73
73
  }
74
+ toBool() {
75
+ return Boolean(this.toBigInt());
76
+ }
74
77
  toNumber() {
75
78
  const value = this.toBigInt();
76
79
  if (value > Number.MAX_SAFE_INTEGER) {
@@ -222,8 +225,8 @@ function modInverse(b) {
222
225
  if (gcd != 1n) {
223
226
  throw Error('Inverse does not exist');
224
227
  }
225
- // Add modulus to ensure positive
226
- return new Fr(x + Fr.MODULUS);
228
+ // Add modulus if -ve to ensure positive
229
+ return new Fr(x > 0 ? x : x + Fr.MODULUS);
227
230
  }
228
231
  /**
229
232
  * The extended Euclidean algorithm can be used to find the multiplicative inverse of a field element
@@ -239,4 +242,4 @@ function extendedEuclidean(a, modulus) {
239
242
  }
240
243
  }
241
244
  export const GrumpkinScalar = Fq;
242
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fields.js","sourceRoot":"","sources":["../../src/fields/fields.ts"],"names":[],"mappings":"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"}
245
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fields.js","sourceRoot":"","sources":["../../src/fields/fields.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aztec/foundation",
3
- "version": "0.22.0",
3
+ "version": "0.24.0",
4
4
  "packageManager": "yarn@3.4.1",
5
5
  "type": "module",
6
6
  "main": "./dest/index.js",
@@ -61,7 +61,7 @@
61
61
  "rootDir": "./src"
62
62
  },
63
63
  "dependencies": {
64
- "@aztec/bb.js": "0.22.0",
64
+ "@aztec/bb.js": "0.24.0",
65
65
  "@koa/cors": "^4.0.0",
66
66
  "@noble/curves": "^1.2.0",
67
67
  "bn.js": "^5.2.1",
package/src/abi/abi.ts ADDED
@@ -0,0 +1,337 @@
1
+ import { inflate } from 'pako';
2
+
3
+ import { type FunctionSelector } from './selector.js';
4
+
5
+ /**
6
+ * A named type.
7
+ */
8
+ export interface ABIVariable {
9
+ /**
10
+ * The name of the variable.
11
+ */
12
+ name: string;
13
+ /**
14
+ * The type of the variable.
15
+ */
16
+ type: ABIType;
17
+ }
18
+
19
+ /**
20
+ * Indicates whether a parameter is public or secret/private.
21
+ */
22
+ export enum ABIParameterVisibility {
23
+ PUBLIC = 'public',
24
+ SECRET = 'secret',
25
+ }
26
+
27
+ /**
28
+ * A function parameter.
29
+ */
30
+ export interface ABIParameter extends ABIVariable {
31
+ /**
32
+ * Indicates whether a parameter is public or secret/private.
33
+ */
34
+ visibility: ABIParameterVisibility;
35
+ }
36
+
37
+ /**
38
+ * A basic type.
39
+ */
40
+ export interface BasicType<T extends string> {
41
+ /**
42
+ * The kind of the type.
43
+ */
44
+ kind: T;
45
+ }
46
+
47
+ /**
48
+ * A variable type.
49
+ */
50
+ export type ABIType = BasicType<'field'> | BasicType<'boolean'> | IntegerType | ArrayType | StringType | StructType;
51
+
52
+ /**
53
+ * An integer type.
54
+ */
55
+ export interface IntegerType extends BasicType<'integer'> {
56
+ /**
57
+ * The sign of the integer.
58
+ */
59
+ sign: string;
60
+ /**
61
+ * The width of the integer in bits.
62
+ */
63
+ width: number;
64
+ }
65
+
66
+ /**
67
+ * An array type.
68
+ */
69
+ export interface ArrayType extends BasicType<'array'> {
70
+ /**
71
+ * The length of the array.
72
+ */
73
+ length: number;
74
+ /**
75
+ * The type of the array elements.
76
+ */
77
+ type: ABIType;
78
+ }
79
+
80
+ /**
81
+ * A string type.
82
+ */
83
+ export interface StringType extends BasicType<'string'> {
84
+ /**
85
+ * The length of the string.
86
+ */
87
+ length: number;
88
+ }
89
+
90
+ /**
91
+ * A struct type.
92
+ */
93
+ export interface StructType extends BasicType<'struct'> {
94
+ /**
95
+ * The fields of the struct.
96
+ */
97
+ fields: ABIVariable[];
98
+ /**
99
+ * Fully qualified name of the struct.
100
+ */
101
+ path: string;
102
+ }
103
+
104
+ /**
105
+ * A contract event.
106
+ */
107
+ export interface EventAbi {
108
+ /**
109
+ * The event name.
110
+ */
111
+ name: string;
112
+ /**
113
+ * Fully qualified name of the event.
114
+ */
115
+ path: string;
116
+ /**
117
+ * The fields of the event.
118
+ */
119
+ fields: ABIVariable[];
120
+ }
121
+
122
+ /**
123
+ * Aztec.nr function types.
124
+ */
125
+ export enum FunctionType {
126
+ SECRET = 'secret',
127
+ OPEN = 'open',
128
+ UNCONSTRAINED = 'unconstrained',
129
+ }
130
+
131
+ /**
132
+ * The abi entry of a function.
133
+ */
134
+ export interface FunctionAbi {
135
+ /**
136
+ * The name of the function.
137
+ */
138
+ name: string;
139
+ /**
140
+ * Whether the function is secret.
141
+ */
142
+ functionType: FunctionType;
143
+ /**
144
+ * Whether the function is internal.
145
+ */
146
+ isInternal: boolean;
147
+ /**
148
+ * Function parameters.
149
+ */
150
+ parameters: ABIParameter[];
151
+ /**
152
+ * The types of the return values.
153
+ */
154
+ returnTypes: ABIType[];
155
+ }
156
+
157
+ /**
158
+ * The artifact entry of a function.
159
+ */
160
+ export interface FunctionArtifact extends FunctionAbi {
161
+ /**
162
+ * The ACIR bytecode of the function.
163
+ */
164
+ bytecode: string;
165
+ /**
166
+ * The verification key of the function.
167
+ */
168
+ verificationKey?: string;
169
+ /**
170
+ * Maps opcodes to source code pointers
171
+ */
172
+ debugSymbols: string;
173
+ }
174
+
175
+ /**
176
+ * A file ID. It's assigned during compilation.
177
+ */
178
+ export type FileId = number;
179
+
180
+ /**
181
+ * A pointer to a specific section of the source code.
182
+ */
183
+ export interface SourceCodeLocation {
184
+ /**
185
+ * The section of the source code.
186
+ */
187
+ span: {
188
+ /**
189
+ * The byte where the section starts.
190
+ */
191
+ start: number;
192
+ /**
193
+ * The byte where the section ends.
194
+ */
195
+ end: number;
196
+ };
197
+ /**
198
+ * The source code file pointed to.
199
+ */
200
+ file: FileId;
201
+ }
202
+
203
+ /**
204
+ * The location of an opcode in the bytecode.
205
+ * It's a string of the form `{acirIndex}` or `{acirIndex}:{brilligIndex}`.
206
+ */
207
+ export type OpcodeLocation = string;
208
+
209
+ /**
210
+ * The debug information for a given function.
211
+ */
212
+ export interface DebugInfo {
213
+ /**
214
+ * A map of the opcode location to the source code location.
215
+ */
216
+ locations: Record<OpcodeLocation, SourceCodeLocation[]>;
217
+ }
218
+
219
+ /**
220
+ * Maps a file ID to its metadata for debugging purposes.
221
+ */
222
+ export type DebugFileMap = Record<
223
+ FileId,
224
+ {
225
+ /**
226
+ * The source code of the file.
227
+ */
228
+ source: string;
229
+ /**
230
+ * The path of the file.
231
+ */
232
+ path: string;
233
+ }
234
+ >;
235
+
236
+ /**
237
+ * Defines artifact of a contract.
238
+ */
239
+ export interface ContractArtifact {
240
+ /**
241
+ * The name of the contract.
242
+ */
243
+ name: string;
244
+
245
+ /**
246
+ * The version of compiler used to create this artifact
247
+ */
248
+ aztecNrVersion?: string;
249
+
250
+ /**
251
+ * The functions of the contract.
252
+ */
253
+ functions: FunctionArtifact[];
254
+ /**
255
+ * The events of the contract.
256
+ */
257
+ events: EventAbi[];
258
+
259
+ /**
260
+ * The map of file ID to the source code and path of the file.
261
+ */
262
+ fileMap: DebugFileMap;
263
+ }
264
+
265
+ /**
266
+ * Debug metadata for a function.
267
+ */
268
+ export interface FunctionDebugMetadata {
269
+ /**
270
+ * Maps opcodes to source code pointers
271
+ */
272
+ debugSymbols: DebugInfo;
273
+ /**
274
+ * Maps the file IDs to the file contents to resolve pointers
275
+ */
276
+ files: DebugFileMap;
277
+ }
278
+
279
+ /** A function artifact with optional debug metadata */
280
+ export interface FunctionArtifactWithDebugMetadata extends FunctionArtifact {
281
+ /** Debug metadata for the function. */
282
+ debug?: FunctionDebugMetadata;
283
+ }
284
+
285
+ /**
286
+ * Gets a function artifact given its name or selector.
287
+ */
288
+ export function getFunctionArtifact(
289
+ artifact: ContractArtifact,
290
+ functionNameOrSelector: string | FunctionSelector,
291
+ ): FunctionArtifact {
292
+ const functionArtifact = artifact.functions.find(f =>
293
+ typeof functionNameOrSelector === 'string'
294
+ ? f.name === functionNameOrSelector
295
+ : functionNameOrSelector.equals(f.name, f.parameters),
296
+ );
297
+ if (!functionArtifact) {
298
+ throw new Error(`Unknown function ${functionNameOrSelector}`);
299
+ }
300
+ return functionArtifact;
301
+ }
302
+
303
+ /** @deprecated Use getFunctionArtifact instead */
304
+ export function getFunctionArtifactWithSelector(artifact: ContractArtifact, selector: FunctionSelector) {
305
+ return getFunctionArtifact(artifact, selector);
306
+ }
307
+
308
+ /**
309
+ * Gets a function artifact including debug metadata given its name or selector.
310
+ */
311
+ export function getFunctionArtifactWithDebugMetadata(
312
+ artifact: ContractArtifact,
313
+ functionNameOrSelector: string | FunctionSelector,
314
+ ): FunctionArtifactWithDebugMetadata {
315
+ const functionArtifact = getFunctionArtifact(artifact, functionNameOrSelector);
316
+ const debugMetadata = getFunctionDebugMetadata(artifact, functionArtifact);
317
+ return { ...functionArtifact, debug: debugMetadata };
318
+ }
319
+
320
+ /**
321
+ * Gets the debug metadata of a given function from the contract artifact
322
+ * @param artifact - The contract build artifact
323
+ * @param functionName - The name of the function
324
+ * @returns The debug metadata of the function
325
+ */
326
+ export function getFunctionDebugMetadata(
327
+ contractArtifact: ContractArtifact,
328
+ functionArtifact: FunctionArtifact,
329
+ ): FunctionDebugMetadata | undefined {
330
+ if (functionArtifact.debugSymbols && contractArtifact.fileMap) {
331
+ const debugSymbols = JSON.parse(
332
+ inflate(Buffer.from(functionArtifact.debugSymbols, 'base64'), { to: 'string', raw: true }),
333
+ );
334
+ return { debugSymbols, files: contractArtifact.fileMap };
335
+ }
336
+ return undefined;
337
+ }
@@ -0,0 +1,36 @@
1
+ import chunk from 'lodash.chunk';
2
+
3
+ import { Fr } from '../fields/fields.js';
4
+
5
+ /**
6
+ * Formats a buffer as an array of fields. Splits the input into 31-byte chunks, and stores each
7
+ * of them into a field, omitting the field's first byte, then adds zero-fields at the end until the max length.
8
+ * @param input - Input to format.
9
+ * @param targetLength - Length of the target array in number of fields.
10
+ * @returns A field with the total length in bytes, followed by an array of fields such that their concatenation is equal to the input buffer, followed by enough zeroes to reach targetLength.
11
+ */
12
+ export function bufferAsFields(input: Buffer, targetLength: number): Fr[] {
13
+ const encoded = [
14
+ new Fr(input.length),
15
+ ...chunk(input, Fr.SIZE_IN_BYTES - 1).map(c => {
16
+ const fieldBytes = Buffer.alloc(Fr.SIZE_IN_BYTES);
17
+ Buffer.from(c).copy(fieldBytes, 1);
18
+ return Fr.fromBuffer(fieldBytes);
19
+ }),
20
+ ];
21
+ if (encoded.length > targetLength) {
22
+ throw new Error(`Input buffer exceeds maximum size: got ${encoded.length} but max is ${targetLength}`);
23
+ }
24
+ // Fun fact: we cannot use padArrayEnd here since typescript cannot deal with a Tuple this big
25
+ return [...encoded, ...Array(targetLength - encoded.length).fill(Fr.ZERO)];
26
+ }
27
+
28
+ /**
29
+ * Recovers a buffer from an array of fields.
30
+ * @param fields - An output from bufferAsFields.
31
+ * @returns The recovered buffer.
32
+ */
33
+ export function bufferFromFields(fields: Fr[]): Buffer {
34
+ const [length, ...payload] = fields;
35
+ return Buffer.concat(payload.map(f => f.toBuffer().subarray(1))).subarray(0, length.toNumber());
36
+ }
@@ -0,0 +1,176 @@
1
+ import { AztecAddress } from '../aztec-address/index.js';
2
+ import { Fr } from '../fields/index.js';
3
+ import { ABIParameter, type ABIType, ABIVariable, FunctionArtifact } from './abi.js';
4
+ import { isAztecAddressStruct } from './utils.js';
5
+
6
+ /**
7
+ * The type of our decoded ABI.
8
+ */
9
+ export type DecodedReturn = bigint | boolean | AztecAddress | DecodedReturn[] | { [key: string]: DecodedReturn };
10
+
11
+ /**
12
+ * Decodes return values from a function call.
13
+ * Missing support for integer and string.
14
+ */
15
+ class ReturnValuesDecoder {
16
+ constructor(private artifact: FunctionArtifact, private flattened: Fr[]) {}
17
+
18
+ /**
19
+ * Decodes a single return value from field to the given type.
20
+ * @param abiType - The type of the return value.
21
+ * @returns The decoded return value.
22
+ */
23
+ private decodeReturn(abiType: ABIType): DecodedReturn {
24
+ switch (abiType.kind) {
25
+ case 'field':
26
+ return this.getNextField().toBigInt();
27
+ case 'integer':
28
+ if (abiType.sign === 'signed') {
29
+ throw new Error('Unsupported type: signed integer');
30
+ }
31
+ return this.getNextField().toBigInt();
32
+ case 'boolean':
33
+ return !this.getNextField().isZero();
34
+ case 'array': {
35
+ const array = [];
36
+ for (let i = 0; i < abiType.length; i += 1) {
37
+ array.push(this.decodeReturn(abiType.type));
38
+ }
39
+ return array;
40
+ }
41
+ case 'struct': {
42
+ const struct: { [key: string]: DecodedReturn } = {};
43
+ if (isAztecAddressStruct(abiType)) {
44
+ return new AztecAddress(this.getNextField().toBuffer());
45
+ }
46
+
47
+ for (const field of abiType.fields) {
48
+ struct[field.name] = this.decodeReturn(field.type);
49
+ }
50
+ return struct;
51
+ }
52
+ case 'string': {
53
+ const array = [];
54
+ for (let i = 0; i < abiType.length; i += 1) {
55
+ array.push(this.getNextField().toBigInt());
56
+ }
57
+ return array;
58
+ }
59
+ default:
60
+ throw new Error(`Unsupported type: ${abiType}`);
61
+ }
62
+ }
63
+
64
+ /**
65
+ * Gets the next field in the flattened return values.
66
+ * @returns The next field in the flattened return values.
67
+ */
68
+ private getNextField(): Fr {
69
+ const field = this.flattened.shift();
70
+ if (!field) {
71
+ throw new Error('Not enough return values');
72
+ }
73
+ return field;
74
+ }
75
+
76
+ /**
77
+ * Decodes all the return values for the given function ABI.
78
+ * Aztec.nr support only single return value
79
+ * The return value can however be simple types, structs or arrays
80
+ * @returns The decoded return values.
81
+ */
82
+ public decode(): DecodedReturn {
83
+ if (this.artifact.returnTypes.length > 1) {
84
+ throw new Error('Multiple return values not supported');
85
+ }
86
+ if (this.artifact.returnTypes.length === 0) {
87
+ return [];
88
+ }
89
+ return this.decodeReturn(this.artifact.returnTypes[0]);
90
+ }
91
+ }
92
+
93
+ /**
94
+ * Decodes return values from a function call.
95
+ * @param abi - The ABI entry of the function.
96
+ * @param returnValues - The decoded return values.
97
+ * @returns
98
+ */
99
+ export function decodeReturnValues(abi: FunctionArtifact, returnValues: Fr[]) {
100
+ return new ReturnValuesDecoder(abi, returnValues.slice()).decode();
101
+ }
102
+
103
+ /**
104
+ * Decodes the signature of a function from the name and parameters.
105
+ */
106
+ export class FunctionSignatureDecoder {
107
+ private separator: string;
108
+ constructor(private name: string, private parameters: ABIParameter[], private includeNames = false) {
109
+ this.separator = includeNames ? ', ' : ',';
110
+ }
111
+
112
+ /**
113
+ * Decodes a single function parameter type for the function signature.
114
+ * @param param - The parameter type to decode.
115
+ * @returns A string representing the parameter type.
116
+ */
117
+ private getParameterType(param: ABIType): string {
118
+ switch (param.kind) {
119
+ case 'field':
120
+ return 'Field';
121
+ case 'integer':
122
+ if (param.sign === 'signed') {
123
+ throw new Error('Unsupported type: signed integer');
124
+ }
125
+ return `u${param.width}`;
126
+ case 'boolean':
127
+ return 'bool';
128
+ case 'array':
129
+ return `[${this.getParameterType(param.type)};${param.length}]`;
130
+ case 'string':
131
+ return `str<${param.length}>`;
132
+ case 'struct':
133
+ return `(${param.fields.map(field => `${this.decodeParameter(field)}`).join(this.separator)})`;
134
+ default:
135
+ throw new Error(`Unsupported type: ${param}`);
136
+ }
137
+ }
138
+
139
+ /**
140
+ * Decodes a single function parameter for the function signature.
141
+ * @param param - The parameter to decode.
142
+ * @returns A string representing the parameter type and optionally its name.
143
+ */
144
+ private decodeParameter(param: ABIVariable): string {
145
+ const type = this.getParameterType(param.type);
146
+ return this.includeNames ? `${param.name}: ${type}` : type;
147
+ }
148
+
149
+ /**
150
+ * Decodes all the parameters and build the function signature
151
+ * @returns The function signature.
152
+ */
153
+ public decode(): string {
154
+ return `${this.name}(${this.parameters.map(param => this.decodeParameter(param)).join(this.separator)})`;
155
+ }
156
+ }
157
+
158
+ /**
159
+ * Decodes a function signature from the name and parameters.
160
+ * @param name - The name of the function.
161
+ * @param parameters - The parameters of the function.
162
+ * @returns - The function signature.
163
+ */
164
+ export function decodeFunctionSignature(name: string, parameters: ABIParameter[]) {
165
+ return new FunctionSignatureDecoder(name, parameters).decode();
166
+ }
167
+
168
+ /**
169
+ * Decodes a function signature from the name and parameters including parameter names.
170
+ * @param name - The name of the function.
171
+ * @param parameters - The parameters of the function.
172
+ * @returns - The user-friendly function signature.
173
+ */
174
+ export function decodeFunctionSignatureWithParameterNames(name: string, parameters: ABIParameter[]) {
175
+ return new FunctionSignatureDecoder(name, parameters, true).decode();
176
+ }