@aztec/pxe 0.0.1-commit.d1f2d6c → 0.0.1-commit.d20b825a7

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 (261) hide show
  1. package/dest/bin/check_oracle_version.js +5 -5
  2. package/dest/block_synchronizer/block_synchronizer.d.ts +10 -4
  3. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
  4. package/dest/block_synchronizer/block_synchronizer.js +30 -6
  5. package/dest/config/index.d.ts +2 -2
  6. package/dest/config/index.d.ts.map +1 -1
  7. package/dest/config/index.js +8 -15
  8. package/dest/config/package_info.js +1 -1
  9. package/dest/contract_function_simulator/contract_function_simulator.d.ts +63 -31
  10. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  11. package/dest/contract_function_simulator/contract_function_simulator.js +206 -77
  12. package/dest/contract_function_simulator/ephemeral_array_service.d.ts +28 -0
  13. package/dest/contract_function_simulator/ephemeral_array_service.d.ts.map +1 -0
  14. package/dest/contract_function_simulator/ephemeral_array_service.js +78 -0
  15. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +7 -7
  16. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
  17. package/dest/contract_function_simulator/execution_tagging_index_cache.js +19 -11
  18. package/dest/contract_function_simulator/index.d.ts +2 -1
  19. package/dest/contract_function_simulator/index.d.ts.map +1 -1
  20. package/dest/contract_function_simulator/index.js +1 -0
  21. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +5 -7
  22. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts.map +1 -1
  23. package/dest/contract_function_simulator/noir-structs/event_validation_request.js +9 -11
  24. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts +1 -1
  25. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.js +1 -1
  26. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +2 -2
  27. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts.map +1 -1
  28. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +2 -4
  29. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +5 -8
  30. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  31. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +7 -12
  32. package/dest/contract_function_simulator/oracle/interfaces.d.ts +62 -46
  33. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  34. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts +9 -0
  35. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts.map +1 -0
  36. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.js +47 -0
  37. package/dest/contract_function_simulator/oracle/oracle.d.ts +75 -44
  38. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  39. package/dest/contract_function_simulator/oracle/oracle.js +310 -113
  40. package/dest/contract_function_simulator/oracle/private_execution.d.ts +3 -22
  41. package/dest/contract_function_simulator/oracle/private_execution.d.ts.map +1 -1
  42. package/dest/contract_function_simulator/oracle/private_execution.js +5 -49
  43. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +60 -84
  44. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  45. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +125 -98
  46. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +128 -70
  47. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  48. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +330 -143
  49. package/dest/contract_function_simulator/pick_notes.d.ts +1 -1
  50. package/dest/contract_function_simulator/pick_notes.d.ts.map +1 -1
  51. package/dest/contract_function_simulator/pick_notes.js +20 -3
  52. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts +1 -1
  53. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts.map +1 -1
  54. package/dest/contract_function_simulator/proxied_contract_data_source.js +3 -0
  55. package/dest/contract_logging.d.ts +27 -0
  56. package/dest/contract_logging.d.ts.map +1 -0
  57. package/dest/contract_logging.js +38 -0
  58. package/dest/contract_sync/contract_sync_service.d.ts +44 -0
  59. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -0
  60. package/dest/contract_sync/contract_sync_service.js +116 -0
  61. package/dest/contract_sync/helpers.d.ts +28 -0
  62. package/dest/contract_sync/helpers.d.ts.map +1 -0
  63. package/dest/contract_sync/helpers.js +60 -0
  64. package/dest/debug/pxe_debug_utils.d.ts +24 -10
  65. package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
  66. package/dest/debug/pxe_debug_utils.js +28 -18
  67. package/dest/entrypoints/client/bundle/index.d.ts +3 -1
  68. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  69. package/dest/entrypoints/client/bundle/index.js +2 -0
  70. package/dest/entrypoints/client/bundle/utils.d.ts +2 -2
  71. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  72. package/dest/entrypoints/client/bundle/utils.js +23 -9
  73. package/dest/entrypoints/client/lazy/index.d.ts +3 -1
  74. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  75. package/dest/entrypoints/client/lazy/index.js +2 -0
  76. package/dest/entrypoints/client/lazy/utils.d.ts +3 -3
  77. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  78. package/dest/entrypoints/client/lazy/utils.js +24 -10
  79. package/dest/entrypoints/pxe_creation_options.d.ts +5 -2
  80. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
  81. package/dest/entrypoints/pxe_creation_options.js +3 -1
  82. package/dest/entrypoints/server/index.d.ts +4 -2
  83. package/dest/entrypoints/server/index.d.ts.map +1 -1
  84. package/dest/entrypoints/server/index.js +3 -1
  85. package/dest/entrypoints/server/utils.d.ts +2 -2
  86. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  87. package/dest/entrypoints/server/utils.js +30 -11
  88. package/dest/events/event_service.d.ts +6 -6
  89. package/dest/events/event_service.d.ts.map +1 -1
  90. package/dest/events/event_service.js +31 -11
  91. package/dest/events/private_event_filter_validator.d.ts +3 -2
  92. package/dest/events/private_event_filter_validator.d.ts.map +1 -1
  93. package/dest/events/private_event_filter_validator.js +15 -0
  94. package/dest/job_coordinator/job_coordinator.d.ts +3 -2
  95. package/dest/job_coordinator/job_coordinator.d.ts.map +1 -1
  96. package/dest/job_coordinator/job_coordinator.js +3 -2
  97. package/dest/logs/log_service.d.ts +10 -9
  98. package/dest/logs/log_service.d.ts.map +1 -1
  99. package/dest/logs/log_service.js +41 -62
  100. package/dest/messages/message_context_service.d.ts +17 -0
  101. package/dest/messages/message_context_service.d.ts.map +1 -0
  102. package/dest/messages/message_context_service.js +36 -0
  103. package/dest/notes/note_service.d.ts +7 -8
  104. package/dest/notes/note_service.d.ts.map +1 -1
  105. package/dest/notes/note_service.js +23 -15
  106. package/dest/notes_filter.d.ts +24 -0
  107. package/dest/notes_filter.d.ts.map +1 -0
  108. package/dest/notes_filter.js +4 -0
  109. package/dest/oracle_version.d.ts +4 -3
  110. package/dest/oracle_version.d.ts.map +1 -1
  111. package/dest/oracle_version.js +20 -10
  112. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
  113. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
  114. package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
  115. package/dest/private_kernel/hints/index.d.ts +1 -1
  116. package/dest/private_kernel/hints/index.js +1 -1
  117. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +4 -3
  118. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -1
  119. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.js +129 -68
  120. package/dest/private_kernel/hints/test_utils.d.ts +122 -0
  121. package/dest/private_kernel/hints/test_utils.d.ts.map +1 -0
  122. package/dest/private_kernel/hints/test_utils.js +203 -0
  123. package/dest/private_kernel/private_kernel_execution_prover.d.ts +3 -2
  124. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  125. package/dest/private_kernel/private_kernel_execution_prover.js +20 -15
  126. package/dest/private_kernel/private_kernel_oracle.d.ts +10 -6
  127. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
  128. package/dest/private_kernel/private_kernel_oracle.js +19 -18
  129. package/dest/pxe.d.ts +85 -24
  130. package/dest/pxe.d.ts.map +1 -1
  131. package/dest/pxe.js +169 -87
  132. package/dest/storage/address_store/address_store.d.ts +1 -1
  133. package/dest/storage/address_store/address_store.d.ts.map +1 -1
  134. package/dest/storage/address_store/address_store.js +12 -11
  135. package/dest/storage/anchor_block_store/anchor_block_store.d.ts +9 -1
  136. package/dest/storage/anchor_block_store/anchor_block_store.d.ts.map +1 -1
  137. package/dest/storage/anchor_block_store/anchor_block_store.js +9 -2
  138. package/dest/storage/capsule_store/capsule_service.d.ts +21 -0
  139. package/dest/storage/capsule_store/capsule_service.d.ts.map +1 -0
  140. package/dest/storage/capsule_store/capsule_service.js +50 -0
  141. package/dest/storage/capsule_store/capsule_store.d.ts +9 -9
  142. package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -1
  143. package/dest/storage/capsule_store/capsule_store.js +42 -36
  144. package/dest/storage/capsule_store/index.d.ts +2 -1
  145. package/dest/storage/capsule_store/index.d.ts.map +1 -1
  146. package/dest/storage/capsule_store/index.js +1 -0
  147. package/dest/storage/contract_store/contract_store.d.ts +42 -16
  148. package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
  149. package/dest/storage/contract_store/contract_store.js +160 -85
  150. package/dest/storage/metadata.d.ts +1 -1
  151. package/dest/storage/metadata.js +1 -1
  152. package/dest/storage/note_store/note_store.d.ts +14 -4
  153. package/dest/storage/note_store/note_store.d.ts.map +1 -1
  154. package/dest/storage/note_store/note_store.js +149 -109
  155. package/dest/storage/private_event_store/private_event_store.d.ts +1 -1
  156. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
  157. package/dest/storage/private_event_store/private_event_store.js +87 -61
  158. package/dest/storage/private_event_store/stored_private_event.d.ts +4 -4
  159. package/dest/storage/private_event_store/stored_private_event.d.ts.map +1 -1
  160. package/dest/storage/private_event_store/stored_private_event.js +2 -2
  161. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +6 -6
  162. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
  163. package/dest/storage/tagging_store/recipient_tagging_store.js +31 -19
  164. package/dest/storage/tagging_store/sender_address_book_store.d.ts +1 -1
  165. package/dest/storage/tagging_store/sender_address_book_store.d.ts.map +1 -1
  166. package/dest/storage/tagging_store/sender_address_book_store.js +20 -14
  167. package/dest/storage/tagging_store/sender_tagging_store.d.ts +29 -28
  168. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
  169. package/dest/storage/tagging_store/sender_tagging_store.js +233 -137
  170. package/dest/tagging/get_all_logs_by_tags.d.ts +4 -4
  171. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -1
  172. package/dest/tagging/get_all_logs_by_tags.js +17 -3
  173. package/dest/tagging/index.d.ts +3 -3
  174. package/dest/tagging/index.d.ts.map +1 -1
  175. package/dest/tagging/index.js +1 -1
  176. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +5 -6
  177. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +1 -1
  178. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +8 -22
  179. package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +2 -2
  180. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +7 -8
  181. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +1 -1
  182. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +12 -11
  183. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +5 -9
  184. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
  185. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +13 -7
  186. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +4 -3
  187. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -1
  188. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +20 -10
  189. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +6 -8
  190. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -1
  191. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +36 -24
  192. package/package.json +25 -16
  193. package/src/bin/check_oracle_version.ts +5 -4
  194. package/src/block_synchronizer/block_synchronizer.ts +45 -21
  195. package/src/config/index.ts +3 -9
  196. package/src/config/package_info.ts +1 -1
  197. package/src/contract_function_simulator/contract_function_simulator.ts +366 -136
  198. package/src/contract_function_simulator/ephemeral_array_service.ts +110 -0
  199. package/src/contract_function_simulator/execution_tagging_index_cache.ts +19 -14
  200. package/src/contract_function_simulator/index.ts +1 -0
  201. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +10 -10
  202. package/src/contract_function_simulator/noir-structs/log_retrieval_request.ts +1 -1
  203. package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +2 -5
  204. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +5 -11
  205. package/src/contract_function_simulator/oracle/interfaces.ts +90 -62
  206. package/src/contract_function_simulator/oracle/legacy_oracle_mappings.ts +104 -0
  207. package/src/contract_function_simulator/oracle/oracle.ts +391 -150
  208. package/src/contract_function_simulator/oracle/private_execution.ts +5 -83
  209. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +160 -193
  210. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +552 -179
  211. package/src/contract_function_simulator/pick_notes.ts +22 -3
  212. package/src/contract_function_simulator/proxied_contract_data_source.ts +8 -1
  213. package/src/contract_logging.ts +52 -0
  214. package/src/contract_sync/contract_sync_service.ts +176 -0
  215. package/src/contract_sync/helpers.ts +98 -0
  216. package/src/debug/pxe_debug_utils.ts +63 -19
  217. package/src/entrypoints/client/bundle/index.ts +2 -0
  218. package/src/entrypoints/client/bundle/utils.ts +18 -18
  219. package/src/entrypoints/client/lazy/index.ts +2 -0
  220. package/src/entrypoints/client/lazy/utils.ts +19 -18
  221. package/src/entrypoints/pxe_creation_options.ts +9 -1
  222. package/src/entrypoints/server/index.ts +3 -1
  223. package/src/entrypoints/server/utils.ts +24 -29
  224. package/src/events/event_service.ts +35 -12
  225. package/src/events/private_event_filter_validator.ts +21 -1
  226. package/src/job_coordinator/job_coordinator.ts +4 -3
  227. package/src/logs/log_service.ts +77 -106
  228. package/src/messages/message_context_service.ts +44 -0
  229. package/src/notes/note_service.ts +25 -17
  230. package/src/notes_filter.ts +24 -0
  231. package/src/oracle_version.ts +20 -10
  232. package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
  233. package/src/private_kernel/hints/index.ts +1 -1
  234. package/src/private_kernel/hints/private_kernel_reset_private_inputs_builder.ts +164 -117
  235. package/src/private_kernel/hints/test_utils.ts +325 -0
  236. package/src/private_kernel/private_kernel_execution_prover.ts +24 -19
  237. package/src/private_kernel/private_kernel_oracle.ts +21 -21
  238. package/src/pxe.ts +318 -144
  239. package/src/storage/address_store/address_store.ts +15 -15
  240. package/src/storage/anchor_block_store/anchor_block_store.ts +9 -1
  241. package/src/storage/capsule_store/capsule_service.ts +90 -0
  242. package/src/storage/capsule_store/capsule_store.ts +52 -34
  243. package/src/storage/capsule_store/index.ts +1 -0
  244. package/src/storage/contract_store/contract_store.ts +193 -101
  245. package/src/storage/metadata.ts +1 -1
  246. package/src/storage/note_store/note_store.ts +168 -134
  247. package/src/storage/private_event_store/private_event_store.ts +106 -81
  248. package/src/storage/private_event_store/stored_private_event.ts +3 -3
  249. package/src/storage/tagging_store/recipient_tagging_store.ts +38 -24
  250. package/src/storage/tagging_store/sender_address_book_store.ts +20 -14
  251. package/src/storage/tagging_store/sender_tagging_store.ts +287 -156
  252. package/src/tagging/get_all_logs_by_tags.ts +31 -7
  253. package/src/tagging/index.ts +2 -2
  254. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +14 -27
  255. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +2 -2
  256. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +12 -17
  257. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +25 -12
  258. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +26 -11
  259. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +30 -29
  260. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
  261. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
@@ -1,9 +1,9 @@
1
1
  import type { FUNCTION_TREE_HEIGHT } from '@aztec/constants';
2
- import type { Fr } from '@aztec/foundation/curves/bn254';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
3
  import { toArray } from '@aztec/foundation/iterable';
4
+ import { BufferReader, numToUInt8, serializeToBuffer } from '@aztec/foundation/serialize';
4
5
  import type { MembershipWitness } from '@aztec/foundation/trees';
5
6
  import type { AztecAsyncKVStore, AztecAsyncMap } from '@aztec/kv-store';
6
- import { isProtocolContract } from '@aztec/protocol-contracts';
7
7
  import {
8
8
  type ContractArtifact,
9
9
  type FunctionAbi,
@@ -20,7 +20,8 @@ import {
20
20
  } from '@aztec/stdlib/abi';
21
21
  import { AztecAddress } from '@aztec/stdlib/aztec-address';
22
22
  import {
23
- type ContractClass,
23
+ type ContractClassIdPreimage,
24
+ type ContractClassWithId,
24
25
  type ContractInstanceWithAddress,
25
26
  SerializableContractInstance,
26
27
  getContractClassFromArtifact,
@@ -28,6 +29,68 @@ import {
28
29
 
29
30
  import { PrivateFunctionsTree } from './private_functions_tree.js';
30
31
 
32
+ const VERSION = 1 as const;
33
+
34
+ /**
35
+ * All contract class data except the large packedBytecode.
36
+ * The expensive data from the ContractClass is precomputed and stored in this format to avoid redundant hashing.
37
+ * Since we have to store the artifacts anyway, the final ContractClass is reconstructed by combining this data
38
+ * with the packedBytecode obtained from the former. That way we can have quick class lookups without wasted storage.
39
+ */
40
+ export class SerializableContractClassData {
41
+ public readonly version = VERSION;
42
+ public readonly id: Fr;
43
+ public readonly artifactHash: Fr;
44
+ public readonly privateFunctionsRoot: Fr;
45
+ public readonly publicBytecodeCommitment: Fr;
46
+ public readonly privateFunctions: { selector: FunctionSelector; vkHash: Fr }[];
47
+
48
+ constructor(
49
+ data: ContractClassIdPreimage & {
50
+ id: Fr;
51
+ privateFunctions: { selector: FunctionSelector; vkHash: Fr }[];
52
+ },
53
+ ) {
54
+ this.id = data.id;
55
+ this.artifactHash = data.artifactHash;
56
+ this.privateFunctionsRoot = data.privateFunctionsRoot;
57
+ this.publicBytecodeCommitment = data.publicBytecodeCommitment;
58
+ this.privateFunctions = data.privateFunctions;
59
+ }
60
+
61
+ toBuffer(): Buffer {
62
+ return serializeToBuffer(
63
+ numToUInt8(this.version),
64
+ this.id,
65
+ this.artifactHash,
66
+ this.privateFunctionsRoot,
67
+ this.publicBytecodeCommitment,
68
+ this.privateFunctions.length,
69
+ ...this.privateFunctions.map(fn => serializeToBuffer(fn.selector, fn.vkHash)),
70
+ );
71
+ }
72
+
73
+ static fromBuffer(bufferOrReader: Buffer | BufferReader): SerializableContractClassData {
74
+ const reader = BufferReader.asReader(bufferOrReader);
75
+ const version = reader.readUInt8();
76
+ if (version !== VERSION) {
77
+ throw new Error(`Unexpected contract class data version ${version}`);
78
+ }
79
+ return new SerializableContractClassData({
80
+ id: reader.readObject(Fr),
81
+ artifactHash: reader.readObject(Fr),
82
+ privateFunctionsRoot: reader.readObject(Fr),
83
+ publicBytecodeCommitment: reader.readObject(Fr),
84
+ privateFunctions: reader.readVector({
85
+ fromBuffer: (r: BufferReader) => ({
86
+ selector: r.readObject(FunctionSelector),
87
+ vkHash: r.readObject(Fr),
88
+ }),
89
+ }),
90
+ });
91
+ }
92
+ }
93
+
31
94
  /**
32
95
  * ContractStore serves as a data manager and retriever for Aztec.nr contracts.
33
96
  * It provides methods to obtain contract addresses, function ABI, bytecode, and membership witnesses
@@ -40,71 +103,95 @@ export class ContractStore {
40
103
  // TODO: Update it to be LRU cache so that it doesn't keep all the data all the time.
41
104
  #privateFunctionTrees: Map<string, PrivateFunctionsTree> = new Map();
42
105
 
43
- /** Map from contract address to contract class id */
106
+ /**
107
+ * In-memory cache of deserialized ContractArtifact objects, keyed by class id string.
108
+ * Avoids repeated LMDB reads + JSON.parse + Zod validation on every oracle call.
109
+ * Artifacts are large but immutable after registration — safe to cache for the lifetime of the store.
110
+ */
111
+ // TODO: Update it to be LRU cache so that it doesn't keep all the data all the time.
112
+ #contractArtifactCache: Map<string, ContractArtifact> = new Map();
113
+
114
+ /** Map from contract address to contract class id (avoids KV round-trip on hot path). */
44
115
  #contractClassIdMap: Map<string, Fr> = new Map();
45
116
 
117
+ #store: AztecAsyncKVStore;
46
118
  #contractArtifacts: AztecAsyncMap<string, Buffer>;
119
+ #contractClassData: AztecAsyncMap<string, Buffer>;
47
120
  #contractInstances: AztecAsyncMap<string, Buffer>;
48
121
 
49
122
  constructor(store: AztecAsyncKVStore) {
123
+ this.#store = store;
50
124
  this.#contractArtifacts = store.openMap('contract_artifacts');
125
+ this.#contractClassData = store.openMap('contract_classes');
51
126
  this.#contractInstances = store.openMap('contracts_instances');
52
127
  }
53
128
 
54
129
  // Setters
55
130
 
56
- public async addContractArtifact(id: Fr, contract: ContractArtifact): Promise<void> {
131
+ /**
132
+ * Registers a new contract artifact and its corresponding class data.
133
+ * IMPORTANT: This method does not verify that the provided artifact matches the class data or that the class id matches the artifact.
134
+ * It is the caller's responsibility to ensure the consistency and correctness of the provided data.
135
+ * This is done to avoid redundant, expensive contract class computations
136
+ */
137
+ public async addContractArtifact(
138
+ contract: ContractArtifact,
139
+ contractClassWithIdAndPreimage?: ContractClassWithId & ContractClassIdPreimage,
140
+ ): Promise<Fr> {
141
+ const contractClass = contractClassWithIdAndPreimage ?? (await getContractClassFromArtifact(contract));
142
+ const key = contractClass.id.toString();
143
+
144
+ if (this.#contractArtifactCache.has(key)) {
145
+ return contractClass.id;
146
+ }
147
+
57
148
  const privateFunctions = contract.functions.filter(
58
149
  functionArtifact => functionArtifact.functionType === FunctionType.PRIVATE,
59
150
  );
60
-
61
151
  const privateSelectors = await Promise.all(
62
- privateFunctions.map(async privateFunctionArtifact =>
63
- (
64
- await FunctionSelector.fromNameAndParameters(privateFunctionArtifact.name, privateFunctionArtifact.parameters)
65
- ).toString(),
152
+ privateFunctions.map(async fn =>
153
+ (await FunctionSelector.fromNameAndParameters(fn.name, fn.parameters)).toString(),
66
154
  ),
67
155
  );
68
-
69
156
  if (privateSelectors.length !== new Set(privateSelectors).size) {
70
157
  throw new Error('Repeated function selectors of private functions');
71
158
  }
72
159
 
73
- await this.#contractArtifacts.set(id.toString(), contractArtifactToBuffer(contract));
160
+ this.#contractArtifactCache.set(key, contract);
161
+
162
+ await this.#store.transactionAsync(async () => {
163
+ await this.#contractArtifacts.set(key, contractArtifactToBuffer(contract));
164
+ await this.#contractClassData.set(key, new SerializableContractClassData(contractClass).toBuffer());
165
+ });
166
+
167
+ return contractClass.id;
74
168
  }
75
169
 
76
170
  async addContractInstance(contract: ContractInstanceWithAddress): Promise<void> {
77
- this.#contractClassIdMap.set(contract.address.toString(), contract.currentContractClassId);
171
+ await this.#store.transactionAsync(async () => {
172
+ await this.#contractInstances.set(
173
+ contract.address.toString(),
174
+ new SerializableContractInstance(contract).toBuffer(),
175
+ );
176
+ });
78
177
 
79
- await this.#contractInstances.set(
80
- contract.address.toString(),
81
- new SerializableContractInstance(contract).toBuffer(),
82
- );
178
+ this.#contractClassIdMap.set(contract.address.toString(), contract.currentContractClassId);
83
179
  }
84
180
 
85
181
  // Private getters
86
182
 
87
183
  async #getContractClassId(contractAddress: AztecAddress): Promise<Fr | undefined> {
88
- if (!this.#contractClassIdMap.has(contractAddress.toString())) {
184
+ const key = contractAddress.toString();
185
+ if (!this.#contractClassIdMap.has(key)) {
89
186
  const instance = await this.getContractInstance(contractAddress);
90
187
  if (!instance) {
91
188
  return;
92
189
  }
93
- this.#contractClassIdMap.set(contractAddress.toString(), instance.currentContractClassId);
190
+ this.#contractClassIdMap.set(key, instance.currentContractClassId);
94
191
  }
95
- return this.#contractClassIdMap.get(contractAddress.toString());
192
+ return this.#contractClassIdMap.get(key);
96
193
  }
97
194
 
98
- /**
99
- * Retrieve or create a ContractTree instance based on the provided class id.
100
- * If an existing tree with the same class id is found in the cache, it will be returned.
101
- * Otherwise, a new ContractTree instance will be created using the contract data from the database
102
- * and added to the cache before returning.
103
- *
104
- * @param classId - The class id of the contract for which the ContractTree is required.
105
- * @returns A ContractTree instance associated with the specified contract address.
106
- * @throws An Error if the contract is not found in the ContractDatabase.
107
- */
108
195
  async #getPrivateFunctionTreeForClassId(classId: Fr): Promise<PrivateFunctionsTree | undefined> {
109
196
  if (!this.#privateFunctionTrees.has(classId.toString())) {
110
197
  const artifact = await this.getContractArtifact(classId);
@@ -117,34 +204,61 @@ export class ContractStore {
117
204
  return this.#privateFunctionTrees.get(classId.toString())!;
118
205
  }
119
206
 
120
- async #getContractArtifactByAddress(contractAddress: AztecAddress): Promise<ContractArtifact | undefined> {
121
- const contractClassId = await this.#getContractClassId(contractAddress);
122
- return contractClassId && this.getContractArtifact(contractClassId);
207
+ async #getArtifactByAddress(contractAddress: AztecAddress): Promise<ContractArtifact | undefined> {
208
+ const classId = await this.#getContractClassId(contractAddress);
209
+ return classId && this.getContractArtifact(classId);
123
210
  }
124
211
 
125
212
  // Public getters
126
213
 
127
- async getContractsAddresses(): Promise<AztecAddress[]> {
128
- const keys = await toArray(this.#contractInstances.keysAsync());
129
- return keys.map(AztecAddress.fromString);
214
+ getContractsAddresses(): Promise<AztecAddress[]> {
215
+ return this.#store.transactionAsync(async () => {
216
+ const keys = await toArray(this.#contractInstances.keysAsync());
217
+ return keys.map(AztecAddress.fromString);
218
+ });
130
219
  }
131
220
 
132
- /** Returns a contract instance for a given address. Throws if not found. */
133
- public async getContractInstance(contractAddress: AztecAddress): Promise<ContractInstanceWithAddress | undefined> {
134
- const contract = await this.#contractInstances.getAsync(contractAddress.toString());
135
- return contract && SerializableContractInstance.fromBuffer(contract).withAddress(contractAddress);
221
+ /** Returns a contract instance for a given address. */
222
+ public getContractInstance(contractAddress: AztecAddress): Promise<ContractInstanceWithAddress | undefined> {
223
+ return this.#store.transactionAsync(async () => {
224
+ const contract = await this.#contractInstances.getAsync(contractAddress.toString());
225
+ return contract && SerializableContractInstance.fromBuffer(contract).withAddress(contractAddress);
226
+ });
136
227
  }
137
228
 
229
+ /** Returns the raw contract artifact for a given class id. */
138
230
  public async getContractArtifact(contractClassId: Fr): Promise<ContractArtifact | undefined> {
139
- const contract = await this.#contractArtifacts.getAsync(contractClassId.toString());
140
- // TODO(@spalladino): AztecAsyncMap lies and returns Uint8Arrays instead of Buffers, hence the extra Buffer.from.
141
- return contract && contractArtifactFromBuffer(Buffer.from(contract));
231
+ const key = contractClassId.toString();
232
+ const cached = this.#contractArtifactCache.get(key);
233
+ if (cached) {
234
+ return cached;
235
+ }
236
+ const artifact = await this.#store.transactionAsync(async () => {
237
+ const buf = await this.#contractArtifacts.getAsync(key);
238
+ return buf && contractArtifactFromBuffer(buf);
239
+ });
240
+ if (artifact) {
241
+ this.#contractArtifactCache.set(key, artifact);
242
+ }
243
+ return artifact;
142
244
  }
143
245
 
144
- /** Returns a contract class for a given class id. Throws if not found. */
145
- public async getContractClass(contractClassId: Fr): Promise<ContractClass | undefined> {
246
+ /** Returns a contract class for a given class id. */
247
+ public async getContractClassWithPreimage(
248
+ contractClassId: Fr,
249
+ ): Promise<(ContractClassWithId & ContractClassIdPreimage) | undefined> {
250
+ const key = contractClassId.toString();
251
+ const buf = await this.#store.transactionAsync(() => this.#contractClassData.getAsync(key));
252
+ if (!buf) {
253
+ return undefined;
254
+ }
255
+ const classData = SerializableContractClassData.fromBuffer(buf);
146
256
  const artifact = await this.getContractArtifact(contractClassId);
147
- return artifact && getContractClassFromArtifact(artifact);
257
+ if (!artifact) {
258
+ return undefined;
259
+ }
260
+ const packedBytecode = artifact.functions.find(f => f.name === 'public_dispatch')?.bytecode ?? Buffer.alloc(0);
261
+ return { ...classData, packedBytecode };
148
262
  }
149
263
 
150
264
  public async getContract(
@@ -163,8 +277,6 @@ export class ContractStore {
163
277
 
164
278
  /**
165
279
  * Retrieves the artifact of a specified function within a given contract.
166
- * The function is identified by its selector, which is a unique code generated from the function's signature.
167
- * Throws an error if the contract address or function selector are invalid or not found.
168
280
  *
169
281
  * @param contractAddress - The AztecAddress representing the contract containing the function.
170
282
  * @param selector - The function selector.
@@ -174,9 +286,12 @@ export class ContractStore {
174
286
  contractAddress: AztecAddress,
175
287
  selector: FunctionSelector,
176
288
  ): Promise<FunctionArtifactWithContractName | undefined> {
177
- const artifact = await this.#getContractArtifactByAddress(contractAddress);
178
- const fnArtifact = artifact && (await this.#findFunctionArtifactBySelector(artifact, selector));
179
- return fnArtifact && { ...fnArtifact, contractName: artifact.name };
289
+ const artifact = await this.#getArtifactByAddress(contractAddress);
290
+ if (!artifact) {
291
+ return undefined;
292
+ }
293
+ const fn = await this.#findFunctionArtifactBySelector(artifact, selector);
294
+ return fn && { ...fn, contractName: artifact.name };
180
295
  }
181
296
 
182
297
  public async getFunctionArtifactWithDebugMetadata(
@@ -197,50 +312,48 @@ export class ContractStore {
197
312
  public async getPublicFunctionArtifact(
198
313
  contractAddress: AztecAddress,
199
314
  ): Promise<FunctionArtifactWithContractName | undefined> {
200
- const artifact = await this.#getContractArtifactByAddress(contractAddress);
201
- const fnArtifact = artifact && artifact.functions.find(fn => fn.functionType === FunctionType.PUBLIC);
202
- return fnArtifact && { ...fnArtifact, contractName: artifact.name };
315
+ const artifact = await this.#getArtifactByAddress(contractAddress);
316
+ const fn = artifact && artifact.functions.find(f => f.functionType === FunctionType.PUBLIC);
317
+ return fn && { ...fn, contractName: artifact.name };
203
318
  }
204
319
 
205
320
  public async getFunctionAbi(
206
321
  contractAddress: AztecAddress,
207
322
  selector: FunctionSelector,
208
323
  ): Promise<FunctionAbi | undefined> {
209
- const artifact = await this.#getContractArtifactByAddress(contractAddress);
324
+ const artifact = await this.#getArtifactByAddress(contractAddress);
210
325
  return artifact && (await this.#findFunctionAbiBySelector(artifact, selector));
211
326
  }
212
327
 
213
328
  /**
214
329
  * Retrieves the debug metadata of a specified function within a given contract.
215
- * The function is identified by its selector, which is a unique code generated from the function's signature.
216
- * Returns undefined if the debug metadata for the given function is not found.
217
- * Throws if the contract has not been added to the database.
218
330
  *
219
331
  * @param contractAddress - The AztecAddress representing the contract containing the function.
220
332
  * @param selector - The function selector.
221
- * @returns The corresponding function's artifact as an object.
333
+ * @returns The corresponding function's debug metadata, or undefined.
222
334
  */
223
335
  public async getFunctionDebugMetadata(
224
336
  contractAddress: AztecAddress,
225
337
  selector: FunctionSelector,
226
338
  ): Promise<FunctionDebugMetadata | undefined> {
227
- const artifact = await this.#getContractArtifactByAddress(contractAddress);
228
- const fnArtifact = artifact && (await this.#findFunctionArtifactBySelector(artifact, selector));
229
- return fnArtifact && getFunctionDebugMetadata(artifact, fnArtifact);
339
+ const artifact = await this.#getArtifactByAddress(contractAddress);
340
+ if (!artifact) {
341
+ return undefined;
342
+ }
343
+ const fn = await this.#findFunctionArtifactBySelector(artifact, selector);
344
+ return fn && getFunctionDebugMetadata(artifact, fn);
230
345
  }
231
346
 
232
347
  public async getPublicFunctionDebugMetadata(
233
348
  contractAddress: AztecAddress,
234
349
  ): Promise<FunctionDebugMetadata | undefined> {
235
- const artifact = await this.#getContractArtifactByAddress(contractAddress);
236
- const fnArtifact = artifact && artifact.functions.find(fn => fn.functionType === FunctionType.PUBLIC);
237
- return fnArtifact && getFunctionDebugMetadata(artifact, fnArtifact);
350
+ const artifact = await this.#getArtifactByAddress(contractAddress);
351
+ const fn = artifact && artifact.functions.find(f => f.functionType === FunctionType.PUBLIC);
352
+ return fn && getFunctionDebugMetadata(artifact, fn);
238
353
  }
239
354
 
240
355
  /**
241
356
  * Retrieve the function membership witness for the given contract class and function selector.
242
- * The function membership witness represents a proof that the function belongs to the specified contract.
243
- * Throws an error if the contract address or function selector is unknown.
244
357
  *
245
358
  * @param contractClassId - The id of the class.
246
359
  * @param selector - The function selector.
@@ -255,23 +368,21 @@ export class ContractStore {
255
368
  }
256
369
 
257
370
  public async getDebugContractName(contractAddress: AztecAddress) {
258
- const artifact = await this.#getContractArtifactByAddress(contractAddress);
371
+ const artifact = await this.#getArtifactByAddress(contractAddress);
259
372
  return artifact?.name;
260
373
  }
261
374
 
262
375
  public async getDebugFunctionName(contractAddress: AztecAddress, selector: FunctionSelector) {
263
- const artifact = await this.#getContractArtifactByAddress(contractAddress);
264
- const fnArtifact = artifact && (await this.#findFunctionAbiBySelector(artifact, selector));
265
- return `${artifact?.name ?? contractAddress}:${fnArtifact?.name ?? selector}`;
376
+ const artifact = await this.#getArtifactByAddress(contractAddress);
377
+ const fn = artifact && (await this.#findFunctionAbiBySelector(artifact, selector));
378
+ return `${artifact?.name ?? contractAddress}:${fn?.name ?? selector}`;
266
379
  }
267
380
 
268
381
  async #findFunctionArtifactBySelector(
269
382
  artifact: ContractArtifact,
270
383
  selector: FunctionSelector,
271
384
  ): Promise<FunctionArtifact | undefined> {
272
- const functions = artifact.functions;
273
- for (let i = 0; i < functions.length; i++) {
274
- const fn = functions[i];
385
+ for (const fn of artifact.functions) {
275
386
  const fnSelector = await FunctionSelector.fromNameAndParameters(fn.name, fn.parameters);
276
387
  if (fnSelector.equals(selector)) {
277
388
  return fn;
@@ -283,9 +394,7 @@ export class ContractStore {
283
394
  artifact: ContractArtifact,
284
395
  selector: FunctionSelector,
285
396
  ): Promise<FunctionAbi | undefined> {
286
- const functions = [...artifact.functions, ...(artifact.nonDispatchPublicFunctions ?? [])];
287
- for (let i = 0; i < functions.length; i++) {
288
- const fn = functions[i];
397
+ for (const fn of [...artifact.functions, ...(artifact.nonDispatchPublicFunctions ?? [])]) {
289
398
  const fnSelector = await FunctionSelector.fromNameAndParameters(fn.name, fn.parameters);
290
399
  if (fnSelector.equals(selector)) {
291
400
  return fn;
@@ -306,34 +415,17 @@ export class ContractStore {
306
415
  throw new Error(`Unknown function ${functionName} in contract ${contract.name}.`);
307
416
  }
308
417
 
309
- return {
418
+ const selector = await FunctionSelector.fromNameAndParameters(functionDao.name, functionDao.parameters);
419
+
420
+ return FunctionCall.from({
310
421
  name: functionDao.name,
311
- args: encodeArguments(functionDao, args),
312
- selector: await FunctionSelector.fromNameAndParameters(functionDao.name, functionDao.parameters),
313
- type: functionDao.functionType,
314
422
  to,
423
+ selector,
424
+ type: functionDao.functionType,
315
425
  hideMsgSender: false,
316
426
  isStatic: functionDao.isStatic,
427
+ args: encodeArguments(functionDao, args),
317
428
  returnTypes: functionDao.returnTypes,
318
- };
319
- }
320
-
321
- // Synchronize target contract data
322
- public async syncPrivateState(
323
- contractAddress: AztecAddress,
324
- functionToInvokeAfterSync: FunctionSelector | null,
325
- utilityExecutor: (privateSyncCall: FunctionCall) => Promise<any>,
326
- ) {
327
- // Protocol contracts don't have private state to sync
328
- if (!isProtocolContract(contractAddress)) {
329
- const syncPrivateStateFunctionCall = await this.getFunctionCall('sync_private_state', [], contractAddress);
330
- if (functionToInvokeAfterSync && functionToInvokeAfterSync.equals(syncPrivateStateFunctionCall.selector)) {
331
- throw new Error(
332
- 'Forbidden `sync_private_state` invocation. `sync_private_state` can only be invoked by PXE, manual execution can lead to inconsistencies.',
333
- );
334
- }
335
-
336
- return utilityExecutor(syncPrivateStateFunctionCall);
337
- }
429
+ });
338
430
  }
339
431
  }
@@ -1 +1 @@
1
- export const PXE_DATA_SCHEMA_VERSION = 2;
1
+ export const PXE_DATA_SCHEMA_VERSION = 5;