@aztec/aztec.js 0.0.0-test.1 → 0.0.1-commit.b655e406

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 (392) hide show
  1. package/README.md +1 -1
  2. package/dest/account/account.d.ts +60 -0
  3. package/dest/account/account.d.ts.map +1 -0
  4. package/dest/account/account.js +59 -0
  5. package/dest/account/{contract.d.ts → account_contract.d.ts} +16 -10
  6. package/dest/account/account_contract.d.ts.map +1 -0
  7. package/dest/account/{contract.js → account_contract.js} +7 -4
  8. package/dest/{wallet/account_wallet_with_private_key.d.ts → account/account_with_secret_key.d.ts} +7 -8
  9. package/dest/account/account_with_secret_key.d.ts.map +1 -0
  10. package/dest/{wallet/account_wallet_with_private_key.js → account/account_with_secret_key.js} +5 -5
  11. package/dest/account/index.d.ts +3 -7
  12. package/dest/account/index.d.ts.map +1 -1
  13. package/dest/account/index.js +2 -6
  14. package/dest/account/interface.d.ts +1 -13
  15. package/dest/account/interface.d.ts.map +1 -1
  16. package/dest/account/interface.js +1 -0
  17. package/dest/account/signerless_account.d.ts +24 -0
  18. package/dest/account/signerless_account.d.ts.map +1 -0
  19. package/dest/account/signerless_account.js +27 -0
  20. package/dest/api/abi.d.ts +2 -1
  21. package/dest/api/abi.d.ts.map +1 -1
  22. package/dest/api/abi.js +1 -1
  23. package/dest/api/account.d.ts +5 -2
  24. package/dest/api/account.d.ts.map +1 -1
  25. package/dest/api/account.js +3 -1
  26. package/dest/api/addresses.d.ts +1 -0
  27. package/dest/api/addresses.d.ts.map +1 -1
  28. package/dest/api/addresses.js +1 -0
  29. package/dest/api/authorization.d.ts +5 -0
  30. package/dest/api/authorization.d.ts.map +1 -0
  31. package/dest/api/authorization.js +4 -0
  32. package/dest/api/block.d.ts +3 -0
  33. package/dest/api/block.d.ts.map +1 -0
  34. package/dest/api/block.js +2 -0
  35. package/dest/{contract/index.d.ts → api/contract.d.ts} +15 -11
  36. package/dest/api/contract.d.ts.map +1 -0
  37. package/dest/{contract/index.js → api/contract.js} +14 -10
  38. package/dest/api/crypto.d.ts +2 -0
  39. package/dest/api/crypto.d.ts.map +1 -0
  40. package/dest/api/crypto.js +1 -0
  41. package/dest/api/deployment.d.ts +4 -3
  42. package/dest/api/deployment.d.ts.map +1 -1
  43. package/dest/api/deployment.js +4 -3
  44. package/dest/api/ethereum.d.ts +2 -0
  45. package/dest/api/ethereum.d.ts.map +1 -0
  46. package/dest/api/ethereum.js +1 -0
  47. package/dest/api/events.d.ts +12 -0
  48. package/dest/api/events.d.ts.map +1 -0
  49. package/dest/api/events.js +30 -0
  50. package/dest/api/fee.d.ts +1 -1
  51. package/dest/api/fee.d.ts.map +1 -1
  52. package/dest/api/fee.js +1 -1
  53. package/dest/api/fee_testing.d.ts +2 -0
  54. package/dest/api/fee_testing.d.ts.map +1 -0
  55. package/dest/api/fee_testing.js +1 -0
  56. package/dest/api/keys.d.ts +4 -0
  57. package/dest/api/keys.d.ts.map +1 -0
  58. package/dest/api/keys.js +3 -0
  59. package/dest/api/log.d.ts +1 -0
  60. package/dest/api/log.d.ts.map +1 -1
  61. package/dest/api/log.js +1 -0
  62. package/dest/api/messaging.d.ts +3 -0
  63. package/dest/api/messaging.d.ts.map +1 -0
  64. package/dest/api/messaging.js +2 -0
  65. package/dest/api/node.d.ts +21 -0
  66. package/dest/api/node.d.ts.map +1 -0
  67. package/dest/api/node.js +18 -0
  68. package/dest/api/note.d.ts +2 -0
  69. package/dest/api/note.d.ts.map +1 -0
  70. package/dest/api/note.js +1 -0
  71. package/dest/api/protocol.d.ts +3 -0
  72. package/dest/api/protocol.d.ts.map +1 -0
  73. package/dest/api/protocol.js +2 -0
  74. package/dest/api/trees.d.ts +3 -0
  75. package/dest/api/trees.d.ts.map +1 -0
  76. package/dest/api/trees.js +2 -0
  77. package/dest/api/tx.d.ts +2 -0
  78. package/dest/api/tx.d.ts.map +1 -0
  79. package/dest/api/tx.js +1 -0
  80. package/dest/api/utils.d.ts +13 -0
  81. package/dest/api/utils.d.ts.map +1 -0
  82. package/dest/api/utils.js +12 -0
  83. package/dest/api/wallet.d.ts +4 -1
  84. package/dest/api/wallet.d.ts.map +1 -1
  85. package/dest/api/wallet.js +4 -1
  86. package/dest/authorization/call_authorization_request.d.ts +67 -0
  87. package/dest/authorization/call_authorization_request.d.ts.map +1 -0
  88. package/dest/authorization/call_authorization_request.js +49 -0
  89. package/dest/contract/base_contract_interaction.d.ts +16 -79
  90. package/dest/contract/base_contract_interaction.d.ts.map +1 -1
  91. package/dest/contract/base_contract_interaction.js +15 -128
  92. package/dest/contract/batch_call.d.ts +13 -14
  93. package/dest/contract/batch_call.d.ts.map +1 -1
  94. package/dest/contract/batch_call.js +60 -60
  95. package/dest/contract/checker.d.ts +1 -1
  96. package/dest/contract/checker.d.ts.map +1 -1
  97. package/dest/contract/checker.js +2 -2
  98. package/dest/contract/contract.d.ts +7 -6
  99. package/dest/contract/contract.d.ts.map +1 -1
  100. package/dest/contract/contract.js +7 -16
  101. package/dest/contract/contract_base.d.ts +3 -9
  102. package/dest/contract/contract_base.d.ts.map +1 -1
  103. package/dest/contract/contract_base.js +2 -2
  104. package/dest/contract/contract_function_interaction.d.ts +52 -44
  105. package/dest/contract/contract_function_interaction.d.ts.map +1 -1
  106. package/dest/contract/contract_function_interaction.js +75 -74
  107. package/dest/contract/deploy_method.d.ts +102 -57
  108. package/dest/contract/deploy_method.d.ts.map +1 -1
  109. package/dest/contract/deploy_method.js +122 -132
  110. package/dest/contract/deploy_sent_tx.d.ts +3 -5
  111. package/dest/contract/deploy_sent_tx.d.ts.map +1 -1
  112. package/dest/contract/deploy_sent_tx.js +10 -13
  113. package/dest/contract/get_gas_limits.d.ts +5 -6
  114. package/dest/contract/get_gas_limits.d.ts.map +1 -1
  115. package/dest/contract/get_gas_limits.js +9 -3
  116. package/dest/contract/interaction_options.d.ts +114 -0
  117. package/dest/contract/interaction_options.d.ts.map +1 -0
  118. package/dest/contract/interaction_options.js +52 -0
  119. package/dest/contract/protocol_contracts.d.ts +6 -6
  120. package/dest/contract/protocol_contracts.d.ts.map +1 -1
  121. package/dest/contract/protocol_contracts.js +7 -7
  122. package/dest/contract/sent_tx.d.ts +8 -18
  123. package/dest/contract/sent_tx.d.ts.map +1 -1
  124. package/dest/contract/sent_tx.js +30 -42
  125. package/dest/contract/unsafe_contract.d.ts +1 -1
  126. package/dest/contract/unsafe_contract.d.ts.map +1 -1
  127. package/dest/contract/wait_for_proven.d.ts +17 -0
  128. package/dest/contract/wait_for_proven.d.ts.map +1 -0
  129. package/dest/contract/wait_for_proven.js +17 -0
  130. package/dest/deployment/broadcast_function.d.ts +3 -3
  131. package/dest/deployment/broadcast_function.d.ts.map +1 -1
  132. package/dest/deployment/broadcast_function.js +27 -23
  133. package/dest/deployment/contract_deployer.d.ts +1 -1
  134. package/dest/deployment/contract_deployer.d.ts.map +1 -1
  135. package/dest/deployment/publish_class.d.ts +6 -0
  136. package/dest/deployment/publish_class.d.ts.map +1 -0
  137. package/dest/deployment/publish_class.js +17 -0
  138. package/dest/deployment/publish_instance.d.ts +10 -0
  139. package/dest/deployment/publish_instance.d.ts.map +1 -0
  140. package/dest/deployment/publish_instance.js +11 -0
  141. package/dest/{api/ethereum → ethereum}/portal_manager.d.ts +29 -25
  142. package/dest/ethereum/portal_manager.d.ts.map +1 -0
  143. package/dest/{api/ethereum → ethereum}/portal_manager.js +106 -73
  144. package/dest/fee/fee_juice_payment_method_with_claim.d.ts +16 -11
  145. package/dest/fee/fee_juice_payment_method_with_claim.d.ts.map +1 -1
  146. package/dest/fee/fee_juice_payment_method_with_claim.js +26 -16
  147. package/dest/fee/fee_payment_method.d.ts +11 -7
  148. package/dest/fee/fee_payment_method.d.ts.map +1 -1
  149. package/dest/fee/private_fee_payment_method.d.ts +25 -8
  150. package/dest/fee/private_fee_payment_method.d.ts.map +1 -1
  151. package/dest/fee/private_fee_payment_method.js +43 -21
  152. package/dest/fee/public_fee_payment_method.d.ts +26 -9
  153. package/dest/fee/public_fee_payment_method.d.ts.map +1 -1
  154. package/dest/fee/public_fee_payment_method.js +45 -23
  155. package/dest/fee/sponsored_fee_payment.d.ts +17 -0
  156. package/dest/fee/sponsored_fee_payment.d.ts.map +1 -0
  157. package/dest/fee/sponsored_fee_payment.js +34 -0
  158. package/dest/utils/abi_types.d.ts +0 -2
  159. package/dest/utils/abi_types.d.ts.map +1 -1
  160. package/dest/utils/authwit.d.ts +81 -24
  161. package/dest/utils/authwit.d.ts.map +1 -1
  162. package/dest/utils/authwit.js +226 -40
  163. package/dest/utils/cross_chain.d.ts +24 -0
  164. package/dest/utils/cross_chain.d.ts.map +1 -0
  165. package/dest/utils/cross_chain.js +30 -0
  166. package/dest/utils/fee_juice.d.ts +3 -2
  167. package/dest/utils/fee_juice.d.ts.map +1 -1
  168. package/dest/utils/fee_juice.js +3 -2
  169. package/dest/utils/field_compressed_string.d.ts.map +1 -1
  170. package/dest/utils/node.d.ts.map +1 -1
  171. package/dest/utils/node.js +1 -1
  172. package/dest/utils/pub_key.d.ts.map +1 -1
  173. package/dest/utils/pub_key.js +1 -2
  174. package/dest/wallet/account_entrypoint_meta_payment_method.d.ts +34 -0
  175. package/dest/wallet/account_entrypoint_meta_payment_method.d.ts.map +1 -0
  176. package/dest/wallet/account_entrypoint_meta_payment_method.js +76 -0
  177. package/dest/wallet/account_manager.d.ts +69 -0
  178. package/dest/wallet/account_manager.d.ts.map +1 -0
  179. package/dest/wallet/account_manager.js +113 -0
  180. package/dest/wallet/base_wallet.d.ts +81 -63
  181. package/dest/wallet/base_wallet.d.ts.map +1 -1
  182. package/dest/wallet/base_wallet.js +221 -106
  183. package/dest/wallet/deploy_account_method.d.ts +52 -0
  184. package/dest/wallet/deploy_account_method.d.ts.map +1 -0
  185. package/dest/wallet/deploy_account_method.js +77 -0
  186. package/dest/wallet/index.d.ts +3 -16
  187. package/dest/wallet/index.d.ts.map +1 -1
  188. package/dest/wallet/index.js +3 -20
  189. package/dest/wallet/wallet.d.ts +2478 -0
  190. package/dest/wallet/wallet.d.ts.map +1 -0
  191. package/dest/wallet/wallet.js +202 -0
  192. package/package.json +40 -32
  193. package/src/account/account.ts +97 -0
  194. package/src/account/{contract.ts → account_contract.ts} +24 -13
  195. package/src/{wallet/account_wallet_with_private_key.ts → account/account_with_secret_key.ts} +6 -8
  196. package/src/account/index.ts +3 -7
  197. package/src/account/interface.ts +1 -12
  198. package/src/account/signerless_account.ts +46 -0
  199. package/src/api/abi.ts +26 -0
  200. package/src/api/account.ts +5 -9
  201. package/src/api/addresses.ts +1 -0
  202. package/src/api/authorization.ts +14 -0
  203. package/src/api/block.ts +2 -0
  204. package/src/{contract/index.ts → api/contract.ts} +37 -13
  205. package/src/api/crypto.ts +1 -0
  206. package/src/api/deployment.ts +4 -3
  207. package/src/api/ethereum.ts +10 -0
  208. package/src/api/events.ts +44 -0
  209. package/src/api/fee.ts +1 -1
  210. package/src/api/fee_testing.ts +1 -0
  211. package/src/api/keys.ts +8 -0
  212. package/src/api/log.ts +1 -0
  213. package/src/api/messaging.ts +2 -0
  214. package/src/api/node.ts +20 -0
  215. package/src/api/note.ts +1 -0
  216. package/src/api/protocol.ts +2 -0
  217. package/src/api/trees.ts +2 -0
  218. package/src/api/tx.ts +11 -0
  219. package/src/api/utils.ts +14 -0
  220. package/src/api/wallet.ts +33 -5
  221. package/src/authorization/call_authorization_request.ts +63 -0
  222. package/src/contract/base_contract_interaction.ts +24 -166
  223. package/src/contract/batch_call.ts +81 -49
  224. package/src/contract/checker.ts +8 -3
  225. package/src/contract/contract.ts +8 -17
  226. package/src/contract/contract_base.ts +4 -11
  227. package/src/contract/contract_function_interaction.ts +136 -106
  228. package/src/contract/deploy_method.ts +199 -129
  229. package/src/contract/deploy_sent_tx.ts +9 -15
  230. package/src/contract/get_gas_limits.ts +15 -8
  231. package/src/contract/interaction_options.ts +169 -0
  232. package/src/contract/protocol_contracts.ts +10 -10
  233. package/src/contract/sent_tx.ts +40 -51
  234. package/src/contract/unsafe_contract.ts +1 -1
  235. package/src/contract/wait_for_proven.ts +38 -0
  236. package/src/deployment/broadcast_function.ts +57 -57
  237. package/src/deployment/contract_deployer.ts +1 -1
  238. package/src/deployment/publish_class.ts +34 -0
  239. package/src/deployment/publish_instance.ts +26 -0
  240. package/src/{api/ethereum → ethereum}/portal_manager.ts +120 -74
  241. package/src/fee/fee_juice_payment_method_with_claim.ts +46 -33
  242. package/src/fee/fee_payment_method.ts +11 -7
  243. package/src/fee/private_fee_payment_method.ts +77 -57
  244. package/src/fee/public_fee_payment_method.ts +91 -67
  245. package/src/fee/sponsored_fee_payment.ts +44 -0
  246. package/src/utils/authwit.ts +255 -53
  247. package/src/utils/cross_chain.ts +53 -0
  248. package/src/utils/fee_juice.ts +4 -4
  249. package/src/utils/node.ts +1 -1
  250. package/src/utils/pub_key.ts +1 -2
  251. package/src/wallet/account_entrypoint_meta_payment_method.ts +105 -0
  252. package/src/wallet/account_manager.ts +154 -0
  253. package/src/wallet/base_wallet.ts +295 -143
  254. package/src/wallet/deploy_account_method.ts +125 -0
  255. package/src/wallet/index.ts +3 -33
  256. package/src/wallet/wallet.ts +362 -0
  257. package/dest/account/contract.d.ts.map +0 -1
  258. package/dest/account/wallet.d.ts +0 -11
  259. package/dest/account/wallet.d.ts.map +0 -1
  260. package/dest/account/wallet.js +0 -3
  261. package/dest/account_manager/deploy_account_method.d.ts +0 -15
  262. package/dest/account_manager/deploy_account_method.d.ts.map +0 -1
  263. package/dest/account_manager/deploy_account_method.js +0 -43
  264. package/dest/account_manager/deploy_account_sent_tx.d.ts +0 -30
  265. package/dest/account_manager/deploy_account_sent_tx.d.ts.map +0 -1
  266. package/dest/account_manager/deploy_account_sent_tx.js +0 -29
  267. package/dest/account_manager/index.d.ts +0 -108
  268. package/dest/account_manager/index.d.ts.map +0 -1
  269. package/dest/account_manager/index.js +0 -159
  270. package/dest/api/cheat_codes.d.ts +0 -26
  271. package/dest/api/cheat_codes.d.ts.map +0 -1
  272. package/dest/api/cheat_codes.js +0 -25
  273. package/dest/api/entrypoint.d.ts +0 -2
  274. package/dest/api/entrypoint.d.ts.map +0 -1
  275. package/dest/api/entrypoint.js +0 -1
  276. package/dest/api/ethereum/anvil_test_watcher.d.ts +0 -32
  277. package/dest/api/ethereum/anvil_test_watcher.d.ts.map +0 -1
  278. package/dest/api/ethereum/anvil_test_watcher.js +0 -133
  279. package/dest/api/ethereum/chain_monitor.d.ts +0 -25
  280. package/dest/api/ethereum/chain_monitor.d.ts.map +0 -1
  281. package/dest/api/ethereum/chain_monitor.js +0 -74
  282. package/dest/api/ethereum/cheat_codes.d.ts +0 -63
  283. package/dest/api/ethereum/cheat_codes.d.ts.map +0 -1
  284. package/dest/api/ethereum/cheat_codes.js +0 -162
  285. package/dest/api/ethereum/index.d.ts +0 -7
  286. package/dest/api/ethereum/index.d.ts.map +0 -1
  287. package/dest/api/ethereum/index.js +0 -6
  288. package/dest/api/ethereum/l1_contracts.d.ts +0 -3
  289. package/dest/api/ethereum/l1_contracts.d.ts.map +0 -1
  290. package/dest/api/ethereum/l1_contracts.js +0 -13
  291. package/dest/api/ethereum/portal_manager.d.ts.map +0 -1
  292. package/dest/api/interfaces/pxe.d.ts +0 -2
  293. package/dest/api/interfaces/pxe.d.ts.map +0 -1
  294. package/dest/api/interfaces/pxe.js +0 -1
  295. package/dest/api/log_id.d.ts +0 -2
  296. package/dest/api/log_id.d.ts.map +0 -1
  297. package/dest/api/log_id.js +0 -1
  298. package/dest/api/tx_hash.d.ts +0 -2
  299. package/dest/api/tx_hash.d.ts.map +0 -1
  300. package/dest/api/tx_hash.js +0 -1
  301. package/dest/contract/deploy_proven_tx.d.ts +0 -21
  302. package/dest/contract/deploy_proven_tx.d.ts.map +0 -1
  303. package/dest/contract/deploy_proven_tx.js +0 -19
  304. package/dest/contract/index.d.ts.map +0 -1
  305. package/dest/contract/proven_tx.d.ts +0 -17
  306. package/dest/contract/proven_tx.d.ts.map +0 -1
  307. package/dest/contract/proven_tx.js +0 -22
  308. package/dest/deployment/deploy_instance.d.ts +0 -10
  309. package/dest/deployment/deploy_instance.d.ts.map +0 -1
  310. package/dest/deployment/deploy_instance.js +0 -14
  311. package/dest/deployment/index.d.ts +0 -2
  312. package/dest/deployment/index.d.ts.map +0 -1
  313. package/dest/deployment/index.js +0 -1
  314. package/dest/deployment/register_class.d.ts +0 -6
  315. package/dest/deployment/register_class.d.ts.map +0 -1
  316. package/dest/deployment/register_class.js +0 -22
  317. package/dest/entrypoint/default_entrypoint.d.ts +0 -12
  318. package/dest/entrypoint/default_entrypoint.d.ts.map +0 -1
  319. package/dest/entrypoint/default_entrypoint.js +0 -28
  320. package/dest/entrypoint/default_multi_call_entrypoint.d.ts +0 -15
  321. package/dest/entrypoint/default_multi_call_entrypoint.d.ts.map +0 -1
  322. package/dest/entrypoint/default_multi_call_entrypoint.js +0 -130
  323. package/dest/entrypoint/entrypoint.d.ts +0 -35
  324. package/dest/entrypoint/entrypoint.d.ts.map +0 -1
  325. package/dest/entrypoint/entrypoint.js +0 -4
  326. package/dest/entrypoint/payload.d.ts +0 -128
  327. package/dest/entrypoint/payload.d.ts.map +0 -1
  328. package/dest/entrypoint/payload.js +0 -143
  329. package/dest/fee/fee_juice_payment_method.d.ts +0 -14
  330. package/dest/fee/fee_juice_payment_method.d.ts.map +0 -1
  331. package/dest/fee/fee_juice_payment_method.js +0 -20
  332. package/dest/index.d.ts +0 -66
  333. package/dest/index.d.ts.map +0 -1
  334. package/dest/index.js +0 -69
  335. package/dest/rpc_clients/index.d.ts +0 -3
  336. package/dest/rpc_clients/index.d.ts.map +0 -1
  337. package/dest/rpc_clients/index.js +0 -2
  338. package/dest/rpc_clients/node/index.d.ts +0 -12
  339. package/dest/rpc_clients/node/index.d.ts.map +0 -1
  340. package/dest/rpc_clients/node/index.js +0 -78
  341. package/dest/rpc_clients/pxe_client.d.ts +0 -10
  342. package/dest/rpc_clients/pxe_client.d.ts.map +0 -1
  343. package/dest/rpc_clients/pxe_client.js +0 -23
  344. package/dest/utils/aztec_cheatcodes.d.ts +0 -59
  345. package/dest/utils/aztec_cheatcodes.d.ts.map +0 -1
  346. package/dest/utils/aztec_cheatcodes.js +0 -62
  347. package/dest/utils/index.d.ts +0 -8
  348. package/dest/utils/index.d.ts.map +0 -1
  349. package/dest/utils/index.js +0 -6
  350. package/dest/utils/pxe.d.ts +0 -4
  351. package/dest/utils/pxe.d.ts.map +0 -1
  352. package/dest/utils/pxe.js +0 -14
  353. package/dest/wallet/account_wallet.d.ts +0 -76
  354. package/dest/wallet/account_wallet.d.ts.map +0 -1
  355. package/dest/wallet/account_wallet.js +0 -231
  356. package/dest/wallet/account_wallet_with_private_key.d.ts.map +0 -1
  357. package/dest/wallet/signerless_wallet.d.ts +0 -25
  358. package/dest/wallet/signerless_wallet.d.ts.map +0 -1
  359. package/dest/wallet/signerless_wallet.js +0 -36
  360. package/src/account/wallet.ts +0 -13
  361. package/src/account_manager/deploy_account_method.ts +0 -86
  362. package/src/account_manager/deploy_account_sent_tx.ts +0 -42
  363. package/src/account_manager/index.ts +0 -229
  364. package/src/api/cheat_codes.ts +0 -35
  365. package/src/api/entrypoint.ts +0 -1
  366. package/src/api/ethereum/anvil_test_watcher.ts +0 -158
  367. package/src/api/ethereum/chain_monitor.ts +0 -88
  368. package/src/api/ethereum/cheat_codes.ts +0 -184
  369. package/src/api/ethereum/index.ts +0 -19
  370. package/src/api/ethereum/l1_contracts.ts +0 -21
  371. package/src/api/interfaces/pxe.ts +0 -1
  372. package/src/api/log_id.ts +0 -1
  373. package/src/api/tx_hash.ts +0 -1
  374. package/src/contract/deploy_proven_tx.ts +0 -34
  375. package/src/contract/proven_tx.ts +0 -42
  376. package/src/deployment/deploy_instance.ts +0 -31
  377. package/src/deployment/index.ts +0 -1
  378. package/src/deployment/register_class.ts +0 -44
  379. package/src/entrypoint/default_entrypoint.ts +0 -39
  380. package/src/entrypoint/default_multi_call_entrypoint.ts +0 -93
  381. package/src/entrypoint/entrypoint.ts +0 -39
  382. package/src/entrypoint/payload.ts +0 -238
  383. package/src/fee/fee_juice_payment_method.ts +0 -26
  384. package/src/index.ts +0 -106
  385. package/src/rpc_clients/index.ts +0 -2
  386. package/src/rpc_clients/node/index.ts +0 -77
  387. package/src/rpc_clients/pxe_client.ts +0 -25
  388. package/src/utils/aztec_cheatcodes.ts +0 -77
  389. package/src/utils/index.ts +0 -21
  390. package/src/utils/pxe.ts +0 -17
  391. package/src/wallet/account_wallet.ts +0 -242
  392. package/src/wallet/signerless_wallet.ts +0 -52
@@ -1,149 +1,36 @@
1
1
  import { createLogger } from '@aztec/foundation/log';
2
- import { GasSettings } from '@aztec/stdlib/gas';
3
- import { FeeJuicePaymentMethod } from '../fee/fee_juice_payment_method.js';
4
- import { getGasLimits } from './get_gas_limits.js';
5
- import { ProvenTx } from './proven_tx.js';
2
+ import { toSendOptions } from './interaction_options.js';
6
3
  import { SentTx } from './sent_tx.js';
7
4
  /**
8
5
  * Base class for an interaction with a contract, be it a deployment, a function call, or a batch.
9
6
  * Implements the sequence create/simulate/send.
10
7
  */ export class BaseContractInteraction {
11
8
  wallet;
12
- log;
9
+ authWitnesses;
13
10
  capsules;
14
- constructor(wallet){
11
+ log;
12
+ constructor(wallet, authWitnesses = [], capsules = []){
15
13
  this.wallet = wallet;
14
+ this.authWitnesses = authWitnesses;
15
+ this.capsules = capsules;
16
16
  this.log = createLogger('aztecjs:contract_interaction');
17
- this.capsules = [];
18
- }
19
- /**
20
- * Creates a transaction execution request, simulates and proves it. Differs from .prove in
21
- * that its result does not include the wallet nor the composed tx object, but only the proving result.
22
- * This object can then be used to either create a ProvenTx ready to be sent, or directly send the transaction.
23
- * @param options - optional arguments to be used in the creation of the transaction
24
- * @returns The proving result.
25
- */ async proveInternal(options = {}) {
26
- const txRequest = await this.create(options);
27
- const txSimulationResult = await this.wallet.simulateTx(txRequest, !options.skipPublicSimulation, undefined, true);
28
- return await this.wallet.proveTx(txRequest, txSimulationResult.privateExecutionResult);
29
- }
30
- // docs:start:prove
31
- /**
32
- * Proves a transaction execution request and returns a tx object ready to be sent.
33
- * @param options - optional arguments to be used in the creation of the transaction
34
- * @returns The resulting transaction
35
- */ async prove(options = {}) {
36
- // docs:end:prove
37
- const txProvingResult = await this.proveInternal(options);
38
- return new ProvenTx(this.wallet, txProvingResult.toTx());
39
17
  }
40
18
  // docs:start:send
41
19
  /**
42
20
  * Sends a transaction to the contract function with the specified options.
43
- * This function throws an error if called on an unconstrained function.
21
+ * This function throws an error if called on a utility function.
44
22
  * It creates and signs the transaction if necessary, and returns a SentTx instance,
45
23
  * which can be used to track the transaction status, receipt, and events.
46
- * @param options - An optional object containing 'from' property representing
47
- * the AztecAddress of the sender. If not provided, the default address is used.
24
+ * @param options - An object containing 'from' property representing
25
+ * the AztecAddress of the sender and optional fee configuration
48
26
  * @returns A SentTx instance for tracking the transaction status and information.
49
- */ send(options = {}) {
27
+ */ send(options) {
50
28
  // docs:end:send
51
- const promise = (async ()=>{
52
- const txProvingResult = await this.proveInternal(options);
53
- return this.wallet.sendTx(txProvingResult.toTx());
54
- })();
55
- return new SentTx(this.wallet, promise);
56
- }
57
- // docs:start:estimateGas
58
- /**
59
- * Estimates gas for a given tx request and returns gas limits for it.
60
- * @param opts - Options.
61
- * @param pad - Percentage to pad the suggested gas limits by, if empty, defaults to 10%.
62
- * @returns Gas limits.
63
- */ async estimateGas(opts) {
64
- // docs:end:estimateGas
65
- const txRequest = await this.create({
66
- ...opts,
67
- fee: {
68
- ...opts?.fee,
69
- estimateGas: false
70
- }
71
- });
72
- const simulationResult = await this.wallet.simulateTx(txRequest, true, undefined /* msgSender */ , undefined /* skipTxValidation */ , true);
73
- const { totalGas: gasLimits, teardownGas: teardownGasLimits } = getGasLimits(simulationResult, opts?.fee?.estimatedGasPadding);
74
- return {
75
- gasLimits,
76
- teardownGasLimits
77
- };
78
- }
79
- /**
80
- * Returns default fee options based on the user opts without running a simulation for gas estimation.
81
- * @param fee - User-provided fee options.
82
- */ async getDefaultFeeOptions(fee) {
83
- const maxFeesPerGas = fee?.gasSettings?.maxFeesPerGas ?? (await this.wallet.getCurrentBaseFees()).mul(1 + (fee?.baseFeePadding ?? 0.5));
84
- const paymentMethod = fee?.paymentMethod ?? new FeeJuicePaymentMethod(this.wallet.getAddress());
85
- const gasSettings = GasSettings.default({
86
- ...fee?.gasSettings,
87
- maxFeesPerGas
88
- });
89
- this.log.debug(`Using L2 gas settings`, gasSettings);
90
- return {
91
- gasSettings,
92
- paymentMethod
29
+ const sendTx = async ()=>{
30
+ const executionPayload = await this.request(options);
31
+ const sendOptions = await toSendOptions(options);
32
+ return this.wallet.sendTx(executionPayload, sendOptions);
93
33
  };
94
- }
95
- // docs:start:getFeeOptions
96
- /**
97
- * Return fee options based on the user opts, estimating tx gas if needed.
98
- * @param request - Request to execute for this interaction.
99
- * @param pad - Percentage to pad the suggested gas limits by, as decimal (e.g., 0.10 for 10%).
100
- * @returns Fee options for the actual transaction.
101
- */ async getFeeOptions(request) {
102
- // docs:end:getFeeOptions
103
- const defaultFeeOptions = await this.getDefaultFeeOptions(request.fee);
104
- const paymentMethod = defaultFeeOptions.paymentMethod;
105
- const maxFeesPerGas = defaultFeeOptions.gasSettings.maxFeesPerGas;
106
- const maxPriorityFeesPerGas = defaultFeeOptions.gasSettings.maxPriorityFeesPerGas;
107
- let gasSettings = defaultFeeOptions.gasSettings;
108
- if (request.fee?.estimateGas) {
109
- const feeForEstimation = {
110
- paymentMethod,
111
- gasSettings
112
- };
113
- const txRequest = await this.wallet.createTxExecutionRequest({
114
- ...request,
115
- fee: feeForEstimation
116
- });
117
- const simulationResult = await this.wallet.simulateTx(txRequest, true, undefined /* msgSender */ , undefined /* skipTxValidation */ , true);
118
- const { totalGas: gasLimits, teardownGas: teardownGasLimits } = getGasLimits(simulationResult, request.fee?.estimatedGasPadding);
119
- gasSettings = GasSettings.from({
120
- maxFeesPerGas,
121
- maxPriorityFeesPerGas,
122
- gasLimits,
123
- teardownGasLimits
124
- });
125
- this.log.verbose(`Estimated gas limits for tx: DA=${gasLimits.daGas} L2=${gasLimits.l2Gas} teardownDA=${teardownGasLimits.daGas} teardownL2=${teardownGasLimits.l2Gas}`);
126
- }
127
- return {
128
- gasSettings,
129
- paymentMethod
130
- };
131
- }
132
- /**
133
- * Add data passed to the oracle calls during this contract interaction.
134
- * @param capsule - Data passed to oracle calls.
135
- */ addCapsule(capsule) {
136
- this.capsules.push(capsule);
137
- }
138
- /**
139
- * Add data passed to the oracle calls during this contract interaction.
140
- * @param capsules - Data passed to oracle calls.
141
- */ addCapsules(capsules) {
142
- this.capsules.push(...capsules);
143
- }
144
- /**
145
- * Return all capsules added for this function interaction.
146
- */ getCapsules() {
147
- return this.capsules;
34
+ return new SentTx(this.wallet, sendTx);
148
35
  }
149
36
  }
@@ -1,28 +1,27 @@
1
- import { type FunctionCall } from '@aztec/stdlib/abi';
2
- import type { TxExecutionRequest } from '@aztec/stdlib/tx';
3
- import type { Wallet } from '../account/index.js';
4
- import { BaseContractInteraction, type SendMethodOptions } from './base_contract_interaction.js';
5
- import type { SimulateMethodOptions } from './contract_function_interaction.js';
1
+ import { ExecutionPayload } from '@aztec/entrypoints/payload';
2
+ import type { Wallet } from '../wallet/wallet.js';
3
+ import { BaseContractInteraction } from './base_contract_interaction.js';
4
+ import { type RequestInteractionOptions, type SimulateInteractionOptions } from './interaction_options.js';
6
5
  /** A batch of function calls to be sent as a single transaction through a wallet. */
7
6
  export declare class BatchCall extends BaseContractInteraction {
8
- protected calls: FunctionCall[];
9
- constructor(wallet: Wallet, calls: FunctionCall[]);
7
+ protected interactions: (BaseContractInteraction | ExecutionPayload)[];
8
+ constructor(wallet: Wallet, interactions: (BaseContractInteraction | ExecutionPayload)[]);
10
9
  /**
11
- * Create a transaction execution request that represents this batch, encoded and authenticated by the
12
- * user's wallet, ready to be simulated.
13
- * @param opts - An optional object containing additional configuration for the transaction.
14
- * @returns A Promise that resolves to a transaction instance.
10
+ * Returns an execution request that represents this operation.
11
+ * @param options - An optional object containing additional configuration for the request generation.
12
+ * @returns An execution payload wrapped in promise.
15
13
  */
16
- create(opts?: SendMethodOptions): Promise<TxExecutionRequest>;
14
+ request(options?: RequestInteractionOptions): Promise<ExecutionPayload>;
17
15
  /**
18
16
  * Simulate a transaction and get its return values
19
17
  * Differs from prove in a few important ways:
20
18
  * 1. It returns the values of the function execution
21
- * 2. It supports `unconstrained`, `private` and `public` functions
19
+ * 2. It supports `utility`, `private` and `public` functions
22
20
  *
23
21
  * @param options - An optional object containing additional configuration for the transaction.
24
22
  * @returns The result of the transaction as returned by the contract function.
25
23
  */
26
- simulate(options?: SimulateMethodOptions): Promise<any>;
24
+ simulate(options: SimulateInteractionOptions): Promise<any>;
25
+ protected getExecutionPayloads(): Promise<ExecutionPayload[]>;
27
26
  }
28
27
  //# sourceMappingURL=batch_call.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"batch_call.d.ts","sourceRoot":"","sources":["../../src/contract/batch_call.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,YAAY,EAA+B,MAAM,mBAAmB,CAAC;AACnF,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AAE3D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,uBAAuB,EAAE,KAAK,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AACjG,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,oCAAoC,CAAC;AAEhF,qFAAqF;AACrF,qBAAa,SAAU,SAAQ,uBAAuB;IACxB,SAAS,CAAC,KAAK,EAAE,YAAY,EAAE;gBAA/C,MAAM,EAAE,MAAM,EAAY,KAAK,EAAE,YAAY,EAAE;IAI3D;;;;;OAKG;IACU,MAAM,CAAC,IAAI,CAAC,EAAE,iBAAiB,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAO1E;;;;;;;;OAQG;IACU,QAAQ,CAAC,OAAO,GAAE,qBAA0B,GAAG,OAAO,CAAC,GAAG,CAAC;CA2DzE"}
1
+ {"version":3,"file":"batch_call.d.ts","sourceRoot":"","sources":["../../src/contract/batch_call.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAA0B,MAAM,4BAA4B,CAAC;AAGtF,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,uBAAuB,EAAE,MAAM,gCAAgC,CAAC;AACzE,OAAO,EACL,KAAK,yBAAyB,EAC9B,KAAK,0BAA0B,EAEhC,MAAM,0BAA0B,CAAC;AAElC,qFAAqF;AACrF,qBAAa,SAAU,SAAQ,uBAAuB;IAGlD,SAAS,CAAC,YAAY,EAAE,CAAC,uBAAuB,GAAG,gBAAgB,CAAC,EAAE;gBADtE,MAAM,EAAE,MAAM,EACJ,YAAY,EAAE,CAAC,uBAAuB,GAAG,gBAAgB,CAAC,EAAE;IAKxE;;;;OAIG;IACU,OAAO,CAAC,OAAO,GAAE,yBAA8B,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAWxF;;;;;;;;OAQG;IACU,QAAQ,CAAC,OAAO,EAAE,0BAA0B,GAAG,OAAO,CAAC,GAAG,CAAC;cA8ExD,oBAAoB,IAAI,OAAO,CAAC,gBAAgB,EAAE,CAAC;CAGpE"}
@@ -1,91 +1,91 @@
1
+ import { ExecutionPayload, mergeExecutionPayloads } from '@aztec/entrypoints/payload';
1
2
  import { FunctionType, decodeFromAbi } from '@aztec/stdlib/abi';
2
3
  import { BaseContractInteraction } from './base_contract_interaction.js';
4
+ import { toSimulateOptions } from './interaction_options.js';
3
5
  /** A batch of function calls to be sent as a single transaction through a wallet. */ export class BatchCall extends BaseContractInteraction {
4
- calls;
5
- constructor(wallet, calls){
6
- super(wallet), this.calls = calls;
6
+ interactions;
7
+ constructor(wallet, interactions){
8
+ super(wallet), this.interactions = interactions;
7
9
  }
8
10
  /**
9
- * Create a transaction execution request that represents this batch, encoded and authenticated by the
10
- * user's wallet, ready to be simulated.
11
- * @param opts - An optional object containing additional configuration for the transaction.
12
- * @returns A Promise that resolves to a transaction instance.
13
- */ async create(opts) {
14
- const calls = this.calls;
15
- const capsules = this.getCapsules();
16
- const fee = await this.getFeeOptions({
17
- calls,
18
- capsules,
19
- ...opts
20
- });
21
- return await this.wallet.createTxExecutionRequest({
22
- calls,
23
- capsules,
24
- ...opts,
25
- fee
26
- });
11
+ * Returns an execution request that represents this operation.
12
+ * @param options - An optional object containing additional configuration for the request generation.
13
+ * @returns An execution payload wrapped in promise.
14
+ */ async request(options = {}) {
15
+ const requests = await this.getExecutionPayloads();
16
+ const feeExecutionPayload = options.fee?.paymentMethod ? await options.fee.paymentMethod.getExecutionPayload() : undefined;
17
+ const finalExecutionPayload = feeExecutionPayload ? mergeExecutionPayloads([
18
+ feeExecutionPayload,
19
+ ...requests
20
+ ]) : mergeExecutionPayloads([
21
+ ...requests
22
+ ]);
23
+ return finalExecutionPayload;
27
24
  }
28
25
  /**
29
26
  * Simulate a transaction and get its return values
30
27
  * Differs from prove in a few important ways:
31
28
  * 1. It returns the values of the function execution
32
- * 2. It supports `unconstrained`, `private` and `public` functions
29
+ * 2. It supports `utility`, `private` and `public` functions
33
30
  *
34
31
  * @param options - An optional object containing additional configuration for the transaction.
35
32
  * @returns The result of the transaction as returned by the contract function.
36
- */ async simulate(options = {}) {
37
- const { indexedCalls, unconstrained } = this.calls.reduce((acc, current, index)=>{
38
- if (current.type === FunctionType.UNCONSTRAINED) {
39
- acc.unconstrained.push([
40
- current,
33
+ */ async simulate(options) {
34
+ const { indexedExecutionPayloads, utility } = (await this.getExecutionPayloads()).reduce((acc, current, index)=>{
35
+ const call = current.calls[0];
36
+ if (call.type === FunctionType.UTILITY) {
37
+ acc.utility.push([
38
+ call,
41
39
  index
42
40
  ]);
43
41
  } else {
44
- acc.indexedCalls.push([
42
+ acc.indexedExecutionPayloads.push([
45
43
  current,
46
44
  index,
47
- current.type === FunctionType.PRIVATE ? acc.privateIndex++ : acc.publicIndex++
45
+ call.type === FunctionType.PRIVATE ? acc.privateIndex++ : acc.publicIndex++
48
46
  ]);
49
47
  }
50
48
  return acc;
51
49
  }, {
52
- indexedCalls: [],
53
- unconstrained: [],
50
+ indexedExecutionPayloads: [],
51
+ utility: [],
54
52
  publicIndex: 0,
55
53
  privateIndex: 0
56
54
  });
57
- const calls = indexedCalls.map(([call])=>call);
58
- const capsules = this.getCapsules();
59
- const fee = await this.getFeeOptions({
60
- calls,
61
- capsules,
62
- ...options
63
- });
64
- const txRequest = await this.wallet.createTxExecutionRequest({
65
- calls,
66
- capsules,
67
- ...options,
68
- fee
69
- });
70
- const unconstrainedCalls = unconstrained.map(async ([call, index])=>[
71
- await this.wallet.simulateUnconstrained(call.name, call.args, call.to, options?.from),
72
- index
73
- ]);
74
- const [unconstrainedResults, simulatedTx] = await Promise.all([
75
- Promise.all(unconstrainedCalls),
76
- this.wallet.simulateTx(txRequest, true, options?.from, options?.skipTxValidation)
55
+ const payloads = indexedExecutionPayloads.map(([request])=>request);
56
+ const combinedPayload = mergeExecutionPayloads(payloads);
57
+ const executionPayload = new ExecutionPayload(combinedPayload.calls, combinedPayload.authWitnesses.concat(options.authWitnesses ?? []), combinedPayload.capsules.concat(options.capsules ?? []), combinedPayload.extraHashedArgs);
58
+ const utilityBatchPromise = utility.length > 0 ? this.wallet.batch(utility.map(([call])=>({
59
+ name: 'simulateUtility',
60
+ args: [
61
+ call.name,
62
+ call.args,
63
+ call.to,
64
+ options?.authWitnesses
65
+ ]
66
+ }))) : Promise.resolve([]);
67
+ const [utilityBatchResults, simulatedTx] = await Promise.all([
68
+ utilityBatchPromise,
69
+ indexedExecutionPayloads.length > 0 ? this.wallet.simulateTx(executionPayload, await toSimulateOptions(options)) : Promise.resolve()
77
70
  ]);
78
71
  const results = [];
79
- unconstrainedResults.forEach(([result, index])=>{
80
- results[index] = result;
81
- });
82
- indexedCalls.forEach(([call, callIndex, resultIndex])=>{
83
- // As account entrypoints are private, for private functions we retrieve the return values from the first nested call
84
- // since we're interested in the first set of values AFTER the account entrypoint
85
- // For public functions we retrieve the first values directly from the public output.
86
- const rawReturnValues = call.type == FunctionType.PRIVATE ? simulatedTx.getPrivateReturnValues()?.nested?.[resultIndex].values : simulatedTx.getPublicReturnValues()?.[resultIndex].values;
87
- results[callIndex] = rawReturnValues ? decodeFromAbi(call.returnTypes, rawReturnValues) : [];
72
+ utilityBatchResults.forEach((wrappedResult, utilityIndex)=>{
73
+ const [, originalIndex] = utility[utilityIndex];
74
+ results[originalIndex] = wrappedResult.result.result;
88
75
  });
76
+ if (simulatedTx) {
77
+ indexedExecutionPayloads.forEach(([request, callIndex, resultIndex])=>{
78
+ const call = request.calls[0];
79
+ // As account entrypoints are private, for private functions we retrieve the return values from the first nested call
80
+ // since we're interested in the first set of values AFTER the account entrypoint
81
+ // For public functions we retrieve the first values directly from the public output.
82
+ const rawReturnValues = call.type == FunctionType.PRIVATE ? simulatedTx.getPrivateReturnValues()?.nested?.[resultIndex].values : simulatedTx.getPublicReturnValues()?.[resultIndex].values;
83
+ results[callIndex] = rawReturnValues ? decodeFromAbi(call.returnTypes, rawReturnValues) : [];
84
+ });
85
+ }
89
86
  return results;
90
87
  }
88
+ async getExecutionPayloads() {
89
+ return await Promise.all(this.interactions.map((i)=>i instanceof ExecutionPayload ? i : i.request()));
90
+ }
91
91
  }
@@ -1,4 +1,4 @@
1
- import type { ContractArtifact } from '@aztec/stdlib/abi';
1
+ import { type ContractArtifact } from '@aztec/stdlib/abi';
2
2
  /**
3
3
  * Validates the given ContractArtifact object by checking its functions and their parameters.
4
4
  * Ensures that the ABI has at least one function, a constructor, valid bytecode, and correct parameter types.
@@ -1 +1 @@
1
- {"version":3,"file":"checker.d.ts","sourceRoot":"","sources":["../../src/contract/checker.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAsB,gBAAgB,EAAc,MAAM,mBAAmB,CAAC;AAQ1F;;;;;;;GAOG;AACH,wBAAgB,UAAU,CAAC,QAAQ,EAAE,gBAAgB,WA8BpD"}
1
+ {"version":3,"file":"checker.d.ts","sourceRoot":"","sources":["../../src/contract/checker.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,KAAK,gBAAgB,EAGtB,MAAM,mBAAmB,CAAC;AAQ3B;;;;;;;GAOG;AACH,wBAAgB,UAAU,CAAC,QAAQ,EAAE,gBAAgB,WA6BpD"}
@@ -1,3 +1,4 @@
1
+ import { getDefaultInitializer } from '@aztec/stdlib/abi';
1
2
  /**
2
3
  * Validates the given ContractArtifact object by checking its functions and their parameters.
3
4
  * Ensures that the ABI has at least one function, a constructor, valid bytecode, and correct parameter types.
@@ -24,8 +25,7 @@
24
25
  abiParameterTypeChecker(param.type);
25
26
  });
26
27
  });
27
- // TODO: implement a better check for constructor (right now only checks if it has it or not)
28
- if (!artifact.functions.find((func)=>func.name === 'constructor')) {
28
+ if (!getDefaultInitializer(artifact)) {
29
29
  throw new Error('ABI has no constructor');
30
30
  }
31
31
  return true;
@@ -1,27 +1,27 @@
1
1
  import type { ContractArtifact } from '@aztec/stdlib/abi';
2
2
  import type { AztecAddress } from '@aztec/stdlib/aztec-address';
3
3
  import { PublicKeys } from '@aztec/stdlib/keys';
4
- import type { Wallet } from '../account/index.js';
4
+ import type { Wallet } from '../wallet/wallet.js';
5
5
  import { ContractBase } from './contract_base.js';
6
6
  import { DeployMethod } from './deploy_method.js';
7
7
  /**
8
8
  * The Contract class represents a contract and provides utility methods for interacting with it.
9
9
  * It enables the creation of ContractFunctionInteraction instances for each function in the contract's ABI,
10
10
  * allowing users to call or send transactions to these functions. Additionally, the Contract class can be used
11
- * to attach the contract instance to a deployed contract on-chain through the PXE, which facilitates
11
+ * to attach the contract instance to a deployed contract onchain through the PXE, which facilitates
12
12
  * interaction with Aztec's privacy protocol.
13
13
  */
14
14
  export declare class Contract extends ContractBase {
15
15
  /**
16
- * Creates a contract instance.
17
- * @param address - The deployed contract's address.
16
+ * Gets a contract instance.
17
+ * @param address - The address of the contract instance.
18
18
  * @param artifact - Build artifact of the contract.
19
19
  * @param wallet - The wallet to use when interacting with the contract.
20
20
  * @returns A promise that resolves to a new Contract instance.
21
21
  */
22
22
  static at(address: AztecAddress, artifact: ContractArtifact, wallet: Wallet): Promise<Contract>;
23
23
  /**
24
- * Creates a tx to deploy a new instance of a contract.
24
+ * Creates a tx to deploy (initialize and/or publish) a new instance of a contract.
25
25
  * @param wallet - The wallet for executing the deployment.
26
26
  * @param artifact - Build artifact of the contract to deploy
27
27
  * @param args - Arguments for the constructor.
@@ -29,7 +29,8 @@ export declare class Contract extends ContractBase {
29
29
  */
30
30
  static deploy(wallet: Wallet, artifact: ContractArtifact, args: any[], constructorName?: string): DeployMethod<Contract>;
31
31
  /**
32
- * Creates a tx to deploy a new instance of a contract using the specified public keys hash to derive the address.
32
+ * Creates a tx to deploy (initialize and/or publish) a new instance of a contract
33
+ * using the specified public keys hash to derive the address.
33
34
  * @param publicKeys - Hash of public keys to use for deriving the address.
34
35
  * @param wallet - The wallet for executing the deployment.
35
36
  * @param artifact - Build artifact of the contract.
@@ -1 +1 @@
1
- {"version":3,"file":"contract.d.ts","sourceRoot":"","sources":["../../src/contract/contract.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAEhE,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAEhD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAElD;;;;;;GAMG;AACH,qBAAa,QAAS,SAAQ,YAAY;IACxC;;;;;;OAMG;WACiB,EAAE,CAAC,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,gBAAgB,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC;IAc5G;;;;;;OAMG;WACW,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,gBAAgB,EAAE,IAAI,EAAE,GAAG,EAAE,EAAE,eAAe,CAAC,EAAE,MAAM;IAKtG;;;;;;;OAOG;WACW,oBAAoB,CAChC,UAAU,EAAE,UAAU,EACtB,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,gBAAgB,EAC1B,IAAI,EAAE,GAAG,EAAE,EACX,eAAe,CAAC,EAAE,MAAM;CAK3B"}
1
+ {"version":3,"file":"contract.d.ts","sourceRoot":"","sources":["../../src/contract/contract.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAChE,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAEhD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAElD;;;;;;GAMG;AACH,qBAAa,QAAS,SAAQ,YAAY;IACxC;;;;;;OAMG;WACiB,EAAE,CAAC,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,gBAAgB,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC;IAK5G;;;;;;OAMG;WACW,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,gBAAgB,EAAE,IAAI,EAAE,GAAG,EAAE,EAAE,eAAe,CAAC,EAAE,MAAM;IAKtG;;;;;;;;OAQG;WACW,oBAAoB,CAChC,UAAU,EAAE,UAAU,EACtB,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,gBAAgB,EAC1B,IAAI,EAAE,GAAG,EAAE,EACX,eAAe,CAAC,EAAE,MAAM;CAK3B"}
@@ -1,4 +1,3 @@
1
- import { getContractClassFromArtifact } from '@aztec/stdlib/contract';
2
1
  import { PublicKeys } from '@aztec/stdlib/keys';
3
2
  import { ContractBase } from './contract_base.js';
4
3
  import { DeployMethod } from './deploy_method.js';
@@ -6,30 +5,21 @@ import { DeployMethod } from './deploy_method.js';
6
5
  * The Contract class represents a contract and provides utility methods for interacting with it.
7
6
  * It enables the creation of ContractFunctionInteraction instances for each function in the contract's ABI,
8
7
  * allowing users to call or send transactions to these functions. Additionally, the Contract class can be used
9
- * to attach the contract instance to a deployed contract on-chain through the PXE, which facilitates
8
+ * to attach the contract instance to a deployed contract onchain through the PXE, which facilitates
10
9
  * interaction with Aztec's privacy protocol.
11
10
  */ export class Contract extends ContractBase {
12
11
  /**
13
- * Creates a contract instance.
14
- * @param address - The deployed contract's address.
12
+ * Gets a contract instance.
13
+ * @param address - The address of the contract instance.
15
14
  * @param artifact - Build artifact of the contract.
16
15
  * @param wallet - The wallet to use when interacting with the contract.
17
16
  * @returns A promise that resolves to a new Contract instance.
18
17
  */ static async at(address, artifact, wallet) {
19
- const instance = (await wallet.getContractMetadata(address)).contractInstance;
20
- if (instance === undefined) {
21
- throw new Error(`Contract instance at ${address.toString()} has not been registered in the wallet's PXE`);
22
- }
23
- const thisContractClass = await getContractClassFromArtifact(artifact);
24
- if (!thisContractClass.id.equals(instance.currentContractClassId)) {
25
- // wallet holds an outdated version of this contract
26
- await wallet.updateContract(address, artifact);
27
- instance.currentContractClassId = thisContractClass.id;
28
- }
18
+ const instance = await wallet.registerContract(address, artifact);
29
19
  return new Contract(instance, artifact, wallet);
30
20
  }
31
21
  /**
32
- * Creates a tx to deploy a new instance of a contract.
22
+ * Creates a tx to deploy (initialize and/or publish) a new instance of a contract.
33
23
  * @param wallet - The wallet for executing the deployment.
34
24
  * @param artifact - Build artifact of the contract to deploy
35
25
  * @param args - Arguments for the constructor.
@@ -39,7 +29,8 @@ import { DeployMethod } from './deploy_method.js';
39
29
  return new DeployMethod(PublicKeys.default(), wallet, artifact, postDeployCtor, args, constructorName);
40
30
  }
41
31
  /**
42
- * Creates a tx to deploy a new instance of a contract using the specified public keys hash to derive the address.
32
+ * Creates a tx to deploy (initialize and/or publish) a new instance of a contract
33
+ * using the specified public keys hash to derive the address.
43
34
  * @param publicKeys - Hash of public keys to use for deriving the address.
44
35
  * @param wallet - The wallet for executing the deployment.
45
36
  * @param artifact - Build artifact of the contract.
@@ -1,6 +1,6 @@
1
- import { type ContractArtifact, type ContractNote, type FieldLayout, FunctionSelector } from '@aztec/stdlib/abi';
1
+ import { type ContractArtifact, type FieldLayout, FunctionSelector } from '@aztec/stdlib/abi';
2
2
  import { type ContractInstanceWithAddress } from '@aztec/stdlib/contract';
3
- import type { Wallet } from '../account/index.js';
3
+ import type { Wallet } from '../wallet/wallet.js';
4
4
  import { ContractFunctionInteraction } from './contract_function_interaction.js';
5
5
  /**
6
6
  * Type representing a contract method that returns a ContractFunctionInteraction instance
@@ -18,12 +18,6 @@ export type ContractMethod = ((...args: any[]) => ContractFunctionInteraction) &
18
18
  export type ContractStorageLayout<T extends string> = {
19
19
  [K in T]: FieldLayout;
20
20
  };
21
- /**
22
- * Type representing the notes used in a contract.
23
- */
24
- export type ContractNotes<T extends string> = {
25
- [K in T]: ContractNote;
26
- };
27
21
  /**
28
22
  * Abstract implementation of a contract extended by the Contract class and generated contract types.
29
23
  */
@@ -48,7 +42,7 @@ export declare class ContractBase {
48
42
  /** The wallet used for interacting with this contract. */
49
43
  wallet: Wallet);
50
44
  /** Address of the contract. */
51
- get address(): import("@aztec/stdlib/aztec-address").AztecAddress;
45
+ get address(): import("../api/addresses.js").AztecAddress;
52
46
  /** Partial address of the contract. */
53
47
  get partialAddress(): Promise<import("@aztec/foundation/schemas").Fr>;
54
48
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"contract_base.d.ts","sourceRoot":"","sources":["../../src/contract/contract_base.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,gBAAgB,EACrB,KAAK,YAAY,EACjB,KAAK,WAAW,EAEhB,gBAAgB,EACjB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,KAAK,2BAA2B,EAAyB,MAAM,wBAAwB,CAAC;AAEjG,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,2BAA2B,EAAE,MAAM,oCAAoC,CAAC;AAEjF;;;GAGG;AACH,MAAM,MAAM,cAAc,GAAG,CAAC,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,2BAA2B,CAAC,GAAG;IAC/E;;OAEG;IACH,QAAQ,EAAE,MAAM,OAAO,CAAC,gBAAgB,CAAC,CAAC;CAC3C,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,qBAAqB,CAAC,CAAC,SAAS,MAAM,IAAI;KACnD,CAAC,IAAI,CAAC,GAAG,WAAW;CACtB,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,aAAa,CAAC,CAAC,SAAS,MAAM,IAAI;KAC3C,CAAC,IAAI,CAAC,GAAG,YAAY;CACvB,CAAC;AAEF;;GAEG;AACH,qBAAa,YAAY;IAOrB,iDAAiD;aACjC,QAAQ,EAAE,2BAA2B;IACrD,yDAAyD;aACzC,QAAQ,EAAE,gBAAgB;IAC1C,0DAA0D;IACnD,MAAM,EAAE,MAAM;IAXvB;;OAEG;IACI,OAAO,EAAE;QAAE,CAAC,IAAI,EAAE,MAAM,GAAG,cAAc,CAAA;KAAE,CAAM;IAExD,SAAS;IACP,iDAAiD;IACjC,QAAQ,EAAE,2BAA2B;IACrD,yDAAyD;IACzC,QAAQ,EAAE,gBAAgB;IAC1C,0DAA0D;IACnD,MAAM,EAAE,MAAM;IAmBvB,+BAA+B;IAC/B,IAAW,OAAO,uDAEjB;IAED,uCAAuC;IACvC,IAAW,cAAc,oDAExB;IAED;;;;OAIG;IACI,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;CAGxC"}
1
+ {"version":3,"file":"contract_base.d.ts","sourceRoot":"","sources":["../../src/contract/contract_base.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,gBAAgB,EACrB,KAAK,WAAW,EAEhB,gBAAgB,EAEjB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,KAAK,2BAA2B,EAAyB,MAAM,wBAAwB,CAAC;AAEjG,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,2BAA2B,EAAE,MAAM,oCAAoC,CAAC;AAEjF;;;GAGG;AACH,MAAM,MAAM,cAAc,GAAG,CAAC,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,2BAA2B,CAAC,GAAG;IAC/E;;OAEG;IACH,QAAQ,EAAE,MAAM,OAAO,CAAC,gBAAgB,CAAC,CAAC;CAC3C,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,qBAAqB,CAAC,CAAC,SAAS,MAAM,IAAI;KACnD,CAAC,IAAI,CAAC,GAAG,WAAW;CACtB,CAAC;AAEF;;GAEG;AACH,qBAAa,YAAY;IAOrB,iDAAiD;aACjC,QAAQ,EAAE,2BAA2B;IACrD,yDAAyD;aACzC,QAAQ,EAAE,gBAAgB;IAC1C,0DAA0D;IACnD,MAAM,EAAE,MAAM;IAXvB;;OAEG;IACI,OAAO,EAAE;QAAE,CAAC,IAAI,EAAE,MAAM,GAAG,cAAc,CAAA;KAAE,CAAM;IAExD,SAAS;IACP,iDAAiD;IACjC,QAAQ,EAAE,2BAA2B;IACrD,yDAAyD;IACzC,QAAQ,EAAE,gBAAgB;IAC1C,0DAA0D;IACnD,MAAM,EAAE,MAAM;IAmBvB,+BAA+B;IAC/B,IAAW,OAAO,+CAEjB;IAED,uCAAuC;IACvC,IAAW,cAAc,oDAExB;IAED;;;;OAIG;IACI,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;CAGxC"}
@@ -1,4 +1,4 @@
1
- import { FunctionSelector } from '@aztec/stdlib/abi';
1
+ import { FunctionSelector, getAllFunctionAbis } from '@aztec/stdlib/abi';
2
2
  import { computePartialAddress } from '@aztec/stdlib/contract';
3
3
  import { ContractFunctionInteraction } from './contract_function_interaction.js';
4
4
  /**
@@ -15,7 +15,7 @@ import { ContractFunctionInteraction } from './contract_function_interaction.js'
15
15
  this.artifact = artifact;
16
16
  this.wallet = wallet;
17
17
  this.methods = {};
18
- artifact.functions.forEach((f)=>{
18
+ getAllFunctionAbis(artifact).forEach((f)=>{
19
19
  const interactionFunction = (...args)=>{
20
20
  return new ContractFunctionInteraction(this.wallet, this.instance.address, f, args);
21
21
  };