@aztec/txe 0.0.1-commit.b655e406 → 0.0.1-commit.b6e433891
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/bin/index.d.ts +1 -1
- package/dest/constants.d.ts +3 -0
- package/dest/constants.d.ts.map +1 -0
- package/dest/constants.js +2 -0
- package/dest/index.d.ts +1 -1
- package/dest/index.d.ts.map +1 -1
- package/dest/index.js +91 -56
- package/dest/oracle/interfaces.d.ts +33 -29
- package/dest/oracle/interfaces.d.ts.map +1 -1
- package/dest/oracle/txe_oracle_public_context.d.ts +16 -16
- package/dest/oracle/txe_oracle_public_context.d.ts.map +1 -1
- package/dest/oracle/txe_oracle_public_context.js +20 -22
- package/dest/oracle/txe_oracle_top_level_context.d.ts +37 -27
- package/dest/oracle/txe_oracle_top_level_context.d.ts.map +1 -1
- package/dest/oracle/txe_oracle_top_level_context.js +228 -106
- package/dest/rpc_translator.d.ts +98 -78
- package/dest/rpc_translator.d.ts.map +1 -1
- package/dest/rpc_translator.js +367 -171
- package/dest/state_machine/archiver.d.ts +21 -51
- package/dest/state_machine/archiver.d.ts.map +1 -1
- package/dest/state_machine/archiver.js +66 -99
- package/dest/state_machine/dummy_p2p_client.d.ts +21 -14
- package/dest/state_machine/dummy_p2p_client.d.ts.map +1 -1
- package/dest/state_machine/dummy_p2p_client.js +42 -22
- package/dest/state_machine/global_variable_builder.d.ts +6 -4
- package/dest/state_machine/global_variable_builder.d.ts.map +1 -1
- package/dest/state_machine/global_variable_builder.js +13 -1
- package/dest/state_machine/index.d.ts +9 -7
- package/dest/state_machine/index.d.ts.map +1 -1
- package/dest/state_machine/index.js +44 -23
- package/dest/state_machine/mock_epoch_cache.d.ts +30 -12
- package/dest/state_machine/mock_epoch_cache.d.ts.map +1 -1
- package/dest/state_machine/mock_epoch_cache.js +53 -15
- package/dest/state_machine/synchronizer.d.ts +6 -5
- package/dest/state_machine/synchronizer.d.ts.map +1 -1
- package/dest/state_machine/synchronizer.js +8 -7
- package/dest/txe_session.d.ts +27 -15
- package/dest/txe_session.d.ts.map +1 -1
- package/dest/txe_session.js +173 -56
- package/dest/util/encoding.d.ts +615 -16
- package/dest/util/encoding.d.ts.map +1 -1
- package/dest/util/encoding.js +1 -1
- package/dest/util/expected_failure_error.d.ts +1 -1
- package/dest/util/expected_failure_error.d.ts.map +1 -1
- package/dest/util/txe_account_store.d.ts +10 -0
- package/dest/util/txe_account_store.d.ts.map +1 -0
- package/dest/util/{txe_account_data_provider.js → txe_account_store.js} +1 -1
- package/dest/util/txe_public_contract_data_source.d.ts +8 -8
- package/dest/util/txe_public_contract_data_source.d.ts.map +1 -1
- package/dest/util/txe_public_contract_data_source.js +12 -29
- package/dest/utils/block_creation.d.ts +21 -6
- package/dest/utils/block_creation.d.ts.map +1 -1
- package/dest/utils/block_creation.js +38 -4
- package/dest/utils/tx_effect_creation.d.ts +3 -3
- package/dest/utils/tx_effect_creation.d.ts.map +1 -1
- package/dest/utils/tx_effect_creation.js +4 -7
- package/package.json +18 -17
- package/src/constants.ts +3 -0
- package/src/index.ts +103 -63
- package/src/oracle/interfaces.ts +36 -32
- package/src/oracle/txe_oracle_public_context.ts +21 -28
- package/src/oracle/txe_oracle_top_level_context.ts +272 -145
- package/src/rpc_translator.ts +422 -194
- package/src/state_machine/archiver.ts +63 -117
- package/src/state_machine/dummy_p2p_client.ts +59 -29
- package/src/state_machine/global_variable_builder.ts +22 -4
- package/src/state_machine/index.ts +64 -21
- package/src/state_machine/mock_epoch_cache.ts +67 -23
- package/src/state_machine/synchronizer.ts +9 -8
- package/src/txe_session.ts +239 -105
- package/src/util/encoding.ts +1 -1
- package/src/util/{txe_account_data_provider.ts → txe_account_store.ts} +1 -1
- package/src/util/txe_public_contract_data_source.ts +20 -45
- package/src/utils/block_creation.ts +49 -14
- package/src/utils/tx_effect_creation.ts +5 -12
- package/dest/util/txe_account_data_provider.d.ts +0 -10
- package/dest/util/txe_account_data_provider.d.ts.map +0 -1
- package/dest/util/txe_contract_data_provider.d.ts +0 -12
- package/dest/util/txe_contract_data_provider.d.ts.map +0 -1
- package/dest/util/txe_contract_data_provider.js +0 -22
- package/src/util/txe_contract_data_provider.ts +0 -36
package/dest/txe_session.js
CHANGED
|
@@ -1,25 +1,27 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { BlockNumber } from '@aztec/foundation/branded-types';
|
|
2
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
2
3
|
import { createLogger } from '@aztec/foundation/log';
|
|
3
4
|
import { KeyStore } from '@aztec/key-store';
|
|
4
5
|
import { openTmpStore } from '@aztec/kv-store/lmdb-v2';
|
|
5
|
-
import {
|
|
6
|
-
import { ExecutionNoteCache, ExecutionTaggingIndexCache, HashedValuesCache, PrivateExecutionOracle, UtilityExecutionOracle } from '@aztec/pxe/simulator';
|
|
7
|
-
import {
|
|
6
|
+
import { AddressStore, AnchorBlockStore, CapsuleStore, ContractSyncService, JobCoordinator, NoteService, NoteStore, PrivateEventStore, RecipientTaggingStore, SenderAddressBookStore, SenderTaggingStore } from '@aztec/pxe/server';
|
|
7
|
+
import { ExecutionNoteCache, ExecutionTaggingIndexCache, HashedValuesCache, Oracle, PrivateExecutionOracle, UtilityExecutionOracle } from '@aztec/pxe/simulator';
|
|
8
|
+
import { ExecutionError, WASMSimulator, createSimulationError, extractCallStack, resolveAssertionMessageFromError, toACVMWitness } from '@aztec/simulator/client';
|
|
9
|
+
import { FunctionSelector, FunctionType } from '@aztec/stdlib/abi';
|
|
8
10
|
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
9
|
-
import { Body, L2Block } from '@aztec/stdlib/block';
|
|
10
11
|
import { GasSettings } from '@aztec/stdlib/gas';
|
|
11
|
-
import {
|
|
12
|
+
import { computeProtocolNullifier } from '@aztec/stdlib/hash';
|
|
13
|
+
import { makeGlobalVariables } from '@aztec/stdlib/testing';
|
|
12
14
|
import { CallContext, TxContext } from '@aztec/stdlib/tx';
|
|
13
15
|
import { z } from 'zod';
|
|
16
|
+
import { DEFAULT_ADDRESS } from './constants.js';
|
|
14
17
|
import { TXEOraclePublicContext } from './oracle/txe_oracle_public_context.js';
|
|
15
18
|
import { TXEOracleTopLevelContext } from './oracle/txe_oracle_top_level_context.js';
|
|
16
19
|
import { RPCTranslator } from './rpc_translator.js';
|
|
20
|
+
import { TXEArchiver } from './state_machine/archiver.js';
|
|
17
21
|
import { TXEStateMachine } from './state_machine/index.js';
|
|
18
|
-
import {
|
|
19
|
-
import {
|
|
20
|
-
import { getSingleTxBlockRequestHash, insertTxEffectIntoWorldTrees, makeTXEBlockHeader } from './utils/block_creation.js';
|
|
22
|
+
import { TXEAccountStore } from './util/txe_account_store.js';
|
|
23
|
+
import { getSingleTxBlockRequestHash, insertTxEffectIntoWorldTrees, makeTXEBlock } from './utils/block_creation.js';
|
|
21
24
|
import { makeTxEffect } from './utils/tx_effect_creation.js';
|
|
22
|
-
const DEFAULT_ADDRESS = AztecAddress.fromNumber(42);
|
|
23
25
|
/**
|
|
24
26
|
* A `TXESession` corresponds to a Noir `#[test]` function, and handles all of its oracle calls, stores test-specific
|
|
25
27
|
* state, etc., independent of all other tests running in parallel.
|
|
@@ -27,56 +29,81 @@ const DEFAULT_ADDRESS = AztecAddress.fromNumber(42);
|
|
|
27
29
|
logger;
|
|
28
30
|
stateMachine;
|
|
29
31
|
oracleHandler;
|
|
30
|
-
|
|
32
|
+
contractStore;
|
|
33
|
+
noteStore;
|
|
31
34
|
keyStore;
|
|
32
|
-
|
|
33
|
-
|
|
35
|
+
addressStore;
|
|
36
|
+
accountStore;
|
|
37
|
+
senderTaggingStore;
|
|
38
|
+
recipientTaggingStore;
|
|
39
|
+
senderAddressBookStore;
|
|
40
|
+
capsuleStore;
|
|
41
|
+
privateEventStore;
|
|
42
|
+
jobCoordinator;
|
|
43
|
+
currentJobId;
|
|
34
44
|
chainId;
|
|
35
45
|
version;
|
|
36
46
|
nextBlockTimestamp;
|
|
37
|
-
|
|
47
|
+
contractSyncService;
|
|
38
48
|
state;
|
|
39
49
|
authwits;
|
|
40
|
-
constructor(logger, stateMachine, oracleHandler,
|
|
50
|
+
constructor(logger, stateMachine, oracleHandler, contractStore, noteStore, keyStore, addressStore, accountStore, senderTaggingStore, recipientTaggingStore, senderAddressBookStore, capsuleStore, privateEventStore, jobCoordinator, currentJobId, chainId, version, nextBlockTimestamp, contractSyncService){
|
|
41
51
|
this.logger = logger;
|
|
42
52
|
this.stateMachine = stateMachine;
|
|
43
53
|
this.oracleHandler = oracleHandler;
|
|
44
|
-
this.
|
|
54
|
+
this.contractStore = contractStore;
|
|
55
|
+
this.noteStore = noteStore;
|
|
45
56
|
this.keyStore = keyStore;
|
|
46
|
-
this.
|
|
47
|
-
this.
|
|
57
|
+
this.addressStore = addressStore;
|
|
58
|
+
this.accountStore = accountStore;
|
|
59
|
+
this.senderTaggingStore = senderTaggingStore;
|
|
60
|
+
this.recipientTaggingStore = recipientTaggingStore;
|
|
61
|
+
this.senderAddressBookStore = senderAddressBookStore;
|
|
62
|
+
this.capsuleStore = capsuleStore;
|
|
63
|
+
this.privateEventStore = privateEventStore;
|
|
64
|
+
this.jobCoordinator = jobCoordinator;
|
|
65
|
+
this.currentJobId = currentJobId;
|
|
48
66
|
this.chainId = chainId;
|
|
49
67
|
this.version = version;
|
|
50
68
|
this.nextBlockTimestamp = nextBlockTimestamp;
|
|
51
|
-
this.
|
|
69
|
+
this.contractSyncService = contractSyncService;
|
|
52
70
|
this.state = {
|
|
53
71
|
name: 'TOP_LEVEL'
|
|
54
72
|
};
|
|
55
73
|
this.authwits = new Map();
|
|
56
74
|
}
|
|
57
|
-
static async init(
|
|
75
|
+
static async init(contractStore) {
|
|
58
76
|
const store = await openTmpStore('txe-session');
|
|
59
|
-
const
|
|
60
|
-
const
|
|
61
|
-
const
|
|
62
|
-
const
|
|
63
|
-
const
|
|
64
|
-
const
|
|
77
|
+
const addressStore = new AddressStore(store);
|
|
78
|
+
const privateEventStore = new PrivateEventStore(store);
|
|
79
|
+
const noteStore = new NoteStore(store);
|
|
80
|
+
const senderTaggingStore = new SenderTaggingStore(store);
|
|
81
|
+
const recipientTaggingStore = new RecipientTaggingStore(store);
|
|
82
|
+
const senderAddressBookStore = new SenderAddressBookStore(store);
|
|
83
|
+
const capsuleStore = new CapsuleStore(store);
|
|
65
84
|
const keyStore = new KeyStore(store);
|
|
66
|
-
const
|
|
67
|
-
//
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
85
|
+
const accountStore = new TXEAccountStore(store);
|
|
86
|
+
// Create job coordinator and register staged stores
|
|
87
|
+
const jobCoordinator = new JobCoordinator(store);
|
|
88
|
+
jobCoordinator.registerStores([
|
|
89
|
+
capsuleStore,
|
|
90
|
+
senderTaggingStore,
|
|
91
|
+
recipientTaggingStore,
|
|
92
|
+
privateEventStore,
|
|
93
|
+
noteStore
|
|
94
|
+
]);
|
|
95
|
+
const archiver = new TXEArchiver(store);
|
|
96
|
+
const anchorBlockStore = new AnchorBlockStore(store);
|
|
97
|
+
const stateMachine = await TXEStateMachine.create(archiver, anchorBlockStore, contractStore, noteStore);
|
|
73
98
|
const nextBlockTimestamp = BigInt(Math.floor(new Date().getTime() / 1000));
|
|
74
99
|
const version = new Fr(await stateMachine.node.getVersion());
|
|
75
100
|
const chainId = new Fr(await stateMachine.node.getChainId());
|
|
76
|
-
const
|
|
77
|
-
const
|
|
78
|
-
|
|
79
|
-
|
|
101
|
+
const initialJobId = jobCoordinator.beginJob();
|
|
102
|
+
const logger = createLogger('txe:session');
|
|
103
|
+
const contractSyncService = new ContractSyncService(stateMachine.node, contractStore, noteStore, logger);
|
|
104
|
+
const topLevelOracleHandler = new TXEOracleTopLevelContext(stateMachine, contractStore, noteStore, keyStore, addressStore, accountStore, senderTaggingStore, recipientTaggingStore, senderAddressBookStore, capsuleStore, privateEventStore, nextBlockTimestamp, version, chainId, new Map(), contractSyncService);
|
|
105
|
+
await topLevelOracleHandler.advanceBlocksBy(1);
|
|
106
|
+
return new TXESession(logger, stateMachine, topLevelOracleHandler, contractStore, noteStore, keyStore, addressStore, accountStore, senderTaggingStore, recipientTaggingStore, senderAddressBookStore, capsuleStore, privateEventStore, jobCoordinator, initialJobId, version, chainId, nextBlockTimestamp, contractSyncService);
|
|
80
107
|
}
|
|
81
108
|
/**
|
|
82
109
|
* Processes an oracle function invoked by the Noir test associated to this session.
|
|
@@ -99,6 +126,14 @@ const DEFAULT_ADDRESS = AztecAddress.fromNumber(42);
|
|
|
99
126
|
}
|
|
100
127
|
}
|
|
101
128
|
}
|
|
129
|
+
getCurrentJob() {
|
|
130
|
+
return this.currentJobId;
|
|
131
|
+
}
|
|
132
|
+
/** Commits the current job and begins a new one. Returns the new job ID. */ async cycleJob() {
|
|
133
|
+
await this.jobCoordinator.commitJob(this.currentJobId);
|
|
134
|
+
this.currentJobId = this.jobCoordinator.beginJob();
|
|
135
|
+
return this.currentJobId;
|
|
136
|
+
}
|
|
102
137
|
async enterTopLevelState() {
|
|
103
138
|
switch(this.state.name){
|
|
104
139
|
case 'PRIVATE':
|
|
@@ -125,7 +160,9 @@ const DEFAULT_ADDRESS = AztecAddress.fromNumber(42);
|
|
|
125
160
|
this.state;
|
|
126
161
|
}
|
|
127
162
|
}
|
|
128
|
-
|
|
163
|
+
// Commit all staged stores from the job that was just completed, then begin a new job
|
|
164
|
+
await this.cycleJob();
|
|
165
|
+
this.oracleHandler = new TXEOracleTopLevelContext(this.stateMachine, this.contractStore, this.noteStore, this.keyStore, this.addressStore, this.accountStore, this.senderTaggingStore, this.recipientTaggingStore, this.senderAddressBookStore, this.capsuleStore, this.privateEventStore, this.nextBlockTimestamp, this.version, this.chainId, this.authwits, this.contractSyncService);
|
|
129
166
|
this.state = {
|
|
130
167
|
name: 'TOP_LEVEL'
|
|
131
168
|
};
|
|
@@ -133,27 +170,49 @@ const DEFAULT_ADDRESS = AztecAddress.fromNumber(42);
|
|
|
133
170
|
}
|
|
134
171
|
async enterPrivateState(contractAddress = DEFAULT_ADDRESS, anchorBlockNumber) {
|
|
135
172
|
this.exitTopLevelState();
|
|
136
|
-
// There is no automatic message discovery and contract-driven syncing process in inlined private or utility
|
|
137
|
-
// contexts, which means that known nullifiers are also not searched for, since it is during the tagging sync that
|
|
138
|
-
// we perform this. We therefore search for known nullifiers now, as otherwise notes that were nullified would not
|
|
139
|
-
// be removed from the database.
|
|
140
|
-
// TODO(#12553): make the synchronizer sync here instead and remove this
|
|
141
|
-
await this.pxeOracleInterface.syncNoteNullifiers(contractAddress);
|
|
142
173
|
// Private execution has two associated block numbers: the anchor block (i.e. the historical block that is used to
|
|
143
174
|
// build the proof), and the *next* block, i.e. the one we'll create once the execution ends, and which will contain
|
|
144
175
|
// a single transaction with the effects of what was done in the test.
|
|
145
176
|
const anchorBlock = await this.stateMachine.node.getBlockHeader(anchorBlockNumber ?? 'latest');
|
|
177
|
+
await new NoteService(this.noteStore, this.stateMachine.node, anchorBlock, this.currentJobId).syncNoteNullifiers(contractAddress, 'ALL_SCOPES');
|
|
146
178
|
const latestBlock = await this.stateMachine.node.getBlockHeader('latest');
|
|
147
179
|
const nextBlockGlobalVariables = makeGlobalVariables(undefined, {
|
|
148
|
-
blockNumber: latestBlock.globalVariables.blockNumber + 1,
|
|
180
|
+
blockNumber: BlockNumber(latestBlock.globalVariables.blockNumber + 1),
|
|
149
181
|
timestamp: this.nextBlockTimestamp,
|
|
150
182
|
version: this.version,
|
|
151
183
|
chainId: this.chainId
|
|
152
184
|
});
|
|
153
185
|
const txRequestHash = getSingleTxBlockRequestHash(nextBlockGlobalVariables.blockNumber);
|
|
154
|
-
const
|
|
186
|
+
const protocolNullifier = await computeProtocolNullifier(txRequestHash);
|
|
187
|
+
const noteCache = new ExecutionNoteCache(protocolNullifier);
|
|
155
188
|
const taggingIndexCache = new ExecutionTaggingIndexCache();
|
|
156
|
-
|
|
189
|
+
const utilityExecutor = this.utilityExecutorForContractSync(anchorBlock);
|
|
190
|
+
this.oracleHandler = new PrivateExecutionOracle({
|
|
191
|
+
argsHash: Fr.ZERO,
|
|
192
|
+
txContext: new TxContext(this.chainId, this.version, GasSettings.empty()),
|
|
193
|
+
callContext: new CallContext(AztecAddress.ZERO, contractAddress, FunctionSelector.empty(), false),
|
|
194
|
+
anchorBlockHeader: anchorBlock,
|
|
195
|
+
utilityExecutor,
|
|
196
|
+
authWitnesses: [],
|
|
197
|
+
capsules: [],
|
|
198
|
+
executionCache: new HashedValuesCache(),
|
|
199
|
+
noteCache,
|
|
200
|
+
taggingIndexCache,
|
|
201
|
+
contractStore: this.contractStore,
|
|
202
|
+
noteStore: this.noteStore,
|
|
203
|
+
keyStore: this.keyStore,
|
|
204
|
+
addressStore: this.addressStore,
|
|
205
|
+
aztecNode: this.stateMachine.node,
|
|
206
|
+
senderTaggingStore: this.senderTaggingStore,
|
|
207
|
+
recipientTaggingStore: this.recipientTaggingStore,
|
|
208
|
+
senderAddressBookStore: this.senderAddressBookStore,
|
|
209
|
+
capsuleStore: this.capsuleStore,
|
|
210
|
+
privateEventStore: this.privateEventStore,
|
|
211
|
+
contractSyncService: this.stateMachine.contractSyncService,
|
|
212
|
+
jobId: this.currentJobId,
|
|
213
|
+
scopes: 'ALL_SCOPES',
|
|
214
|
+
messageContextService: this.stateMachine.messageContextService
|
|
215
|
+
});
|
|
157
216
|
// We store the note and tagging index caches fed into the PrivateExecutionOracle (along with some other auxiliary
|
|
158
217
|
// data) in order to refer to it later, mimicking the way this object is used by the ContractFunctionSimulator. The
|
|
159
218
|
// difference resides in that the simulator has all information needed in order to run the simulation, while ours
|
|
@@ -162,7 +221,6 @@ const DEFAULT_ADDRESS = AztecAddress.fromNumber(42);
|
|
|
162
221
|
this.state = {
|
|
163
222
|
name: 'PRIVATE',
|
|
164
223
|
nextBlockGlobalVariables,
|
|
165
|
-
txRequestHash,
|
|
166
224
|
noteCache,
|
|
167
225
|
taggingIndexCache
|
|
168
226
|
};
|
|
@@ -175,7 +233,7 @@ const DEFAULT_ADDRESS = AztecAddress.fromNumber(42);
|
|
|
175
233
|
// the test. The block therefore gets the *next* block number and timestamp.
|
|
176
234
|
const latestBlockNumber = (await this.stateMachine.node.getBlockHeader('latest')).globalVariables.blockNumber;
|
|
177
235
|
const globalVariables = makeGlobalVariables(undefined, {
|
|
178
|
-
blockNumber: latestBlockNumber + 1,
|
|
236
|
+
blockNumber: BlockNumber(latestBlockNumber + 1),
|
|
179
237
|
timestamp: this.nextBlockTimestamp,
|
|
180
238
|
version: this.version,
|
|
181
239
|
chainId: this.chainId
|
|
@@ -188,13 +246,32 @@ const DEFAULT_ADDRESS = AztecAddress.fromNumber(42);
|
|
|
188
246
|
}
|
|
189
247
|
async enterUtilityState(contractAddress = DEFAULT_ADDRESS) {
|
|
190
248
|
this.exitTopLevelState();
|
|
249
|
+
const anchorBlockHeader = await this.stateMachine.anchorBlockStore.getBlockHeader();
|
|
191
250
|
// There is no automatic message discovery and contract-driven syncing process in inlined private or utility
|
|
192
251
|
// contexts, which means that known nullifiers are also not searched for, since it is during the tagging sync that
|
|
193
252
|
// we perform this. We therefore search for known nullifiers now, as otherwise notes that were nullified would not
|
|
194
253
|
// be removed from the database.
|
|
195
254
|
// TODO(#12553): make the synchronizer sync here instead and remove this
|
|
196
|
-
await this.
|
|
197
|
-
this.oracleHandler = new UtilityExecutionOracle(
|
|
255
|
+
await new NoteService(this.noteStore, this.stateMachine.node, anchorBlockHeader, this.currentJobId).syncNoteNullifiers(contractAddress, 'ALL_SCOPES');
|
|
256
|
+
this.oracleHandler = new UtilityExecutionOracle({
|
|
257
|
+
contractAddress,
|
|
258
|
+
authWitnesses: [],
|
|
259
|
+
capsules: [],
|
|
260
|
+
anchorBlockHeader,
|
|
261
|
+
contractStore: this.contractStore,
|
|
262
|
+
noteStore: this.noteStore,
|
|
263
|
+
keyStore: this.keyStore,
|
|
264
|
+
addressStore: this.addressStore,
|
|
265
|
+
aztecNode: this.stateMachine.node,
|
|
266
|
+
recipientTaggingStore: this.recipientTaggingStore,
|
|
267
|
+
senderAddressBookStore: this.senderAddressBookStore,
|
|
268
|
+
capsuleStore: this.capsuleStore,
|
|
269
|
+
privateEventStore: this.privateEventStore,
|
|
270
|
+
messageContextService: this.stateMachine.messageContextService,
|
|
271
|
+
contractSyncService: this.contractSyncService,
|
|
272
|
+
jobId: this.currentJobId,
|
|
273
|
+
scopes: 'ALL_SCOPES'
|
|
274
|
+
});
|
|
198
275
|
this.state = {
|
|
199
276
|
name: 'UTILITY'
|
|
200
277
|
};
|
|
@@ -206,8 +283,8 @@ const DEFAULT_ADDRESS = AztecAddress.fromNumber(42);
|
|
|
206
283
|
}
|
|
207
284
|
// Note that while all public and private contexts do is build a single block that we then process when exiting
|
|
208
285
|
// those, the top level context performs a large number of actions not captured in the following 'close' call. Among
|
|
209
|
-
// others, it will create empty blocks (via `
|
|
210
|
-
// `
|
|
286
|
+
// others, it will create empty blocks (via `advanceBlocksBy` and `deploy`), create blocks with transactions via
|
|
287
|
+
// `privateCallNewFlow` and `publicCallNewFlow`, add accounts to PXE via `addAccount`, etc. This is a
|
|
211
288
|
// slight inconsistency in the working model of this class, but is not too bad.
|
|
212
289
|
// TODO: it's quite unfortunate that we need to capture the authwits created to later pass them again when the top
|
|
213
290
|
// level context is re-created. This is because authwits create a temporary utility context that'd otherwise reset
|
|
@@ -224,13 +301,13 @@ const DEFAULT_ADDRESS = AztecAddress.fromNumber(42);
|
|
|
224
301
|
});
|
|
225
302
|
// We rely on the note cache to determine the effects of the transaction. This is incomplete as it doesn't private
|
|
226
303
|
// logs (other effects like enqueued public calls don't need to be considered since those are not allowed).
|
|
227
|
-
const txEffect = await makeTxEffect(this.state.noteCache, this.state.
|
|
304
|
+
const txEffect = await makeTxEffect(this.state.noteCache, this.state.nextBlockGlobalVariables.blockNumber);
|
|
228
305
|
// We build a block holding just this transaction
|
|
229
306
|
const forkedWorldTrees = await this.stateMachine.synchronizer.nativeWorldStateService.fork();
|
|
230
307
|
await insertTxEffectIntoWorldTrees(txEffect, forkedWorldTrees);
|
|
231
|
-
const block =
|
|
308
|
+
const block = await makeTXEBlock(forkedWorldTrees, this.state.nextBlockGlobalVariables, [
|
|
232
309
|
txEffect
|
|
233
|
-
])
|
|
310
|
+
]);
|
|
234
311
|
await this.stateMachine.handleL2Block(block);
|
|
235
312
|
await forkedWorldTrees.close();
|
|
236
313
|
this.logger.debug('Exited PublicContext with built block', {
|
|
@@ -250,4 +327,44 @@ const DEFAULT_ADDRESS = AztecAddress.fromNumber(42);
|
|
|
250
327
|
throw new Error(`Expected to be in state 'UTILITY', but got '${this.state.name}' instead`);
|
|
251
328
|
}
|
|
252
329
|
}
|
|
330
|
+
utilityExecutorForContractSync(anchorBlock) {
|
|
331
|
+
return async (call, scopes)=>{
|
|
332
|
+
const entryPointArtifact = await this.contractStore.getFunctionArtifactWithDebugMetadata(call.to, call.selector);
|
|
333
|
+
if (entryPointArtifact.functionType !== FunctionType.UTILITY) {
|
|
334
|
+
throw new Error(`Cannot run ${entryPointArtifact.functionType} function as utility`);
|
|
335
|
+
}
|
|
336
|
+
try {
|
|
337
|
+
const oracle = new UtilityExecutionOracle({
|
|
338
|
+
contractAddress: call.to,
|
|
339
|
+
authWitnesses: [],
|
|
340
|
+
capsules: [],
|
|
341
|
+
anchorBlockHeader: anchorBlock,
|
|
342
|
+
contractStore: this.contractStore,
|
|
343
|
+
noteStore: this.noteStore,
|
|
344
|
+
keyStore: this.keyStore,
|
|
345
|
+
addressStore: this.addressStore,
|
|
346
|
+
aztecNode: this.stateMachine.node,
|
|
347
|
+
recipientTaggingStore: this.recipientTaggingStore,
|
|
348
|
+
senderAddressBookStore: this.senderAddressBookStore,
|
|
349
|
+
capsuleStore: this.capsuleStore,
|
|
350
|
+
privateEventStore: this.privateEventStore,
|
|
351
|
+
messageContextService: this.stateMachine.messageContextService,
|
|
352
|
+
contractSyncService: this.contractSyncService,
|
|
353
|
+
jobId: this.currentJobId,
|
|
354
|
+
scopes
|
|
355
|
+
});
|
|
356
|
+
await new WASMSimulator().executeUserCircuit(toACVMWitness(0, call.args), entryPointArtifact, new Oracle(oracle).toACIRCallback()).catch((err)=>{
|
|
357
|
+
err.message = resolveAssertionMessageFromError(err, entryPointArtifact);
|
|
358
|
+
throw new ExecutionError(err.message, {
|
|
359
|
+
contractAddress: call.to,
|
|
360
|
+
functionSelector: call.selector
|
|
361
|
+
}, extractCallStack(err, entryPointArtifact.debug), {
|
|
362
|
+
cause: err
|
|
363
|
+
});
|
|
364
|
+
});
|
|
365
|
+
} catch (err) {
|
|
366
|
+
throw createSimulationError(err instanceof Error ? err : new Error('Unknown error contract data sync'));
|
|
367
|
+
}
|
|
368
|
+
};
|
|
369
|
+
}
|
|
253
370
|
}
|