@aztec/test-wallet 0.0.1-commit.0b941701 → 0.0.1-commit.134ed76
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/server.d.ts +2 -2
- package/dest/server.d.ts.map +1 -1
- package/dest/server.js +1 -1
- package/dest/wallet/server.d.ts +29 -2
- package/dest/wallet/server.d.ts.map +1 -1
- package/dest/wallet/server.js +41 -2
- package/dest/wallet/test_wallet.d.ts +9 -2
- package/dest/wallet/test_wallet.d.ts.map +1 -1
- package/dest/wallet/test_wallet.js +16 -2
- package/package.json +10 -10
- package/src/server.ts +1 -1
- package/src/wallet/server.ts +56 -3
- package/src/wallet/test_wallet.ts +20 -2
package/dest/server.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export { TestWallet } from './wallet/server.js';
|
|
1
|
+
export { TestWallet, AztecNodeProxy } from './wallet/server.js';
|
|
2
2
|
export { type AccountData } from './wallet/test_wallet.js';
|
|
3
3
|
export { deployFundedSchnorrAccounts, registerInitialLocalNetworkAccountsInWallet, ProvenTx, proveInteraction, } from './utils.js';
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VydmVyLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvc2VydmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsY0FBYyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDaEUsT0FBTyxFQUFFLEtBQUssV0FBVyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDM0QsT0FBTyxFQUNMLDJCQUEyQixFQUMzQiwyQ0FBMkMsRUFDM0MsUUFBUSxFQUNSLGdCQUFnQixHQUNqQixNQUFNLFlBQVksQ0FBQyJ9
|
package/dest/server.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../src/server.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../src/server.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAChE,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAC3D,OAAO,EACL,2BAA2B,EAC3B,2CAA2C,EAC3C,QAAQ,EACR,gBAAgB,GACjB,MAAM,YAAY,CAAC"}
|
package/dest/server.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export { TestWallet } from './wallet/server.js';
|
|
1
|
+
export { TestWallet, AztecNodeProxy } from './wallet/server.js';
|
|
2
2
|
export { deployFundedSchnorrAccounts, registerInitialLocalNetworkAccountsInWallet, ProvenTx, proveInteraction } from './utils.js';
|
package/dest/wallet/server.d.ts
CHANGED
|
@@ -2,7 +2,7 @@ import type { AztecAddress } from '@aztec/aztec.js/addresses';
|
|
|
2
2
|
import { Fq, Fr } from '@aztec/aztec.js/fields';
|
|
3
3
|
import type { AztecNode } from '@aztec/aztec.js/node';
|
|
4
4
|
import { AccountManager } from '@aztec/aztec.js/wallet';
|
|
5
|
-
import { type PXEConfig, type PXECreationOptions } from '@aztec/pxe/server';
|
|
5
|
+
import { PXE, type PXEConfig, type PXECreationOptions } from '@aztec/pxe/server';
|
|
6
6
|
import { BaseTestWallet } from './test_wallet.js';
|
|
7
7
|
/**
|
|
8
8
|
* A TestWallet implementation to be used in server settings (e.g. e2e tests).
|
|
@@ -10,7 +10,14 @@ import { BaseTestWallet } from './test_wallet.js';
|
|
|
10
10
|
* from the `pxe/server` package.
|
|
11
11
|
*/
|
|
12
12
|
export declare class TestWallet extends BaseTestWallet {
|
|
13
|
+
private readonly nodeRef;
|
|
14
|
+
constructor(pxe: PXE, nodeRef: AztecNodeProxy);
|
|
13
15
|
static create(node: AztecNode, overridePXEConfig?: Partial<PXEConfig>, options?: PXECreationOptions): Promise<TestWallet>;
|
|
16
|
+
/**
|
|
17
|
+
* Updates the underlying node that this wallet and its PXE communicate with.
|
|
18
|
+
* @param node - The new AztecNode to forward all calls to.
|
|
19
|
+
*/
|
|
20
|
+
updateNode(node: AztecNode): void;
|
|
14
21
|
createSchnorrAccount(secret: Fr, salt: Fr, signingKey?: Fq): Promise<AccountManager>;
|
|
15
22
|
createECDSARAccount(secret: Fr, salt: Fr, signingKey: Buffer): Promise<AccountManager>;
|
|
16
23
|
createECDSAKAccount(secret: Fr, salt: Fr, signingKey: Buffer): Promise<AccountManager>;
|
|
@@ -26,4 +33,24 @@ export declare class TestWallet extends BaseTestWallet {
|
|
|
26
33
|
artifact: import("@aztec/stdlib/abi").ContractArtifact;
|
|
27
34
|
}>;
|
|
28
35
|
}
|
|
29
|
-
|
|
36
|
+
/**
|
|
37
|
+
* Extends AztecNode via declaration merging so instances can be used wherever AztecNode is expected.
|
|
38
|
+
* The actual method forwarding is handled by a Proxy in the class constructor.
|
|
39
|
+
*/
|
|
40
|
+
export interface AztecNodeProxy extends AztecNode {
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Mutable wrapper around an AztecNode that forwards all calls to the current target.
|
|
44
|
+
* Allows swapping the underlying node at runtime via updateTargetNode, which is useful
|
|
45
|
+
* for tests that need to redirect a wallet from one node to another without recreating it.
|
|
46
|
+
*/
|
|
47
|
+
export declare class AztecNodeProxy {
|
|
48
|
+
private target;
|
|
49
|
+
constructor(target: AztecNode);
|
|
50
|
+
/**
|
|
51
|
+
* Updates the underlying node that this reference points to.
|
|
52
|
+
* @param node - The new node to forward calls to.
|
|
53
|
+
*/
|
|
54
|
+
updateTargetNode(node: AztecNode): void;
|
|
55
|
+
}
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VydmVyLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvd2FsbGV0L3NlcnZlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFJQSxPQUFPLEtBQUssRUFBRSxZQUFZLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUU5RCxPQUFPLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ2hELE9BQU8sS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsR0FBRyxFQUFFLEtBQUssU0FBUyxFQUFFLEtBQUssa0JBQWtCLEVBQTJCLE1BQU0sbUJBQW1CLENBQUM7QUFHMUcsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRWxEOzs7O0dBSUc7QUFDSCxxQkFBYSxVQUFXLFNBQVEsY0FBYztJQUcxQyxPQUFPLENBQUMsUUFBUSxDQUFDLE9BQU87SUFGMUIsWUFDRSxHQUFHLEVBQUUsR0FBRyxFQUNTLE9BQU8sRUFBRSxjQUFjLEVBR3pDO0lBRUQsT0FBYSxNQUFNLENBQ2pCLElBQUksRUFBRSxTQUFTLEVBQ2YsaUJBQWlCLENBQUMsRUFBRSxPQUFPLENBQUMsU0FBUyxDQUFDLEVBQ3RDLE9BQU8sR0FBRSxrQkFBb0MsR0FDNUMsT0FBTyxDQUFDLFVBQVUsQ0FBQyxDQVFyQjtJQUVEOzs7T0FHRztJQUNILFVBQVUsQ0FBQyxJQUFJLEVBQUUsU0FBUyxHQUFHLElBQUksQ0FFaEM7SUFFRCxvQkFBb0IsQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLElBQUksRUFBRSxFQUFFLEVBQUUsVUFBVSxDQUFDLEVBQUUsRUFBRSxHQUFHLE9BQU8sQ0FBQyxjQUFjLENBQUMsQ0FRbkY7SUFFRCxtQkFBbUIsQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLElBQUksRUFBRSxFQUFFLEVBQUUsVUFBVSxFQUFFLE1BQU0sR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLENBT3JGO0lBRUQsbUJBQW1CLENBQUMsTUFBTSxFQUFFLEVBQUUsRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFLFVBQVUsRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLGNBQWMsQ0FBQyxDQU9yRjtJQUVEOzs7OztPQUtHO0lBQ0cscUJBQXFCLENBQUMsT0FBTyxFQUFFLFlBQVk7Ozs7T0FzQmhEO0NBQ0Y7QUFFRDs7O0dBR0c7QUFFSCxNQUFNLFdBQVcsY0FBZSxTQUFRLFNBQVM7Q0FBRztBQUVwRDs7OztHQUlHO0FBRUgscUJBQWEsY0FBYztJQUNiLE9BQU8sQ0FBQyxNQUFNO0lBQTFCLFlBQW9CLE1BQU0sRUFBRSxTQUFTLEVBWXBDO0lBRUQ7OztPQUdHO0lBQ0gsZ0JBQWdCLENBQUMsSUFBSSxFQUFFLFNBQVMsR0FBRyxJQUFJLENBRXRDO0NBQ0YifQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../src/wallet/server.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAE9D,OAAO,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAC;AAChD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,KAAK,SAAS,EAAE,KAAK,kBAAkB,EAA2B,MAAM,mBAAmB,CAAC;
|
|
1
|
+
{"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../src/wallet/server.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAE9D,OAAO,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAC;AAChD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,GAAG,EAAE,KAAK,SAAS,EAAE,KAAK,kBAAkB,EAA2B,MAAM,mBAAmB,CAAC;AAG1G,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD;;;;GAIG;AACH,qBAAa,UAAW,SAAQ,cAAc;IAG1C,OAAO,CAAC,QAAQ,CAAC,OAAO;IAF1B,YACE,GAAG,EAAE,GAAG,EACS,OAAO,EAAE,cAAc,EAGzC;IAED,OAAa,MAAM,CACjB,IAAI,EAAE,SAAS,EACf,iBAAiB,CAAC,EAAE,OAAO,CAAC,SAAS,CAAC,EACtC,OAAO,GAAE,kBAAoC,GAC5C,OAAO,CAAC,UAAU,CAAC,CAQrB;IAED;;;OAGG;IACH,UAAU,CAAC,IAAI,EAAE,SAAS,GAAG,IAAI,CAEhC;IAED,oBAAoB,CAAC,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,UAAU,CAAC,EAAE,EAAE,GAAG,OAAO,CAAC,cAAc,CAAC,CAQnF;IAED,mBAAmB,CAAC,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,CAAC,CAOrF;IAED,mBAAmB,CAAC,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,CAAC,CAOrF;IAED;;;;;OAKG;IACG,qBAAqB,CAAC,OAAO,EAAE,YAAY;;;;OAsBhD;CACF;AAED;;;GAGG;AAEH,MAAM,WAAW,cAAe,SAAQ,SAAS;CAAG;AAEpD;;;;GAIG;AAEH,qBAAa,cAAc;IACb,OAAO,CAAC,MAAM;IAA1B,YAAoB,MAAM,EAAE,SAAS,EAYpC;IAED;;;OAGG;IACH,gBAAgB,CAAC,IAAI,EAAE,SAAS,GAAG,IAAI,CAEtC;CACF"}
|
package/dest/wallet/server.js
CHANGED
|
@@ -12,15 +12,26 @@ import { BaseTestWallet } from './test_wallet.js';
|
|
|
12
12
|
* Note that the only difference from `lazy` and `bundle` test wallets is that it uses the `createPXE` function
|
|
13
13
|
* from the `pxe/server` package.
|
|
14
14
|
*/ export class TestWallet extends BaseTestWallet {
|
|
15
|
+
nodeRef;
|
|
16
|
+
constructor(pxe, nodeRef){
|
|
17
|
+
super(pxe, nodeRef), this.nodeRef = nodeRef;
|
|
18
|
+
}
|
|
15
19
|
static async create(node, overridePXEConfig, options = {
|
|
16
20
|
loggers: {}
|
|
17
21
|
}) {
|
|
22
|
+
const nodeRef = new AztecNodeProxy(node);
|
|
18
23
|
const pxeConfig = Object.assign(getPXEConfig(), {
|
|
19
24
|
proverEnabled: overridePXEConfig?.proverEnabled ?? false,
|
|
20
25
|
...overridePXEConfig
|
|
21
26
|
});
|
|
22
|
-
const pxe = await createPXE(
|
|
23
|
-
return new TestWallet(pxe,
|
|
27
|
+
const pxe = await createPXE(nodeRef, pxeConfig, options);
|
|
28
|
+
return new TestWallet(pxe, nodeRef);
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Updates the underlying node that this wallet and its PXE communicate with.
|
|
32
|
+
* @param node - The new AztecNode to forward all calls to.
|
|
33
|
+
*/ updateNode(node) {
|
|
34
|
+
this.nodeRef.updateTargetNode(node);
|
|
24
35
|
}
|
|
25
36
|
createSchnorrAccount(secret, salt, signingKey) {
|
|
26
37
|
signingKey = signingKey ?? deriveSigningKey(secret);
|
|
@@ -76,3 +87,31 @@ import { BaseTestWallet } from './test_wallet.js';
|
|
|
76
87
|
};
|
|
77
88
|
}
|
|
78
89
|
}
|
|
90
|
+
/**
|
|
91
|
+
* Mutable wrapper around an AztecNode that forwards all calls to the current target.
|
|
92
|
+
* Allows swapping the underlying node at runtime via updateTargetNode, which is useful
|
|
93
|
+
* for tests that need to redirect a wallet from one node to another without recreating it.
|
|
94
|
+
*/ // eslint-disable-next-line @typescript-eslint/no-unsafe-declaration-merging
|
|
95
|
+
export class AztecNodeProxy {
|
|
96
|
+
target;
|
|
97
|
+
constructor(target){
|
|
98
|
+
this.target = target;
|
|
99
|
+
return new Proxy(this, {
|
|
100
|
+
get: (obj, prop, receiver)=>{
|
|
101
|
+
// Own properties and methods (updateTargetNode, target) are served directly.
|
|
102
|
+
if (Reflect.has(obj, prop)) {
|
|
103
|
+
return Reflect.get(obj, prop, receiver);
|
|
104
|
+
}
|
|
105
|
+
// Everything else is forwarded to the current target node.
|
|
106
|
+
const val = obj.target[prop];
|
|
107
|
+
return typeof val === 'function' ? val.bind(obj.target) : val;
|
|
108
|
+
}
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
/**
|
|
112
|
+
* Updates the underlying node that this reference points to.
|
|
113
|
+
* @param node - The new node to forward calls to.
|
|
114
|
+
*/ updateTargetNode(node) {
|
|
115
|
+
this.target = node;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
@@ -7,7 +7,7 @@ import { AuthWitness } from '@aztec/stdlib/auth-witness';
|
|
|
7
7
|
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
8
8
|
import type { ContractInstanceWithAddress } from '@aztec/stdlib/contract';
|
|
9
9
|
import type { NoteDao, NotesFilter } from '@aztec/stdlib/note';
|
|
10
|
-
import type { TxHash, TxReceipt, TxSimulationResult } from '@aztec/stdlib/tx';
|
|
10
|
+
import type { BlockHeader, TxHash, TxReceipt, TxSimulationResult } from '@aztec/stdlib/tx';
|
|
11
11
|
import { ExecutionPayload } from '@aztec/stdlib/tx';
|
|
12
12
|
import { BaseWallet } from '@aztec/wallet-sdk/base-wallet';
|
|
13
13
|
import { ProvenTx } from '../utils.js';
|
|
@@ -146,6 +146,13 @@ export declare abstract class BaseTestWallet extends BaseWallet {
|
|
|
146
146
|
* @returns The requested notes.
|
|
147
147
|
*/
|
|
148
148
|
getNotes(filter: NotesFilter): Promise<NoteDao[]>;
|
|
149
|
+
/** Returns the block header up to which the wallet has synced. */
|
|
150
|
+
getSyncedBlockHeader(): Promise<BlockHeader>;
|
|
151
|
+
/**
|
|
152
|
+
* Triggers a sync of the wallet with the node to update the latest block header.
|
|
153
|
+
* Blocks until the sync is complete.
|
|
154
|
+
*/
|
|
155
|
+
sync(): Promise<void>;
|
|
149
156
|
/**
|
|
150
157
|
* Stops the internal job queue.
|
|
151
158
|
*
|
|
@@ -153,4 +160,4 @@ export declare abstract class BaseTestWallet extends BaseWallet {
|
|
|
153
160
|
*/
|
|
154
161
|
stop(): Promise<void>;
|
|
155
162
|
}
|
|
156
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
163
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdF93YWxsZXQuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy93YWxsZXQvdGVzdF93YWxsZXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxLQUFLLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsS0FBSyxPQUFPLEVBQUUsS0FBSyxlQUFlLEVBQXFCLE1BQU0seUJBQXlCLENBQUM7QUFDaEcsT0FBTyxFQUNMLEtBQUssVUFBVSxFQUNmLEtBQUsscUNBQXFDLEVBQzFDLEtBQUssZUFBZSxFQUNwQixtQ0FBbUMsRUFJcEMsTUFBTSwrQkFBK0IsQ0FBQztBQUN2QyxPQUFPLEVBQUUsY0FBYyxFQUFFLEtBQUssV0FBVyxFQUFFLEtBQUssZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFaEcsT0FBTyxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUV4RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDekQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQzNELE9BQU8sS0FBSyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDMUUsT0FBTyxLQUFLLEVBQUUsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQy9ELE9BQU8sS0FBSyxFQUFFLFdBQVcsRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDM0YsT0FBTyxFQUFFLGdCQUFnQixFQUEwQixNQUFNLGtCQUFrQixDQUFDO0FBQzVFLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUUzRCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRXZDOztHQUVHO0FBQ0gsTUFBTSxXQUFXLFdBQVc7SUFDMUI7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
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"test_wallet.d.ts","sourceRoot":"","sources":["../../src/wallet/test_wallet.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAC5D,OAAO,EAAE,KAAK,OAAO,EAAE,KAAK,eAAe,EAAqB,MAAM,yBAAyB,CAAC;AAChG,OAAO,EACL,KAAK,UAAU,EACf,KAAK,qCAAqC,EAC1C,KAAK,eAAe,EACpB,mCAAmC,EAIpC,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,cAAc,EAAE,KAAK,WAAW,EAAE,KAAK,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAEhG,OAAO,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AAExD,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAC3D,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,wBAAwB,CAAC;AAC1E,OAAO,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAC/D,OAAO,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"test_wallet.d.ts","sourceRoot":"","sources":["../../src/wallet/test_wallet.ts"],"names":[],"mappings":"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"}
|
|
@@ -143,8 +143,13 @@ import { ProvenTx } from '../utils.js';
|
|
|
143
143
|
artifact
|
|
144
144
|
}
|
|
145
145
|
};
|
|
146
|
-
return this.pxe.simulateTx(txRequest,
|
|
147
|
-
|
|
146
|
+
return this.pxe.simulateTx(txRequest, {
|
|
147
|
+
simulatePublic: true,
|
|
148
|
+
skipTxValidation: true,
|
|
149
|
+
skipFeeEnforcement: true,
|
|
150
|
+
overrides: {
|
|
151
|
+
contracts: contractOverrides
|
|
152
|
+
}
|
|
148
153
|
});
|
|
149
154
|
}
|
|
150
155
|
}
|
|
@@ -183,6 +188,15 @@ import { ProvenTx } from '../utils.js';
|
|
|
183
188
|
*/ getNotes(filter) {
|
|
184
189
|
return this.pxe.debug.getNotes(filter);
|
|
185
190
|
}
|
|
191
|
+
/** Returns the block header up to which the wallet has synced. */ getSyncedBlockHeader() {
|
|
192
|
+
return this.pxe.getSyncedBlockHeader();
|
|
193
|
+
}
|
|
194
|
+
/**
|
|
195
|
+
* Triggers a sync of the wallet with the node to update the latest block header.
|
|
196
|
+
* Blocks until the sync is complete.
|
|
197
|
+
*/ sync() {
|
|
198
|
+
return this.pxe.debug.sync();
|
|
199
|
+
}
|
|
186
200
|
/**
|
|
187
201
|
* Stops the internal job queue.
|
|
188
202
|
*
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@aztec/test-wallet",
|
|
3
3
|
"homepage": "https://github.com/AztecProtocol/aztec-packages/tree/master/yarn-project/test-wallet",
|
|
4
|
-
"version": "0.0.1-commit.
|
|
4
|
+
"version": "0.0.1-commit.134ed76",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"exports": {
|
|
7
7
|
"./client/bundle": "./dest/bundle.js",
|
|
@@ -10,7 +10,7 @@
|
|
|
10
10
|
},
|
|
11
11
|
"typedocOptions": {
|
|
12
12
|
"entryPoints": [
|
|
13
|
-
"./src/
|
|
13
|
+
"./src/server.ts"
|
|
14
14
|
],
|
|
15
15
|
"tsconfig": "./tsconfig.json"
|
|
16
16
|
},
|
|
@@ -62,14 +62,14 @@
|
|
|
62
62
|
]
|
|
63
63
|
},
|
|
64
64
|
"dependencies": {
|
|
65
|
-
"@aztec/accounts": "0.0.1-commit.
|
|
66
|
-
"@aztec/aztec.js": "0.0.1-commit.
|
|
67
|
-
"@aztec/entrypoints": "0.0.1-commit.
|
|
68
|
-
"@aztec/foundation": "0.0.1-commit.
|
|
69
|
-
"@aztec/noir-contracts.js": "0.0.1-commit.
|
|
70
|
-
"@aztec/pxe": "0.0.1-commit.
|
|
71
|
-
"@aztec/stdlib": "0.0.1-commit.
|
|
72
|
-
"@aztec/wallet-sdk": "0.0.1-commit.
|
|
65
|
+
"@aztec/accounts": "0.0.1-commit.134ed76",
|
|
66
|
+
"@aztec/aztec.js": "0.0.1-commit.134ed76",
|
|
67
|
+
"@aztec/entrypoints": "0.0.1-commit.134ed76",
|
|
68
|
+
"@aztec/foundation": "0.0.1-commit.134ed76",
|
|
69
|
+
"@aztec/noir-contracts.js": "0.0.1-commit.134ed76",
|
|
70
|
+
"@aztec/pxe": "0.0.1-commit.134ed76",
|
|
71
|
+
"@aztec/stdlib": "0.0.1-commit.134ed76",
|
|
72
|
+
"@aztec/wallet-sdk": "0.0.1-commit.134ed76"
|
|
73
73
|
},
|
|
74
74
|
"devDependencies": {
|
|
75
75
|
"@jest/globals": "^30.0.0",
|
package/src/server.ts
CHANGED
package/src/wallet/server.ts
CHANGED
|
@@ -7,7 +7,7 @@ import { getContractInstanceFromInstantiationParams } from '@aztec/aztec.js/cont
|
|
|
7
7
|
import { Fq, Fr } from '@aztec/aztec.js/fields';
|
|
8
8
|
import type { AztecNode } from '@aztec/aztec.js/node';
|
|
9
9
|
import { AccountManager } from '@aztec/aztec.js/wallet';
|
|
10
|
-
import { type PXEConfig, type PXECreationOptions, createPXE, getPXEConfig } from '@aztec/pxe/server';
|
|
10
|
+
import { PXE, type PXEConfig, type PXECreationOptions, createPXE, getPXEConfig } from '@aztec/pxe/server';
|
|
11
11
|
import { deriveSigningKey } from '@aztec/stdlib/keys';
|
|
12
12
|
|
|
13
13
|
import { BaseTestWallet } from './test_wallet.js';
|
|
@@ -18,17 +18,33 @@ import { BaseTestWallet } from './test_wallet.js';
|
|
|
18
18
|
* from the `pxe/server` package.
|
|
19
19
|
*/
|
|
20
20
|
export class TestWallet extends BaseTestWallet {
|
|
21
|
+
constructor(
|
|
22
|
+
pxe: PXE,
|
|
23
|
+
private readonly nodeRef: AztecNodeProxy,
|
|
24
|
+
) {
|
|
25
|
+
super(pxe, nodeRef);
|
|
26
|
+
}
|
|
27
|
+
|
|
21
28
|
static async create(
|
|
22
29
|
node: AztecNode,
|
|
23
30
|
overridePXEConfig?: Partial<PXEConfig>,
|
|
24
31
|
options: PXECreationOptions = { loggers: {} },
|
|
25
32
|
): Promise<TestWallet> {
|
|
33
|
+
const nodeRef = new AztecNodeProxy(node);
|
|
26
34
|
const pxeConfig = Object.assign(getPXEConfig(), {
|
|
27
35
|
proverEnabled: overridePXEConfig?.proverEnabled ?? false,
|
|
28
36
|
...overridePXEConfig,
|
|
29
37
|
});
|
|
30
|
-
const pxe = await createPXE(
|
|
31
|
-
return new TestWallet(pxe,
|
|
38
|
+
const pxe = await createPXE(nodeRef, pxeConfig, options);
|
|
39
|
+
return new TestWallet(pxe, nodeRef);
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* Updates the underlying node that this wallet and its PXE communicate with.
|
|
44
|
+
* @param node - The new AztecNode to forward all calls to.
|
|
45
|
+
*/
|
|
46
|
+
updateNode(node: AztecNode): void {
|
|
47
|
+
this.nodeRef.updateTargetNode(node);
|
|
32
48
|
}
|
|
33
49
|
|
|
34
50
|
createSchnorrAccount(secret: Fr, salt: Fr, signingKey?: Fq): Promise<AccountManager> {
|
|
@@ -89,3 +105,40 @@ export class TestWallet extends BaseTestWallet {
|
|
|
89
105
|
};
|
|
90
106
|
}
|
|
91
107
|
}
|
|
108
|
+
|
|
109
|
+
/**
|
|
110
|
+
* Extends AztecNode via declaration merging so instances can be used wherever AztecNode is expected.
|
|
111
|
+
* The actual method forwarding is handled by a Proxy in the class constructor.
|
|
112
|
+
*/
|
|
113
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-declaration-merging
|
|
114
|
+
export interface AztecNodeProxy extends AztecNode {}
|
|
115
|
+
|
|
116
|
+
/**
|
|
117
|
+
* Mutable wrapper around an AztecNode that forwards all calls to the current target.
|
|
118
|
+
* Allows swapping the underlying node at runtime via updateTargetNode, which is useful
|
|
119
|
+
* for tests that need to redirect a wallet from one node to another without recreating it.
|
|
120
|
+
*/
|
|
121
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-declaration-merging
|
|
122
|
+
export class AztecNodeProxy {
|
|
123
|
+
constructor(private target: AztecNode) {
|
|
124
|
+
return new Proxy(this, {
|
|
125
|
+
get: (obj, prop, receiver) => {
|
|
126
|
+
// Own properties and methods (updateTargetNode, target) are served directly.
|
|
127
|
+
if (Reflect.has(obj, prop)) {
|
|
128
|
+
return Reflect.get(obj, prop, receiver);
|
|
129
|
+
}
|
|
130
|
+
// Everything else is forwarded to the current target node.
|
|
131
|
+
const val = (obj.target as unknown as Record<string | symbol, unknown>)[prop];
|
|
132
|
+
return typeof val === 'function' ? val.bind(obj.target) : val;
|
|
133
|
+
},
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
/**
|
|
138
|
+
* Updates the underlying node that this reference points to.
|
|
139
|
+
* @param node - The new node to forward calls to.
|
|
140
|
+
*/
|
|
141
|
+
updateTargetNode(node: AztecNode): void {
|
|
142
|
+
this.target = node;
|
|
143
|
+
}
|
|
144
|
+
}
|
|
@@ -18,7 +18,7 @@ import { AuthWitness } from '@aztec/stdlib/auth-witness';
|
|
|
18
18
|
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
19
19
|
import type { ContractInstanceWithAddress } from '@aztec/stdlib/contract';
|
|
20
20
|
import type { NoteDao, NotesFilter } from '@aztec/stdlib/note';
|
|
21
|
-
import type { TxHash, TxReceipt, TxSimulationResult } from '@aztec/stdlib/tx';
|
|
21
|
+
import type { BlockHeader, TxHash, TxReceipt, TxSimulationResult } from '@aztec/stdlib/tx';
|
|
22
22
|
import { ExecutionPayload, mergeExecutionPayloads } from '@aztec/stdlib/tx';
|
|
23
23
|
import { BaseWallet } from '@aztec/wallet-sdk/base-wallet';
|
|
24
24
|
|
|
@@ -232,7 +232,12 @@ export abstract class BaseTestWallet extends BaseWallet {
|
|
|
232
232
|
const contractOverrides = {
|
|
233
233
|
[opts.from.toString()]: { instance, artifact },
|
|
234
234
|
};
|
|
235
|
-
return this.pxe.simulateTx(txRequest,
|
|
235
|
+
return this.pxe.simulateTx(txRequest, {
|
|
236
|
+
simulatePublic: true,
|
|
237
|
+
skipTxValidation: true,
|
|
238
|
+
skipFeeEnforcement: true,
|
|
239
|
+
overrides: { contracts: contractOverrides },
|
|
240
|
+
});
|
|
236
241
|
}
|
|
237
242
|
}
|
|
238
243
|
|
|
@@ -282,6 +287,19 @@ export abstract class BaseTestWallet extends BaseWallet {
|
|
|
282
287
|
return this.pxe.debug.getNotes(filter);
|
|
283
288
|
}
|
|
284
289
|
|
|
290
|
+
/** Returns the block header up to which the wallet has synced. */
|
|
291
|
+
getSyncedBlockHeader(): Promise<BlockHeader> {
|
|
292
|
+
return this.pxe.getSyncedBlockHeader();
|
|
293
|
+
}
|
|
294
|
+
|
|
295
|
+
/**
|
|
296
|
+
* Triggers a sync of the wallet with the node to update the latest block header.
|
|
297
|
+
* Blocks until the sync is complete.
|
|
298
|
+
*/
|
|
299
|
+
sync(): Promise<void> {
|
|
300
|
+
return this.pxe.debug.sync();
|
|
301
|
+
}
|
|
302
|
+
|
|
285
303
|
/**
|
|
286
304
|
* Stops the internal job queue.
|
|
287
305
|
*
|