@aztec/aztec.js 0.0.0-test.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (299) hide show
  1. package/README.md +44 -0
  2. package/dest/account/contract.d.ts +37 -0
  3. package/dest/account/contract.d.ts.map +1 -0
  4. package/dest/account/contract.js +16 -0
  5. package/dest/account/index.d.ts +15 -0
  6. package/dest/account/index.d.ts.map +1 -0
  7. package/dest/account/index.js +9 -0
  8. package/dest/account/interface.d.ts +31 -0
  9. package/dest/account/interface.d.ts.map +1 -0
  10. package/dest/account/interface.js +4 -0
  11. package/dest/account/wallet.d.ts +11 -0
  12. package/dest/account/wallet.d.ts.map +1 -0
  13. package/dest/account/wallet.js +3 -0
  14. package/dest/account_manager/deploy_account_method.d.ts +15 -0
  15. package/dest/account_manager/deploy_account_method.d.ts.map +1 -0
  16. package/dest/account_manager/deploy_account_method.js +43 -0
  17. package/dest/account_manager/deploy_account_sent_tx.d.ts +30 -0
  18. package/dest/account_manager/deploy_account_sent_tx.d.ts.map +1 -0
  19. package/dest/account_manager/deploy_account_sent_tx.js +29 -0
  20. package/dest/account_manager/index.d.ts +108 -0
  21. package/dest/account_manager/index.d.ts.map +1 -0
  22. package/dest/account_manager/index.js +159 -0
  23. package/dest/api/abi.d.ts +3 -0
  24. package/dest/api/abi.d.ts.map +1 -0
  25. package/dest/api/abi.js +1 -0
  26. package/dest/api/account.d.ts +3 -0
  27. package/dest/api/account.d.ts.map +1 -0
  28. package/dest/api/account.js +2 -0
  29. package/dest/api/addresses.d.ts +3 -0
  30. package/dest/api/addresses.d.ts.map +1 -0
  31. package/dest/api/addresses.js +2 -0
  32. package/dest/api/cheat_codes.d.ts +26 -0
  33. package/dest/api/cheat_codes.d.ts.map +1 -0
  34. package/dest/api/cheat_codes.js +25 -0
  35. package/dest/api/deployment.d.ts +4 -0
  36. package/dest/api/deployment.d.ts.map +1 -0
  37. package/dest/api/deployment.js +3 -0
  38. package/dest/api/entrypoint.d.ts +2 -0
  39. package/dest/api/entrypoint.d.ts.map +1 -0
  40. package/dest/api/entrypoint.js +1 -0
  41. package/dest/api/eth_address.d.ts +2 -0
  42. package/dest/api/eth_address.d.ts.map +1 -0
  43. package/dest/api/eth_address.js +1 -0
  44. package/dest/api/ethereum/anvil_test_watcher.d.ts +32 -0
  45. package/dest/api/ethereum/anvil_test_watcher.d.ts.map +1 -0
  46. package/dest/api/ethereum/anvil_test_watcher.js +133 -0
  47. package/dest/api/ethereum/chain_monitor.d.ts +25 -0
  48. package/dest/api/ethereum/chain_monitor.d.ts.map +1 -0
  49. package/dest/api/ethereum/chain_monitor.js +74 -0
  50. package/dest/api/ethereum/cheat_codes.d.ts +63 -0
  51. package/dest/api/ethereum/cheat_codes.d.ts.map +1 -0
  52. package/dest/api/ethereum/cheat_codes.js +162 -0
  53. package/dest/api/ethereum/index.d.ts +7 -0
  54. package/dest/api/ethereum/index.d.ts.map +1 -0
  55. package/dest/api/ethereum/index.js +6 -0
  56. package/dest/api/ethereum/l1_contracts.d.ts +3 -0
  57. package/dest/api/ethereum/l1_contracts.d.ts.map +1 -0
  58. package/dest/api/ethereum/l1_contracts.js +13 -0
  59. package/dest/api/ethereum/portal_manager.d.ts +136 -0
  60. package/dest/api/ethereum/portal_manager.d.ts.map +1 -0
  61. package/dest/api/ethereum/portal_manager.js +286 -0
  62. package/dest/api/fee.d.ts +6 -0
  63. package/dest/api/fee.d.ts.map +1 -0
  64. package/dest/api/fee.js +4 -0
  65. package/dest/api/fields.d.ts +2 -0
  66. package/dest/api/fields.d.ts.map +1 -0
  67. package/dest/api/fields.js +1 -0
  68. package/dest/api/interfaces/pxe.d.ts +2 -0
  69. package/dest/api/interfaces/pxe.d.ts.map +1 -0
  70. package/dest/api/interfaces/pxe.js +1 -0
  71. package/dest/api/log.d.ts +2 -0
  72. package/dest/api/log.d.ts.map +1 -0
  73. package/dest/api/log.js +1 -0
  74. package/dest/api/log_id.d.ts +2 -0
  75. package/dest/api/log_id.d.ts.map +1 -0
  76. package/dest/api/log_id.js +1 -0
  77. package/dest/api/tx_hash.d.ts +2 -0
  78. package/dest/api/tx_hash.d.ts.map +1 -0
  79. package/dest/api/tx_hash.js +1 -0
  80. package/dest/api/wallet.d.ts +2 -0
  81. package/dest/api/wallet.d.ts.map +1 -0
  82. package/dest/api/wallet.js +1 -0
  83. package/dest/contract/base_contract_interaction.d.ts +98 -0
  84. package/dest/contract/base_contract_interaction.d.ts.map +1 -0
  85. package/dest/contract/base_contract_interaction.js +149 -0
  86. package/dest/contract/batch_call.d.ts +28 -0
  87. package/dest/contract/batch_call.d.ts.map +1 -0
  88. package/dest/contract/batch_call.js +91 -0
  89. package/dest/contract/checker.d.ts +11 -0
  90. package/dest/contract/checker.d.ts.map +1 -0
  91. package/dest/contract/checker.js +107 -0
  92. package/dest/contract/contract.d.ts +41 -0
  93. package/dest/contract/contract.d.ts.map +1 -0
  94. package/dest/contract/contract.js +52 -0
  95. package/dest/contract/contract_base.d.ts +61 -0
  96. package/dest/contract/contract_base.d.ts.map +1 -0
  97. package/dest/contract/contract_base.js +45 -0
  98. package/dest/contract/contract_function_interaction.d.ts +68 -0
  99. package/dest/contract/contract_function_interaction.d.ts.map +1 -0
  100. package/dest/contract/contract_function_interaction.js +122 -0
  101. package/dest/contract/deploy_method.d.ts +113 -0
  102. package/dest/contract/deploy_method.d.ts.map +1 -0
  103. package/dest/contract/deploy_method.js +212 -0
  104. package/dest/contract/deploy_proven_tx.d.ts +21 -0
  105. package/dest/contract/deploy_proven_tx.d.ts.map +1 -0
  106. package/dest/contract/deploy_proven_tx.js +19 -0
  107. package/dest/contract/deploy_sent_tx.d.ts +45 -0
  108. package/dest/contract/deploy_sent_tx.d.ts.map +1 -0
  109. package/dest/contract/deploy_sent_tx.js +43 -0
  110. package/dest/contract/get_gas_limits.d.ts +18 -0
  111. package/dest/contract/get_gas_limits.d.ts.map +1 -0
  112. package/dest/contract/get_gas_limits.js +10 -0
  113. package/dest/contract/index.d.ts +45 -0
  114. package/dest/contract/index.d.ts.map +1 -0
  115. package/dest/contract/index.js +43 -0
  116. package/dest/contract/protocol_contracts.d.ts +9 -0
  117. package/dest/contract/protocol_contracts.d.ts.map +1 -0
  118. package/dest/contract/protocol_contracts.js +26 -0
  119. package/dest/contract/proven_tx.d.ts +17 -0
  120. package/dest/contract/proven_tx.d.ts.map +1 -0
  121. package/dest/contract/proven_tx.js +22 -0
  122. package/dest/contract/sent_tx.d.ts +61 -0
  123. package/dest/contract/sent_tx.d.ts.map +1 -0
  124. package/dest/contract/sent_tx.js +102 -0
  125. package/dest/contract/unsafe_contract.d.ts +15 -0
  126. package/dest/contract/unsafe_contract.d.ts.map +1 -0
  127. package/dest/contract/unsafe_contract.js +6 -0
  128. package/dest/deployment/broadcast_function.d.ts +24 -0
  129. package/dest/deployment/broadcast_function.d.ts.map +1 -0
  130. package/dest/deployment/broadcast_function.js +70 -0
  131. package/dest/deployment/contract_deployer.d.ts +27 -0
  132. package/dest/deployment/contract_deployer.d.ts.map +1 -0
  133. package/dest/deployment/contract_deployer.js +30 -0
  134. package/dest/deployment/deploy_instance.d.ts +10 -0
  135. package/dest/deployment/deploy_instance.d.ts.map +1 -0
  136. package/dest/deployment/deploy_instance.js +14 -0
  137. package/dest/deployment/index.d.ts +2 -0
  138. package/dest/deployment/index.d.ts.map +1 -0
  139. package/dest/deployment/index.js +1 -0
  140. package/dest/deployment/register_class.d.ts +6 -0
  141. package/dest/deployment/register_class.d.ts.map +1 -0
  142. package/dest/deployment/register_class.js +22 -0
  143. package/dest/entrypoint/default_entrypoint.d.ts +12 -0
  144. package/dest/entrypoint/default_entrypoint.d.ts.map +1 -0
  145. package/dest/entrypoint/default_entrypoint.js +28 -0
  146. package/dest/entrypoint/default_multi_call_entrypoint.d.ts +15 -0
  147. package/dest/entrypoint/default_multi_call_entrypoint.d.ts.map +1 -0
  148. package/dest/entrypoint/default_multi_call_entrypoint.js +130 -0
  149. package/dest/entrypoint/entrypoint.d.ts +35 -0
  150. package/dest/entrypoint/entrypoint.d.ts.map +1 -0
  151. package/dest/entrypoint/entrypoint.js +4 -0
  152. package/dest/entrypoint/payload.d.ts +128 -0
  153. package/dest/entrypoint/payload.d.ts.map +1 -0
  154. package/dest/entrypoint/payload.js +143 -0
  155. package/dest/fee/fee_juice_payment_method.d.ts +14 -0
  156. package/dest/fee/fee_juice_payment_method.d.ts.map +1 -0
  157. package/dest/fee/fee_juice_payment_method.js +20 -0
  158. package/dest/fee/fee_juice_payment_method_with_claim.d.ts +18 -0
  159. package/dest/fee/fee_juice_payment_method_with_claim.d.ts.map +1 -0
  160. package/dest/fee/fee_juice_payment_method_with_claim.js +37 -0
  161. package/dest/fee/fee_payment_method.d.ts +22 -0
  162. package/dest/fee/fee_payment_method.d.ts.map +1 -0
  163. package/dest/fee/fee_payment_method.js +3 -0
  164. package/dest/fee/private_fee_payment_method.d.ts +51 -0
  165. package/dest/fee/private_fee_payment_method.d.ts.map +1 -0
  166. package/dest/fee/private_fee_payment_method.js +103 -0
  167. package/dest/fee/public_fee_payment_method.d.ts +41 -0
  168. package/dest/fee/public_fee_payment_method.d.ts.map +1 -0
  169. package/dest/fee/public_fee_payment_method.js +97 -0
  170. package/dest/index.d.ts +66 -0
  171. package/dest/index.d.ts.map +1 -0
  172. package/dest/index.js +69 -0
  173. package/dest/rpc_clients/index.d.ts +3 -0
  174. package/dest/rpc_clients/index.d.ts.map +1 -0
  175. package/dest/rpc_clients/index.js +2 -0
  176. package/dest/rpc_clients/node/index.d.ts +12 -0
  177. package/dest/rpc_clients/node/index.d.ts.map +1 -0
  178. package/dest/rpc_clients/node/index.js +78 -0
  179. package/dest/rpc_clients/pxe_client.d.ts +10 -0
  180. package/dest/rpc_clients/pxe_client.d.ts.map +1 -0
  181. package/dest/rpc_clients/pxe_client.js +23 -0
  182. package/dest/utils/abi_types.d.ts +29 -0
  183. package/dest/utils/abi_types.d.ts.map +1 -0
  184. package/dest/utils/abi_types.js +1 -0
  185. package/dest/utils/authwit.d.ts +60 -0
  186. package/dest/utils/authwit.d.ts.map +1 -0
  187. package/dest/utils/authwit.js +74 -0
  188. package/dest/utils/aztec_cheatcodes.d.ts +59 -0
  189. package/dest/utils/aztec_cheatcodes.d.ts.map +1 -0
  190. package/dest/utils/aztec_cheatcodes.js +62 -0
  191. package/dest/utils/fee_juice.d.ts +7 -0
  192. package/dest/utils/fee_juice.d.ts.map +1 -0
  193. package/dest/utils/fee_juice.js +9 -0
  194. package/dest/utils/field_compressed_string.d.ts +17 -0
  195. package/dest/utils/field_compressed_string.d.ts.map +1 -0
  196. package/dest/utils/field_compressed_string.js +15 -0
  197. package/dest/utils/index.d.ts +8 -0
  198. package/dest/utils/index.d.ts.map +1 -0
  199. package/dest/utils/index.js +6 -0
  200. package/dest/utils/node.d.ts +5 -0
  201. package/dest/utils/node.d.ts.map +1 -0
  202. package/dest/utils/node.js +15 -0
  203. package/dest/utils/pub_key.d.ts +9 -0
  204. package/dest/utils/pub_key.d.ts.map +1 -0
  205. package/dest/utils/pub_key.js +9 -0
  206. package/dest/utils/pxe.d.ts +4 -0
  207. package/dest/utils/pxe.d.ts.map +1 -0
  208. package/dest/utils/pxe.js +14 -0
  209. package/dest/wallet/account_wallet.d.ts +76 -0
  210. package/dest/wallet/account_wallet.d.ts.map +1 -0
  211. package/dest/wallet/account_wallet.js +231 -0
  212. package/dest/wallet/account_wallet_with_private_key.d.ts +26 -0
  213. package/dest/wallet/account_wallet_with_private_key.d.ts.map +1 -0
  214. package/dest/wallet/account_wallet_with_private_key.js +22 -0
  215. package/dest/wallet/base_wallet.d.ts +73 -0
  216. package/dest/wallet/base_wallet.d.ts.map +1 -0
  217. package/dest/wallet/base_wallet.js +123 -0
  218. package/dest/wallet/index.d.ts +17 -0
  219. package/dest/wallet/index.d.ts.map +1 -0
  220. package/dest/wallet/index.js +20 -0
  221. package/dest/wallet/signerless_wallet.d.ts +25 -0
  222. package/dest/wallet/signerless_wallet.d.ts.map +1 -0
  223. package/dest/wallet/signerless_wallet.js +36 -0
  224. package/package.json +116 -0
  225. package/src/account/contract.ts +56 -0
  226. package/src/account/index.ts +16 -0
  227. package/src/account/interface.ts +36 -0
  228. package/src/account/wallet.ts +13 -0
  229. package/src/account_manager/deploy_account_method.ts +86 -0
  230. package/src/account_manager/deploy_account_sent_tx.ts +42 -0
  231. package/src/account_manager/index.ts +229 -0
  232. package/src/api/README.md +7 -0
  233. package/src/api/abi.ts +10 -0
  234. package/src/api/account.ts +10 -0
  235. package/src/api/addresses.ts +2 -0
  236. package/src/api/cheat_codes.ts +35 -0
  237. package/src/api/deployment.ts +3 -0
  238. package/src/api/entrypoint.ts +1 -0
  239. package/src/api/eth_address.ts +1 -0
  240. package/src/api/ethereum/anvil_test_watcher.ts +158 -0
  241. package/src/api/ethereum/chain_monitor.ts +88 -0
  242. package/src/api/ethereum/cheat_codes.ts +184 -0
  243. package/src/api/ethereum/index.ts +19 -0
  244. package/src/api/ethereum/l1_contracts.ts +21 -0
  245. package/src/api/ethereum/portal_manager.ts +410 -0
  246. package/src/api/fee.ts +5 -0
  247. package/src/api/fields.ts +1 -0
  248. package/src/api/interfaces/pxe.ts +1 -0
  249. package/src/api/log.ts +1 -0
  250. package/src/api/log_id.ts +1 -0
  251. package/src/api/tx_hash.ts +1 -0
  252. package/src/api/wallet.ts +7 -0
  253. package/src/contract/base_contract_interaction.ts +192 -0
  254. package/src/contract/batch_call.ts +95 -0
  255. package/src/contract/checker.ts +117 -0
  256. package/src/contract/contract.ts +69 -0
  257. package/src/contract/contract_base.ts +90 -0
  258. package/src/contract/contract_function_interaction.ts +173 -0
  259. package/src/contract/deploy_method.ts +271 -0
  260. package/src/contract/deploy_proven_tx.ts +34 -0
  261. package/src/contract/deploy_sent_tx.ts +74 -0
  262. package/src/contract/get_gas_limits.ts +26 -0
  263. package/src/contract/index.ts +48 -0
  264. package/src/contract/protocol_contracts.ts +35 -0
  265. package/src/contract/proven_tx.ts +42 -0
  266. package/src/contract/sent_tx.ts +141 -0
  267. package/src/contract/unsafe_contract.ts +19 -0
  268. package/src/deployment/broadcast_function.ts +148 -0
  269. package/src/deployment/contract_deployer.ts +41 -0
  270. package/src/deployment/deploy_instance.ts +31 -0
  271. package/src/deployment/index.ts +1 -0
  272. package/src/deployment/register_class.ts +44 -0
  273. package/src/entrypoint/default_entrypoint.ts +39 -0
  274. package/src/entrypoint/default_multi_call_entrypoint.ts +93 -0
  275. package/src/entrypoint/entrypoint.ts +39 -0
  276. package/src/entrypoint/payload.ts +238 -0
  277. package/src/fee/fee_juice_payment_method.ts +26 -0
  278. package/src/fee/fee_juice_payment_method_with_claim.ts +49 -0
  279. package/src/fee/fee_payment_method.ts +22 -0
  280. package/src/fee/private_fee_payment_method.ts +118 -0
  281. package/src/fee/public_fee_payment_method.ts +114 -0
  282. package/src/index.ts +106 -0
  283. package/src/rpc_clients/index.ts +2 -0
  284. package/src/rpc_clients/node/index.ts +77 -0
  285. package/src/rpc_clients/pxe_client.ts +25 -0
  286. package/src/utils/abi_types.ts +25 -0
  287. package/src/utils/authwit.ts +110 -0
  288. package/src/utils/aztec_cheatcodes.ts +77 -0
  289. package/src/utils/fee_juice.ts +14 -0
  290. package/src/utils/field_compressed_string.ts +27 -0
  291. package/src/utils/index.ts +21 -0
  292. package/src/utils/node.ts +19 -0
  293. package/src/utils/pub_key.ts +13 -0
  294. package/src/utils/pxe.ts +17 -0
  295. package/src/wallet/account_wallet.ts +242 -0
  296. package/src/wallet/account_wallet_with_private_key.ts +40 -0
  297. package/src/wallet/base_wallet.ts +198 -0
  298. package/src/wallet/index.ts +33 -0
  299. package/src/wallet/signerless_wallet.ts +52 -0
package/README.md ADDED
@@ -0,0 +1,44 @@
1
+ # Aztec.js
2
+
3
+ Aztec.js is a library that provides APIs for managing accounts and interacting with contracts on the Aztec network. It communicates with the [Private eXecution Environment (PXE)](https://docs.aztec.network/developers/reference/aztecjs/pxe) through a `PXE` implementation, allowing developers to easily register new accounts, deploy contracts, view functions, and send transactions.
4
+
5
+ ## Installing
6
+
7
+ ```
8
+ npm install @aztec/aztec.js
9
+ ```
10
+
11
+ ## Usage
12
+
13
+ Use the `@aztec/accounts` package in order to create and manage accounts, and acquire a `Wallet` object needed to send transactions and interact with the network.
14
+
15
+ ### Deploy a contract
16
+
17
+ ```typescript
18
+ import { Contract } from '@aztec/aztec.js';
19
+
20
+ const contract = await Contract.deploy(wallet, MyContractArtifact, [...constructorArgs])
21
+ .send()
22
+ .deployed();
23
+ console.log(`Contract deployed at ${contract.address}`);
24
+ ```
25
+
26
+ ### Send a transaction
27
+
28
+ ```typescript
29
+ import { Contract } from '@aztec/aztec.js';
30
+
31
+ const contract = await Contract.at(contractAddress, MyContractArtifact, wallet);
32
+ const tx = await contract.methods.transfer(amount, recipientAddress).send().wait();
33
+ console.log(`Transferred ${amount} to ${recipientAddress} on block ${tx.blockNumber}`);
34
+ ```
35
+
36
+ ### Simulate a function
37
+
38
+ ```typescript
39
+ import { Contract } from '@aztec/aztec.js';
40
+
41
+ const contract = await Contract.at(contractAddress, MyContractArtifact, wallet);
42
+ const balance = await contract.methods.get_balance(wallet.getAddress()).simulate();
43
+ console.log(`Account balance is ${balance}`);
44
+ ```
@@ -0,0 +1,37 @@
1
+ import { Fr } from '@aztec/foundation/fields';
2
+ import type { ContractArtifact } from '@aztec/stdlib/abi';
3
+ import type { CompleteAddress, NodeInfo } from '@aztec/stdlib/contract';
4
+ import type { AccountInterface, AuthWitnessProvider } from './interface.js';
5
+ /**
6
+ * An account contract instance. Knows its artifact, deployment arguments, how to create
7
+ * transaction execution requests out of function calls, and how to authorize actions.
8
+ */
9
+ export interface AccountContract {
10
+ /**
11
+ * Returns the artifact of this account contract.
12
+ */
13
+ getContractArtifact(): Promise<ContractArtifact>;
14
+ /**
15
+ * Returns the deployment arguments for this instance, or undefined if this contract does not require deployment.
16
+ */
17
+ getDeploymentArgs(): Promise<any[] | undefined>;
18
+ /**
19
+ * Returns the account interface for this account contract given a deployment at the provided address.
20
+ * The account interface is responsible for assembling tx requests given requested function calls, and
21
+ * for creating signed auth witnesses given action identifiers (message hashes).
22
+ * @param address - Address where this account contract is deployed.
23
+ * @param nodeInfo - Info on the chain where it is deployed.
24
+ * @returns An account interface instance for creating tx requests and authorizing actions.
25
+ */
26
+ getInterface(address: CompleteAddress, nodeInfo: NodeInfo): AccountInterface;
27
+ /**
28
+ * Returns the auth witness provider for the given address.
29
+ * @param address - Address for which to create auth witnesses.
30
+ */
31
+ getAuthWitnessProvider(address: CompleteAddress): AuthWitnessProvider;
32
+ }
33
+ /**
34
+ * Compute the address of an account contract from secret and salt.
35
+ */
36
+ export declare function getAccountContractAddress(accountContract: AccountContract, secret: Fr, salt: Fr): Promise<import("@aztec/stdlib/aztec-address").AztecAddress>;
37
+ //# sourceMappingURL=contract.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"contract.d.ts","sourceRoot":"","sources":["../../src/account/contract.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAC9C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,KAAK,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAIxE,OAAO,KAAK,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAG5E;;;GAGG;AACH,MAAM,WAAW,eAAe;IAC9B;;OAEG;IACH,mBAAmB,IAAI,OAAO,CAAC,gBAAgB,CAAC,CAAC;IAEjD;;OAEG;IACH,iBAAiB,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC,CAAC;IAEhD;;;;;;;OAOG;IACH,YAAY,CAAC,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,QAAQ,GAAG,gBAAgB,CAAC;IAE7E;;;OAGG;IACH,sBAAsB,CAAC,OAAO,EAAE,eAAe,GAAG,mBAAmB,CAAC;CACvE;AAGD;;GAEG;AACH,wBAAsB,yBAAyB,CAAC,eAAe,EAAE,eAAe,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,+DAUrG"}
@@ -0,0 +1,16 @@
1
+ import { getContractInstanceFromDeployParams } from '@aztec/stdlib/contract';
2
+ import { deriveKeys } from '@aztec/stdlib/keys';
3
+ // docs:end:account-contract-interface
4
+ /**
5
+ * Compute the address of an account contract from secret and salt.
6
+ */ export async function getAccountContractAddress(accountContract, secret, salt) {
7
+ const { publicKeys } = await deriveKeys(secret);
8
+ const constructorArgs = await accountContract.getDeploymentArgs();
9
+ const artifact = await accountContract.getContractArtifact();
10
+ const instance = await getContractInstanceFromDeployParams(artifact, {
11
+ constructorArgs,
12
+ salt,
13
+ publicKeys
14
+ });
15
+ return instance.address;
16
+ }
@@ -0,0 +1,15 @@
1
+ /**
2
+ * The `account` module provides utilities for managing accounts. The {@link AccountManager} class
3
+ * allows to deploy and register a fresh account, or to obtain a `Wallet` instance out of an account
4
+ * already deployed. Use the `@aztec/accounts` package to load default account implementations that rely
5
+ * on ECDSA or Schnorr signatures.
6
+ *
7
+ * @packageDocumentation
8
+ */
9
+ import type { Fr } from '@aztec/foundation/fields';
10
+ export { type AccountContract, getAccountContractAddress } from './contract.js';
11
+ export { type AccountInterface, type AuthWitnessProvider } from './interface.js';
12
+ export * from './wallet.js';
13
+ /** A contract deployment salt. */
14
+ export type Salt = Fr | number | bigint;
15
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/account/index.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAEnD,OAAO,EAAE,KAAK,eAAe,EAAE,yBAAyB,EAAE,MAAM,eAAe,CAAC;AAChF,OAAO,EAAE,KAAK,gBAAgB,EAAE,KAAK,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AACjF,cAAc,aAAa,CAAC;AAE5B,kCAAkC;AAClC,MAAM,MAAM,IAAI,GAAG,EAAE,GAAG,MAAM,GAAG,MAAM,CAAC"}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * The `account` module provides utilities for managing accounts. The {@link AccountManager} class
3
+ * allows to deploy and register a fresh account, or to obtain a `Wallet` instance out of an account
4
+ * already deployed. Use the `@aztec/accounts` package to load default account implementations that rely
5
+ * on ECDSA or Schnorr signatures.
6
+ *
7
+ * @packageDocumentation
8
+ */ export { getAccountContractAddress } from './contract.js';
9
+ export * from './wallet.js';
@@ -0,0 +1,31 @@
1
+ /// <reference types="node" resolution-mode="require"/>
2
+ /// <reference types="node" resolution-mode="require"/>
3
+ import type { Fr } from '@aztec/foundation/fields';
4
+ import type { AuthWitness } from '@aztec/stdlib/auth-witness';
5
+ import type { AztecAddress } from '@aztec/stdlib/aztec-address';
6
+ import type { CompleteAddress } from '@aztec/stdlib/contract';
7
+ import type { EntrypointInterface } from '../entrypoint/entrypoint.js';
8
+ /** Creates authorization witnesses. */
9
+ export interface AuthWitnessProvider {
10
+ /**
11
+ * Computes an authentication witness from either a message hash
12
+ * @param messageHash - The message hash to approve
13
+ * @returns The authentication witness
14
+ */
15
+ createAuthWit(messageHash: Fr | Buffer): Promise<AuthWitness>;
16
+ }
17
+ /**
18
+ * Handler for interfacing with an account. Knows how to create transaction execution
19
+ * requests and authorize actions for its corresponding account.
20
+ */
21
+ export interface AccountInterface extends EntrypointInterface, AuthWitnessProvider {
22
+ /** Returns the complete address for this account. */
23
+ getCompleteAddress(): CompleteAddress;
24
+ /** Returns the address for this account. */
25
+ getAddress(): AztecAddress;
26
+ /** Returns the chain id for this account */
27
+ getChainId(): Fr;
28
+ /** Returns the rollup version for this account */
29
+ getVersion(): Fr;
30
+ }
31
+ //# sourceMappingURL=interface.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../src/account/interface.ts"],"names":[],"mappings":";;AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AACnD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAChE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAE9D,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAC;AAGvE,uCAAuC;AACvC,MAAM,WAAW,mBAAmB;IAClC;;;;OAIG;IACH,aAAa,CAAC,WAAW,EAAE,EAAE,GAAG,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;CAC/D;AAED;;;GAGG;AACH,MAAM,WAAW,gBAAiB,SAAQ,mBAAmB,EAAE,mBAAmB;IAChF,qDAAqD;IACrD,kBAAkB,IAAI,eAAe,CAAC;IAEtC,4CAA4C;IAC5C,UAAU,IAAI,YAAY,CAAC;IAE3B,4CAA4C;IAC5C,UAAU,IAAI,EAAE,CAAC;IAEjB,kDAAkD;IAClD,UAAU,IAAI,EAAE,CAAC;CAClB"}
@@ -0,0 +1,4 @@
1
+ /**
2
+ * Handler for interfacing with an account. Knows how to create transaction execution
3
+ * requests and authorize actions for its corresponding account.
4
+ */ export { }; // docs:end:account-interface
@@ -0,0 +1,11 @@
1
+ import type { AuthWitness } from '@aztec/stdlib/auth-witness';
2
+ import type { PXE } from '@aztec/stdlib/interfaces/client';
3
+ import type { IntentAction, IntentInnerHash } from '../utils/authwit.js';
4
+ import type { AccountInterface } from './interface.js';
5
+ /**
6
+ * The wallet interface.
7
+ */
8
+ export type Wallet = AccountInterface & PXE & {
9
+ createAuthWit(intent: IntentInnerHash | IntentAction): Promise<AuthWitness>;
10
+ };
11
+ //# sourceMappingURL=wallet.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"wallet.d.ts","sourceRoot":"","sources":["../../src/account/wallet.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,iCAAiC,CAAC;AAE3D,OAAO,KAAK,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACzE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAEvD;;GAEG;AACH,MAAM,MAAM,MAAM,GAAG,gBAAgB,GACnC,GAAG,GAAG;IACJ,aAAa,CAAC,MAAM,EAAE,eAAe,GAAG,YAAY,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;CAC7E,CAAC"}
@@ -0,0 +1,3 @@
1
+ /**
2
+ * The wallet interface.
3
+ */ export { };
@@ -0,0 +1,15 @@
1
+ import { type ContractArtifact, type FunctionArtifact } from '@aztec/stdlib/abi';
2
+ import type { PublicKeys } from '@aztec/stdlib/keys';
3
+ import type { AuthWitnessProvider } from '../account/interface.js';
4
+ import type { Wallet } from '../account/wallet.js';
5
+ import type { ExecutionRequestInit } from '../api/entrypoint.js';
6
+ import { DeployMethod, type DeployOptions } from '../contract/deploy_method.js';
7
+ /**
8
+ * Contract interaction for deploying an account contract. Handles fee preparation and contract initialization.
9
+ */
10
+ export declare class DeployAccountMethod extends DeployMethod {
11
+ #private;
12
+ constructor(authWitnessProvider: AuthWitnessProvider, publicKeys: PublicKeys, wallet: Wallet, artifact: ContractArtifact, args?: any[], constructorNameOrArtifact?: string | FunctionArtifact, feePaymentNameOrArtifact?: string | FunctionArtifact);
13
+ protected getInitializeFunctionCalls(options: DeployOptions): Promise<Pick<ExecutionRequestInit, 'calls' | 'authWitnesses' | 'hashedArguments'>>;
14
+ }
15
+ //# sourceMappingURL=deploy_account_method.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"deploy_account_method.d.ts","sourceRoot":"","sources":["../../src/account_manager/deploy_account_method.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,gBAAgB,EACrB,KAAK,gBAAgB,EAItB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAErD,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAEjE,OAAO,EAAE,YAAY,EAAE,KAAK,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAGhF;;GAEG;AACH,qBAAa,mBAAoB,SAAQ,YAAY;;gBAKjD,mBAAmB,EAAE,mBAAmB,EACxC,UAAU,EAAE,UAAU,EACtB,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,gBAAgB,EAC1B,IAAI,GAAE,GAAG,EAAO,EAChB,yBAAyB,CAAC,EAAE,MAAM,GAAG,gBAAgB,EACrD,wBAAwB,CAAC,EAAE,MAAM,GAAG,gBAAgB;cAkB7B,0BAA0B,CACjD,OAAO,EAAE,aAAa,GACrB,OAAO,CAAC,IAAI,CAAC,oBAAoB,EAAE,OAAO,GAAG,eAAe,GAAG,iBAAiB,CAAC,CAAC;CAmCtF"}
@@ -0,0 +1,43 @@
1
+ import { FunctionSelector, encodeArguments, getFunctionArtifactByName } from '@aztec/stdlib/abi';
2
+ import { Contract } from '../contract/contract.js';
3
+ import { DeployMethod } from '../contract/deploy_method.js';
4
+ import { EntrypointPayload, computeCombinedPayloadHash } from '../entrypoint/payload.js';
5
+ /**
6
+ * Contract interaction for deploying an account contract. Handles fee preparation and contract initialization.
7
+ */ export class DeployAccountMethod extends DeployMethod {
8
+ #authWitnessProvider;
9
+ #feePaymentArtifact;
10
+ constructor(authWitnessProvider, publicKeys, wallet, artifact, args = [], constructorNameOrArtifact, feePaymentNameOrArtifact){
11
+ super(publicKeys, wallet, artifact, (address, wallet)=>Contract.at(address, artifact, wallet), args, constructorNameOrArtifact);
12
+ this.#authWitnessProvider = authWitnessProvider;
13
+ this.#feePaymentArtifact = typeof feePaymentNameOrArtifact === 'string' ? getFunctionArtifactByName(artifact, feePaymentNameOrArtifact) : feePaymentNameOrArtifact;
14
+ }
15
+ async getInitializeFunctionCalls(options) {
16
+ const exec = await super.getInitializeFunctionCalls(options);
17
+ if (options.fee && this.#feePaymentArtifact) {
18
+ const { address } = await this.getInstance();
19
+ const emptyAppPayload = await EntrypointPayload.fromAppExecution([]);
20
+ const fee = await this.getDefaultFeeOptions(options.fee);
21
+ const feePayload = await EntrypointPayload.fromFeeOptions(address, fee);
22
+ exec.calls.push({
23
+ name: this.#feePaymentArtifact.name,
24
+ to: address,
25
+ args: encodeArguments(this.#feePaymentArtifact, [
26
+ emptyAppPayload,
27
+ feePayload,
28
+ false
29
+ ]),
30
+ selector: await FunctionSelector.fromNameAndParameters(this.#feePaymentArtifact.name, this.#feePaymentArtifact.parameters),
31
+ type: this.#feePaymentArtifact.functionType,
32
+ isStatic: this.#feePaymentArtifact.isStatic,
33
+ returnTypes: this.#feePaymentArtifact.returnTypes
34
+ });
35
+ exec.authWitnesses ??= [];
36
+ exec.hashedArguments ??= [];
37
+ exec.authWitnesses.push(await this.#authWitnessProvider.createAuthWit(await computeCombinedPayloadHash(emptyAppPayload, feePayload)));
38
+ exec.hashedArguments.push(...emptyAppPayload.hashedArguments);
39
+ exec.hashedArguments.push(...feePayload.hashedArguments);
40
+ }
41
+ return exec;
42
+ }
43
+ }
@@ -0,0 +1,30 @@
1
+ import type { FieldsOf } from '@aztec/foundation/types';
2
+ import type { PXE } from '@aztec/stdlib/interfaces/client';
3
+ import type { TxHash, TxReceipt } from '@aztec/stdlib/tx';
4
+ import type { Wallet } from '../account/index.js';
5
+ import { SentTx, type WaitOpts } from '../contract/sent_tx.js';
6
+ /** Extends a transaction receipt with a wallet instance for the newly deployed contract. */
7
+ export type DeployAccountTxReceipt = FieldsOf<TxReceipt> & {
8
+ /** Wallet that corresponds to the newly deployed account contract. */
9
+ wallet: Wallet;
10
+ };
11
+ /**
12
+ * A deployment transaction for an account contract sent to the network, extending SentTx with methods to get the resulting wallet.
13
+ */
14
+ export declare class DeployAccountSentTx extends SentTx {
15
+ private getWalletPromise;
16
+ constructor(pxe: PXE, txHashPromise: Promise<TxHash>, getWalletPromise: Promise<Wallet>);
17
+ /**
18
+ * Awaits for the tx to be mined and returns the contract instance. Throws if tx is not mined.
19
+ * @param opts - Options for configuring the waiting for the tx to be mined.
20
+ * @returns The deployed contract instance.
21
+ */
22
+ getWallet(opts?: WaitOpts): Promise<Wallet>;
23
+ /**
24
+ * Awaits for the tx to be mined and returns the receipt along with a wallet instance. Throws if tx is not mined.
25
+ * @param opts - Options for configuring the waiting for the tx to be mined.
26
+ * @returns The transaction receipt with the wallet for the deployed account contract.
27
+ */
28
+ wait(opts?: WaitOpts): Promise<DeployAccountTxReceipt>;
29
+ }
30
+ //# sourceMappingURL=deploy_account_sent_tx.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"deploy_account_sent_tx.d.ts","sourceRoot":"","sources":["../../src/account_manager/deploy_account_sent_tx.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAC;AACxD,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,iCAAiC,CAAC;AAC3D,OAAO,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAE1D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAmB,MAAM,EAAE,KAAK,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAEhF,4FAA4F;AAC5F,MAAM,MAAM,sBAAsB,GAAG,QAAQ,CAAC,SAAS,CAAC,GAAG;IACzD,sEAAsE;IACtE,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF;;GAEG;AACH,qBAAa,mBAAoB,SAAQ,MAAM;IACS,OAAO,CAAC,gBAAgB;gBAAlE,GAAG,EAAE,GAAG,EAAE,aAAa,EAAE,OAAO,CAAC,MAAM,CAAC,EAAU,gBAAgB,EAAE,OAAO,CAAC,MAAM,CAAC;IAI/F;;;;OAIG;IACU,SAAS,CAAC,IAAI,CAAC,EAAE,QAAQ,GAAG,OAAO,CAAC,MAAM,CAAC;IAKxD;;;;OAIG;IACmB,IAAI,CAAC,IAAI,GAAE,QAA0B,GAAG,OAAO,CAAC,sBAAsB,CAAC;CAK9F"}
@@ -0,0 +1,29 @@
1
+ import { DefaultWaitOpts, SentTx } from '../contract/sent_tx.js';
2
+ /**
3
+ * A deployment transaction for an account contract sent to the network, extending SentTx with methods to get the resulting wallet.
4
+ */ export class DeployAccountSentTx extends SentTx {
5
+ getWalletPromise;
6
+ constructor(pxe, txHashPromise, getWalletPromise){
7
+ super(pxe, txHashPromise), this.getWalletPromise = getWalletPromise;
8
+ }
9
+ /**
10
+ * Awaits for the tx to be mined and returns the contract instance. Throws if tx is not mined.
11
+ * @param opts - Options for configuring the waiting for the tx to be mined.
12
+ * @returns The deployed contract instance.
13
+ */ async getWallet(opts) {
14
+ const receipt = await this.wait(opts);
15
+ return receipt.wallet;
16
+ }
17
+ /**
18
+ * Awaits for the tx to be mined and returns the receipt along with a wallet instance. Throws if tx is not mined.
19
+ * @param opts - Options for configuring the waiting for the tx to be mined.
20
+ * @returns The transaction receipt with the wallet for the deployed account contract.
21
+ */ async wait(opts = DefaultWaitOpts) {
22
+ const receipt = await super.wait(opts);
23
+ const wallet = await this.getWalletPromise;
24
+ return {
25
+ ...receipt,
26
+ wallet
27
+ };
28
+ }
29
+ }
@@ -0,0 +1,108 @@
1
+ import { Fr } from '@aztec/foundation/fields';
2
+ import { CompleteAddress, type ContractInstanceWithAddress } from '@aztec/stdlib/contract';
3
+ import type { PXE } from '@aztec/stdlib/interfaces/client';
4
+ import type { AccountContract } from '../account/contract.js';
5
+ import type { Salt, Wallet } from '../account/index.js';
6
+ import type { AccountInterface } from '../account/interface.js';
7
+ import { DeployMethod, type DeployOptions } from '../contract/deploy_method.js';
8
+ import { Contract } from '../contract/index.js';
9
+ import { type WaitOpts } from '../contract/sent_tx.js';
10
+ import { AccountWalletWithSecretKey } from '../wallet/index.js';
11
+ import { DeployAccountMethod } from './deploy_account_method.js';
12
+ import { DeployAccountSentTx } from './deploy_account_sent_tx.js';
13
+ /**
14
+ * Options to deploy an account contract.
15
+ */
16
+ export type DeployAccountOptions = Pick<DeployOptions, 'fee' | 'skipClassRegistration' | 'skipPublicDeployment' | 'skipInitialization'> & {
17
+ /**
18
+ * Wallet used for deploying the account contract. Must be funded in order to pay for the fee.
19
+ */
20
+ deployWallet?: Wallet;
21
+ };
22
+ /**
23
+ * Manages a user account. Provides methods for calculating the account's address, deploying the account contract,
24
+ * and creating and registering the user wallet in the PXE Service.
25
+ */
26
+ export declare class AccountManager {
27
+ private pxe;
28
+ private secretKey;
29
+ private accountContract;
30
+ private instance;
31
+ /**
32
+ * Deployment salt for the account contract
33
+ */
34
+ readonly salt: Salt;
35
+ private constructor();
36
+ static create(pxe: PXE, secretKey: Fr, accountContract: AccountContract, salt?: Salt): Promise<AccountManager>;
37
+ protected getPublicKeys(): import("@aztec/stdlib/keys").PublicKeys;
38
+ protected getPublicKeysHash(): Fr | Promise<Fr>;
39
+ /**
40
+ * Returns the entrypoint for this account as defined by its account contract.
41
+ * @returns An entrypoint.
42
+ */
43
+ getAccount(): Promise<AccountInterface>;
44
+ /**
45
+ * Gets the calculated complete address associated with this account.
46
+ * Does not require the account to be deployed or registered.
47
+ * @returns The address, partial address, and encryption public key.
48
+ */
49
+ getCompleteAddress(): Promise<CompleteAddress>;
50
+ /**
51
+ * Gets the address for this given account.
52
+ * Does not require the account to be deployed or registered.
53
+ * @returns The address.
54
+ */
55
+ getAddress(): import("@aztec/stdlib/aztec-address").AztecAddress;
56
+ /**
57
+ * Returns the contract instance definition associated with this account.
58
+ * Does not require the account to be deployed or registered.
59
+ * @returns ContractInstance instance.
60
+ */
61
+ getInstance(): ContractInstanceWithAddress;
62
+ /**
63
+ * Returns a Wallet instance associated with this account. Use it to create Contract
64
+ * instances to be interacted with from this account.
65
+ * @returns A Wallet instance.
66
+ */
67
+ getWallet(): Promise<AccountWalletWithSecretKey>;
68
+ /**
69
+ * Registers this account in the PXE Service and returns the associated wallet. Registering
70
+ * the account on the PXE Service is required for managing private state associated with it.
71
+ * Use the returned wallet to create Contract instances to be interacted with from this account.
72
+ * @param opts - Options to wait for the account to be synched.
73
+ * @returns A Wallet instance.
74
+ */
75
+ register(): Promise<AccountWalletWithSecretKey>;
76
+ /**
77
+ * Returns the pre-populated deployment method to deploy the account contract that backs this account.
78
+ * Typically you will not need this method and can call `deploy` directly. Use this for having finer
79
+ * grained control on when to create, simulate, and send the deployment tx.
80
+ * @param deployWallet - Wallet used for deploying the account contract.
81
+ * @returns A DeployMethod instance that deploys this account contract.
82
+ */
83
+ getDeployMethod(deployWallet?: Wallet): Promise<DeployMethod<Contract> | DeployAccountMethod>;
84
+ /**
85
+ * Deploys the account contract that backs this account.
86
+ * Does not register the associated class nor publicly deploy the instance by default.
87
+ * Uses the salt provided in the constructor or a randomly generated one.
88
+ * Registers the account in the PXE Service before deploying the contract.
89
+ * @param opts - Fee options to be used for the deployment.
90
+ * @returns A SentTx object that can be waited to get the associated Wallet.
91
+ */
92
+ deploy(opts?: DeployAccountOptions): DeployAccountSentTx;
93
+ /**
94
+ * Deploys the account contract that backs this account if needed and awaits the tx to be mined.
95
+ * Uses the salt provided in the constructor or a randomly generated one. If no initialization
96
+ * is required it skips the transaction, and only registers the account in the PXE Service.
97
+ * @param opts - Options to wait for the tx to be mined.
98
+ * @returns A Wallet instance.
99
+ */
100
+ waitSetup(opts?: DeployAccountOptions & WaitOpts): Promise<AccountWalletWithSecretKey>;
101
+ /**
102
+ * Returns whether this account contract has a constructor and needs deployment.
103
+ */
104
+ isDeployable(): Promise<boolean>;
105
+ }
106
+ export { DeployAccountMethod } from './deploy_account_method.js';
107
+ export { type DeployAccountTxReceipt, DeployAccountSentTx } from './deploy_account_sent_tx.js';
108
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/account_manager/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,KAAK,2BAA2B,EAAE,MAAM,wBAAwB,CAAC;AAE3F,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,iCAAiC,CAAC;AAG3D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAChE,OAAO,EAAE,YAAY,EAAE,KAAK,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAChF,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAmB,KAAK,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAExE,OAAO,EAAE,0BAA0B,EAAoB,MAAM,oBAAoB,CAAC;AAClF,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAC;AAElE;;GAEG;AACH,MAAM,MAAM,oBAAoB,GAAG,IAAI,CACrC,aAAa,EACb,KAAK,GAAG,uBAAuB,GAAG,sBAAsB,GAAG,oBAAoB,CAChF,GAAG;IACF;;OAEG;IACH,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,CAAC;AAEF;;;GAGG;AACH,qBAAa,cAAc;IAEvB,OAAO,CAAC,GAAG;IACX,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,eAAe;IACvB,OAAO,CAAC,QAAQ;IAChB;;OAEG;aACa,IAAI,EAAE,IAAI;IAR5B,OAAO;WAWM,MAAM,CAAC,GAAG,EAAE,GAAG,EAAE,SAAS,EAAE,EAAE,EAAE,eAAe,EAAE,eAAe,EAAE,IAAI,CAAC,EAAE,IAAI;IAc1F,SAAS,CAAC,aAAa;IAIvB,SAAS,CAAC,iBAAiB;IAI3B;;;OAGG;IACU,UAAU,IAAI,OAAO,CAAC,gBAAgB,CAAC;IAMpD;;;;OAIG;IACI,kBAAkB,IAAI,OAAO,CAAC,eAAe,CAAC;IAIrD;;;;OAIG;IACI,UAAU;IAIjB;;;;OAIG;IACI,WAAW,IAAI,2BAA2B;IAIjD;;;;OAIG;IACU,SAAS,IAAI,OAAO,CAAC,0BAA0B,CAAC;IAK7D;;;;;;OAMG;IACU,QAAQ,IAAI,OAAO,CAAC,0BAA0B,CAAC;IAW5D;;;;;;OAMG;IACU,eAAe,CAAC,YAAY,CAAC,EAAE,MAAM;IA2ClD;;;;;;;OAOG;IACI,MAAM,CAAC,IAAI,CAAC,EAAE,oBAAoB,GAAG,mBAAmB;IAgB/D;;;;;;OAMG;IACU,SAAS,CAAC,IAAI,GAAE,oBAAoB,GAAG,QAA0B,GAAG,OAAO,CAAC,0BAA0B,CAAC;IAKpH;;OAEG;IACU,YAAY;CAG1B;AAED,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,EAAE,KAAK,sBAAsB,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAC"}
@@ -0,0 +1,159 @@
1
+ import { Fr } from '@aztec/foundation/fields';
2
+ import { CompleteAddress } from '@aztec/stdlib/contract';
3
+ import { getContractInstanceFromDeployParams } from '@aztec/stdlib/contract';
4
+ import { deriveKeys } from '@aztec/stdlib/keys';
5
+ import { DeployMethod } from '../contract/deploy_method.js';
6
+ import { Contract } from '../contract/index.js';
7
+ import { DefaultWaitOpts } from '../contract/sent_tx.js';
8
+ import { DefaultMultiCallEntrypoint } from '../entrypoint/default_multi_call_entrypoint.js';
9
+ import { AccountWalletWithSecretKey, SignerlessWallet } from '../wallet/index.js';
10
+ import { DeployAccountMethod } from './deploy_account_method.js';
11
+ import { DeployAccountSentTx } from './deploy_account_sent_tx.js';
12
+ /**
13
+ * Manages a user account. Provides methods for calculating the account's address, deploying the account contract,
14
+ * and creating and registering the user wallet in the PXE Service.
15
+ */ export class AccountManager {
16
+ pxe;
17
+ secretKey;
18
+ accountContract;
19
+ instance;
20
+ salt;
21
+ constructor(pxe, secretKey, accountContract, instance, /**
22
+ * Deployment salt for the account contract
23
+ */ salt){
24
+ this.pxe = pxe;
25
+ this.secretKey = secretKey;
26
+ this.accountContract = accountContract;
27
+ this.instance = instance;
28
+ this.salt = salt;
29
+ }
30
+ static async create(pxe, secretKey, accountContract, salt) {
31
+ const { publicKeys } = await deriveKeys(secretKey);
32
+ salt = salt !== undefined ? new Fr(salt) : Fr.random();
33
+ const artifact = await accountContract.getContractArtifact();
34
+ const instance = await getContractInstanceFromDeployParams(artifact, {
35
+ constructorArgs: await accountContract.getDeploymentArgs(),
36
+ salt: salt,
37
+ publicKeys
38
+ });
39
+ return new AccountManager(pxe, secretKey, accountContract, instance, salt);
40
+ }
41
+ getPublicKeys() {
42
+ return this.instance.publicKeys;
43
+ }
44
+ getPublicKeysHash() {
45
+ return this.getPublicKeys().hash();
46
+ }
47
+ /**
48
+ * Returns the entrypoint for this account as defined by its account contract.
49
+ * @returns An entrypoint.
50
+ */ async getAccount() {
51
+ const nodeInfo = await this.pxe.getNodeInfo();
52
+ const completeAddress = await this.getCompleteAddress();
53
+ return this.accountContract.getInterface(completeAddress, nodeInfo);
54
+ }
55
+ /**
56
+ * Gets the calculated complete address associated with this account.
57
+ * Does not require the account to be deployed or registered.
58
+ * @returns The address, partial address, and encryption public key.
59
+ */ getCompleteAddress() {
60
+ return CompleteAddress.fromSecretKeyAndInstance(this.secretKey, this.instance);
61
+ }
62
+ /**
63
+ * Gets the address for this given account.
64
+ * Does not require the account to be deployed or registered.
65
+ * @returns The address.
66
+ */ getAddress() {
67
+ return this.instance.address;
68
+ }
69
+ /**
70
+ * Returns the contract instance definition associated with this account.
71
+ * Does not require the account to be deployed or registered.
72
+ * @returns ContractInstance instance.
73
+ */ getInstance() {
74
+ return this.instance;
75
+ }
76
+ /**
77
+ * Returns a Wallet instance associated with this account. Use it to create Contract
78
+ * instances to be interacted with from this account.
79
+ * @returns A Wallet instance.
80
+ */ async getWallet() {
81
+ const entrypoint = await this.getAccount();
82
+ return new AccountWalletWithSecretKey(this.pxe, entrypoint, this.secretKey, this.salt);
83
+ }
84
+ /**
85
+ * Registers this account in the PXE Service and returns the associated wallet. Registering
86
+ * the account on the PXE Service is required for managing private state associated with it.
87
+ * Use the returned wallet to create Contract instances to be interacted with from this account.
88
+ * @param opts - Options to wait for the account to be synched.
89
+ * @returns A Wallet instance.
90
+ */ async register() {
91
+ await this.pxe.registerContract({
92
+ artifact: await this.accountContract.getContractArtifact(),
93
+ instance: this.getInstance()
94
+ });
95
+ await this.pxe.registerAccount(this.secretKey, (await this.getCompleteAddress()).partialAddress);
96
+ return this.getWallet();
97
+ }
98
+ /**
99
+ * Returns the pre-populated deployment method to deploy the account contract that backs this account.
100
+ * Typically you will not need this method and can call `deploy` directly. Use this for having finer
101
+ * grained control on when to create, simulate, and send the deployment tx.
102
+ * @param deployWallet - Wallet used for deploying the account contract.
103
+ * @returns A DeployMethod instance that deploys this account contract.
104
+ */ async getDeployMethod(deployWallet) {
105
+ const artifact = await this.accountContract.getContractArtifact();
106
+ if (!await this.isDeployable()) {
107
+ throw new Error(`Account contract ${artifact.name} does not require deployment.`);
108
+ }
109
+ const completeAddress = await this.getCompleteAddress();
110
+ await this.pxe.registerAccount(this.secretKey, completeAddress.partialAddress);
111
+ const args = await this.accountContract.getDeploymentArgs() ?? [];
112
+ if (deployWallet) {
113
+ // If deploying using an existing wallet/account, treat it like regular contract deployment.
114
+ const thisWallet = await this.getWallet();
115
+ return new DeployMethod(this.getPublicKeys(), deployWallet, artifact, (address)=>Contract.at(address, artifact, thisWallet), args, 'constructor');
116
+ }
117
+ const { l1ChainId: chainId, protocolVersion } = await this.pxe.getNodeInfo();
118
+ // We use a signerless wallet with the multi call entrypoint in order to make multiple calls in one go.
119
+ // If we used getWallet, the deployment would get routed via the account contract entrypoint
120
+ // and it can't be used unless the contract is initialized.
121
+ const wallet = new SignerlessWallet(this.pxe, new DefaultMultiCallEntrypoint(chainId, protocolVersion));
122
+ return new DeployAccountMethod(this.accountContract.getAuthWitnessProvider(completeAddress), this.getPublicKeys(), wallet, artifact, args, 'constructor', 'entrypoint');
123
+ }
124
+ /**
125
+ * Deploys the account contract that backs this account.
126
+ * Does not register the associated class nor publicly deploy the instance by default.
127
+ * Uses the salt provided in the constructor or a randomly generated one.
128
+ * Registers the account in the PXE Service before deploying the contract.
129
+ * @param opts - Fee options to be used for the deployment.
130
+ * @returns A SentTx object that can be waited to get the associated Wallet.
131
+ */ deploy(opts) {
132
+ const sentTx = this.getDeployMethod(opts?.deployWallet).then((deployMethod)=>deployMethod.send({
133
+ contractAddressSalt: new Fr(this.salt),
134
+ skipClassRegistration: opts?.skipClassRegistration ?? true,
135
+ skipPublicDeployment: opts?.skipPublicDeployment ?? true,
136
+ skipInitialization: opts?.skipInitialization ?? false,
137
+ universalDeploy: true,
138
+ fee: opts?.fee
139
+ })).then((tx)=>tx.getTxHash());
140
+ return new DeployAccountSentTx(this.pxe, sentTx, this.getWallet());
141
+ }
142
+ /**
143
+ * Deploys the account contract that backs this account if needed and awaits the tx to be mined.
144
+ * Uses the salt provided in the constructor or a randomly generated one. If no initialization
145
+ * is required it skips the transaction, and only registers the account in the PXE Service.
146
+ * @param opts - Options to wait for the tx to be mined.
147
+ * @returns A Wallet instance.
148
+ */ async waitSetup(opts = DefaultWaitOpts) {
149
+ await (await this.isDeployable() ? this.deploy(opts).wait(opts) : this.register());
150
+ return this.getWallet();
151
+ }
152
+ /**
153
+ * Returns whether this account contract has a constructor and needs deployment.
154
+ */ async isDeployable() {
155
+ return await this.accountContract.getDeploymentArgs() !== undefined;
156
+ }
157
+ }
158
+ export { DeployAccountMethod } from './deploy_account_method.js';
159
+ export { DeployAccountSentTx } from './deploy_account_sent_tx.js';
@@ -0,0 +1,3 @@
1
+ export { type ContractArtifact, type FunctionArtifact, EventSelector, FunctionSelector, loadContractArtifact, contractArtifactToBuffer, contractArtifactFromBuffer, } from '@aztec/stdlib/abi';
2
+ export { type NoirCompiledContract } from '@aztec/stdlib/noir';
3
+ //# sourceMappingURL=abi.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"abi.d.ts","sourceRoot":"","sources":["../../src/api/abi.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,gBAAgB,EACrB,KAAK,gBAAgB,EACrB,aAAa,EACb,gBAAgB,EAChB,oBAAoB,EACpB,wBAAwB,EACxB,0BAA0B,GAC3B,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,KAAK,oBAAoB,EAAE,MAAM,oBAAoB,CAAC"}
@@ -0,0 +1 @@
1
+ export { EventSelector, FunctionSelector, loadContractArtifact, contractArtifactToBuffer, contractArtifactFromBuffer } from '@aztec/stdlib/abi';
@@ -0,0 +1,3 @@
1
+ export { type AccountContract, type AccountInterface, type AuthWitnessProvider, type Salt, type Wallet, getAccountContractAddress, } from '../account/index.js';
2
+ export { AccountManager } from '../account_manager/index.js';
3
+ //# sourceMappingURL=account.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"account.d.ts","sourceRoot":"","sources":["../../src/api/account.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,eAAe,EACpB,KAAK,gBAAgB,EACrB,KAAK,mBAAmB,EACxB,KAAK,IAAI,EACT,KAAK,MAAM,EACX,yBAAyB,GAC1B,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { getAccountContractAddress } from '../account/index.js';
2
+ export { AccountManager } from '../account_manager/index.js';
@@ -0,0 +1,3 @@
1
+ export { AztecAddress } from '@aztec/stdlib/aztec-address';
2
+ export { CompleteAddress } from '@aztec/stdlib/contract';
3
+ //# sourceMappingURL=addresses.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"addresses.d.ts","sourceRoot":"","sources":["../../src/api/addresses.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAC3D,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC"}