@aztec/wallets 0.0.1-commit.fff30aa → 0.0.1-private.3d175340d2
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.
- package/dest/embedded/account-contract-providers/bundle.d.ts +2 -6
- package/dest/embedded/account-contract-providers/bundle.d.ts.map +1 -1
- package/dest/embedded/account-contract-providers/bundle.js +0 -4
- package/dest/embedded/account-contract-providers/lazy.d.ts +2 -6
- package/dest/embedded/account-contract-providers/lazy.d.ts.map +1 -1
- package/dest/embedded/account-contract-providers/lazy.js +0 -4
- package/dest/embedded/account-contract-providers/types.d.ts +2 -6
- package/dest/embedded/account-contract-providers/types.d.ts.map +1 -1
- package/dest/embedded/embedded_wallet.d.ts +29 -3
- package/dest/embedded/embedded_wallet.d.ts.map +1 -1
- package/dest/embedded/embedded_wallet.js +75 -25
- package/dest/embedded/entrypoints/browser.d.ts +1 -1
- package/dest/embedded/entrypoints/browser.d.ts.map +1 -1
- package/dest/embedded/entrypoints/browser.js +22 -5
- package/dest/embedded/entrypoints/node.d.ts +1 -1
- package/dest/embedded/entrypoints/node.d.ts.map +1 -1
- package/dest/embedded/entrypoints/node.js +16 -5
- package/dest/embedded/store_encryption.d.ts +67 -0
- package/dest/embedded/store_encryption.d.ts.map +1 -0
- package/dest/embedded/store_encryption.js +71 -0
- package/dest/embedded/wallet_db.d.ts +5 -4
- package/dest/embedded/wallet_db.d.ts.map +1 -1
- package/dest/embedded/wallet_db.js +9 -9
- package/package.json +17 -15
- package/src/embedded/account-contract-providers/bundle.ts +1 -6
- package/src/embedded/account-contract-providers/lazy.ts +1 -6
- package/src/embedded/account-contract-providers/types.ts +1 -2
- package/src/embedded/embedded_wallet.ts +114 -18
- package/src/embedded/entrypoints/browser.ts +31 -14
- package/src/embedded/entrypoints/node.ts +30 -20
- package/src/embedded/store_encryption.ts +107 -0
- package/src/embedded/wallet_db.ts +12 -9
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import type { Account, AccountContract } from '@aztec/aztec.js/account';
|
|
2
2
|
import type { Fq } from '@aztec/foundation/curves/bn254';
|
|
3
3
|
import type { ContractArtifact } from '@aztec/stdlib/abi';
|
|
4
|
-
import type { CompleteAddress
|
|
4
|
+
import type { CompleteAddress } from '@aztec/stdlib/contract';
|
|
5
5
|
import type { AccountType } from '../wallet_db.js';
|
|
6
6
|
import type { AccountContractsProvider } from './types.js';
|
|
7
7
|
/**
|
|
@@ -14,9 +14,5 @@ export declare class BundleAccountContractsProvider implements AccountContractsP
|
|
|
14
14
|
getEcdsaKAccountContract(signingKey: Buffer): Promise<AccountContract>;
|
|
15
15
|
getStubAccountContractArtifact(type: AccountType): Promise<ContractArtifact>;
|
|
16
16
|
createStubAccount(address: CompleteAddress, type: AccountType): Promise<Account>;
|
|
17
|
-
getMulticallContract(): Promise<{
|
|
18
|
-
instance: ContractInstanceWithAddress;
|
|
19
|
-
artifact: ContractArtifact;
|
|
20
|
-
}>;
|
|
21
17
|
}
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVuZGxlLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZW1iZWRkZWQvYWNjb3VudC1jb250cmFjdC1wcm92aWRlcnMvYnVuZGxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE9BQU8sS0FBSyxFQUFFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN4RSxPQUFPLEtBQUssRUFBRSxFQUFFLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN6RCxPQUFPLEtBQUssRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQzFELE9BQU8sS0FBSyxFQUFFLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRTlELE9BQU8sS0FBSyxFQUFFLFdBQVcsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ25ELE9BQU8sS0FBSyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sWUFBWSxDQUFDO0FBRTNEOzs7R0FHRztBQUNILHFCQUFhLDhCQUErQixZQUFXLHdCQUF3QjtJQUM3RSx5QkFBeUIsQ0FBQyxVQUFVLEVBQUUsRUFBRSxHQUFHLE9BQU8sQ0FBQyxlQUFlLENBQUMsQ0FFbEU7SUFFRCx3QkFBd0IsQ0FBQyxVQUFVLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FBQyxlQUFlLENBQUMsQ0FFckU7SUFFRCx3QkFBd0IsQ0FBQyxVQUFVLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FBQyxlQUFlLENBQUMsQ0FFckU7SUFFRCw4QkFBOEIsQ0FBQyxJQUFJLEVBQUUsV0FBVyxHQUFHLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUUzRTtJQUVELGlCQUFpQixDQUFDLE9BQU8sRUFBRSxlQUFlLEVBQUUsSUFBSSxFQUFFLFdBQVcsR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLENBRS9FO0NBQ0YifQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bundle.d.ts","sourceRoot":"","sources":["../../../src/embedded/account-contract-providers/bundle.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AACxE,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;
|
|
1
|
+
{"version":3,"file":"bundle.d.ts","sourceRoot":"","sources":["../../../src/embedded/account-contract-providers/bundle.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AACxE,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AACzD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAE9D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,YAAY,CAAC;AAE3D;;;GAGG;AACH,qBAAa,8BAA+B,YAAW,wBAAwB;IAC7E,yBAAyB,CAAC,UAAU,EAAE,EAAE,GAAG,OAAO,CAAC,eAAe,CAAC,CAElE;IAED,wBAAwB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,CAAC,CAErE;IAED,wBAAwB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,CAAC,CAErE;IAED,8BAA8B,CAAC,IAAI,EAAE,WAAW,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAE3E;IAED,iBAAiB,CAAC,OAAO,EAAE,eAAe,EAAE,IAAI,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC,CAE/E;CACF"}
|
|
@@ -2,7 +2,6 @@ import { EcdsaKAccountContract, EcdsaRAccountContract } from '@aztec/accounts/ec
|
|
|
2
2
|
import { SchnorrAccountContract } from '@aztec/accounts/schnorr';
|
|
3
3
|
import { StubEcdsaAccountContractArtifact, createStubEcdsaAccount } from '@aztec/accounts/stub/ecdsa';
|
|
4
4
|
import { StubSchnorrAccountContractArtifact, createStubSchnorrAccount } from '@aztec/accounts/stub/schnorr';
|
|
5
|
-
import { getCanonicalMultiCallEntrypoint } from '@aztec/protocol-contracts/multi-call-entrypoint';
|
|
6
5
|
/**
|
|
7
6
|
* Loads account contract artifacts eagerly via static imports.
|
|
8
7
|
* Designed for Node.js environments where all artifacts are available at startup.
|
|
@@ -22,7 +21,4 @@ import { getCanonicalMultiCallEntrypoint } from '@aztec/protocol-contracts/multi
|
|
|
22
21
|
createStubAccount(address, type) {
|
|
23
22
|
return Promise.resolve(type === 'schnorr' ? createStubSchnorrAccount(address) : createStubEcdsaAccount(address));
|
|
24
23
|
}
|
|
25
|
-
getMulticallContract() {
|
|
26
|
-
return getCanonicalMultiCallEntrypoint();
|
|
27
|
-
}
|
|
28
24
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import type { Account, AccountContract } from '@aztec/aztec.js/account';
|
|
2
2
|
import type { Fq } from '@aztec/foundation/curves/bn254';
|
|
3
3
|
import type { ContractArtifact } from '@aztec/stdlib/abi';
|
|
4
|
-
import type { CompleteAddress
|
|
4
|
+
import type { CompleteAddress } from '@aztec/stdlib/contract';
|
|
5
5
|
import type { AccountType } from '../wallet_db.js';
|
|
6
6
|
import type { AccountContractsProvider } from './types.js';
|
|
7
7
|
/**
|
|
@@ -14,9 +14,5 @@ export declare class LazyAccountContractsProvider implements AccountContractsPro
|
|
|
14
14
|
getEcdsaKAccountContract(signingKey: Buffer): Promise<AccountContract>;
|
|
15
15
|
getStubAccountContractArtifact(type: AccountType): Promise<ContractArtifact>;
|
|
16
16
|
createStubAccount(address: CompleteAddress, type: AccountType): Promise<Account>;
|
|
17
|
-
getMulticallContract(): Promise<{
|
|
18
|
-
instance: ContractInstanceWithAddress;
|
|
19
|
-
artifact: ContractArtifact;
|
|
20
|
-
}>;
|
|
21
17
|
}
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF6eS5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2VtYmVkZGVkL2FjY291bnQtY29udHJhY3QtcHJvdmlkZXJzL2xhenkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLEVBQUUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3hFLE9BQU8sS0FBSyxFQUFFLEVBQUUsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ3pELE9BQU8sS0FBSyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDMUQsT0FBTyxLQUFLLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFOUQsT0FBTyxLQUFLLEVBQUUsV0FBVyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDbkQsT0FBTyxLQUFLLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFFM0Q7OztHQUdHO0FBQ0gscUJBQWEsNEJBQTZCLFlBQVcsd0JBQXdCO0lBQ3JFLHlCQUF5QixDQUFDLFVBQVUsRUFBRSxFQUFFLEdBQUcsT0FBTyxDQUFDLGVBQWUsQ0FBQyxDQUd4RTtJQUVLLHdCQUF3QixDQUFDLFVBQVUsRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLGVBQWUsQ0FBQyxDQUczRTtJQUVLLHdCQUF3QixDQUFDLFVBQVUsRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLGVBQWUsQ0FBQyxDQUczRTtJQUVLLDhCQUE4QixDQUFDLElBQUksRUFBRSxXQUFXLEdBQUcsT0FBTyxDQUFDLGdCQUFnQixDQUFDLENBUWpGO0lBRUssaUJBQWlCLENBQUMsT0FBTyxFQUFFLGVBQWUsRUFBRSxJQUFJLEVBQUUsV0FBVyxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FRckY7Q0FDRiJ9
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lazy.d.ts","sourceRoot":"","sources":["../../../src/embedded/account-contract-providers/lazy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AACxE,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;
|
|
1
|
+
{"version":3,"file":"lazy.d.ts","sourceRoot":"","sources":["../../../src/embedded/account-contract-providers/lazy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AACxE,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AACzD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAE9D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,YAAY,CAAC;AAE3D;;;GAGG;AACH,qBAAa,4BAA6B,YAAW,wBAAwB;IACrE,yBAAyB,CAAC,UAAU,EAAE,EAAE,GAAG,OAAO,CAAC,eAAe,CAAC,CAGxE;IAEK,wBAAwB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,CAAC,CAG3E;IAEK,wBAAwB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,CAAC,CAG3E;IAEK,8BAA8B,CAAC,IAAI,EAAE,WAAW,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAQjF;IAEK,iBAAiB,CAAC,OAAO,EAAE,eAAe,EAAE,IAAI,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC,CAQrF;CACF"}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { getCanonicalMultiCallEntrypoint } from '@aztec/protocol-contracts/multi-call-entrypoint/lazy';
|
|
2
1
|
/**
|
|
3
2
|
* Loads account contract artifacts lazily via dynamic imports.
|
|
4
3
|
* Designed for browser environments where code splitting reduces initial bundle size.
|
|
@@ -33,7 +32,4 @@ import { getCanonicalMultiCallEntrypoint } from '@aztec/protocol-contracts/multi
|
|
|
33
32
|
return createStubEcdsaAccount(address);
|
|
34
33
|
}
|
|
35
34
|
}
|
|
36
|
-
getMulticallContract() {
|
|
37
|
-
return getCanonicalMultiCallEntrypoint();
|
|
38
|
-
}
|
|
39
35
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import type { Account, AccountContract } from '@aztec/aztec.js/account';
|
|
2
2
|
import type { Fq } from '@aztec/foundation/curves/bn254';
|
|
3
3
|
import type { ContractArtifact } from '@aztec/stdlib/abi';
|
|
4
|
-
import type { CompleteAddress
|
|
4
|
+
import type { CompleteAddress } from '@aztec/stdlib/contract';
|
|
5
5
|
import type { AccountType } from '../wallet_db.js';
|
|
6
6
|
/**
|
|
7
7
|
* Provides account contract implementations and stub accounts for the EmbeddedWallet.
|
|
@@ -14,10 +14,6 @@ export interface AccountContractsProvider {
|
|
|
14
14
|
getEcdsaRAccountContract(signingKey: Buffer): Promise<AccountContract>;
|
|
15
15
|
getEcdsaKAccountContract(signingKey: Buffer): Promise<AccountContract>;
|
|
16
16
|
getStubAccountContractArtifact(type: AccountType): Promise<ContractArtifact>;
|
|
17
|
-
getMulticallContract(): Promise<{
|
|
18
|
-
instance: ContractInstanceWithAddress;
|
|
19
|
-
artifact: ContractArtifact;
|
|
20
|
-
}>;
|
|
21
17
|
createStubAccount(address: CompleteAddress, type: AccountType): Promise<Account>;
|
|
22
18
|
}
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9lbWJlZGRlZC9hY2NvdW50LWNvbnRyYWN0LXByb3ZpZGVycy90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssRUFBRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDeEUsT0FBTyxLQUFLLEVBQUUsRUFBRSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDekQsT0FBTyxLQUFLLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUMxRCxPQUFPLEtBQUssRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUU5RCxPQUFPLEtBQUssRUFBRSxXQUFXLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUVuRDs7Ozs7R0FLRztBQUNILE1BQU0sV0FBVyx3QkFBd0I7SUFDdkMseUJBQXlCLENBQUMsVUFBVSxFQUFFLEVBQUUsR0FBRyxPQUFPLENBQUMsZUFBZSxDQUFDLENBQUM7SUFDcEUsd0JBQXdCLENBQUMsVUFBVSxFQUFFLE1BQU0sR0FBRyxPQUFPLENBQUMsZUFBZSxDQUFDLENBQUM7SUFDdkUsd0JBQXdCLENBQUMsVUFBVSxFQUFFLE1BQU0sR0FBRyxPQUFPLENBQUMsZUFBZSxDQUFDLENBQUM7SUFDdkUsOEJBQThCLENBQUMsSUFBSSxFQUFFLFdBQVcsR0FBRyxPQUFPLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUM3RSxpQkFBaUIsQ0FBQyxPQUFPLEVBQUUsZUFBZSxFQUFFLElBQUksRUFBRSxXQUFXLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0NBQ2xGIn0=
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/embedded/account-contract-providers/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AACxE,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AACzD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,KAAK,EAAE,eAAe,EAAE,
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/embedded/account-contract-providers/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AACxE,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AACzD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAE9D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAEnD;;;;;GAKG;AACH,MAAM,WAAW,wBAAwB;IACvC,yBAAyB,CAAC,UAAU,EAAE,EAAE,GAAG,OAAO,CAAC,eAAe,CAAC,CAAC;IACpE,wBAAwB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,CAAC,CAAC;IACvE,wBAAwB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,CAAC,CAAC;IACvE,8BAA8B,CAAC,IAAI,EAAE,WAAW,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC;IAC7E,iBAAiB,CAAC,OAAO,EAAE,eAAe,EAAE,IAAI,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;CAClF"}
|
|
@@ -1,14 +1,17 @@
|
|
|
1
1
|
import { type Account } from '@aztec/aztec.js/account';
|
|
2
2
|
import { type InteractionWaitOptions, type SendReturn } from '@aztec/aztec.js/contracts';
|
|
3
|
-
import type { Aliased, SendOptions } from '@aztec/aztec.js/wallet';
|
|
3
|
+
import type { Aliased, ExecuteUtilityOptions, PrivateEvent, PrivateEventFilter, ProfileOptions, SendOptions, SimulateOptions } from '@aztec/aztec.js/wallet';
|
|
4
4
|
import { AccountManager, TxSimulationResultWithAppOffset } from '@aztec/aztec.js/wallet';
|
|
5
5
|
import { Fq, Fr } from '@aztec/foundation/curves/bn254';
|
|
6
6
|
import type { Logger } from '@aztec/foundation/log';
|
|
7
|
+
import type { AztecAsyncKVStore } from '@aztec/kv-store';
|
|
7
8
|
import type { PXEConfig, PXECreationOptions } from '@aztec/pxe/client/lazy';
|
|
8
9
|
import type { PXE } from '@aztec/pxe/server';
|
|
10
|
+
import type { ContractArtifact, EventMetadataDefinition, FunctionCall } from '@aztec/stdlib/abi';
|
|
9
11
|
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
12
|
+
import { type ContractInstanceWithAddress } from '@aztec/stdlib/contract';
|
|
10
13
|
import type { AztecNode } from '@aztec/stdlib/interfaces/client';
|
|
11
|
-
import { type ContractOverrides, ExecutionPayload } from '@aztec/stdlib/tx';
|
|
14
|
+
import { type ContractOverrides, ExecutionPayload, type TxProfileResult, type UtilityExecutionResult } from '@aztec/stdlib/tx';
|
|
12
15
|
import { BaseWallet, type SimulateViaEntrypointOptions } from '@aztec/wallet-sdk/base-wallet';
|
|
13
16
|
import type { AccountContractsProvider } from './account-contract-providers/types.js';
|
|
14
17
|
import { type AccountType, WalletDB } from './wallet_db.js';
|
|
@@ -19,6 +22,11 @@ export declare function splitPxeOptions(pxe?: EmbeddedWalletPXEOptions): {
|
|
|
19
22
|
config: Partial<PXEConfig>;
|
|
20
23
|
creation: PXECreationOptions;
|
|
21
24
|
};
|
|
25
|
+
/** Options for the EmbeddedWallet's own DB (accounts, senders — distinct from PXE state). */
|
|
26
|
+
export type EmbeddedWalletDBOptions = {
|
|
27
|
+
/** Override the wallet DB backend. If omitted, an IndexedDB (browser) / LMDB (node) store is created. */
|
|
28
|
+
store?: AztecAsyncKVStore;
|
|
29
|
+
};
|
|
22
30
|
export type EmbeddedWalletOptions = {
|
|
23
31
|
/** Parent logger. Child loggers are derived via createChild() for each subsystem. */
|
|
24
32
|
logger?: Logger;
|
|
@@ -26,6 +34,8 @@ export type EmbeddedWalletOptions = {
|
|
|
26
34
|
ephemeral?: boolean;
|
|
27
35
|
/** PXE configuration and dependency overrides (custom store, prover, simulator). */
|
|
28
36
|
pxe?: EmbeddedWalletPXEOptions;
|
|
37
|
+
/** Wallet DB dependency overrides (custom store). */
|
|
38
|
+
walletDb?: EmbeddedWalletDBOptions;
|
|
29
39
|
/**
|
|
30
40
|
* Override PXE configuration.
|
|
31
41
|
* @deprecated Use `pxe` instead.
|
|
@@ -41,6 +51,7 @@ export declare class EmbeddedWallet extends BaseWallet {
|
|
|
41
51
|
protected walletDB: WalletDB;
|
|
42
52
|
protected accountContracts: AccountContractsProvider;
|
|
43
53
|
protected estimatedGasPadding: number;
|
|
54
|
+
protected stubClassIds: Map<"ecdsasecp256k1" | "ecdsasecp256r1" | "schnorr", Fr>;
|
|
44
55
|
constructor(pxe: PXE, aztecNode: AztecNode, walletDB: WalletDB, accountContracts: AccountContractsProvider, log?: Logger);
|
|
45
56
|
protected getAccountFromAddress(address: AztecAddress): Promise<Account>;
|
|
46
57
|
getAccounts(): Promise<Aliased<AztecAddress>[]>;
|
|
@@ -52,6 +63,21 @@ export declare class EmbeddedWallet extends BaseWallet {
|
|
|
52
63
|
* the necessary authwitnesses.
|
|
53
64
|
*/
|
|
54
65
|
sendTx<W extends InteractionWaitOptions = undefined>(executionPayload: ExecutionPayload, opts: SendOptions<W>): Promise<SendReturn<W>>;
|
|
66
|
+
/**
|
|
67
|
+
* Overrides the base simulateTx to drive PXE syncing explicitly. The PXE created by the embedded
|
|
68
|
+
* wallet has autoSync disabled (so we can share one sync across simulate+send in sendTx); for
|
|
69
|
+
* standalone simulations we still need a fresh anchor block, which we provide here.
|
|
70
|
+
*/
|
|
71
|
+
simulateTx(executionPayload: ExecutionPayload, opts: SimulateOptions): Promise<TxSimulationResultWithAppOffset>;
|
|
72
|
+
profileTx(executionPayload: ExecutionPayload, opts: ProfileOptions): Promise<TxProfileResult>;
|
|
73
|
+
executeUtility(call: FunctionCall, opts: ExecuteUtilityOptions): Promise<UtilityExecutionResult>;
|
|
74
|
+
getPrivateEvents<T>(eventDef: EventMetadataDefinition, eventFilter: PrivateEventFilter): Promise<PrivateEvent<T>[]>;
|
|
75
|
+
registerContract(instance: ContractInstanceWithAddress, artifact?: ContractArtifact, secretKey?: Fr): Promise<ContractInstanceWithAddress>;
|
|
76
|
+
/**
|
|
77
|
+
* Hashes and registers the stub class for every supported account type with PXE, populating
|
|
78
|
+
* stubClassIds. Called on wallet initialization.
|
|
79
|
+
*/
|
|
80
|
+
initStubClasses(): Promise<void>;
|
|
55
81
|
/**
|
|
56
82
|
* Builds contract overrides for all provided addresses by replacing their account contracts with stub implementations.
|
|
57
83
|
* Uses a type-specific stub artifact so that the stub's constructor selector matches the real account's constructor.
|
|
@@ -72,4 +98,4 @@ export declare class EmbeddedWallet extends BaseWallet {
|
|
|
72
98
|
setEstimatedGasPadding(value?: number): void;
|
|
73
99
|
stop(): Promise<void>;
|
|
74
100
|
}
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1iZWRkZWRfd2FsbGV0LmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZW1iZWRkZWQvZW1iZWRkZWRfd2FsbGV0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxLQUFLLE9BQU8sRUFBVyxNQUFNLHlCQUF5QixDQUFDO0FBRWhFLE9BQU8sRUFBRSxLQUFLLHNCQUFzQixFQUFFLEtBQUssVUFBVSxFQUErQixNQUFNLDJCQUEyQixDQUFDO0FBQ3RILE9BQU8sS0FBSyxFQUNWLE9BQU8sRUFDUCxxQkFBcUIsRUFDckIsWUFBWSxFQUNaLGtCQUFrQixFQUNsQixjQUFjLEVBQ2QsV0FBVyxFQUNYLGVBQWUsRUFDaEIsTUFBTSx3QkFBd0IsQ0FBQztBQUNoQyxPQUFPLEVBQUUsY0FBYyxFQUFFLCtCQUErQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFHekYsT0FBTyxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN4RCxPQUFPLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNwRCxPQUFPLEtBQUssRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3pELE9BQU8sS0FBSyxFQUFFLFNBQVMsRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzVFLE9BQU8sS0FBSyxFQUFFLEdBQUcsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQzdDLE9BQU8sS0FBSyxFQUFFLGdCQUFnQixFQUFFLHVCQUF1QixFQUFFLFlBQVksRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ2pHLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsS0FBSywyQkFBMkIsRUFBZ0MsTUFBTSx3QkFBd0IsQ0FBQztBQUV4RyxPQUFPLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUVqRSxPQUFP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
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"embedded_wallet.d.ts","sourceRoot":"","sources":["../../src/embedded/embedded_wallet.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,OAAO,EAAW,MAAM,yBAAyB,CAAC;AAEhE,OAAO,EAAE,KAAK,sBAAsB,EAAE,KAAK,UAAU,EAA+B,MAAM,2BAA2B,CAAC;AACtH,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"embedded_wallet.d.ts","sourceRoot":"","sources":["../../src/embedded/embedded_wallet.ts"],"names":[],"mappings":"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"}
|
|
@@ -4,7 +4,7 @@ import { getGasLimits } from '@aztec/aztec.js/contracts';
|
|
|
4
4
|
import { AccountManager, TxSimulationResultWithAppOffset } from '@aztec/aztec.js/wallet';
|
|
5
5
|
import { DefaultEntrypoint } from '@aztec/entrypoints/default';
|
|
6
6
|
import { Fq, Fr } from '@aztec/foundation/curves/bn254';
|
|
7
|
-
import {
|
|
7
|
+
import { getContractClassFromArtifact } from '@aztec/stdlib/contract';
|
|
8
8
|
import { GasSettings } from '@aztec/stdlib/gas';
|
|
9
9
|
import { deriveSigningKey } from '@aztec/stdlib/keys';
|
|
10
10
|
import { SimulationOverrides, TxStatus, collectOffchainEffects, mergeExecutionPayloads } from '@aztec/stdlib/tx';
|
|
@@ -16,7 +16,7 @@ import { BaseWallet } from '@aztec/wallet-sdk/base-wallet';
|
|
|
16
16
|
creation: {}
|
|
17
17
|
};
|
|
18
18
|
}
|
|
19
|
-
const { loggers, loggerActorLabel, proverOrOptions, store, simulator, ...config } = pxe;
|
|
19
|
+
const { loggers, loggerActorLabel, proverOrOptions, store, simulator, hooks, preloadedContractsProvider, ...config } = pxe;
|
|
20
20
|
return {
|
|
21
21
|
config,
|
|
22
22
|
creation: {
|
|
@@ -24,7 +24,9 @@ import { BaseWallet } from '@aztec/wallet-sdk/base-wallet';
|
|
|
24
24
|
loggerActorLabel,
|
|
25
25
|
proverOrOptions,
|
|
26
26
|
store,
|
|
27
|
-
simulator
|
|
27
|
+
simulator,
|
|
28
|
+
hooks,
|
|
29
|
+
preloadedContractsProvider
|
|
28
30
|
}
|
|
29
31
|
};
|
|
30
32
|
}
|
|
@@ -33,8 +35,11 @@ export class EmbeddedWallet extends BaseWallet {
|
|
|
33
35
|
walletDB;
|
|
34
36
|
accountContracts;
|
|
35
37
|
estimatedGasPadding;
|
|
38
|
+
// Stub class ids, populated on wallet startup
|
|
39
|
+
// to avoid redundant work per simulation
|
|
40
|
+
stubClassIds;
|
|
36
41
|
constructor(pxe, aztecNode, walletDB, accountContracts, log){
|
|
37
|
-
super(pxe, aztecNode, log), this.walletDB = walletDB, this.accountContracts = accountContracts, this.estimatedGasPadding = DEFAULT_ESTIMATED_GAS_PADDING;
|
|
42
|
+
super(pxe, aztecNode, log), this.walletDB = walletDB, this.accountContracts = accountContracts, this.estimatedGasPadding = DEFAULT_ESTIMATED_GAS_PADDING, this.stubClassIds = new Map();
|
|
38
43
|
}
|
|
39
44
|
async getAccountFromAddress(address) {
|
|
40
45
|
const { secretKey, salt, signingKey, type } = await this.walletDB.retrieveAccount(address);
|
|
@@ -67,6 +72,9 @@ export class EmbeddedWallet extends BaseWallet {
|
|
|
67
72
|
* estimates actual gas usage and captures call authorization requests to generate
|
|
68
73
|
* the necessary authwitnesses.
|
|
69
74
|
*/ async sendTx(executionPayload, opts) {
|
|
75
|
+
// PXE has autoSync disabled by the embedded wallet entrypoints, so we sync once here to cover
|
|
76
|
+
// both the inner simulateTx (via simulateViaEntrypoint) and the proveTx that super.sendTx
|
|
77
|
+
await this.pxe.sync();
|
|
70
78
|
const feeOptions = await this.completeFeeOptions({
|
|
71
79
|
from: opts.from,
|
|
72
80
|
feePayer: executionPayload.feePayer,
|
|
@@ -79,7 +87,8 @@ export class EmbeddedWallet extends BaseWallet {
|
|
|
79
87
|
from: opts.from,
|
|
80
88
|
feeOptions,
|
|
81
89
|
additionalScopes: opts.additionalScopes,
|
|
82
|
-
skipTxValidation: true
|
|
90
|
+
skipTxValidation: true,
|
|
91
|
+
sendMessagesAs: opts.sendMessagesAs
|
|
83
92
|
});
|
|
84
93
|
const offchainEffects = collectOffchainEffects(simulationResult.privateExecutionResult);
|
|
85
94
|
const authWitnesses = await Promise.all(offchainEffects.map(async (effect)=>{
|
|
@@ -127,6 +136,47 @@ export class EmbeddedWallet extends BaseWallet {
|
|
|
127
136
|
});
|
|
128
137
|
}
|
|
129
138
|
/**
|
|
139
|
+
* Overrides the base simulateTx to drive PXE syncing explicitly. The PXE created by the embedded
|
|
140
|
+
* wallet has autoSync disabled (so we can share one sync across simulate+send in sendTx); for
|
|
141
|
+
* standalone simulations we still need a fresh anchor block, which we provide here.
|
|
142
|
+
*/ async simulateTx(executionPayload, opts) {
|
|
143
|
+
await this.pxe.sync();
|
|
144
|
+
return super.simulateTx(executionPayload, opts);
|
|
145
|
+
}
|
|
146
|
+
async profileTx(executionPayload, opts) {
|
|
147
|
+
await this.pxe.sync();
|
|
148
|
+
return super.profileTx(executionPayload, opts);
|
|
149
|
+
}
|
|
150
|
+
async executeUtility(call, opts) {
|
|
151
|
+
await this.pxe.sync();
|
|
152
|
+
return super.executeUtility(call, opts);
|
|
153
|
+
}
|
|
154
|
+
async getPrivateEvents(eventDef, eventFilter) {
|
|
155
|
+
await this.pxe.sync();
|
|
156
|
+
return super.getPrivateEvents(eventDef, eventFilter);
|
|
157
|
+
}
|
|
158
|
+
async registerContract(instance, artifact, secretKey) {
|
|
159
|
+
// registerContract may call pxe.updateContract under the hood, which depends on a fresh anchor
|
|
160
|
+
// block to verify the current class id from the node.
|
|
161
|
+
await this.pxe.sync();
|
|
162
|
+
return super.registerContract(instance, artifact, secretKey);
|
|
163
|
+
}
|
|
164
|
+
/**
|
|
165
|
+
* Hashes and registers the stub class for every supported account type with PXE, populating
|
|
166
|
+
* stubClassIds. Called on wallet initialization.
|
|
167
|
+
*/ async initStubClasses() {
|
|
168
|
+
const schnorrArtifact = await this.accountContracts.getStubAccountContractArtifact('schnorr');
|
|
169
|
+
const { id: schnorrClassId } = await getContractClassFromArtifact(schnorrArtifact);
|
|
170
|
+
await this.pxe.registerContractClass(schnorrArtifact);
|
|
171
|
+
// ecdsa stubs share the same class id
|
|
172
|
+
const ecdsaArtifact = await this.accountContracts.getStubAccountContractArtifact('ecdsasecp256r1');
|
|
173
|
+
const { id: ecdsaClassId } = await getContractClassFromArtifact(ecdsaArtifact);
|
|
174
|
+
await this.pxe.registerContractClass(ecdsaArtifact);
|
|
175
|
+
this.stubClassIds.set('schnorr', schnorrClassId);
|
|
176
|
+
this.stubClassIds.set('ecdsasecp256k1', ecdsaClassId);
|
|
177
|
+
this.stubClassIds.set('ecdsasecp256r1', ecdsaClassId);
|
|
178
|
+
}
|
|
179
|
+
/**
|
|
130
180
|
* Builds contract overrides for all provided addresses by replacing their account contracts with stub implementations.
|
|
131
181
|
* Uses a type-specific stub artifact so that the stub's constructor selector matches the real account's constructor.
|
|
132
182
|
*/ async buildAccountOverrides(addresses) {
|
|
@@ -136,27 +186,21 @@ export class EmbeddedWallet extends BaseWallet {
|
|
|
136
186
|
for (const account of filtered){
|
|
137
187
|
const address = account.item;
|
|
138
188
|
const { type } = await this.walletDB.retrieveAccount(address);
|
|
139
|
-
const
|
|
189
|
+
const stubClassId = this.stubClassIds.get(type);
|
|
190
|
+
if (!stubClassId) {
|
|
191
|
+
throw new Error(`Stub class for account type '${type}' was not registered at wallet init. This is a bug — initStubClasses should cover every supported AccountType.`);
|
|
192
|
+
}
|
|
140
193
|
const originalAccount = await this.getAccountFromAddress(address);
|
|
141
194
|
const completeAddress = originalAccount.getCompleteAddress();
|
|
142
195
|
const contractInstance = await this.pxe.getContractInstance(completeAddress.address);
|
|
143
196
|
if (!contractInstance) {
|
|
144
197
|
throw new Error(`No contract instance found for address: ${completeAddress.address} during account override building. This is a bug!`);
|
|
145
198
|
}
|
|
146
|
-
const stubConstructorArgs = type === 'schnorr' ? [
|
|
147
|
-
Fr.ZERO,
|
|
148
|
-
Fr.ZERO
|
|
149
|
-
] : [
|
|
150
|
-
Buffer.alloc(32),
|
|
151
|
-
Buffer.alloc(32)
|
|
152
|
-
];
|
|
153
|
-
const stubInstance = await getContractInstanceFromInstantiationParams(stubArtifact, {
|
|
154
|
-
salt: Fr.random(),
|
|
155
|
-
constructorArgs: stubConstructorArgs
|
|
156
|
-
});
|
|
157
199
|
contracts[address.toString()] = {
|
|
158
|
-
instance:
|
|
159
|
-
|
|
200
|
+
instance: {
|
|
201
|
+
...contractInstance,
|
|
202
|
+
currentContractClassId: stubClassId
|
|
203
|
+
}
|
|
160
204
|
};
|
|
161
205
|
}
|
|
162
206
|
return contracts;
|
|
@@ -166,7 +210,7 @@ export class EmbeddedWallet extends BaseWallet {
|
|
|
166
210
|
* This allows kernelless simulation with contract overrides, skipping expensive
|
|
167
211
|
* private kernel circuit execution.
|
|
168
212
|
*/ async simulateViaEntrypoint(executionPayload, opts) {
|
|
169
|
-
const { from, feeOptions, additionalScopes, skipTxValidation, skipFeeEnforcement } = opts;
|
|
213
|
+
const { from, feeOptions, additionalScopes, skipTxValidation, skipFeeEnforcement, sendMessagesAs } = opts;
|
|
170
214
|
const scopes = this.scopesFrom(from, additionalScopes);
|
|
171
215
|
const feeExecutionPayload = await feeOptions.walletFeePaymentMethod?.getExecutionPayload();
|
|
172
216
|
const finalExecutionPayload = feeExecutionPayload ? mergeExecutionPayloads([
|
|
@@ -175,7 +219,9 @@ export class EmbeddedWallet extends BaseWallet {
|
|
|
175
219
|
]) : executionPayload;
|
|
176
220
|
const chainInfo = await this.getChainInfo();
|
|
177
221
|
const accountOverrides = await this.buildAccountOverrides(scopes);
|
|
178
|
-
const overrides = new SimulationOverrides(
|
|
222
|
+
const overrides = new SimulationOverrides({
|
|
223
|
+
contracts: accountOverrides
|
|
224
|
+
});
|
|
179
225
|
let txRequest;
|
|
180
226
|
if (from === NO_FROM) {
|
|
181
227
|
const entrypoint = new DefaultEntrypoint();
|
|
@@ -198,7 +244,8 @@ export class EmbeddedWallet extends BaseWallet {
|
|
|
198
244
|
skipFeeEnforcement,
|
|
199
245
|
skipTxValidation,
|
|
200
246
|
overrides,
|
|
201
|
-
scopes
|
|
247
|
+
scopes,
|
|
248
|
+
senderForTags: this.senderForTagsFrom(from, sendMessagesAs)
|
|
202
249
|
});
|
|
203
250
|
const appCallOffset = await this.computeAppCallOffset(from, feeOptions);
|
|
204
251
|
return TxSimulationResultWithAppOffset.fromResultAndOffset(result, appCallOffset);
|
|
@@ -226,7 +273,9 @@ export class EmbeddedWallet extends BaseWallet {
|
|
|
226
273
|
throw new Error(`Unknown account type ${type}`);
|
|
227
274
|
}
|
|
228
275
|
}
|
|
229
|
-
const accountManager = await AccountManager.create(this, secret, contract,
|
|
276
|
+
const accountManager = await AccountManager.create(this, secret, contract, {
|
|
277
|
+
salt
|
|
278
|
+
});
|
|
230
279
|
const instance = accountManager.getInstance();
|
|
231
280
|
const existingInstance = await this.pxe.getContractInstance(instance.address);
|
|
232
281
|
if (!existingInstance) {
|
|
@@ -262,7 +311,8 @@ export class EmbeddedWallet extends BaseWallet {
|
|
|
262
311
|
setEstimatedGasPadding(value) {
|
|
263
312
|
this.estimatedGasPadding = value ?? DEFAULT_ESTIMATED_GAS_PADDING;
|
|
264
313
|
}
|
|
265
|
-
stop() {
|
|
266
|
-
|
|
314
|
+
async stop() {
|
|
315
|
+
await this.pxe.stop();
|
|
316
|
+
await this.walletDB.close();
|
|
267
317
|
}
|
|
268
318
|
}
|
|
@@ -11,4 +11,4 @@ export { BrowserEmbeddedWallet as EmbeddedWallet };
|
|
|
11
11
|
export type { EmbeddedWalletOptions, EmbeddedWalletPXEOptions } from '../embedded_wallet.js';
|
|
12
12
|
export { WalletDB } from '../wallet_db.js';
|
|
13
13
|
export type { AccountType } from '../wallet_db.js';
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJvd3Nlci5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2VtYmVkZGVkL2VudHJ5cG9pbnRzL2Jyb3dzZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLEtBQUssU0FBUyxFQUF5QixNQUFNLHNCQUFzQixDQUFDO0FBQzdFLE9BQU8sRUFBRSxLQUFLLE1BQU0sRUFBZ0IsTUFBTSx1QkFBdUIsQ0FBQztBQUVsRSxPQUFPLEVBQUUsS0FBSyxHQUFHLEVBQXNDLE1BQU0sd0JBQXdCLENBQUM7QUFNdEYsT0FBTyxLQUFLLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUN2RixPQUFPLEVBQUUsY0FBYyxFQUFFLEtBQUsscUJBQXFCLEVBQW1CLE1BQU0sdUJBQXVCLENBQUM7QUFDcEcsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRTNDLHFCQUFhLHFCQUFzQixTQUFRLGNBQWM7SUFDdkQsT0FBYSxNQUFNLENBQUMsQ0FBQyxTQUFTLHFCQUFxQixHQUFHLHFCQUFxQixFQUN6RSxJQUFJLEVBQUUsS0FDSixHQUFHLEVBQUUsR0FBRyxFQUNSLFNBQVMsRUFBRSxTQUFTLEVBQ3BCLFFBQVEsRUFBRSxRQUFRLEVBQ2xCLGdCQUFnQixFQUFFLHdCQUF3QixFQUMxQyxHQUFHLENBQUMsRUFBRSxNQUFNLEtBQ1QsQ0FBQyxFQUNOLFNBQVMsRUFBRSxNQUFNLEdBQUcsU0FBUyxFQUM3QixPQUFPLEdBQUUscUJBQTBCLEdBQ2xDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0F3RFo7Q0FDRjtBQUVELE9BQU8sRUFBRSxxQkFBcUIsSUFBSSxjQUFjLEVBQUUsQ0FBQztBQUNuRCxZQUFZLEVBQUUscUJBQXFCLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUM3RixPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDM0MsWUFBWSxFQUFFLFdBQVcsRUFBRSxNQUFNLGlCQUFpQixDQUFDIn0=
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"browser.d.ts","sourceRoot":"","sources":["../../../src/embedded/entrypoints/browser.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAyB,MAAM,sBAAsB,CAAC;AAC7E,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,uBAAuB,CAAC;AAElE,OAAO,EAAE,KAAK,GAAG,EAAsC,MAAM,wBAAwB,CAAC;
|
|
1
|
+
{"version":3,"file":"browser.d.ts","sourceRoot":"","sources":["../../../src/embedded/entrypoints/browser.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAyB,MAAM,sBAAsB,CAAC;AAC7E,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,uBAAuB,CAAC;AAElE,OAAO,EAAE,KAAK,GAAG,EAAsC,MAAM,wBAAwB,CAAC;AAMtF,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,wCAAwC,CAAC;AACvF,OAAO,EAAE,cAAc,EAAE,KAAK,qBAAqB,EAAmB,MAAM,uBAAuB,CAAC;AACpG,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAE3C,qBAAa,qBAAsB,SAAQ,cAAc;IACvD,OAAa,MAAM,CAAC,CAAC,SAAS,qBAAqB,GAAG,qBAAqB,EACzE,IAAI,EAAE,KACJ,GAAG,EAAE,GAAG,EACR,SAAS,EAAE,SAAS,EACpB,QAAQ,EAAE,QAAQ,EAClB,gBAAgB,EAAE,wBAAwB,EAC1C,GAAG,CAAC,EAAE,MAAM,KACT,CAAC,EACN,SAAS,EAAE,MAAM,GAAG,SAAS,EAC7B,OAAO,GAAE,qBAA0B,GAClC,OAAO,CAAC,CAAC,CAAC,CAwDZ;CACF;AAED,OAAO,EAAE,qBAAqB,IAAI,cAAc,EAAE,CAAC;AACnD,YAAY,EAAE,qBAAqB,EAAE,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AAC7F,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,YAAY,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC"}
|
|
@@ -3,6 +3,8 @@ import { createLogger } from '@aztec/foundation/log';
|
|
|
3
3
|
import { createStore, openTmpStore } from '@aztec/kv-store/indexeddb';
|
|
4
4
|
import { createPXE } from '@aztec/pxe/client/lazy';
|
|
5
5
|
import { getPXEConfig } from '@aztec/pxe/config';
|
|
6
|
+
import { getStandardAuthRegistry } from '@aztec/standard-contracts/auth-registry/lazy';
|
|
7
|
+
import { getStandardMultiCallEntrypoint } from '@aztec/standard-contracts/multi-call-entrypoint/lazy';
|
|
6
8
|
import { LazyAccountContractsProvider } from '../account-contract-providers/lazy.js';
|
|
7
9
|
import { EmbeddedWallet, splitPxeOptions } from '../embedded_wallet.js';
|
|
8
10
|
import { WalletDB } from '../wallet_db.js';
|
|
@@ -24,6 +26,7 @@ export class BrowserEmbeddedWallet extends EmbeddedWallet {
|
|
|
24
26
|
const pxeConfig = Object.assign(getPXEConfig(), {
|
|
25
27
|
proverEnabled: mergedConfigOverrides.proverEnabled ?? false,
|
|
26
28
|
dataDirectory: `pxe_data_${l1Contracts.rollupAddress}`,
|
|
29
|
+
autoSync: false,
|
|
27
30
|
...mergedConfigOverrides
|
|
28
31
|
});
|
|
29
32
|
if (options.ephemeral) {
|
|
@@ -31,6 +34,12 @@ export class BrowserEmbeddedWallet extends EmbeddedWallet {
|
|
|
31
34
|
}
|
|
32
35
|
const pxeOptions = {
|
|
33
36
|
...mergedCreationOverrides,
|
|
37
|
+
preloadedContractsProvider: mergedCreationOverrides.preloadedContractsProvider ?? {
|
|
38
|
+
getPreloadedContracts: async ()=>[
|
|
39
|
+
await getStandardMultiCallEntrypoint(),
|
|
40
|
+
await getStandardAuthRegistry()
|
|
41
|
+
]
|
|
42
|
+
},
|
|
34
43
|
loggers: {
|
|
35
44
|
store: rootLogger.createChild('pxe:data'),
|
|
36
45
|
pxe: rootLogger.createChild('pxe:service'),
|
|
@@ -39,14 +48,22 @@ export class BrowserEmbeddedWallet extends EmbeddedWallet {
|
|
|
39
48
|
}
|
|
40
49
|
};
|
|
41
50
|
const pxe = await createPXE(aztecNode, pxeConfig, pxeOptions);
|
|
42
|
-
const walletDBStore = options.ephemeral ? await openTmpStore(true) : await createStore('wallet_data', {
|
|
51
|
+
const walletDBStore = options.walletDb?.store ?? (options.ephemeral ? await openTmpStore(true) : await createStore('wallet_data', {
|
|
43
52
|
dataDirectory: `wallet_data_${l1Contracts.rollupAddress}`,
|
|
44
53
|
dataStoreMapSizeKb: pxeConfig.dataStoreMapSizeKb,
|
|
45
|
-
l1Contracts
|
|
46
|
-
}, 1, rootLogger.createChild('wallet:data'));
|
|
47
|
-
const walletDB = WalletDB
|
|
48
|
-
|
|
54
|
+
rollupAddress: l1Contracts.rollupAddress
|
|
55
|
+
}, 1, rootLogger.createChild('wallet:data')));
|
|
56
|
+
const walletDB = new WalletDB(walletDBStore, rootLogger.createChild('wallet:db').info);
|
|
57
|
+
const wallet = new this(pxe, aztecNode, walletDB, new LazyAccountContractsProvider(), rootLogger);
|
|
58
|
+
await wallet.initStubClasses();
|
|
59
|
+
return wallet;
|
|
49
60
|
}
|
|
50
61
|
}
|
|
51
62
|
export { BrowserEmbeddedWallet as EmbeddedWallet };
|
|
52
63
|
export { WalletDB } from '../wallet_db.js';
|
|
64
|
+
// At-rest encryption helpers are intentionally NOT re-exported here. They live
|
|
65
|
+
// on the `@aztec/wallets/embedded/store-encryption` sub-path so consumers
|
|
66
|
+
// (and bundlers) of this entrypoint don't transitively pull in
|
|
67
|
+
// `@aztec/kv-store/sqlite-opfs` and its `new Worker(new URL('./worker.js'))`
|
|
68
|
+
// chain into `@aztec/sqlite3mc-wasm`. Apps that don't use encryption-at-rest
|
|
69
|
+
// (e.g. the playground) should never see sqlite-opfs in their bundle.
|
|
@@ -11,4 +11,4 @@ export { NodeEmbeddedWallet as EmbeddedWallet };
|
|
|
11
11
|
export type { EmbeddedWalletOptions, EmbeddedWalletPXEOptions } from '../embedded_wallet.js';
|
|
12
12
|
export { WalletDB } from '../wallet_db.js';
|
|
13
13
|
export type { AccountType } from '../wallet_db.js';
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2VtYmVkZGVkL2VudHJ5cG9pbnRzL25vZGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLEtBQUssTUFBTSxFQUFnQixNQUFNLHVCQUF1QixDQUFDO0FBR2xFLE9BQU8sRUFBRSxLQUFLLEdBQUcsRUFBc0MsTUFBTSxtQkFBbUIsQ0FBQztBQUdqRixPQUFPLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUdqRSxPQUFPLEtBQUssRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBQ3ZGLE9BQU8sRUFBRSxjQUFjLEVBQUUsS0FBSyxxQkFBcUIsRUFBbUIsTUFBTSx1QkFBdUIsQ0FBQztBQUNwRyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFM0MscUJBQWEsa0JBQW1CLFNBQVEsY0FBYztJQUNwRCxPQUFhLE1BQU0sQ0FBQyxDQUFDLFNBQVMsa0JBQWtCLEdBQUcsa0JBQWtCLEVBQ25FLElBQUksRUFBRSxLQUNKLEdBQUcsRUFBRSxHQUFHLEVBQ1IsU0FBUyxFQUFFLFNBQVMsRUFDcEIsUUFBUSxFQUFFLFFBQVEsRUFDbEIsZ0JBQWdCLEVBQUUsd0JBQXdCLEVBQzFDLEdBQUcsQ0FBQyxFQUFFLE1BQU0sS0FDVCxDQUFDLEVBQ04sU0FBUyxFQUFFLE1BQU0sR0FBRyxTQUFTLEVBQzdCLE9BQU8sR0FBRSxxQkFBMEIsR0FDbEMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQThEWjtDQUNGO0FBRUQsT0FBTyxFQUFFLGtCQUFrQixJQUFJLGNBQWMsRUFBRSxDQUFDO0FBQ2hELFlBQVksRUFBRSxxQkFBcUIsRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzdGLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMzQyxZQUFZLEVBQUUsV0FBVyxFQUFFLE1BQU0saUJBQWlCLENBQUMifQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"node.d.ts","sourceRoot":"","sources":["../../../src/embedded/entrypoints/node.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,uBAAuB,CAAC;AAGlE,OAAO,EAAE,KAAK,GAAG,EAAsC,MAAM,mBAAmB,CAAC;
|
|
1
|
+
{"version":3,"file":"node.d.ts","sourceRoot":"","sources":["../../../src/embedded/entrypoints/node.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,uBAAuB,CAAC;AAGlE,OAAO,EAAE,KAAK,GAAG,EAAsC,MAAM,mBAAmB,CAAC;AAGjF,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iCAAiC,CAAC;AAGjE,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,wCAAwC,CAAC;AACvF,OAAO,EAAE,cAAc,EAAE,KAAK,qBAAqB,EAAmB,MAAM,uBAAuB,CAAC;AACpG,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAE3C,qBAAa,kBAAmB,SAAQ,cAAc;IACpD,OAAa,MAAM,CAAC,CAAC,SAAS,kBAAkB,GAAG,kBAAkB,EACnE,IAAI,EAAE,KACJ,GAAG,EAAE,GAAG,EACR,SAAS,EAAE,SAAS,EACpB,QAAQ,EAAE,QAAQ,EAClB,gBAAgB,EAAE,wBAAwB,EAC1C,GAAG,CAAC,EAAE,MAAM,KACT,CAAC,EACN,SAAS,EAAE,MAAM,GAAG,SAAS,EAC7B,OAAO,GAAE,qBAA0B,GAClC,OAAO,CAAC,CAAC,CAAC,CA8DZ;CACF;AAED,OAAO,EAAE,kBAAkB,IAAI,cAAc,EAAE,CAAC;AAChD,YAAY,EAAE,qBAAqB,EAAE,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AAC7F,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,YAAY,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC"}
|
|
@@ -3,6 +3,8 @@ import { createLogger } from '@aztec/foundation/log';
|
|
|
3
3
|
import { createStore, openTmpStore } from '@aztec/kv-store/lmdb-v2';
|
|
4
4
|
import { getPXEConfig } from '@aztec/pxe/config';
|
|
5
5
|
import { createPXE } from '@aztec/pxe/server';
|
|
6
|
+
import { getStandardAuthRegistry } from '@aztec/standard-contracts/auth-registry';
|
|
7
|
+
import { getStandardMultiCallEntrypoint } from '@aztec/standard-contracts/multi-call-entrypoint';
|
|
6
8
|
import { BundleAccountContractsProvider } from '../account-contract-providers/bundle.js';
|
|
7
9
|
import { EmbeddedWallet, splitPxeOptions } from '../embedded_wallet.js';
|
|
8
10
|
import { WalletDB } from '../wallet_db.js';
|
|
@@ -24,6 +26,7 @@ export class NodeEmbeddedWallet extends EmbeddedWallet {
|
|
|
24
26
|
const pxeConfig = Object.assign(getPXEConfig(), {
|
|
25
27
|
proverEnabled: mergedConfigOverrides.proverEnabled ?? false,
|
|
26
28
|
dataDirectory: `pxe_data_${l1Contracts.rollupAddress}`,
|
|
29
|
+
autoSync: false,
|
|
27
30
|
...mergedConfigOverrides
|
|
28
31
|
});
|
|
29
32
|
if (options.ephemeral) {
|
|
@@ -31,6 +34,12 @@ export class NodeEmbeddedWallet extends EmbeddedWallet {
|
|
|
31
34
|
}
|
|
32
35
|
const pxeOptions = {
|
|
33
36
|
...mergedCreationOverrides,
|
|
37
|
+
preloadedContractsProvider: mergedCreationOverrides.preloadedContractsProvider ?? {
|
|
38
|
+
getPreloadedContracts: async ()=>[
|
|
39
|
+
await getStandardMultiCallEntrypoint(),
|
|
40
|
+
await getStandardAuthRegistry()
|
|
41
|
+
]
|
|
42
|
+
},
|
|
34
43
|
loggers: {
|
|
35
44
|
store: rootLogger.createChild('pxe:data'),
|
|
36
45
|
pxe: rootLogger.createChild('pxe:service'),
|
|
@@ -39,13 +48,15 @@ export class NodeEmbeddedWallet extends EmbeddedWallet {
|
|
|
39
48
|
}
|
|
40
49
|
};
|
|
41
50
|
const pxe = await createPXE(aztecNode, pxeConfig, pxeOptions);
|
|
42
|
-
const walletDBStore = options.ephemeral ? await openTmpStore(`wallet_data_${l1Contracts.rollupAddress}`, true, undefined, undefined, rootLogger.createChild('wallet:data').getBindings()) : await createStore('wallet_data', 1, {
|
|
51
|
+
const walletDBStore = options.walletDb?.store ?? (options.ephemeral ? await openTmpStore(`wallet_data_${l1Contracts.rollupAddress}`, true, undefined, undefined, rootLogger.createChild('wallet:data').getBindings()) : await createStore('wallet_data', 1, {
|
|
43
52
|
dataDirectory: `wallet_data_${l1Contracts.rollupAddress}`,
|
|
44
53
|
dataStoreMapSizeKb: pxeConfig.dataStoreMapSizeKb,
|
|
45
|
-
l1Contracts
|
|
46
|
-
}, rootLogger.createChild('wallet:data').getBindings());
|
|
47
|
-
const walletDB = WalletDB
|
|
48
|
-
|
|
54
|
+
rollupAddress: l1Contracts.rollupAddress
|
|
55
|
+
}, rootLogger.createChild('wallet:data').getBindings()));
|
|
56
|
+
const walletDB = new WalletDB(walletDBStore, rootLogger.createChild('wallet:db').info);
|
|
57
|
+
const wallet = new this(pxe, aztecNode, walletDB, new BundleAccountContractsProvider(), rootLogger);
|
|
58
|
+
await wallet.initStubClasses();
|
|
59
|
+
return wallet;
|
|
49
60
|
}
|
|
50
61
|
}
|
|
51
62
|
export { NodeEmbeddedWallet as EmbeddedWallet };
|