@aztec/aztec.js 0.7.10 → 0.8.5

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 (133) hide show
  1. package/README.md +25 -23
  2. package/dest/abis/ecdsa_account_contract.json +20 -8
  3. package/dest/abis/schnorr_account_contract.json +20 -8
  4. package/dest/abis/schnorr_single_key_account_contract.json +19 -7
  5. package/dest/account/defaults/default_entrypoint.js +3 -3
  6. package/dest/account/index.d.ts +33 -11
  7. package/dest/account/index.d.ts.map +1 -1
  8. package/dest/account/index.js +40 -18
  9. package/dest/account/manager/index.d.ts +8 -8
  10. package/dest/account/manager/index.d.ts.map +1 -1
  11. package/dest/account/manager/index.js +12 -12
  12. package/dest/{utils/account.d.ts → account/utils.d.ts} +10 -10
  13. package/dest/account/utils.d.ts.map +1 -0
  14. package/dest/account/utils.js +40 -0
  15. package/dest/contract/base_contract_interaction.d.ts +5 -5
  16. package/dest/contract/base_contract_interaction.d.ts.map +1 -1
  17. package/dest/contract/base_contract_interaction.js +6 -6
  18. package/dest/contract/contract.d.ts +1 -1
  19. package/dest/contract/contract.js +1 -1
  20. package/dest/contract/contract_base.d.ts +3 -3
  21. package/dest/contract/contract_base.d.ts.map +1 -1
  22. package/dest/contract/contract_base.js +2 -2
  23. package/dest/contract/contract_function_interaction.d.ts +2 -2
  24. package/dest/contract/contract_function_interaction.d.ts.map +1 -1
  25. package/dest/contract/index.d.ts +37 -0
  26. package/dest/contract/index.d.ts.map +1 -1
  27. package/dest/contract/index.js +38 -1
  28. package/dest/contract/sent_tx.d.ts +6 -6
  29. package/dest/contract/sent_tx.d.ts.map +1 -1
  30. package/dest/contract/sent_tx.js +9 -9
  31. package/dest/contract_deployer/contract_deployer.d.ts +4 -4
  32. package/dest/contract_deployer/contract_deployer.d.ts.map +1 -1
  33. package/dest/contract_deployer/contract_deployer.js +5 -5
  34. package/dest/contract_deployer/deploy_method.d.ts +5 -5
  35. package/dest/contract_deployer/deploy_method.d.ts.map +1 -1
  36. package/dest/contract_deployer/deploy_method.js +7 -7
  37. package/dest/contract_deployer/deploy_sent_tx.d.ts +2 -2
  38. package/dest/contract_deployer/deploy_sent_tx.d.ts.map +1 -1
  39. package/dest/contract_deployer/deploy_sent_tx.js +3 -3
  40. package/dest/index.d.ts +2 -2
  41. package/dest/index.d.ts.map +1 -1
  42. package/dest/index.js +3 -3
  43. package/dest/pxe_client.d.ts +4 -0
  44. package/dest/pxe_client.d.ts.map +1 -0
  45. package/dest/pxe_client.js +20 -0
  46. package/dest/sandbox/index.d.ts +8 -8
  47. package/dest/sandbox/index.d.ts.map +1 -1
  48. package/dest/sandbox/index.js +13 -13
  49. package/dest/utils/abi_types.d.ts +9 -1
  50. package/dest/utils/abi_types.d.ts.map +1 -1
  51. package/dest/utils/authwit.d.ts +12 -0
  52. package/dest/utils/authwit.d.ts.map +1 -0
  53. package/dest/utils/authwit.js +20 -0
  54. package/dest/utils/cheat_codes.d.ts +8 -8
  55. package/dest/utils/cheat_codes.d.ts.map +1 -1
  56. package/dest/utils/cheat_codes.js +11 -11
  57. package/dest/utils/index.d.ts +1 -1
  58. package/dest/utils/index.d.ts.map +1 -1
  59. package/dest/utils/index.js +2 -2
  60. package/dest/utils/l1_contracts.d.ts +1 -30
  61. package/dest/utils/l1_contracts.d.ts.map +1 -1
  62. package/dest/utils/l1_contracts.js +5 -6
  63. package/dest/utils/l2_contracts.d.ts +3 -3
  64. package/dest/utils/l2_contracts.d.ts.map +1 -1
  65. package/dest/utils/l2_contracts.js +4 -4
  66. package/dest/wallet/account_wallet.d.ts +2 -2
  67. package/dest/wallet/account_wallet.d.ts.map +1 -1
  68. package/dest/wallet/account_wallet.js +4 -4
  69. package/dest/wallet/base_wallet.d.ts +7 -5
  70. package/dest/wallet/base_wallet.d.ts.map +1 -1
  71. package/dest/wallet/base_wallet.js +35 -29
  72. package/dest/wallet/index.d.ts +2 -2
  73. package/dest/wallet/index.d.ts.map +1 -1
  74. package/dest/wallet/signerless_wallet.js +1 -1
  75. package/package.json +69 -6
  76. package/src/abis/ecdsa_account_contract.json +20 -8
  77. package/src/abis/schnorr_account_contract.json +20 -8
  78. package/src/abis/schnorr_single_key_account_contract.json +19 -7
  79. package/src/account/defaults/default_entrypoint.ts +2 -2
  80. package/src/account/index.ts +40 -18
  81. package/src/account/manager/index.ts +11 -11
  82. package/src/{utils/account.ts → account/utils.ts} +12 -12
  83. package/src/contract/base_contract_interaction.ts +7 -7
  84. package/src/contract/contract.ts +1 -1
  85. package/src/contract/contract_base.ts +2 -2
  86. package/src/contract/contract_function_interaction.ts +2 -2
  87. package/src/contract/index.ts +37 -0
  88. package/src/contract/sent_tx.ts +9 -9
  89. package/src/contract_deployer/contract_deployer.ts +4 -4
  90. package/src/contract_deployer/deploy_method.ts +8 -8
  91. package/src/contract_deployer/deploy_sent_tx.ts +4 -4
  92. package/src/index.ts +4 -2
  93. package/src/{aztec_rpc_client.ts → pxe_client.ts} +5 -3
  94. package/src/sandbox/index.ts +12 -12
  95. package/src/utils/abi_types.ts +7 -1
  96. package/src/utils/authwit.ts +24 -0
  97. package/src/utils/cheat_codes.ts +10 -10
  98. package/src/utils/index.ts +1 -1
  99. package/src/utils/l1_contracts.ts +5 -44
  100. package/src/utils/l2_contracts.ts +4 -4
  101. package/src/wallet/account_wallet.ts +4 -4
  102. package/src/wallet/base_wallet.ts +42 -28
  103. package/src/wallet/index.ts +2 -2
  104. package/src/wallet/signerless_wallet.ts +1 -1
  105. package/.eslintrc.cjs +0 -1
  106. package/.tsbuildinfo +0 -1
  107. package/dest/aztec_rpc_client.d.ts +0 -4
  108. package/dest/aztec_rpc_client.d.ts.map +0 -1
  109. package/dest/aztec_rpc_client.js +0 -19
  110. package/dest/contract/checker.test.d.ts +0 -2
  111. package/dest/contract/checker.test.d.ts.map +0 -1
  112. package/dest/contract/checker.test.js +0 -169
  113. package/dest/contract/contract.test.d.ts +0 -2
  114. package/dest/contract/contract.test.d.ts.map +0 -1
  115. package/dest/contract/contract.test.js +0 -147
  116. package/dest/contract/sent_tx.test.d.ts +0 -2
  117. package/dest/contract/sent_tx.test.d.ts.map +0 -1
  118. package/dest/contract/sent_tx.test.js +0 -42
  119. package/dest/contract_deployer/contract_deployer.test.d.ts +0 -2
  120. package/dest/contract_deployer/contract_deployer.test.d.ts.map +0 -1
  121. package/dest/contract_deployer/contract_deployer.test.js +0 -46
  122. package/dest/main.js +0 -2
  123. package/dest/main.js.LICENSE.txt +0 -10
  124. package/dest/utils/account.d.ts.map +0 -1
  125. package/dest/utils/account.js +0 -40
  126. package/package.local.json +0 -5
  127. package/src/contract/checker.test.ts +0 -178
  128. package/src/contract/contract.test.ts +0 -172
  129. package/src/contract/sent_tx.test.ts +0 -52
  130. package/src/contract_deployer/contract_deployer.test.ts +0 -55
  131. package/tsconfig.dest.json +0 -15
  132. package/tsconfig.json +0 -20
  133. package/webpack.config.js +0 -74
@@ -1,3 +1,24 @@
1
+ /**
2
+ * The `account` module provides utilities for managing accounts. The most common methods to use
3
+ * are {@link getEcdsaAccount} and {@link getSchnorrAccount}, which return {@link AccountManager} instances
4
+ * using the default ECDSA or Schnorr account implementation respectively. The {@link AccountManager} class then
5
+ * allows to deploy and register a fresh account, or to obtain a `Wallet` instance out of an account already deployed.
6
+ *
7
+ * ```ts
8
+ * const encryptionPrivateKey = GrumpkinScalar.random();
9
+ * const signingPrivateKey = GrumpkinScalar.random();
10
+ * const wallet = getSchnorrAccount(pxe, encryptionPrivateKey, signingPrivateKey).waitDeploy();
11
+ * ```
12
+ *
13
+ * For testing purposes, consider using the {@link createAccount} and {@link createAccounts} methods,
14
+ * which create, register, and deploy random accounts, and return their associated `Wallet`s.
15
+ *
16
+ * For implementing your own account contract, the recommended way is to extend from the base
17
+ * {@link BaseAccountContract} class.
18
+ * Read more in {@link https://docs.aztec.network/dev_docs/wallets/writing_an_account_contract | Writing an account contract}.
19
+ *
20
+ * @packageDocumentation
21
+ */
1
22
  import { CompleteAddress } from '@aztec/types';
2
23
  import { AccountWallet } from '../index.js';
3
24
  import { EcdsaAccountContract } from './contract/ecdsa_account_contract.js';
@@ -6,60 +27,61 @@ import { SingleKeyAccountContract } from './contract/single_key_account_contract
6
27
  import { AccountManager } from './manager/index.js';
7
28
  export * from './contract/index.js';
8
29
  export * from './defaults/index.js';
30
+ export * from './utils.js';
9
31
  export { AccountManager, CompleteAddress };
10
32
  /**
11
33
  * Creates an Account that relies on an ECDSA signing key for authentication.
12
- * @param rpc - An AztecRPC server instance.
34
+ * @param pxe - An PXE server instance.
13
35
  * @param encryptionPrivateKey - Grumpkin key used for note encryption.
14
36
  * @param signingPrivateKey - Secp256k1 key used for signing transactions.
15
37
  * @param saltOrAddress - Deployment salt or complete address if account contract is already deployed.
16
38
  */
17
- export function getEcdsaAccount(rpc, encryptionPrivateKey, signingPrivateKey, saltOrAddress) {
18
- return new AccountManager(rpc, encryptionPrivateKey, new EcdsaAccountContract(signingPrivateKey), saltOrAddress);
39
+ export function getEcdsaAccount(pxe, encryptionPrivateKey, signingPrivateKey, saltOrAddress) {
40
+ return new AccountManager(pxe, encryptionPrivateKey, new EcdsaAccountContract(signingPrivateKey), saltOrAddress);
19
41
  }
20
42
  /**
21
43
  * Creates an Account that relies on a Grumpkin signing key for authentication.
22
- * @param rpc - An AztecRPC server instance.
44
+ * @param pxe - An PXE server instance.
23
45
  * @param encryptionPrivateKey - Grumpkin key used for note encryption.
24
46
  * @param signingPrivateKey - Grumpkin key used for signing transactions.
25
47
  * @param saltOrAddress - Deployment salt or complete address if account contract is already deployed.
26
48
  */
27
- export function getSchnorrAccount(rpc, encryptionPrivateKey, signingPrivateKey, saltOrAddress) {
28
- return new AccountManager(rpc, encryptionPrivateKey, new SchnorrAccountContract(signingPrivateKey), saltOrAddress);
49
+ export function getSchnorrAccount(pxe, encryptionPrivateKey, signingPrivateKey, saltOrAddress) {
50
+ return new AccountManager(pxe, encryptionPrivateKey, new SchnorrAccountContract(signingPrivateKey), saltOrAddress);
29
51
  }
30
52
  /**
31
53
  * Creates an Account that uses the same Grumpkin key for encryption and authentication.
32
- * @param rpc - An AztecRPC server instance.
54
+ * @param pxe - An PXE server instance.
33
55
  * @param encryptionAndSigningPrivateKey - Grumpkin key used for note encryption and signing transactions.
34
56
  * @param saltOrAddress - Deployment salt or complete address if account contract is already deployed.
35
57
  */
36
- export function getUnsafeSchnorrAccount(rpc, encryptionAndSigningPrivateKey, saltOrAddress) {
37
- return new AccountManager(rpc, encryptionAndSigningPrivateKey, new SingleKeyAccountContract(encryptionAndSigningPrivateKey), saltOrAddress);
58
+ export function getUnsafeSchnorrAccount(pxe, encryptionAndSigningPrivateKey, saltOrAddress) {
59
+ return new AccountManager(pxe, encryptionAndSigningPrivateKey, new SingleKeyAccountContract(encryptionAndSigningPrivateKey), saltOrAddress);
38
60
  }
39
61
  /**
40
62
  * Gets a wallet for an already registered account using Schnorr signatures with a single key for encryption and authentication.
41
- * @param rpc - An AztecRPC server instance.
63
+ * @param pxe - An PXE server instance.
42
64
  * @param address - Address for the account.
43
65
  * @param signingPrivateKey - Grumpkin key used for note encryption and signing transactions.
44
66
  * @returns A wallet for this account that can be used to interact with a contract instance.
45
67
  */
46
- export function getUnsafeSchnorrWallet(rpc, address, signingKey) {
47
- return getWallet(rpc, address, new SingleKeyAccountContract(signingKey));
68
+ export function getUnsafeSchnorrWallet(pxe, address, signingKey) {
69
+ return getWallet(pxe, address, new SingleKeyAccountContract(signingKey));
48
70
  }
49
71
  /**
50
72
  * Gets a wallet for an already registered account.
51
- * @param rpc - An AztecRPC server instance.
73
+ * @param pxe - PXE Service instance.
52
74
  * @param address - Address for the account.
53
75
  * @param accountContract - Account contract implementation.
54
76
  * @returns A wallet for this account that can be used to interact with a contract instance.
55
77
  */
56
- export async function getWallet(rpc, address, accountContract) {
57
- const completeAddress = await rpc.getRegisteredAccount(address);
78
+ export async function getWallet(pxe, address, accountContract) {
79
+ const completeAddress = await pxe.getRegisteredAccount(address);
58
80
  if (!completeAddress) {
59
81
  throw new Error(`Account ${address} not found`);
60
82
  }
61
- const nodeInfo = await rpc.getNodeInfo();
83
+ const nodeInfo = await pxe.getNodeInfo();
62
84
  const entrypoint = await accountContract.getInterface(completeAddress, nodeInfo);
63
- return new AccountWallet(rpc, entrypoint);
85
+ return new AccountWallet(pxe, entrypoint);
64
86
  }
65
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYWNjb3VudC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQVksZUFBZSxFQUFzQixNQUFNLGNBQWMsQ0FBQztBQUU3RSxPQUFPLEVBQW1CLGFBQWEsRUFBb0IsTUFBTSxhQUFhLENBQUM7QUFDL0UsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDNUUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sd0NBQXdDLENBQUM7QUFDaEYsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDckYsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRXBELGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxxQkFBcUIsQ0FBQztBQUVwQyxPQUFPLEVBQUUsY0FBYyxFQUFFLGVBQWUsRUFBRSxDQUFDO0FBSzNDOzs7Ozs7R0FNRztBQUNILE1BQU0sVUFBVSxlQUFlLENBQzdCLEdBQWEsRUFDYixvQkFBd0MsRUFDeEMsaUJBQXlCLEVBQ3pCLGFBQXNDO0lBRXRDLE9BQU8sSUFBSSxjQUFjLENBQUMsR0FBRyxFQUFFLG9CQUFvQixFQUFFLElBQUksb0JBQW9CLENBQUMsaUJBQWlCLENBQUMsRUFBRSxhQUFhLENBQUMsQ0FBQztBQUNuSCxDQUFDO0FBRUQ7Ozs7OztHQU1HO0FBQ0gsTUFBTSxVQUFVLGlCQUFpQixDQUMvQixHQUFhLEVBQ2Isb0JBQXdDLEVBQ3hDLGlCQUFxQyxFQUNyQyxhQUFzQztJQUV0QyxPQUFPLElBQUksY0FBYyxDQUFDLEdBQUcsRUFBRSxvQkFBb0IsRUFBRSxJQUFJLHNCQUFzQixDQUFDLGlCQUFpQixDQUFDLEVBQUUsYUFBYSxDQUFDLENBQUM7QUFDckgsQ0FBQztBQUVEOzs7OztHQUtHO0FBQ0gsTUFBTSxVQUFVLHVCQUF1QixDQUNyQyxHQUFhLEVBQ2IsOEJBQWtELEVBQ2xELGFBQXNDO0lBRXRDLE9BQU8sSUFBSSxjQUFjLENBQ3ZCLEdBQUcsRUFDSCw4QkFBOEIsRUFDOUIsSUFBSSx3QkFBd0IsQ0FBQyw4QkFBOEIsQ0FBQyxFQUM1RCxhQUFhLENBQ2QsQ0FBQztBQUNKLENBQUM7QUFFRDs7Ozs7O0dBTUc7QUFDSCxNQUFNLFVBQVUsc0JBQXNCLENBQ3BDLEdBQWEsRUFDYixPQUFxQixFQUNyQixVQUE4QjtJQUU5QixPQUFPLFNBQVMsQ0FBQyxHQUFHLEVBQUUsT0FBTyxFQUFFLElBQUksd0JBQXdCLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztBQUMzRSxDQUFDO0FBRUQ7Ozs7OztHQU1HO0FBQ0gsTUFBTSxDQUFDLEtBQUssVUFBVSxTQUFTLENBQzdCLEdBQWEsRUFDYixPQUFxQixFQUNyQixlQUFnQztJQUVoQyxNQUFNLGVBQWUsR0FBRyxNQUFNLEdBQUcsQ0FBQyxvQkFBb0IsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNoRSxJQUFJLENBQUMsZUFBZSxFQUFFO1FBQ3BCLE1BQU0sSUFBSSxLQUFLLENBQUMsV0FBVyxPQUFPLFlBQVksQ0FBQyxDQUFDO0tBQ2pEO0lBQ0QsTUFBTSxRQUFRLEdBQUcsTUFBTSxHQUFHLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDekMsTUFBTSxVQUFVLEdBQUcsTUFBTSxlQUFlLENBQUMsWUFBWSxDQUFDLGVBQWUsRUFBRSxRQUFRLENBQUMsQ0FBQztJQUNqRixPQUFPLElBQUksYUFBYSxDQUFDLEdBQUcsRUFBRSxVQUFVLENBQUMsQ0FBQztBQUM1QyxDQUFDIn0=
87
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYWNjb3VudC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FvQkc7QUFDSCxPQUFPLEVBQUUsZUFBZSxFQUEyQixNQUFNLGNBQWMsQ0FBQztBQUV4RSxPQUFPLEVBQW1CLGFBQWEsRUFBb0IsTUFBTSxhQUFhLENBQUM7QUFDL0UsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDNUUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sd0NBQXdDLENBQUM7QUFDaEYsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDckYsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRXBELGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLFlBQVksQ0FBQztBQUUzQixPQUFPLEVBQUUsY0FBYyxFQUFFLGVBQWUsRUFBRSxDQUFDO0FBSzNDOzs7Ozs7R0FNRztBQUNILE1BQU0sVUFBVSxlQUFlLENBQzdCLEdBQVEsRUFDUixvQkFBd0MsRUFDeEMsaUJBQXlCLEVBQ3pCLGFBQXNDO0lBRXRDLE9BQU8sSUFBSSxjQUFjLENBQUMsR0FBRyxFQUFFLG9CQUFvQixFQUFFLElBQUksb0JBQW9CLENBQUMsaUJBQWlCLENBQUMsRUFBRSxhQUFhLENBQUMsQ0FBQztBQUNuSCxDQUFDO0FBRUQ7Ozs7OztHQU1HO0FBQ0gsTUFBTSxVQUFVLGlCQUFpQixDQUMvQixHQUFRLEVBQ1Isb0JBQXdDLEVBQ3hDLGlCQUFxQyxFQUNyQyxhQUFzQztJQUV0QyxPQUFPLElBQUksY0FBYyxDQUFDLEdBQUcsRUFBRSxvQkFBb0IsRUFBRSxJQUFJLHNCQUFzQixDQUFDLGlCQUFpQixDQUFDLEVBQUUsYUFBYSxDQUFDLENBQUM7QUFDckgsQ0FBQztBQUVEOzs7OztHQUtHO0FBQ0gsTUFBTSxVQUFVLHVCQUF1QixDQUNyQyxHQUFRLEVBQ1IsOEJBQWtELEVBQ2xELGFBQXNDO0lBRXRDLE9BQU8sSUFBSSxjQUFjLENBQ3ZCLEdBQUcsRUFDSCw4QkFBOEIsRUFDOUIsSUFBSSx3QkFBd0IsQ0FBQyw4QkFBOEIsQ0FBQyxFQUM1RCxhQUFhLENBQ2QsQ0FBQztBQUNKLENBQUM7QUFFRDs7Ozs7O0dBTUc7QUFDSCxNQUFNLFVBQVUsc0JBQXNCLENBQ3BDLEdBQVEsRUFDUixPQUFxQixFQUNyQixVQUE4QjtJQUU5QixPQUFPLFNBQVMsQ0FBQyxHQUFHLEVBQUUsT0FBTyxFQUFFLElBQUksd0JBQXdCLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztBQUMzRSxDQUFDO0FBRUQ7Ozs7OztHQU1HO0FBQ0gsTUFBTSxDQUFDLEtBQUssVUFBVSxTQUFTLENBQzdCLEdBQVEsRUFDUixPQUFxQixFQUNyQixlQUFnQztJQUVoQyxNQUFNLGVBQWUsR0FBRyxNQUFNLEdBQUcsQ0FBQyxvQkFBb0IsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNoRSxJQUFJLENBQUMsZUFBZSxFQUFFO1FBQ3BCLE1BQU0sSUFBSSxLQUFLLENBQUMsV0FBVyxPQUFPLFlBQVksQ0FBQyxDQUFDO0tBQ2pEO0lBQ0QsTUFBTSxRQUFRLEdBQUcsTUFBTSxHQUFHLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDekMsTUFBTSxVQUFVLEdBQUcsTUFBTSxlQUFlLENBQUMsWUFBWSxDQUFDLGVBQWUsRUFBRSxRQUFRLENBQUMsQ0FBQztJQUNqRixPQUFPLElBQUksYUFBYSxDQUFDLEdBQUcsRUFBRSxVQUFVLENBQUMsQ0FBQztBQUM1QyxDQUFDIn0=
@@ -1,15 +1,15 @@
1
1
  import { Fr } from '@aztec/circuits.js';
2
- import { AztecRPC, CompleteAddress, GrumpkinPrivateKey } from '@aztec/types';
2
+ import { CompleteAddress, GrumpkinPrivateKey, PXE } from '@aztec/types';
3
3
  import { AccountWallet, DeployMethod, WaitOpts } from '../../index.js';
4
4
  import { AccountContract, Salt } from '../index.js';
5
5
  import { AccountInterface } from '../interface.js';
6
6
  import { DeployAccountSentTx } from './deploy_account_sent_tx.js';
7
7
  /**
8
8
  * Manages a user account. Provides methods for calculating the account's address, deploying the account contract,
9
- * and creating and registering the user wallet in the RPC server.
9
+ * and creating and registering the user wallet in the PXE Service.
10
10
  */
11
11
  export declare class AccountManager {
12
- private rpc;
12
+ private pxe;
13
13
  private encryptionPrivateKey;
14
14
  private accountContract;
15
15
  /** Deployment salt for the account contract. */
@@ -17,7 +17,7 @@ export declare class AccountManager {
17
17
  private completeAddress?;
18
18
  private encryptionPublicKey?;
19
19
  private deployMethod?;
20
- constructor(rpc: AztecRPC, encryptionPrivateKey: GrumpkinPrivateKey, accountContract: AccountContract, saltOrAddress?: Salt | CompleteAddress);
20
+ constructor(pxe: PXE, encryptionPrivateKey: GrumpkinPrivateKey, accountContract: AccountContract, saltOrAddress?: Salt | CompleteAddress);
21
21
  protected getEncryptionPublicKey(): Promise<import("@aztec/circuits.js").Point>;
22
22
  /**
23
23
  * Returns the entrypoint for this account as defined by its account contract.
@@ -37,8 +37,8 @@ export declare class AccountManager {
37
37
  */
38
38
  getWallet(): Promise<AccountWallet>;
39
39
  /**
40
- * Registers this account in the RPC server and returns the associated wallet. Registering
41
- * the account on the RPC server is required for managing private state associated with it.
40
+ * Registers this account in the PXE Service and returns the associated wallet. Registering
41
+ * the account on the PXE Service is required for managing private state associated with it.
42
42
  * Use the returned wallet to create Contract instances to be interacted with from this account.
43
43
  * @returns A Wallet instance.
44
44
  */
@@ -55,7 +55,7 @@ export declare class AccountManager {
55
55
  * Uses the salt provided in the constructor or a randomly generated one.
56
56
  * Note that if the Account is constructed with an explicit complete address
57
57
  * it is assumed that the account contract has already been deployed and this method will throw.
58
- * Registers the account in the RPC server before deploying the contract.
58
+ * Registers the account in the PXE Service before deploying the contract.
59
59
  * @returns A SentTx object that can be waited to get the associated Wallet.
60
60
  */
61
61
  deploy(): Promise<DeployAccountSentTx>;
@@ -64,7 +64,7 @@ export declare class AccountManager {
64
64
  * Uses the salt provided in the constructor or a randomly generated one.
65
65
  * Note that if the Account is constructed with an explicit complete address
66
66
  * it is assumed that the account contract has already been deployed and this method will throw.
67
- * Registers the account in the RPC server before deploying the contract.
67
+ * Registers the account in the PXE Service before deploying the contract.
68
68
  * @param opts - Options to wait for the tx to be mined.
69
69
  * @returns A Wallet instance.
70
70
  */
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/account/manager/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAwC,MAAM,oBAAoB,CAAC;AAC9E,OAAO,EAAE,QAAQ,EAAE,eAAe,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAE7E,OAAO,EAAE,aAAa,EAAoB,YAAY,EAAE,QAAQ,EAAqB,MAAM,gBAAgB,CAAC;AAC5G,OAAO,EAAE,eAAe,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AACpD,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAC;AAElE;;;GAGG;AACH,qBAAa,cAAc;IASvB,OAAO,CAAC,GAAG;IACX,OAAO,CAAC,oBAAoB;IAC5B,OAAO,CAAC,eAAe;IAVzB,gDAAgD;IAChD,SAAgB,IAAI,CAAC,EAAE,EAAE,CAAC;IAE1B,OAAO,CAAC,eAAe,CAAC,CAAkB;IAC1C,OAAO,CAAC,mBAAmB,CAAC,CAAY;IACxC,OAAO,CAAC,YAAY,CAAC,CAAe;gBAG1B,GAAG,EAAE,QAAQ,EACb,oBAAoB,EAAE,kBAAkB,EACxC,eAAe,EAAE,eAAe,EACxC,aAAa,CAAC,EAAE,IAAI,GAAG,eAAe;cASxB,sBAAsB;IAOtC;;;OAGG;IACU,UAAU,IAAI,OAAO,CAAC,gBAAgB,CAAC;IAMpD;;;;OAIG;IACU,kBAAkB,IAAI,OAAO,CAAC,eAAe,CAAC;IAc3D;;;;OAIG;IACU,SAAS,IAAI,OAAO,CAAC,aAAa,CAAC;IAKhD;;;;;OAKG;IACU,QAAQ,IAAI,OAAO,CAAC,aAAa,CAAC;IAM/C;;;;;OAKG;IACU,eAAe;IAY5B;;;;;;;OAOG;IACU,MAAM,IAAI,OAAO,CAAC,mBAAmB,CAAC;IAOnD;;;;;;;;OAQG;IACU,UAAU,CAAC,IAAI,GAAE,QAAa,GAAG,OAAO,CAAC,aAAa,CAAC;CAIrE"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/account/manager/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAwC,MAAM,oBAAoB,CAAC;AAC9E,OAAO,EAAE,eAAe,EAAE,kBAAkB,EAAE,GAAG,EAAE,MAAM,cAAc,CAAC;AAExE,OAAO,EAAE,aAAa,EAAoB,YAAY,EAAE,QAAQ,EAAqB,MAAM,gBAAgB,CAAC;AAC5G,OAAO,EAAE,eAAe,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AACpD,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAC;AAElE;;;GAGG;AACH,qBAAa,cAAc;IASvB,OAAO,CAAC,GAAG;IACX,OAAO,CAAC,oBAAoB;IAC5B,OAAO,CAAC,eAAe;IAVzB,gDAAgD;IAChD,SAAgB,IAAI,CAAC,EAAE,EAAE,CAAC;IAE1B,OAAO,CAAC,eAAe,CAAC,CAAkB;IAC1C,OAAO,CAAC,mBAAmB,CAAC,CAAY;IACxC,OAAO,CAAC,YAAY,CAAC,CAAe;gBAG1B,GAAG,EAAE,GAAG,EACR,oBAAoB,EAAE,kBAAkB,EACxC,eAAe,EAAE,eAAe,EACxC,aAAa,CAAC,EAAE,IAAI,GAAG,eAAe;cASxB,sBAAsB;IAOtC;;;OAGG;IACU,UAAU,IAAI,OAAO,CAAC,gBAAgB,CAAC;IAMpD;;;;OAIG;IACU,kBAAkB,IAAI,OAAO,CAAC,eAAe,CAAC;IAc3D;;;;OAIG;IACU,SAAS,IAAI,OAAO,CAAC,aAAa,CAAC;IAKhD;;;;;OAKG;IACU,QAAQ,IAAI,OAAO,CAAC,aAAa,CAAC;IAM/C;;;;;OAKG;IACU,eAAe;IAY5B;;;;;;;OAOG;IACU,MAAM,IAAI,OAAO,CAAC,mBAAmB,CAAC;IAOnD;;;;;;;;OAQG;IACU,UAAU,CAAC,IAAI,GAAE,QAAa,GAAG,OAAO,CAAC,aAAa,CAAC;CAIrE"}
@@ -4,11 +4,11 @@ import { AccountWallet, ContractDeployer, generatePublicKey } from '../../index.
4
4
  import { DeployAccountSentTx } from './deploy_account_sent_tx.js';
5
5
  /**
6
6
  * Manages a user account. Provides methods for calculating the account's address, deploying the account contract,
7
- * and creating and registering the user wallet in the RPC server.
7
+ * and creating and registering the user wallet in the PXE Service.
8
8
  */
9
9
  export class AccountManager {
10
- constructor(rpc, encryptionPrivateKey, accountContract, saltOrAddress) {
11
- this.rpc = rpc;
10
+ constructor(pxe, encryptionPrivateKey, accountContract, saltOrAddress) {
11
+ this.pxe = pxe;
12
12
  this.encryptionPrivateKey = encryptionPrivateKey;
13
13
  this.accountContract = accountContract;
14
14
  if (saltOrAddress instanceof CompleteAddress) {
@@ -29,7 +29,7 @@ export class AccountManager {
29
29
  * @returns An entrypoint.
30
30
  */
31
31
  async getAccount() {
32
- const nodeInfo = await this.rpc.getNodeInfo();
32
+ const nodeInfo = await this.pxe.getNodeInfo();
33
33
  const completeAddress = await this.getCompleteAddress();
34
34
  return this.accountContract.getInterface(completeAddress, nodeInfo);
35
35
  }
@@ -53,17 +53,17 @@ export class AccountManager {
53
53
  */
54
54
  async getWallet() {
55
55
  const entrypoint = await this.getAccount();
56
- return new AccountWallet(this.rpc, entrypoint);
56
+ return new AccountWallet(this.pxe, entrypoint);
57
57
  }
58
58
  /**
59
- * Registers this account in the RPC server and returns the associated wallet. Registering
60
- * the account on the RPC server is required for managing private state associated with it.
59
+ * Registers this account in the PXE Service and returns the associated wallet. Registering
60
+ * the account on the PXE Service is required for managing private state associated with it.
61
61
  * Use the returned wallet to create Contract instances to be interacted with from this account.
62
62
  * @returns A Wallet instance.
63
63
  */
64
64
  async register() {
65
65
  const completeAddress = await this.getCompleteAddress();
66
- await this.rpc.registerAccount(this.encryptionPrivateKey, completeAddress.partialAddress);
66
+ await this.pxe.registerAccount(this.encryptionPrivateKey, completeAddress.partialAddress);
67
67
  return this.getWallet();
68
68
  }
69
69
  /**
@@ -78,7 +78,7 @@ export class AccountManager {
78
78
  throw new Error(`Cannot deploy account contract without known salt.`);
79
79
  await this.register();
80
80
  const encryptionPublicKey = await this.getEncryptionPublicKey();
81
- const deployer = new ContractDeployer(this.accountContract.getContractAbi(), this.rpc, encryptionPublicKey);
81
+ const deployer = new ContractDeployer(this.accountContract.getContractAbi(), this.pxe, encryptionPublicKey);
82
82
  const args = await this.accountContract.getDeploymentArgs();
83
83
  this.deployMethod = deployer.deploy(...args);
84
84
  }
@@ -89,7 +89,7 @@ export class AccountManager {
89
89
  * Uses the salt provided in the constructor or a randomly generated one.
90
90
  * Note that if the Account is constructed with an explicit complete address
91
91
  * it is assumed that the account contract has already been deployed and this method will throw.
92
- * Registers the account in the RPC server before deploying the contract.
92
+ * Registers the account in the PXE Service before deploying the contract.
93
93
  * @returns A SentTx object that can be waited to get the associated Wallet.
94
94
  */
95
95
  async deploy() {
@@ -103,7 +103,7 @@ export class AccountManager {
103
103
  * Uses the salt provided in the constructor or a randomly generated one.
104
104
  * Note that if the Account is constructed with an explicit complete address
105
105
  * it is assumed that the account contract has already been deployed and this method will throw.
106
- * Registers the account in the RPC server before deploying the contract.
106
+ * Registers the account in the PXE Service before deploying the contract.
107
107
  * @param opts - Options to wait for the tx to be mined.
108
108
  * @returns A Wallet instance.
109
109
  */
@@ -112,4 +112,4 @@ export class AccountManager {
112
112
  return this.getWallet();
113
113
  }
114
114
  }
115
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYWNjb3VudC9tYW5hZ2VyL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxFQUFFLEVBQWEseUJBQXlCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUM5RSxPQUFPLEVBQVksZUFBZSxFQUFzQixNQUFNLGNBQWMsQ0FBQztBQUU3RSxPQUFPLEVBQUUsYUFBYSxFQUFFLGdCQUFnQixFQUEwQixpQkFBaUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRzVHLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBRWxFOzs7R0FHRztBQUNILE1BQU0sT0FBTyxjQUFjO0lBUXpCLFlBQ1UsR0FBYSxFQUNiLG9CQUF3QyxFQUN4QyxlQUFnQyxFQUN4QyxhQUFzQztRQUg5QixRQUFHLEdBQUgsR0FBRyxDQUFVO1FBQ2IseUJBQW9CLEdBQXBCLG9CQUFvQixDQUFvQjtRQUN4QyxvQkFBZSxHQUFmLGVBQWUsQ0FBaUI7UUFHeEMsSUFBSSxhQUFhLFlBQVksZUFBZSxFQUFFO1lBQzVDLElBQUksQ0FBQyxlQUFlLEdBQUcsYUFBYSxDQUFDO1NBQ3RDO2FBQU07WUFDTCxJQUFJLENBQUMsSUFBSSxHQUFHLGFBQWEsQ0FBQyxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxNQUFNLEVBQUUsQ0FBQztTQUNqRTtJQUNILENBQUM7SUFFUyxLQUFLLENBQUMsc0JBQXNCO1FBQ3BDLElBQUksQ0FBQyxJQUFJLENBQUMsbUJBQW1CLEVBQUU7WUFDN0IsSUFBSSxDQUFDLG1CQUFtQixHQUFHLE1BQU0saUJBQWlCLENBQUMsSUFBSSxDQUFDLG9CQUFvQixDQUFDLENBQUM7U0FDL0U7UUFDRCxPQUFPLElBQUksQ0FBQyxtQkFBbUIsQ0FBQztJQUNsQyxDQUFDO0lBRUQ7OztPQUdHO0lB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
115
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYWNjb3VudC9tYW5hZ2VyL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxFQUFFLEVBQWEseUJBQXlCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUM5RSxPQUFPLEVBQUUsZUFBZSxFQUEyQixNQUFNLGNBQWMsQ0FBQztBQUV4RSxPQUFPLEVBQUUsYUFBYSxFQUFFLGdCQUFnQixFQUEwQixpQkFBaUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRzVHLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBRWxFOzs7R0FHRztBQUNILE1BQU0sT0FBTyxjQUFjO0lBUXpCLFlBQ1UsR0FBUSxFQUNSLG9CQUF3QyxFQUN4QyxlQUFnQyxFQUN4QyxhQUFzQztRQUg5QixRQUFHLEdBQUgsR0FBRyxDQUFLO1FBQ1IseUJBQW9CLEdBQXBCLG9CQUFvQixDQUFvQjtRQUN4QyxvQkFBZSxHQUFmLGVBQWUsQ0FBaUI7UUFHeEMsSUFBSSxhQUFhLFlBQVksZUFBZSxFQUFFO1lBQzVDLElBQUksQ0FBQyxlQUFlLEdBQUcsYUFBYSxDQUFDO1NBQ3RDO2FBQU07WUFDTCxJQUFJLENBQUMsSUFBSSxHQUFHLGFBQWEsQ0FBQyxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxNQUFNLEVBQUUsQ0FBQztTQUNqRTtJQUNILENBQUM7SUFFUyxLQUFLLENBQUMsc0JBQXNCO1FBQ3BDLElBQUksQ0FBQyxJQUFJLENBQUMsbUJBQW1CLEVBQUU7WUFDN0IsSUFBSSxDQUFDLG1CQUFtQixHQUFHLE1BQU0saUJBQWlCLENBQUMsSUFBSSxDQUFDLG9CQUFvQixDQUFDLENBQUM7U0FDL0U7UUFDRCxPQUFPLElBQUksQ0FBQyxtQkFBbUIsQ0FBQztJQUNsQyxDQUFDO0lBRUQ7OztPQUdHO0lB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
@@ -1,23 +1,23 @@
1
1
  import { CompleteAddress } from '@aztec/circuits.js';
2
- import { AztecRPC } from '@aztec/types';
2
+ import { PXE } from '@aztec/types';
3
3
  import { AccountWallet } from '../wallet/account_wallet.js';
4
4
  /**
5
- * Deploys and registers a new account using random private keys and returns the associated wallet. Useful for testing.
6
- * @param rpc - RPC client.
5
+ * Deploys and registers a new account using random private keys and returns the associated Schnorr account wallet. Useful for testing.
6
+ * @param pxe - PXE.
7
7
  * @returns - A wallet for a fresh account.
8
8
  */
9
- export declare function createAccount(rpc: AztecRPC): Promise<AccountWallet>;
9
+ export declare function createAccount(pxe: PXE): Promise<AccountWallet>;
10
10
  /**
11
- * Creates a random address and registers it as a recipient on the RPC server. Useful for testing.
12
- * @param rpc - RPC client.
11
+ * Creates a random address and registers it as a recipient on the pxe server. Useful for testing.
12
+ * @param pxe - PXE.
13
13
  * @returns Complete address of the registered recipient.
14
14
  */
15
- export declare function createRecipient(rpc: AztecRPC): Promise<CompleteAddress>;
15
+ export declare function createRecipient(pxe: PXE): Promise<CompleteAddress>;
16
16
  /**
17
17
  * Creates a given number of random accounts using the Schnorr account wallet.
18
- * @param rpc - RPC interface.
18
+ * @param pxe - PXE.
19
19
  * @param numberOfAccounts - How many accounts to create.
20
20
  * @returns The created account wallets.
21
21
  */
22
- export declare function createAccounts(rpc: AztecRPC, numberOfAccounts?: number): Promise<AccountWallet[]>;
23
- //# sourceMappingURL=account.d.ts.map
22
+ export declare function createAccounts(pxe: PXE, numberOfAccounts?: number): Promise<AccountWallet[]>;
23
+ //# sourceMappingURL=utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/account/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAkB,MAAM,oBAAoB,CAAC;AACrE,OAAO,EAAE,GAAG,EAAE,MAAM,cAAc,CAAC;AAGnC,OAAO,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAE5D;;;;GAIG;AACH,wBAAgB,aAAa,CAAC,GAAG,EAAE,GAAG,GAAG,OAAO,CAAC,aAAa,CAAC,CAE9D;AAED;;;;GAIG;AACH,wBAAsB,eAAe,CAAC,GAAG,EAAE,GAAG,GAAG,OAAO,CAAC,eAAe,CAAC,CAIxE;AAED;;;;;GAKG;AACH,wBAAsB,cAAc,CAAC,GAAG,EAAE,GAAG,EAAE,gBAAgB,SAAI,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC,CAc7F"}
@@ -0,0 +1,40 @@
1
+ import { CompleteAddress, GrumpkinScalar } from '@aztec/circuits.js';
2
+ import { getSchnorrAccount } from '../index.js';
3
+ /**
4
+ * Deploys and registers a new account using random private keys and returns the associated Schnorr account wallet. Useful for testing.
5
+ * @param pxe - PXE.
6
+ * @returns - A wallet for a fresh account.
7
+ */
8
+ export function createAccount(pxe) {
9
+ return getSchnorrAccount(pxe, GrumpkinScalar.random(), GrumpkinScalar.random()).waitDeploy();
10
+ }
11
+ /**
12
+ * Creates a random address and registers it as a recipient on the pxe server. Useful for testing.
13
+ * @param pxe - PXE.
14
+ * @returns Complete address of the registered recipient.
15
+ */
16
+ export async function createRecipient(pxe) {
17
+ const completeAddress = await CompleteAddress.random();
18
+ await pxe.registerRecipient(completeAddress);
19
+ return completeAddress;
20
+ }
21
+ /**
22
+ * Creates a given number of random accounts using the Schnorr account wallet.
23
+ * @param pxe - PXE.
24
+ * @param numberOfAccounts - How many accounts to create.
25
+ * @returns The created account wallets.
26
+ */
27
+ export async function createAccounts(pxe, numberOfAccounts = 1) {
28
+ const accounts = [];
29
+ // Prepare deployments
30
+ for (let i = 0; i < numberOfAccounts; ++i) {
31
+ const account = getSchnorrAccount(pxe, GrumpkinScalar.random(), GrumpkinScalar.random());
32
+ await account.getDeployMethod().then(d => d.simulate({ contractAddressSalt: account.salt }));
33
+ accounts.push(account);
34
+ }
35
+ // Send them and await them to be mined
36
+ const txs = await Promise.all(accounts.map(account => account.deploy()));
37
+ await Promise.all(txs.map(tx => tx.wait({ interval: 0.1 })));
38
+ return Promise.all(accounts.map(account => account.getWallet()));
39
+ }
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYWNjb3VudC91dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFFLGNBQWMsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBR3JFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUdoRDs7OztHQUlHO0FBQ0gsTUFBTSxVQUFVLGFBQWEsQ0FBQyxHQUFRO0lBQ3BDLE9BQU8saUJBQWlCLENBQUMsR0FBRyxFQUFFLGNBQWMsQ0FBQyxNQUFNLEVBQUUsRUFBRSxjQUFjLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQyxVQUFVLEVBQUUsQ0FBQztBQUMvRixDQUFDO0FBRUQ7Ozs7R0FJRztBQUNILE1BQU0sQ0FBQyxLQUFLLFVBQVUsZUFBZSxDQUFDLEdBQVE7SUFDNUMsTUFBTSxlQUFlLEdBQUcsTUFBTSxlQUFlLENBQUMsTUFBTSxFQUFFLENBQUM7SUFDdkQsTUFBTSxHQUFHLENBQUMsaUJBQWlCLENBQUMsZUFBZSxDQUFDLENBQUM7SUFDN0MsT0FBTyxlQUFlLENBQUM7QUFDekIsQ0FBQztBQUVEOzs7OztHQUtHO0FBQ0gsTUFBTSxDQUFDLEtBQUssVUFBVSxjQUFjLENBQUMsR0FBUSxFQUFFLGdCQUFnQixHQUFHLENBQUM7SUFDakUsTUFBTSxRQUFRLEdBQUcsRUFBRSxDQUFDO0lBRXBCLHNCQUFzQjtJQUN0QixLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsZ0JBQWdCLEVBQUUsRUFBRSxDQUFDLEVBQUU7UUFDekMsTUFBTSxPQUFPLEdBQUcsaUJBQWlCLENBQUMsR0FBRyxFQUFFLGNBQWMsQ0FBQyxNQUFNLEVBQUUsRUFBRSxjQUFjLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQztRQUN6RixNQUFNLE9BQU8sQ0FBQyxlQUFlLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLEVBQUUsbUJBQW1CLEVBQUUsT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQztRQUM3RixRQUFRLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0tBQ3hCO0lBRUQsdUNBQXVDO0lBQ3ZDLE1BQU0sR0FBRyxHQUFHLE1BQU0sT0FBTyxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUMsQ0FBQztJQUN6RSxNQUFNLE9BQU8sQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFBRSxRQUFRLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDN0QsT0FBTyxPQUFPLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUMsU0FBUyxFQUFFLENBQUMsQ0FBQyxDQUFDO0FBQ25FLENBQUMifQ==
@@ -1,24 +1,24 @@
1
- import { AztecRPC, Tx, TxExecutionRequest } from '@aztec/types';
1
+ import { PXE, Tx, TxExecutionRequest } from '@aztec/types';
2
2
  import { SentTx } from './sent_tx.js';
3
3
  /**
4
4
  * Represents options for calling a (constrained) function in a contract.
5
5
  * Allows the user to specify the sender address and nonce for a transaction.
6
6
  */
7
- export interface SendMethodOptions {
7
+ export type SendMethodOptions = {
8
8
  /**
9
9
  * Wether to skip the simulation of the public part of the transaction.
10
10
  */
11
11
  skipPublicSimulation?: boolean;
12
- }
12
+ };
13
13
  /**
14
14
  * Base class for an interaction with a contract, be it a deployment, a function call, or a batch.
15
15
  * Implements the sequence create/simulate/send.
16
16
  */
17
17
  export declare abstract class BaseContractInteraction {
18
- protected rpc: AztecRPC;
18
+ protected pxe: PXE;
19
19
  protected tx?: Tx;
20
20
  protected txRequest?: TxExecutionRequest;
21
- constructor(rpc: AztecRPC);
21
+ constructor(pxe: PXE);
22
22
  /**
23
23
  * Create a transaction execution request ready to be simulated.
24
24
  * @param options - An optional object containing additional configuration for the transaction.
@@ -1 +1 @@
1
- {"version":3,"file":"base_contract_interaction.d.ts","sourceRoot":"","sources":["../../src/contract/base_contract_interaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAEhE,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AAEtC;;;GAGG;AACH,MAAM,WAAW,iBAAiB;IAChC;;OAEG;IACH,oBAAoB,CAAC,EAAE,OAAO,CAAC;CAChC;AAED;;;GAGG;AACH,8BAAsB,uBAAuB;IAI/B,SAAS,CAAC,GAAG,EAAE,QAAQ;IAHnC,SAAS,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;IAClB,SAAS,CAAC,SAAS,CAAC,EAAE,kBAAkB,CAAC;gBAEnB,GAAG,EAAE,QAAQ;IAEnC;;;;OAIG;aACa,MAAM,CAAC,OAAO,CAAC,EAAE,iBAAiB,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAEhF;;;;OAIG;IACU,QAAQ,CAAC,OAAO,GAAE,iBAAsB,GAAG,OAAO,CAAC,EAAE,CAAC;IAMnE;;;;;;;;OAQG;IACI,IAAI,CAAC,OAAO,GAAE,iBAAsB;CAQ5C"}
1
+ {"version":3,"file":"base_contract_interaction.d.ts","sourceRoot":"","sources":["../../src/contract/base_contract_interaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,EAAE,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAE3D,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AAEtC;;;GAGG;AACH,MAAM,MAAM,iBAAiB,GAAG;IAC9B;;OAEG;IACH,oBAAoB,CAAC,EAAE,OAAO,CAAC;CAChC,CAAC;AAEF;;;GAGG;AACH,8BAAsB,uBAAuB;IAI/B,SAAS,CAAC,GAAG,EAAE,GAAG;IAH9B,SAAS,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;IAClB,SAAS,CAAC,SAAS,CAAC,EAAE,kBAAkB,CAAC;gBAEnB,GAAG,EAAE,GAAG;IAE9B;;;;OAIG;aACa,MAAM,CAAC,OAAO,CAAC,EAAE,iBAAiB,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAEhF;;;;OAIG;IACU,QAAQ,CAAC,OAAO,GAAE,iBAAsB,GAAG,OAAO,CAAC,EAAE,CAAC;IAMnE;;;;;;;;OAQG;IACI,IAAI,CAAC,OAAO,GAAE,iBAAsB;CAQ5C"}
@@ -4,8 +4,8 @@ import { SentTx } from './sent_tx.js';
4
4
  * Implements the sequence create/simulate/send.
5
5
  */
6
6
  export class BaseContractInteraction {
7
- constructor(rpc) {
8
- this.rpc = rpc;
7
+ constructor(pxe) {
8
+ this.pxe = pxe;
9
9
  }
10
10
  /**
11
11
  * Simulates a transaction execution request and returns a tx object ready to be sent.
@@ -14,7 +14,7 @@ export class BaseContractInteraction {
14
14
  */
15
15
  async simulate(options = {}) {
16
16
  const txRequest = this.txRequest ?? (await this.create(options));
17
- this.tx = await this.rpc.simulateTx(txRequest, !options.skipPublicSimulation);
17
+ this.tx = await this.pxe.simulateTx(txRequest, !options.skipPublicSimulation);
18
18
  return this.tx;
19
19
  }
20
20
  /**
@@ -29,9 +29,9 @@ export class BaseContractInteraction {
29
29
  send(options = {}) {
30
30
  const promise = (async () => {
31
31
  const tx = this.tx ?? (await this.simulate(options));
32
- return this.rpc.sendTx(tx);
32
+ return this.pxe.sendTx(tx);
33
33
  })();
34
- return new SentTx(this.rpc, promise);
34
+ return new SentTx(this.pxe, promise);
35
35
  }
36
36
  }
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZV9jb250cmFjdF9pbnRlcmFjdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb250cmFjdC9iYXNlX2NvbnRyYWN0X2ludGVyYWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFhdEM7OztHQUdHO0FBQ0gsTUFBTSxPQUFnQix1QkFBdUI7SUFJM0MsWUFBc0IsR0FBYTtRQUFiLFFBQUcsR0FBSCxHQUFHLENBQVU7SUFBRyxDQUFDO0lBU3ZDOzs7O09BSUc7SUFDSSxLQUFLLENBQUMsUUFBUSxDQUFDLFVBQTZCLEVBQUU7UUFDbkQsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLFNBQVMsSUFBSSxDQUFDLE1BQU0sSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO1FBQ2pFLElBQUksQ0FBQyxFQUFFLEdBQUcsTUFBTSxJQUFJLENBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBQyxTQUFTLEVBQUUsQ0FBQyxPQUFPLENBQUMsb0JBQW9CLENBQUMsQ0FBQztRQUM5RSxPQUFPLElBQUksQ0FBQyxFQUFFLENBQUM7SUFDakIsQ0FBQztJQUVEOzs7Ozs7OztPQVFHO0lBQ0ksSUFBSSxDQUFDLFVBQTZCLEVBQUU7UUFDekMsTUFBTSxPQUFPLEdBQUcsQ0FBQyxLQUFLLElBQUksRUFBRTtZQUMxQixNQUFNLEVBQUUsR0FBRyxJQUFJLENBQUMsRUFBRSxJQUFJLENBQUMsTUFBTSxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7WUFDckQsT0FBTyxJQUFJLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUM3QixDQUFDLENBQUMsRUFBRSxDQUFDO1FBRUwsT0FBTyxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ3ZDLENBQUM7Q0FDRiJ9
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZV9jb250cmFjdF9pbnRlcmFjdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb250cmFjdC9iYXNlX2NvbnRyYWN0X2ludGVyYWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFhdEM7OztHQUdHO0FBQ0gsTUFBTSxPQUFnQix1QkFBdUI7SUFJM0MsWUFBc0IsR0FBUTtRQUFSLFFBQUcsR0FBSCxHQUFHLENBQUs7SUFBRyxDQUFDO0lBU2xDOzs7O09BSUc7SUFDSSxLQUFLLENBQUMsUUFBUSxDQUFDLFVBQTZCLEVBQUU7UUFDbkQsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLFNBQVMsSUFBSSxDQUFDLE1BQU0sSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO1FBQ2pFLElBQUksQ0FBQyxFQUFFLEdBQUcsTUFBTSxJQUFJLENBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBQyxTQUFTLEVBQUUsQ0FBQyxPQUFPLENBQUMsb0JBQW9CLENBQUMsQ0FBQztRQUM5RSxPQUFPLElBQUksQ0FBQyxFQUFFLENBQUM7SUFDakIsQ0FBQztJQUVEOzs7Ozs7OztPQVFHO0lBQ0ksSUFBSSxDQUFDLFVBQTZCLEVBQUU7UUFDekMsTUFBTSxPQUFPLEdBQUcsQ0FBQyxLQUFLLElBQUksRUFBRTtZQUMxQixNQUFNLEVBQUUsR0FBRyxJQUFJLENBQUMsRUFBRSxJQUFJLENBQUMsTUFBTSxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7WUFDckQsT0FBTyxJQUFJLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUM3QixDQUFDLENBQUMsRUFBRSxDQUFDO1FBRUwsT0FBTyxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ3ZDLENBQUM7Q0FDRiJ9
@@ -8,7 +8,7 @@ import { ContractBase } from './contract_base.js';
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 AztecRPCClient, which facilitates
11
+ * to attach the contract instance to a deployed contract on-chain through the PXE, which facilitates
12
12
  * interaction with Aztec's privacy protocol.
13
13
  */
14
14
  export declare class Contract extends ContractBase {
@@ -4,7 +4,7 @@ import { ContractBase } from './contract_base.js';
4
4
  * The Contract class represents a contract and provides utility methods for interacting with it.
5
5
  * It enables the creation of ContractFunctionInteraction instances for each function in the contract's ABI,
6
6
  * allowing users to call or send transactions to these functions. Additionally, the Contract class can be used
7
- * to attach the contract instance to a deployed contract on-chain through the AztecRPCClient, which facilitates
7
+ * to attach the contract instance to a deployed contract on-chain through the PXE, which facilitates
8
8
  * interaction with Aztec's privacy protocol.
9
9
  */
10
10
  export class Contract extends ContractBase {
@@ -51,7 +51,7 @@ export declare class ContractBase {
51
51
  /**
52
52
  * Address of the contract.
53
53
  */
54
- get address(): import("@aztec/circuits.js").AztecAddress;
54
+ get address(): import("../index.js").AztecAddress;
55
55
  /**
56
56
  * Creates a new instance of the contract wrapper attached to a different wallet.
57
57
  * @param wallet - Wallet to use for sending txs.
@@ -60,12 +60,12 @@ export declare class ContractBase {
60
60
  withWallet(wallet: Wallet): this;
61
61
  /**
62
62
  * Attach the current contract instance to a portal contract and optionally add its dependencies.
63
- * The function will return a promise that resolves when all contracts have been added to the AztecRPCClient.
63
+ * The function will return a promise that resolves when all contracts have been added to the PXE.
64
64
  * This is useful when you need to interact with a deployed contract that has multiple nested contracts.
65
65
  *
66
66
  * @param portalContract - The Ethereum address of the portal contract.
67
67
  * @param dependencies - An optional array of additional DeployedContract instances to be attached.
68
- * @returns A promise that resolves when all contracts are successfully added to the AztecRPCClient.
68
+ * @returns A promise that resolves when all contracts are successfully added to the PXE.
69
69
  */
70
70
  attach(portalContract: EthAddress, dependencies?: DeployedContract[]): Promise<void>;
71
71
  }
@@ -1 +1 @@
1
- {"version":3,"file":"contract_base.d.ts","sourceRoot":"","sources":["../../src/contract/contract_base.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAe,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AACnF,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAC3D,OAAO,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAEjE,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAC5C,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,CAAC,QAAQ,EAAE,gBAAgB,CAAC;CACrC,CAAC;AAEF;;GAEG;AACH,qBAAa,YAAY;IAOrB;;OAEG;aACa,eAAe,EAAE,eAAe;IAChD;;OAEG;aACa,GAAG,EAAE,WAAW;IAChC;;OAEG;IACH,SAAS,CAAC,MAAM,EAAE,MAAM;IAjB1B;;OAEG;IACI,OAAO,EAAE;QAAE,CAAC,IAAI,EAAE,MAAM,GAAG,cAAc,CAAA;KAAE,CAAM;IAExD,SAAS;IACP;;OAEG;IACa,eAAe,EAAE,eAAe;IAChD;;OAEG;IACa,GAAG,EAAE,WAAW;IAChC;;OAEG;IACO,MAAM,EAAE,MAAM;IAmB1B;;OAEG;IACH,IAAW,OAAO,8CAEjB;IAED;;;;OAIG;IACI,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAIvC;;;;;;;;OAQG;IACI,MAAM,CAAC,cAAc,EAAE,UAAU,EAAE,YAAY,GAAE,gBAAgB,EAAO;CAQhF"}
1
+ {"version":3,"file":"contract_base.d.ts","sourceRoot":"","sources":["../../src/contract/contract_base.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAe,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AACnF,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAC3D,OAAO,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAEjE,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAC5C,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,CAAC,QAAQ,EAAE,gBAAgB,CAAC;CACrC,CAAC;AAEF;;GAEG;AACH,qBAAa,YAAY;IAOrB;;OAEG;aACa,eAAe,EAAE,eAAe;IAChD;;OAEG;aACa,GAAG,EAAE,WAAW;IAChC;;OAEG;IACH,SAAS,CAAC,MAAM,EAAE,MAAM;IAjB1B;;OAEG;IACI,OAAO,EAAE;QAAE,CAAC,IAAI,EAAE,MAAM,GAAG,cAAc,CAAA;KAAE,CAAM;IAExD,SAAS;IACP;;OAEG;IACa,eAAe,EAAE,eAAe;IAChD;;OAEG;IACa,GAAG,EAAE,WAAW;IAChC;;OAEG;IACO,MAAM,EAAE,MAAM;IAmB1B;;OAEG;IACH,IAAW,OAAO,uCAEjB;IAED;;;;OAIG;IACI,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAIvC;;;;;;;;OAQG;IACI,MAAM,CAAC,cAAc,EAAE,UAAU,EAAE,YAAY,GAAE,gBAAgB,EAAO;CAQhF"}
@@ -55,12 +55,12 @@ export class ContractBase {
55
55
  }
56
56
  /**
57
57
  * Attach the current contract instance to a portal contract and optionally add its dependencies.
58
- * The function will return a promise that resolves when all contracts have been added to the AztecRPCClient.
58
+ * The function will return a promise that resolves when all contracts have been added to the PXE.
59
59
  * This is useful when you need to interact with a deployed contract that has multiple nested contracts.
60
60
  *
61
61
  * @param portalContract - The Ethereum address of the portal contract.
62
62
  * @param dependencies - An optional array of additional DeployedContract instances to be attached.
63
- * @returns A promise that resolves when all contracts are successfully added to the AztecRPCClient.
63
+ * @returns A promise that resolves when all contracts are successfully added to the PXE.
64
64
  */
65
65
  attach(portalContract, dependencies = []) {
66
66
  const deployedContract = {
@@ -8,12 +8,12 @@ export { SendMethodOptions };
8
8
  * Represents the options for a view method in a contract function interaction.
9
9
  * Allows specifying the address from which the view method should be called.
10
10
  */
11
- export interface ViewMethodOptions {
11
+ export type ViewMethodOptions = {
12
12
  /**
13
13
  * The sender's Aztec address.
14
14
  */
15
15
  from?: AztecAddress;
16
- }
16
+ };
17
17
  /**
18
18
  * This is the class that is returned when calling e.g. `contract.methods.myMethod(arg0, arg1)`.
19
19
  * It contains available interactions one can call on a method, including view.
@@ -1 +1 @@
1
- {"version":3,"file":"contract_function_interaction.d.ts","sourceRoot":"","sources":["../../src/contract/contract_function_interaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAgB,MAAM,oBAAoB,CAAC;AAChE,OAAO,EAAE,iBAAiB,EAAiC,MAAM,uBAAuB,CAAC;AACzF,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAEhE,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAC5C,OAAO,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AAE5F,OAAO,EAAE,iBAAiB,EAAE,CAAC;AAE7B;;;GAGG;AACH,MAAM,WAAW,iBAAiB;IAChC;;OAEG;IACH,IAAI,CAAC,EAAE,YAAY,CAAC;CACrB;AAED;;;GAGG;AACH,qBAAa,2BAA4B,SAAQ,uBAAuB;IAEpE,SAAS,CAAC,MAAM,EAAE,MAAM;IACxB,SAAS,CAAC,eAAe,EAAE,YAAY;IACvC,SAAS,CAAC,WAAW,EAAE,iBAAiB;IACxC,SAAS,CAAC,IAAI,EAAE,GAAG,EAAE;gBAHX,MAAM,EAAE,MAAM,EACd,eAAe,EAAE,YAAY,EAC7B,WAAW,EAAE,iBAAiB,EAC9B,IAAI,EAAE,GAAG,EAAE;IAQvB;;;;OAIG;IACU,MAAM,IAAI,OAAO,CAAC,kBAAkB,CAAC;IAUlD;;;;;OAKG;IACI,OAAO,IAAI,YAAY;IAM9B;;;;;;OAMG;IACI,IAAI,CAAC,OAAO,GAAE,iBAAsB;CAQ5C"}
1
+ {"version":3,"file":"contract_function_interaction.d.ts","sourceRoot":"","sources":["../../src/contract/contract_function_interaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAgB,MAAM,oBAAoB,CAAC;AAChE,OAAO,EAAE,iBAAiB,EAAiC,MAAM,uBAAuB,CAAC;AACzF,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAEhE,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAC5C,OAAO,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AAE5F,OAAO,EAAE,iBAAiB,EAAE,CAAC;AAE7B;;;GAGG;AACH,MAAM,MAAM,iBAAiB,GAAG;IAC9B;;OAEG;IACH,IAAI,CAAC,EAAE,YAAY,CAAC;CACrB,CAAC;AAEF;;;GAGG;AACH,qBAAa,2BAA4B,SAAQ,uBAAuB;IAEpE,SAAS,CAAC,MAAM,EAAE,MAAM;IACxB,SAAS,CAAC,eAAe,EAAE,YAAY;IACvC,SAAS,CAAC,WAAW,EAAE,iBAAiB;IACxC,SAAS,CAAC,IAAI,EAAE,GAAG,EAAE;gBAHX,MAAM,EAAE,MAAM,EACd,eAAe,EAAE,YAAY,EAC7B,WAAW,EAAE,iBAAiB,EAC9B,IAAI,EAAE,GAAG,EAAE;IAQvB;;;;OAIG;IACU,MAAM,IAAI,OAAO,CAAC,kBAAkB,CAAC;IAUlD;;;;;OAKG;IACI,OAAO,IAAI,YAAY;IAM9B;;;;;;OAMG;IACI,IAAI,CAAC,OAAO,GAAE,iBAAsB;CAQ5C"}
@@ -1,3 +1,40 @@
1
+ /**
2
+ * The `contract` module provides utilities for deploying and interacting with contracts, based on a
3
+ * `Wallet` instance and a compiled artifact. Refer to the {@link account} module for how to obtain a valid
4
+ * `Wallet` instance, and to the {@link https://docs.aztec.network/dev_docs/contracts/compiling | Compiling contracts}
5
+ * section of the documentation for how to generate an artifact out of your Noir source code.
6
+ *
7
+ * The {@link Contract} class is the main class in this module, and provides static methods for deploying
8
+ * a contract or interacting with an already deployed one. The `methods` property of the contract instance
9
+ * provides access to private, public, and view methods, that can be invoked in a transaction via `send()`,
10
+ * or can be queried via `view()`.
11
+ *
12
+ * ```ts
13
+ * const contract = await Contract.deploy(wallet, MyContractAbi, [...constructorArgs]).send().deployed();
14
+ * console.log(`Contract deployed at ${contract.address}`);
15
+ * ```
16
+ *
17
+ * ```ts
18
+ * const contract = await Contract.at(address, MyContractAbi, wallet);
19
+ * await contract.methods.mint(1000, owner).send().wait();
20
+ * console.log(`Total supply is now ${await contract.methods.totalSupply().view()}`);
21
+ * ```
22
+ *
23
+ * The result of calling a method in a contract instance, such as `contract.methods.mint(1000, owner)`
24
+ * in the example, is a {@link ContractFunctionInteraction} instance. Usually this will be just sent as
25
+ * a transaction to the network via the `send` method, but you can also `simulate` it without sending,
26
+ * or obtaining the `request` for aggregating into a {@link BatchCall}.
27
+ *
28
+ * The result of `send`ing a transaction is a {@link SentTx} object, from which you can get the
29
+ * transaction hash, or simply `wait` until the transaction is mined and the local PXE Service
30
+ * has synchronised its changes.
31
+ *
32
+ * @remarks If you are using typescript, consider using the
33
+ * {@link https://docs.aztec.network/dev_docs/contracts/compiling#typescript-interfaces | autogenerated type-safe interfaces}
34
+ * for interacting with your contracts.
35
+ *
36
+ * @packageDocumentation
37
+ */
1
38
  export * from './contract.js';
2
39
  export * from './contract_function_interaction.js';
3
40
  export * from './sent_tx.js';
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/contract/index.ts"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAC;AAC9B,cAAc,oCAAoC,CAAC;AACnD,cAAc,cAAc,CAAC;AAC7B,cAAc,oBAAoB,CAAC;AACnC,cAAc,iBAAiB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/contract/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAoCG;AACH,cAAc,eAAe,CAAC;AAC9B,cAAc,oCAAoC,CAAC;AACnD,cAAc,cAAc,CAAC;AAC7B,cAAc,oBAAoB,CAAC;AACnC,cAAc,iBAAiB,CAAC"}
@@ -1,6 +1,43 @@
1
+ /**
2
+ * The `contract` module provides utilities for deploying and interacting with contracts, based on a
3
+ * `Wallet` instance and a compiled artifact. Refer to the {@link account} module for how to obtain a valid
4
+ * `Wallet` instance, and to the {@link https://docs.aztec.network/dev_docs/contracts/compiling | Compiling contracts}
5
+ * section of the documentation for how to generate an artifact out of your Noir source code.
6
+ *
7
+ * The {@link Contract} class is the main class in this module, and provides static methods for deploying
8
+ * a contract or interacting with an already deployed one. The `methods` property of the contract instance
9
+ * provides access to private, public, and view methods, that can be invoked in a transaction via `send()`,
10
+ * or can be queried via `view()`.
11
+ *
12
+ * ```ts
13
+ * const contract = await Contract.deploy(wallet, MyContractAbi, [...constructorArgs]).send().deployed();
14
+ * console.log(`Contract deployed at ${contract.address}`);
15
+ * ```
16
+ *
17
+ * ```ts
18
+ * const contract = await Contract.at(address, MyContractAbi, wallet);
19
+ * await contract.methods.mint(1000, owner).send().wait();
20
+ * console.log(`Total supply is now ${await contract.methods.totalSupply().view()}`);
21
+ * ```
22
+ *
23
+ * The result of calling a method in a contract instance, such as `contract.methods.mint(1000, owner)`
24
+ * in the example, is a {@link ContractFunctionInteraction} instance. Usually this will be just sent as
25
+ * a transaction to the network via the `send` method, but you can also `simulate` it without sending,
26
+ * or obtaining the `request` for aggregating into a {@link BatchCall}.
27
+ *
28
+ * The result of `send`ing a transaction is a {@link SentTx} object, from which you can get the
29
+ * transaction hash, or simply `wait` until the transaction is mined and the local PXE Service
30
+ * has synchronised its changes.
31
+ *
32
+ * @remarks If you are using typescript, consider using the
33
+ * {@link https://docs.aztec.network/dev_docs/contracts/compiling#typescript-interfaces | autogenerated type-safe interfaces}
34
+ * for interacting with your contracts.
35
+ *
36
+ * @packageDocumentation
37
+ */
1
38
  export * from './contract.js';
2
39
  export * from './contract_function_interaction.js';
3
40
  export * from './sent_tx.js';
4
41
  export * from './contract_base.js';
5
42
  export * from './batch_call.js';
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29udHJhY3QvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsaUJBQWlCLENBQUMifQ==
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29udHJhY3QvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW9DRztBQUNILGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGlCQUFpQixDQUFDIn0=