@aztec/cli-wallet 0.0.1-commit.29c6b1a3 → 0.0.1-commit.2d9cb6034

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 (44) hide show
  1. package/dest/cmds/authorize_action.d.ts +2 -2
  2. package/dest/cmds/authorize_action.d.ts.map +1 -1
  3. package/dest/cmds/check_tx.d.ts +1 -1
  4. package/dest/cmds/check_tx.d.ts.map +1 -1
  5. package/dest/cmds/check_tx.js +37 -9
  6. package/dest/cmds/create_account.d.ts +4 -3
  7. package/dest/cmds/create_account.d.ts.map +1 -1
  8. package/dest/cmds/create_account.js +32 -21
  9. package/dest/cmds/deploy.d.ts +4 -3
  10. package/dest/cmds/deploy.d.ts.map +1 -1
  11. package/dest/cmds/deploy.js +27 -23
  12. package/dest/cmds/deploy_account.d.ts +4 -3
  13. package/dest/cmds/deploy_account.d.ts.map +1 -1
  14. package/dest/cmds/deploy_account.js +27 -16
  15. package/dest/cmds/get_fee_juice_balance.d.ts +5 -0
  16. package/dest/cmds/get_fee_juice_balance.d.ts.map +1 -0
  17. package/dest/cmds/get_fee_juice_balance.js +27 -0
  18. package/dest/cmds/index.d.ts +1 -1
  19. package/dest/cmds/index.d.ts.map +1 -1
  20. package/dest/cmds/index.js +30 -14
  21. package/dest/cmds/send.d.ts +4 -3
  22. package/dest/cmds/send.d.ts.map +1 -1
  23. package/dest/cmds/send.js +27 -23
  24. package/dest/storage/wallet_db.d.ts +6 -1
  25. package/dest/storage/wallet_db.d.ts.map +1 -1
  26. package/dest/storage/wallet_db.js +60 -31
  27. package/dest/utils/options/fees.d.ts +2 -2
  28. package/dest/utils/options/fees.d.ts.map +1 -1
  29. package/dest/utils/options/fees.js +8 -5
  30. package/dest/utils/wallet.d.ts +8 -3
  31. package/dest/utils/wallet.d.ts.map +1 -1
  32. package/dest/utils/wallet.js +52 -44
  33. package/package.json +14 -14
  34. package/src/cmds/check_tx.ts +43 -11
  35. package/src/cmds/create_account.ts +32 -18
  36. package/src/cmds/deploy.ts +24 -15
  37. package/src/cmds/deploy_account.ts +26 -13
  38. package/src/cmds/get_fee_juice_balance.ts +37 -0
  39. package/src/cmds/index.ts +57 -4
  40. package/src/cmds/send.ts +24 -16
  41. package/src/cmds/simulate.ts +1 -1
  42. package/src/storage/wallet_db.ts +63 -36
  43. package/src/utils/options/fees.ts +13 -5
  44. package/src/utils/wallet.ts +59 -57
@@ -2,7 +2,7 @@ import { EcdsaRAccountContract, EcdsaRSSHAccountContract } from '@aztec/accounts
2
2
  import { SchnorrAccountContract } from '@aztec/accounts/schnorr';
3
3
  import { StubAccountContractArtifact, createStubAccount } from '@aztec/accounts/stub';
4
4
  import { getIdentities } from '@aztec/accounts/utils';
5
- import { type Account, type AccountContract, SignerlessAccount } from '@aztec/aztec.js/account';
5
+ import { type Account, type AccountContract, NO_FROM } from '@aztec/aztec.js/account';
6
6
  import {
7
7
  type InteractionFeeOptions,
8
8
  getContractInstanceFromInstantiationParams,
@@ -11,18 +11,19 @@ import {
11
11
  import type { AztecNode } from '@aztec/aztec.js/node';
12
12
  import { AccountManager, type Aliased, type SimulateOptions } from '@aztec/aztec.js/wallet';
13
13
  import type { DefaultAccountEntrypointOptions } from '@aztec/entrypoints/account';
14
+ import { DefaultEntrypoint } from '@aztec/entrypoints/default';
14
15
  import { Fr } from '@aztec/foundation/curves/bn254';
15
16
  import type { LogFn } from '@aztec/foundation/log';
17
+ import type { NotesFilter } from '@aztec/pxe/client/lazy';
16
18
  import type { PXEConfig } from '@aztec/pxe/config';
17
19
  import type { PXE } from '@aztec/pxe/server';
18
20
  import { createPXE, getPXEConfig } from '@aztec/pxe/server';
19
21
  import { AztecAddress } from '@aztec/stdlib/aztec-address';
20
22
  import { deriveSigningKey } from '@aztec/stdlib/keys';
21
23
  import { NoteDao } from '@aztec/stdlib/note';
22
- import type { NotesFilter } from '@aztec/stdlib/note';
23
- import type { TxProvingResult, TxSimulationResult } from '@aztec/stdlib/tx';
24
+ import type { SimulationOverrides, TxExecutionRequest, TxProvingResult, TxSimulationResult } from '@aztec/stdlib/tx';
24
25
  import { ExecutionPayload, mergeExecutionPayloads } from '@aztec/stdlib/tx';
25
- import { BaseWallet } from '@aztec/wallet-sdk/base-wallet';
26
+ import { BaseWallet, type SimulateViaEntrypointOptions } from '@aztec/wallet-sdk/base-wallet';
26
27
 
27
28
  import type { WalletDB } from '../storage/wallet_db.js';
28
29
  import type { AccountType } from './constants.js';
@@ -55,7 +56,12 @@ export class CLIWallet extends BaseWallet {
55
56
 
56
57
  override async getAccounts(): Promise<Aliased<AztecAddress>[]> {
57
58
  const accounts = (await this.db?.listAliases('accounts')) ?? [];
58
- return Promise.resolve(accounts.map(({ key, value }) => ({ alias: value, item: AztecAddress.fromString(key) })));
59
+ return Promise.resolve(
60
+ accounts.map(({ key, value }) => {
61
+ const alias = key.includes(':') ? key.slice(key.indexOf(':') + 1) : key;
62
+ return { alias, item: AztecAddress.fromString(value) };
63
+ }),
64
+ );
59
65
  }
60
66
 
61
67
  private async createCancellationTxExecutionRequest(
@@ -71,7 +77,8 @@ export class CLIWallet extends BaseWallet {
71
77
  const executionOptions: DefaultAccountEntrypointOptions = {
72
78
  txNonce,
73
79
  cancellable: this.cancellableTransactions,
74
- feePaymentMethodOptions: feeOptions.accountFeePaymentMethodOptions,
80
+ // If from is an address, feeOptions include the way the account contract should handle the fee payment
81
+ feePaymentMethodOptions: feeOptions.accountFeePaymentMethodOptions!,
75
82
  };
76
83
  return await fromAccount.createTxExecutionRequest(
77
84
  feeExecutionPayload ?? executionPayload,
@@ -87,14 +94,12 @@ export class CLIWallet extends BaseWallet {
87
94
  increasedFee: InteractionFeeOptions,
88
95
  ): Promise<TxProvingResult> {
89
96
  const cancellationTxRequest = await this.createCancellationTxExecutionRequest(from, txNonce, increasedFee);
90
- return await this.pxe.proveTx(cancellationTxRequest);
97
+ return await this.pxe.proveTx(cancellationTxRequest, this.scopesFrom(from));
91
98
  }
92
99
 
93
100
  override async getAccountFromAddress(address: AztecAddress) {
94
101
  let account: Account | undefined;
95
- if (address.equals(AztecAddress.ZERO)) {
96
- account = new SignerlessAccount();
97
- } else if (this.accountCache.has(address.toString())) {
102
+ if (this.accountCache.has(address.toString())) {
98
103
  return this.accountCache.get(address.toString())!;
99
104
  } else {
100
105
  const accountManager = await this.createOrRetrieveAccount(address);
@@ -185,13 +190,7 @@ export class CLIWallet extends BaseWallet {
185
190
  */
186
191
  private async getFakeAccountDataFor(address: AztecAddress) {
187
192
  const originalAccount = await this.getAccountFromAddress(address);
188
- // Account contracts can only be overridden if they have an associated address
189
- // Overwriting SignerlessAccount is not supported, and does not really make sense
190
- // since it has no authorization mechanism.
191
- if (originalAccount instanceof SignerlessAccount) {
192
- throw new Error(`Cannot create fake account data for SignerlessAccount at address: ${address}`);
193
- }
194
- const originalAddress = (originalAccount as Account).getCompleteAddress();
193
+ const originalAddress = originalAccount.getCompleteAddress();
195
194
  const contractInstance = await this.pxe.getContractInstance(originalAddress.address);
196
195
  if (!contractInstance) {
197
196
  throw new Error(`No contract instance found for address: ${originalAddress.address}`);
@@ -208,59 +207,62 @@ export class CLIWallet extends BaseWallet {
208
207
  }
209
208
 
210
209
  override async simulateTx(executionPayload: ExecutionPayload, opts: SimulateOptions): Promise<TxSimulationResult> {
211
- let simulationResults;
212
- const feeOptions = opts.fee?.estimateGas
213
- ? await this.completeFeeOptionsForEstimation(opts.from, executionPayload.feePayer, opts.fee?.gasSettings)
214
- : await this.completeFeeOptions(opts.from, executionPayload.feePayer, opts.fee?.gasSettings);
210
+ const simulationResults = await super.simulateTx(executionPayload, opts);
211
+
212
+ if (opts.fee?.estimateGas) {
213
+ const feeOptions = await this.completeFeeOptions(opts.from, executionPayload.feePayer, opts.fee?.gasSettings);
214
+ const limits = getGasLimits(simulationResults, opts.fee?.estimatedGasPadding);
215
+ printGasEstimates(feeOptions, limits, this.userLog);
216
+ }
217
+ return simulationResults;
218
+ }
219
+
220
+ /**
221
+ * Uses a stub account for kernelless simulation, bypassing real account authorization.
222
+ * Uses DefaultEntrypoint directly for NO_FROM transactions.
223
+ */
224
+ protected override async simulateViaEntrypoint(
225
+ executionPayload: ExecutionPayload,
226
+ opts: SimulateViaEntrypointOptions,
227
+ ): Promise<TxSimulationResult> {
228
+ const { from, feeOptions, scopes } = opts;
215
229
  const feeExecutionPayload = await feeOptions.walletFeePaymentMethod?.getExecutionPayload();
216
- const chainInfo = await this.getChainInfo();
217
- const executionOptions: DefaultAccountEntrypointOptions = {
218
- txNonce: Fr.random(),
219
- cancellable: this.cancellableTransactions,
220
- feePaymentMethodOptions: feeOptions.accountFeePaymentMethodOptions,
221
- };
222
230
  const finalExecutionPayload = feeExecutionPayload
223
231
  ? mergeExecutionPayloads([feeExecutionPayload, executionPayload])
224
232
  : executionPayload;
233
+ const chainInfo = await this.getChainInfo();
225
234
 
226
- // Kernelless simulations using the multicall entrypoints are not currently supported,
227
- // since we only override proper account contracts.
228
- // TODO: allow disabling kernels even when no overrides are necessary
229
- if (opts.from.equals(AztecAddress.ZERO)) {
230
- const fromAccount = await this.getAccountFromAddress(opts.from);
231
- const txRequest = await fromAccount.createTxExecutionRequest(
232
- finalExecutionPayload,
233
- feeOptions.gasSettings,
234
- chainInfo,
235
- executionOptions,
236
- );
237
- simulationResults = await this.pxe.simulateTx(
238
- txRequest,
239
- true /* simulatePublic */,
240
- opts?.skipTxValidation,
241
- opts?.skipFeeEnforcement ?? true,
242
- );
235
+ let overrides: SimulationOverrides | undefined;
236
+ let txRequest: TxExecutionRequest;
237
+ if (from === NO_FROM) {
238
+ const entrypoint = new DefaultEntrypoint();
239
+ txRequest = await entrypoint.createTxExecutionRequest(finalExecutionPayload, feeOptions.gasSettings, chainInfo);
243
240
  } else {
244
- const { account: fromAccount, instance, artifact } = await this.getFakeAccountDataFor(opts.from);
245
- const txRequest = await fromAccount.createTxExecutionRequest(
241
+ const { account, instance, artifact } = await this.getFakeAccountDataFor(from);
242
+ overrides = {
243
+ contracts: { [from.toString()]: { instance, artifact } },
244
+ };
245
+ const executionOptions: DefaultAccountEntrypointOptions = {
246
+ txNonce: Fr.random(),
247
+ cancellable: this.cancellableTransactions,
248
+ // If from is an address, feeOptions include the way the account contract should handle the fee payment
249
+ feePaymentMethodOptions: feeOptions.accountFeePaymentMethodOptions!,
250
+ };
251
+ txRequest = await account.createTxExecutionRequest(
246
252
  finalExecutionPayload,
247
253
  feeOptions.gasSettings,
248
254
  chainInfo,
249
255
  executionOptions,
250
256
  );
251
- const contractOverrides = {
252
- [opts.from.toString()]: { instance, artifact },
253
- };
254
- simulationResults = await this.pxe.simulateTx(txRequest, true /* simulatePublic */, true, true, {
255
- contracts: contractOverrides,
256
- });
257
257
  }
258
258
 
259
- if (opts.fee?.estimateGas) {
260
- const limits = getGasLimits(simulationResults, opts.fee?.estimatedGasPadding);
261
- printGasEstimates(feeOptions, limits, this.userLog);
262
- }
263
- return simulationResults;
259
+ return this.pxe.simulateTx(txRequest, {
260
+ simulatePublic: true,
261
+ skipFeeEnforcement: true,
262
+ skipTxValidation: true,
263
+ overrides,
264
+ scopes,
265
+ });
264
266
  }
265
267
 
266
268
  // Exposed because of the `aztec-wallet get-tx` command. It has been decided that it's fine to keep around because