@aztec/txe 0.0.1-commit.aada20e3 → 0.0.1-commit.b33fc05d0
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/index.d.ts +1 -1
- package/dest/index.d.ts.map +1 -1
- package/dest/index.js +88 -54
- package/dest/oracle/interfaces.d.ts +29 -28
- package/dest/oracle/interfaces.d.ts.map +1 -1
- package/dest/oracle/txe_oracle_public_context.d.ts +13 -13
- package/dest/oracle/txe_oracle_public_context.d.ts.map +1 -1
- package/dest/oracle/txe_oracle_public_context.js +12 -12
- package/dest/oracle/txe_oracle_top_level_context.d.ts +22 -23
- package/dest/oracle/txe_oracle_top_level_context.d.ts.map +1 -1
- package/dest/oracle/txe_oracle_top_level_context.js +120 -50
- package/dest/rpc_translator.d.ts +85 -83
- package/dest/rpc_translator.d.ts.map +1 -1
- package/dest/rpc_translator.js +249 -150
- package/dest/state_machine/archiver.d.ts +3 -3
- package/dest/state_machine/archiver.d.ts.map +1 -1
- package/dest/state_machine/archiver.js +7 -7
- package/dest/state_machine/dummy_p2p_client.d.ts +16 -12
- package/dest/state_machine/dummy_p2p_client.d.ts.map +1 -1
- package/dest/state_machine/dummy_p2p_client.js +28 -16
- package/dest/state_machine/index.d.ts +7 -5
- package/dest/state_machine/index.d.ts.map +1 -1
- package/dest/state_machine/index.js +19 -10
- package/dest/state_machine/mock_epoch_cache.d.ts +3 -1
- package/dest/state_machine/mock_epoch_cache.d.ts.map +1 -1
- package/dest/state_machine/mock_epoch_cache.js +4 -0
- package/dest/txe_session.d.ts +9 -6
- package/dest/txe_session.d.ts.map +1 -1
- package/dest/txe_session.js +85 -23
- package/dest/util/txe_public_contract_data_source.d.ts +2 -3
- package/dest/util/txe_public_contract_data_source.d.ts.map +1 -1
- package/dest/util/txe_public_contract_data_source.js +5 -22
- package/dest/utils/block_creation.d.ts +1 -1
- package/dest/utils/block_creation.d.ts.map +1 -1
- package/dest/utils/block_creation.js +3 -1
- package/package.json +15 -15
- package/src/index.ts +89 -52
- package/src/oracle/interfaces.ts +32 -31
- package/src/oracle/txe_oracle_public_context.ts +12 -12
- package/src/oracle/txe_oracle_top_level_context.ts +123 -103
- package/src/rpc_translator.ts +277 -169
- package/src/state_machine/archiver.ts +7 -5
- package/src/state_machine/dummy_p2p_client.ts +40 -22
- package/src/state_machine/index.ts +29 -9
- package/src/state_machine/mock_epoch_cache.ts +5 -0
- package/src/txe_session.ts +88 -71
- package/src/util/txe_public_contract_data_source.ts +10 -36
- package/src/utils/block_creation.ts +3 -1
- package/dest/util/txe_contract_store.d.ts +0 -12
- package/dest/util/txe_contract_store.d.ts.map +0 -1
- package/dest/util/txe_contract_store.js +0 -22
- package/src/util/txe_contract_store.ts +0 -36
package/src/rpc_translator.ts
CHANGED
|
@@ -30,7 +30,7 @@ import {
|
|
|
30
30
|
toSingle,
|
|
31
31
|
} from './util/encoding.js';
|
|
32
32
|
|
|
33
|
-
const MAX_EVENT_LEN =
|
|
33
|
+
const MAX_EVENT_LEN = 10; // This is MAX_MESSAGE_CONTENT_LEN - PRIVATE_EVENT_MSG_PLAINTEXT_RESERVED_FIELDS_LEN
|
|
34
34
|
const MAX_PRIVATE_EVENTS_PER_TXE_QUERY = 5;
|
|
35
35
|
|
|
36
36
|
export class UnavailableOracleError extends Error {
|
|
@@ -104,13 +104,15 @@ export class RPCTranslator {
|
|
|
104
104
|
|
|
105
105
|
// TXE session state transition functions - these get handled by the state handler
|
|
106
106
|
|
|
107
|
-
|
|
107
|
+
// eslint-disable-next-line camelcase
|
|
108
|
+
async aztec_txe_setTopLevelTXEContext() {
|
|
108
109
|
await this.stateHandler.enterTopLevelState();
|
|
109
110
|
|
|
110
111
|
return toForeignCallResult([]);
|
|
111
112
|
}
|
|
112
113
|
|
|
113
|
-
|
|
114
|
+
// eslint-disable-next-line camelcase
|
|
115
|
+
async aztec_txe_setPrivateTXEContext(
|
|
114
116
|
foreignContractAddressIsSome: ForeignCallSingle,
|
|
115
117
|
foreignContractAddressValue: ForeignCallSingle,
|
|
116
118
|
foreignAnchorBlockNumberIsSome: ForeignCallSingle,
|
|
@@ -129,7 +131,8 @@ export class RPCTranslator {
|
|
|
129
131
|
return toForeignCallResult(privateContextInputs.toFields().map(toSingle));
|
|
130
132
|
}
|
|
131
133
|
|
|
132
|
-
|
|
134
|
+
// eslint-disable-next-line camelcase
|
|
135
|
+
async aztec_txe_setPublicTXEContext(
|
|
133
136
|
foreignContractAddressIsSome: ForeignCallSingle,
|
|
134
137
|
foreignContractAddressValue: ForeignCallSingle,
|
|
135
138
|
) {
|
|
@@ -142,7 +145,8 @@ export class RPCTranslator {
|
|
|
142
145
|
return toForeignCallResult([]);
|
|
143
146
|
}
|
|
144
147
|
|
|
145
|
-
|
|
148
|
+
// eslint-disable-next-line camelcase
|
|
149
|
+
async aztec_txe_setUtilityTXEContext(
|
|
146
150
|
foreignContractAddressIsSome: ForeignCallSingle,
|
|
147
151
|
foreignContractAddressValue: ForeignCallSingle,
|
|
148
152
|
) {
|
|
@@ -159,44 +163,54 @@ export class RPCTranslator {
|
|
|
159
163
|
|
|
160
164
|
// TXE-specific oracles
|
|
161
165
|
|
|
162
|
-
|
|
163
|
-
|
|
166
|
+
// eslint-disable-next-line camelcase
|
|
167
|
+
aztec_txe_getDefaultAddress() {
|
|
168
|
+
const defaultAddress = this.handlerAsTxe().getDefaultAddress();
|
|
164
169
|
|
|
165
170
|
return toForeignCallResult([toSingle(defaultAddress)]);
|
|
166
171
|
}
|
|
167
172
|
|
|
168
|
-
|
|
169
|
-
|
|
173
|
+
// eslint-disable-next-line camelcase
|
|
174
|
+
async aztec_txe_getNextBlockNumber() {
|
|
175
|
+
const nextBlockNumber = await this.handlerAsTxe().getNextBlockNumber();
|
|
170
176
|
|
|
171
177
|
return toForeignCallResult([toSingle(nextBlockNumber)]);
|
|
172
178
|
}
|
|
173
179
|
|
|
174
|
-
|
|
175
|
-
|
|
180
|
+
// eslint-disable-next-line camelcase
|
|
181
|
+
async aztec_txe_getNextBlockTimestamp() {
|
|
182
|
+
const nextBlockTimestamp = await this.handlerAsTxe().getNextBlockTimestamp();
|
|
176
183
|
|
|
177
184
|
return toForeignCallResult([toSingle(nextBlockTimestamp)]);
|
|
178
185
|
}
|
|
179
186
|
|
|
180
|
-
|
|
187
|
+
// eslint-disable-next-line camelcase
|
|
188
|
+
async aztec_txe_advanceBlocksBy(foreignBlocks: ForeignCallSingle) {
|
|
181
189
|
const blocks = fromSingle(foreignBlocks).toNumber();
|
|
182
190
|
|
|
183
|
-
await this.handlerAsTxe().
|
|
191
|
+
await this.handlerAsTxe().advanceBlocksBy(blocks);
|
|
184
192
|
|
|
185
193
|
return toForeignCallResult([]);
|
|
186
194
|
}
|
|
187
195
|
|
|
188
|
-
|
|
196
|
+
// eslint-disable-next-line camelcase
|
|
197
|
+
aztec_txe_advanceTimestampBy(foreignDuration: ForeignCallSingle) {
|
|
189
198
|
const duration = fromSingle(foreignDuration).toBigInt();
|
|
190
199
|
|
|
191
|
-
this.handlerAsTxe().
|
|
200
|
+
this.handlerAsTxe().advanceTimestampBy(duration);
|
|
192
201
|
|
|
193
202
|
return toForeignCallResult([]);
|
|
194
203
|
}
|
|
195
204
|
|
|
196
|
-
|
|
205
|
+
// eslint-disable-next-line camelcase
|
|
206
|
+
async aztec_txe_deploy(
|
|
207
|
+
artifact: ContractArtifact,
|
|
208
|
+
instance: ContractInstanceWithAddress,
|
|
209
|
+
foreignSecret: ForeignCallSingle,
|
|
210
|
+
) {
|
|
197
211
|
const secret = fromSingle(foreignSecret);
|
|
198
212
|
|
|
199
|
-
await this.handlerAsTxe().
|
|
213
|
+
await this.handlerAsTxe().deploy(artifact, instance, secret);
|
|
200
214
|
|
|
201
215
|
return toForeignCallResult([
|
|
202
216
|
toArray([
|
|
@@ -209,10 +223,11 @@ export class RPCTranslator {
|
|
|
209
223
|
]);
|
|
210
224
|
}
|
|
211
225
|
|
|
212
|
-
|
|
226
|
+
// eslint-disable-next-line camelcase
|
|
227
|
+
async aztec_txe_createAccount(foreignSecret: ForeignCallSingle) {
|
|
213
228
|
const secret = fromSingle(foreignSecret);
|
|
214
229
|
|
|
215
|
-
const completeAddress = await this.handlerAsTxe().
|
|
230
|
+
const completeAddress = await this.handlerAsTxe().createAccount(secret);
|
|
216
231
|
|
|
217
232
|
return toForeignCallResult([
|
|
218
233
|
toSingle(completeAddress.address),
|
|
@@ -220,14 +235,15 @@ export class RPCTranslator {
|
|
|
220
235
|
]);
|
|
221
236
|
}
|
|
222
237
|
|
|
223
|
-
|
|
238
|
+
// eslint-disable-next-line camelcase
|
|
239
|
+
async aztec_txe_addAccount(
|
|
224
240
|
artifact: ContractArtifact,
|
|
225
241
|
instance: ContractInstanceWithAddress,
|
|
226
242
|
foreignSecret: ForeignCallSingle,
|
|
227
243
|
) {
|
|
228
244
|
const secret = fromSingle(foreignSecret);
|
|
229
245
|
|
|
230
|
-
const completeAddress = await this.handlerAsTxe().
|
|
246
|
+
const completeAddress = await this.handlerAsTxe().addAccount(artifact, instance, secret);
|
|
231
247
|
|
|
232
248
|
return toForeignCallResult([
|
|
233
249
|
toSingle(completeAddress.address),
|
|
@@ -235,39 +251,44 @@ export class RPCTranslator {
|
|
|
235
251
|
]);
|
|
236
252
|
}
|
|
237
253
|
|
|
238
|
-
|
|
254
|
+
// eslint-disable-next-line camelcase
|
|
255
|
+
async aztec_txe_addAuthWitness(foreignAddress: ForeignCallSingle, foreignMessageHash: ForeignCallSingle) {
|
|
239
256
|
const address = addressFromSingle(foreignAddress);
|
|
240
257
|
const messageHash = fromSingle(foreignMessageHash);
|
|
241
258
|
|
|
242
|
-
await this.handlerAsTxe().
|
|
259
|
+
await this.handlerAsTxe().addAuthWitness(address, messageHash);
|
|
243
260
|
|
|
244
261
|
return toForeignCallResult([]);
|
|
245
262
|
}
|
|
246
263
|
|
|
247
264
|
// PXE oracles
|
|
248
265
|
|
|
249
|
-
|
|
266
|
+
// eslint-disable-next-line camelcase
|
|
267
|
+
aztec_utl_assertCompatibleOracleVersion(foreignVersion: ForeignCallSingle) {
|
|
250
268
|
const version = fromSingle(foreignVersion).toNumber();
|
|
251
269
|
|
|
252
|
-
this.handlerAsMisc().
|
|
270
|
+
this.handlerAsMisc().assertCompatibleOracleVersion(version);
|
|
253
271
|
|
|
254
272
|
return toForeignCallResult([]);
|
|
255
273
|
}
|
|
256
274
|
|
|
257
|
-
|
|
258
|
-
|
|
275
|
+
// eslint-disable-next-line camelcase
|
|
276
|
+
aztec_utl_getRandomField() {
|
|
277
|
+
const randomField = this.handlerAsMisc().getRandomField();
|
|
259
278
|
|
|
260
279
|
return toForeignCallResult([toSingle(randomField)]);
|
|
261
280
|
}
|
|
262
281
|
|
|
263
|
-
|
|
264
|
-
|
|
282
|
+
// eslint-disable-next-line camelcase
|
|
283
|
+
async aztec_txe_getLastBlockTimestamp() {
|
|
284
|
+
const timestamp = await this.handlerAsTxe().getLastBlockTimestamp();
|
|
265
285
|
|
|
266
286
|
return toForeignCallResult([toSingle(new Fr(timestamp))]);
|
|
267
287
|
}
|
|
268
288
|
|
|
269
|
-
|
|
270
|
-
|
|
289
|
+
// eslint-disable-next-line camelcase
|
|
290
|
+
async aztec_txe_getLastTxEffects() {
|
|
291
|
+
const { txHash, noteHashes, nullifiers } = await this.handlerAsTxe().getLastTxEffects();
|
|
271
292
|
|
|
272
293
|
return toForeignCallResult([
|
|
273
294
|
toSingle(txHash.hash),
|
|
@@ -276,7 +297,8 @@ export class RPCTranslator {
|
|
|
276
297
|
]);
|
|
277
298
|
}
|
|
278
299
|
|
|
279
|
-
|
|
300
|
+
// eslint-disable-next-line camelcase
|
|
301
|
+
async aztec_txe_getPrivateEvents(
|
|
280
302
|
foreignSelector: ForeignCallSingle,
|
|
281
303
|
foreignContractAddress: ForeignCallSingle,
|
|
282
304
|
foreignScope: ForeignCallSingle,
|
|
@@ -285,7 +307,14 @@ export class RPCTranslator {
|
|
|
285
307
|
const contractAddress = addressFromSingle(foreignContractAddress);
|
|
286
308
|
const scope = addressFromSingle(foreignScope);
|
|
287
309
|
|
|
288
|
-
|
|
310
|
+
// TODO(F-335): Avoid doing the following 2 calls here.
|
|
311
|
+
{
|
|
312
|
+
await this.handlerAsTxe().syncContractNonOracleMethod(contractAddress, scope, this.stateHandler.getCurrentJob());
|
|
313
|
+
// We cycle job to commit the stores after the contract sync.
|
|
314
|
+
await this.stateHandler.cycleJob();
|
|
315
|
+
}
|
|
316
|
+
|
|
317
|
+
const events = await this.handlerAsTxe().getPrivateEvents(selector, contractAddress, scope);
|
|
289
318
|
|
|
290
319
|
if (events.length > MAX_PRIVATE_EVENTS_PER_TXE_QUERY) {
|
|
291
320
|
throw new Error(`Array of length ${events.length} larger than maxLen ${MAX_PRIVATE_EVENTS_PER_TXE_QUERY}`);
|
|
@@ -309,26 +338,29 @@ export class RPCTranslator {
|
|
|
309
338
|
return toForeignCallResult([toArray(rawArrayStorage), toArray(eventLengths), toSingle(queryLength)]);
|
|
310
339
|
}
|
|
311
340
|
|
|
312
|
-
|
|
341
|
+
// eslint-disable-next-line camelcase
|
|
342
|
+
aztec_prv_storeInExecutionCache(foreignValues: ForeignCallArray, foreignHash: ForeignCallSingle) {
|
|
313
343
|
const values = fromArray(foreignValues);
|
|
314
344
|
const hash = fromSingle(foreignHash);
|
|
315
345
|
|
|
316
|
-
this.handlerAsPrivate().
|
|
346
|
+
this.handlerAsPrivate().storeInExecutionCache(values, hash);
|
|
317
347
|
|
|
318
348
|
return toForeignCallResult([]);
|
|
319
349
|
}
|
|
320
350
|
|
|
321
|
-
|
|
351
|
+
// eslint-disable-next-line camelcase
|
|
352
|
+
async aztec_prv_loadFromExecutionCache(foreignHash: ForeignCallSingle) {
|
|
322
353
|
const hash = fromSingle(foreignHash);
|
|
323
354
|
|
|
324
|
-
const returns = await this.handlerAsPrivate().
|
|
355
|
+
const returns = await this.handlerAsPrivate().loadFromExecutionCache(hash);
|
|
325
356
|
|
|
326
357
|
return toForeignCallResult([toArray(returns)]);
|
|
327
358
|
}
|
|
328
359
|
|
|
329
360
|
// When the argument is a slice, noir automatically adds a length field to oracle call.
|
|
330
361
|
// When the argument is an array, we add the field length manually to the signature.
|
|
331
|
-
|
|
362
|
+
// eslint-disable-next-line camelcase
|
|
363
|
+
async aztec_utl_log(
|
|
332
364
|
foreignLevel: ForeignCallSingle,
|
|
333
365
|
foreignMessage: ForeignCallArray,
|
|
334
366
|
_foreignLength: ForeignCallSingle,
|
|
@@ -340,12 +372,13 @@ export class RPCTranslator {
|
|
|
340
372
|
.join('');
|
|
341
373
|
const fields = fromArray(foreignFields);
|
|
342
374
|
|
|
343
|
-
this.handlerAsMisc().
|
|
375
|
+
await this.handlerAsMisc().log(level, message, fields);
|
|
344
376
|
|
|
345
377
|
return toForeignCallResult([]);
|
|
346
378
|
}
|
|
347
379
|
|
|
348
|
-
|
|
380
|
+
// eslint-disable-next-line camelcase
|
|
381
|
+
async aztec_utl_storageRead(
|
|
349
382
|
foreignBlockHash: ForeignCallSingle,
|
|
350
383
|
foreignContractAddress: ForeignCallSingle,
|
|
351
384
|
foreignStartStorageSlot: ForeignCallSingle,
|
|
@@ -356,7 +389,7 @@ export class RPCTranslator {
|
|
|
356
389
|
const startStorageSlot = fromSingle(foreignStartStorageSlot);
|
|
357
390
|
const numberOfElements = fromSingle(foreignNumberOfElements).toNumber();
|
|
358
391
|
|
|
359
|
-
const values = await this.handlerAsUtility().
|
|
392
|
+
const values = await this.handlerAsUtility().storageRead(
|
|
360
393
|
blockHash,
|
|
361
394
|
contractAddress,
|
|
362
395
|
startStorageSlot,
|
|
@@ -366,11 +399,12 @@ export class RPCTranslator {
|
|
|
366
399
|
return toForeignCallResult([toArray(values)]);
|
|
367
400
|
}
|
|
368
401
|
|
|
369
|
-
|
|
402
|
+
// eslint-disable-next-line camelcase
|
|
403
|
+
async aztec_utl_getPublicDataWitness(foreignBlockHash: ForeignCallSingle, foreignLeafSlot: ForeignCallSingle) {
|
|
370
404
|
const blockHash = new BlockHash(fromSingle(foreignBlockHash));
|
|
371
405
|
const leafSlot = fromSingle(foreignLeafSlot);
|
|
372
406
|
|
|
373
|
-
const witness = await this.handlerAsUtility().
|
|
407
|
+
const witness = await this.handlerAsUtility().getPublicDataWitness(blockHash, leafSlot);
|
|
374
408
|
|
|
375
409
|
if (!witness) {
|
|
376
410
|
throw new Error(`Public data witness not found for slot ${leafSlot} at block ${blockHash.toString()}.`);
|
|
@@ -378,7 +412,8 @@ export class RPCTranslator {
|
|
|
378
412
|
return toForeignCallResult(witness.toNoirRepresentation());
|
|
379
413
|
}
|
|
380
414
|
|
|
381
|
-
|
|
415
|
+
// eslint-disable-next-line camelcase
|
|
416
|
+
async aztec_utl_getNotes(
|
|
382
417
|
foreignOwnerIsSome: ForeignCallSingle,
|
|
383
418
|
foreignOwnerValue: ForeignCallSingle,
|
|
384
419
|
foreignStorageSlot: ForeignCallSingle,
|
|
@@ -419,7 +454,7 @@ export class RPCTranslator {
|
|
|
419
454
|
const maxNotes = fromSingle(foreignMaxNotes).toNumber();
|
|
420
455
|
const packedHintedNoteLength = fromSingle(foreignPackedHintedNoteLength).toNumber();
|
|
421
456
|
|
|
422
|
-
const noteDatas = await this.handlerAsUtility().
|
|
457
|
+
const noteDatas = await this.handlerAsUtility().getNotes(
|
|
423
458
|
owner,
|
|
424
459
|
storageSlot,
|
|
425
460
|
numSelects,
|
|
@@ -460,7 +495,8 @@ export class RPCTranslator {
|
|
|
460
495
|
);
|
|
461
496
|
}
|
|
462
497
|
|
|
463
|
-
|
|
498
|
+
// eslint-disable-next-line camelcase
|
|
499
|
+
aztec_prv_notifyCreatedNote(
|
|
464
500
|
foreignOwner: ForeignCallSingle,
|
|
465
501
|
foreignStorageSlot: ForeignCallSingle,
|
|
466
502
|
foreignRandomness: ForeignCallSingle,
|
|
@@ -477,20 +513,13 @@ export class RPCTranslator {
|
|
|
477
513
|
const noteHash = fromSingle(foreignNoteHash);
|
|
478
514
|
const counter = fromSingle(foreignCounter).toNumber();
|
|
479
515
|
|
|
480
|
-
this.handlerAsPrivate().
|
|
481
|
-
owner,
|
|
482
|
-
storageSlot,
|
|
483
|
-
randomness,
|
|
484
|
-
noteTypeId,
|
|
485
|
-
note,
|
|
486
|
-
noteHash,
|
|
487
|
-
counter,
|
|
488
|
-
);
|
|
516
|
+
this.handlerAsPrivate().notifyCreatedNote(owner, storageSlot, randomness, noteTypeId, note, noteHash, counter);
|
|
489
517
|
|
|
490
518
|
return toForeignCallResult([]);
|
|
491
519
|
}
|
|
492
520
|
|
|
493
|
-
|
|
521
|
+
// eslint-disable-next-line camelcase
|
|
522
|
+
async aztec_prv_notifyNullifiedNote(
|
|
494
523
|
foreignInnerNullifier: ForeignCallSingle,
|
|
495
524
|
foreignNoteHash: ForeignCallSingle,
|
|
496
525
|
foreignCounter: ForeignCallSingle,
|
|
@@ -499,40 +528,47 @@ export class RPCTranslator {
|
|
|
499
528
|
const noteHash = fromSingle(foreignNoteHash);
|
|
500
529
|
const counter = fromSingle(foreignCounter).toNumber();
|
|
501
530
|
|
|
502
|
-
await this.handlerAsPrivate().
|
|
531
|
+
await this.handlerAsPrivate().notifyNullifiedNote(innerNullifier, noteHash, counter);
|
|
503
532
|
|
|
504
533
|
return toForeignCallResult([]);
|
|
505
534
|
}
|
|
506
535
|
|
|
507
|
-
|
|
536
|
+
// eslint-disable-next-line camelcase
|
|
537
|
+
async aztec_prv_notifyCreatedNullifier(foreignInnerNullifier: ForeignCallSingle) {
|
|
508
538
|
const innerNullifier = fromSingle(foreignInnerNullifier);
|
|
509
539
|
|
|
510
|
-
await this.handlerAsPrivate().
|
|
540
|
+
await this.handlerAsPrivate().notifyCreatedNullifier(innerNullifier);
|
|
511
541
|
|
|
512
542
|
return toForeignCallResult([]);
|
|
513
543
|
}
|
|
514
544
|
|
|
515
|
-
|
|
545
|
+
// eslint-disable-next-line camelcase
|
|
546
|
+
async aztec_prv_isNullifierPending(
|
|
547
|
+
foreignInnerNullifier: ForeignCallSingle,
|
|
548
|
+
foreignContractAddress: ForeignCallSingle,
|
|
549
|
+
) {
|
|
516
550
|
const innerNullifier = fromSingle(foreignInnerNullifier);
|
|
517
551
|
const contractAddress = addressFromSingle(foreignContractAddress);
|
|
518
552
|
|
|
519
|
-
const isPending = await this.handlerAsPrivate().
|
|
553
|
+
const isPending = await this.handlerAsPrivate().isNullifierPending(innerNullifier, contractAddress);
|
|
520
554
|
|
|
521
555
|
return toForeignCallResult([toSingle(new Fr(isPending))]);
|
|
522
556
|
}
|
|
523
557
|
|
|
524
|
-
|
|
558
|
+
// eslint-disable-next-line camelcase
|
|
559
|
+
async aztec_utl_checkNullifierExists(foreignInnerNullifier: ForeignCallSingle) {
|
|
525
560
|
const innerNullifier = fromSingle(foreignInnerNullifier);
|
|
526
561
|
|
|
527
|
-
const exists = await this.handlerAsUtility().
|
|
562
|
+
const exists = await this.handlerAsUtility().checkNullifierExists(innerNullifier);
|
|
528
563
|
|
|
529
564
|
return toForeignCallResult([toSingle(new Fr(exists))]);
|
|
530
565
|
}
|
|
531
566
|
|
|
532
|
-
|
|
567
|
+
// eslint-disable-next-line camelcase
|
|
568
|
+
async aztec_utl_getContractInstance(foreignAddress: ForeignCallSingle) {
|
|
533
569
|
const address = addressFromSingle(foreignAddress);
|
|
534
570
|
|
|
535
|
-
const instance = await this.handlerAsUtility().
|
|
571
|
+
const instance = await this.handlerAsUtility().getContractInstance(address);
|
|
536
572
|
|
|
537
573
|
return toForeignCallResult(
|
|
538
574
|
[
|
|
@@ -545,10 +581,11 @@ export class RPCTranslator {
|
|
|
545
581
|
);
|
|
546
582
|
}
|
|
547
583
|
|
|
548
|
-
|
|
584
|
+
// eslint-disable-next-line camelcase
|
|
585
|
+
async aztec_utl_tryGetPublicKeysAndPartialAddress(foreignAddress: ForeignCallSingle) {
|
|
549
586
|
const address = addressFromSingle(foreignAddress);
|
|
550
587
|
|
|
551
|
-
const result = await this.handlerAsUtility().
|
|
588
|
+
const result = await this.handlerAsUtility().tryGetPublicKeysAndPartialAddress(address);
|
|
552
589
|
|
|
553
590
|
// We are going to return a Noir Option struct to represent the possibility of null values. Options are a struct
|
|
554
591
|
// with two fields: `some` (a boolean) and `value` (a field array in this case).
|
|
@@ -564,15 +601,17 @@ export class RPCTranslator {
|
|
|
564
601
|
}
|
|
565
602
|
}
|
|
566
603
|
|
|
567
|
-
|
|
604
|
+
// eslint-disable-next-line camelcase
|
|
605
|
+
async aztec_utl_getKeyValidationRequest(foreignPkMHash: ForeignCallSingle) {
|
|
568
606
|
const pkMHash = fromSingle(foreignPkMHash);
|
|
569
607
|
|
|
570
|
-
const keyValidationRequest = await this.handlerAsUtility().
|
|
608
|
+
const keyValidationRequest = await this.handlerAsUtility().getKeyValidationRequest(pkMHash);
|
|
571
609
|
|
|
572
610
|
return toForeignCallResult(keyValidationRequest.toFields().map(toSingle));
|
|
573
611
|
}
|
|
574
612
|
|
|
575
|
-
|
|
613
|
+
// eslint-disable-next-line camelcase
|
|
614
|
+
aztec_prv_callPrivateFunction(
|
|
576
615
|
_foreignTargetContractAddress: ForeignCallSingle,
|
|
577
616
|
_foreignFunctionSelector: ForeignCallSingle,
|
|
578
617
|
_foreignArgsHash: ForeignCallSingle,
|
|
@@ -584,11 +623,15 @@ export class RPCTranslator {
|
|
|
584
623
|
);
|
|
585
624
|
}
|
|
586
625
|
|
|
587
|
-
|
|
626
|
+
// eslint-disable-next-line camelcase
|
|
627
|
+
async aztec_utl_getNullifierMembershipWitness(
|
|
628
|
+
foreignBlockHash: ForeignCallSingle,
|
|
629
|
+
foreignNullifier: ForeignCallSingle,
|
|
630
|
+
) {
|
|
588
631
|
const blockHash = new BlockHash(fromSingle(foreignBlockHash));
|
|
589
632
|
const nullifier = fromSingle(foreignNullifier);
|
|
590
633
|
|
|
591
|
-
const witness = await this.handlerAsUtility().
|
|
634
|
+
const witness = await this.handlerAsUtility().getNullifierMembershipWitness(blockHash, nullifier);
|
|
592
635
|
|
|
593
636
|
if (!witness) {
|
|
594
637
|
throw new Error(`Nullifier membership witness not found at block ${blockHash}.`);
|
|
@@ -596,10 +639,11 @@ export class RPCTranslator {
|
|
|
596
639
|
return toForeignCallResult(witness.toNoirRepresentation());
|
|
597
640
|
}
|
|
598
641
|
|
|
599
|
-
|
|
642
|
+
// eslint-disable-next-line camelcase
|
|
643
|
+
async aztec_utl_getAuthWitness(foreignMessageHash: ForeignCallSingle) {
|
|
600
644
|
const messageHash = fromSingle(foreignMessageHash);
|
|
601
645
|
|
|
602
|
-
const authWitness = await this.handlerAsUtility().
|
|
646
|
+
const authWitness = await this.handlerAsUtility().getAuthWitness(messageHash);
|
|
603
647
|
|
|
604
648
|
if (!authWitness) {
|
|
605
649
|
throw new Error(`Auth witness not found for message hash ${messageHash}.`);
|
|
@@ -607,44 +651,35 @@ export class RPCTranslator {
|
|
|
607
651
|
return toForeignCallResult([toArray(authWitness)]);
|
|
608
652
|
}
|
|
609
653
|
|
|
610
|
-
|
|
611
|
-
|
|
612
|
-
_foreignCalldataHash: ForeignCallSingle,
|
|
613
|
-
_foreignSideEffectCounter: ForeignCallSingle,
|
|
614
|
-
_foreignIsStaticCall: ForeignCallSingle,
|
|
615
|
-
) {
|
|
616
|
-
throw new Error('Enqueueing public calls is not supported in TestEnvironment::private_context');
|
|
617
|
-
}
|
|
618
|
-
|
|
619
|
-
public privateNotifySetPublicTeardownFunctionCall(
|
|
620
|
-
_foreignTargetContractAddress: ForeignCallSingle,
|
|
621
|
-
_foreignCalldataHash: ForeignCallSingle,
|
|
622
|
-
_foreignSideEffectCounter: ForeignCallSingle,
|
|
623
|
-
_foreignIsStaticCall: ForeignCallSingle,
|
|
624
|
-
) {
|
|
654
|
+
// eslint-disable-next-line camelcase
|
|
655
|
+
public aztec_prv_validatePublicCalldata(_foreignCalldataHash: ForeignCallSingle) {
|
|
625
656
|
throw new Error('Enqueueing public calls is not supported in TestEnvironment::private_context');
|
|
626
657
|
}
|
|
627
658
|
|
|
628
|
-
|
|
659
|
+
// eslint-disable-next-line camelcase
|
|
660
|
+
public aztec_prv_notifyRevertiblePhaseStart(_foreignMinRevertibleSideEffectCounter: ForeignCallSingle) {
|
|
629
661
|
throw new Error('Enqueueing public calls is not supported in TestEnvironment::private_context');
|
|
630
662
|
}
|
|
631
663
|
|
|
632
|
-
|
|
664
|
+
// eslint-disable-next-line camelcase
|
|
665
|
+
public async aztec_prv_inRevertiblePhase(foreignSideEffectCounter: ForeignCallSingle) {
|
|
633
666
|
const sideEffectCounter = fromSingle(foreignSideEffectCounter).toNumber();
|
|
634
|
-
const isRevertible = await this.handlerAsPrivate().
|
|
667
|
+
const isRevertible = await this.handlerAsPrivate().inRevertiblePhase(sideEffectCounter);
|
|
635
668
|
return toForeignCallResult([toSingle(new Fr(isRevertible))]);
|
|
636
669
|
}
|
|
637
670
|
|
|
638
|
-
|
|
639
|
-
|
|
671
|
+
// eslint-disable-next-line camelcase
|
|
672
|
+
aztec_utl_getUtilityContext() {
|
|
673
|
+
const context = this.handlerAsUtility().getUtilityContext();
|
|
640
674
|
|
|
641
675
|
return toForeignCallResult(context.toNoirRepresentation());
|
|
642
676
|
}
|
|
643
677
|
|
|
644
|
-
|
|
678
|
+
// eslint-disable-next-line camelcase
|
|
679
|
+
async aztec_utl_getBlockHeader(foreignBlockNumber: ForeignCallSingle) {
|
|
645
680
|
const blockNumber = BlockNumber(fromSingle(foreignBlockNumber).toNumber());
|
|
646
681
|
|
|
647
|
-
const header = await this.handlerAsUtility().
|
|
682
|
+
const header = await this.handlerAsUtility().getBlockHeader(blockNumber);
|
|
648
683
|
|
|
649
684
|
if (!header) {
|
|
650
685
|
throw new Error(`Block header not found for block ${blockNumber}.`);
|
|
@@ -652,14 +687,15 @@ export class RPCTranslator {
|
|
|
652
687
|
return toForeignCallResult(header.toFields().map(toSingle));
|
|
653
688
|
}
|
|
654
689
|
|
|
655
|
-
|
|
690
|
+
// eslint-disable-next-line camelcase
|
|
691
|
+
async aztec_utl_getNoteHashMembershipWitness(
|
|
656
692
|
foreignAnchorBlockHash: ForeignCallSingle,
|
|
657
693
|
foreignNoteHash: ForeignCallSingle,
|
|
658
694
|
) {
|
|
659
695
|
const blockHash = new BlockHash(fromSingle(foreignAnchorBlockHash));
|
|
660
696
|
const noteHash = fromSingle(foreignNoteHash);
|
|
661
697
|
|
|
662
|
-
const witness = await this.handlerAsUtility().
|
|
698
|
+
const witness = await this.handlerAsUtility().getNoteHashMembershipWitness(blockHash, noteHash);
|
|
663
699
|
|
|
664
700
|
if (!witness) {
|
|
665
701
|
throw new Error(`Note hash ${noteHash} not found in the note hash tree at block ${blockHash.toString()}.`);
|
|
@@ -667,14 +703,15 @@ export class RPCTranslator {
|
|
|
667
703
|
return toForeignCallResult(witness.toNoirRepresentation());
|
|
668
704
|
}
|
|
669
705
|
|
|
670
|
-
|
|
706
|
+
// eslint-disable-next-line camelcase
|
|
707
|
+
async aztec_utl_getBlockHashMembershipWitness(
|
|
671
708
|
foreignAnchorBlockHash: ForeignCallSingle,
|
|
672
709
|
foreignBlockHash: ForeignCallSingle,
|
|
673
710
|
) {
|
|
674
711
|
const anchorBlockHash = new BlockHash(fromSingle(foreignAnchorBlockHash));
|
|
675
712
|
const blockHash = new BlockHash(fromSingle(foreignBlockHash));
|
|
676
713
|
|
|
677
|
-
const witness = await this.handlerAsUtility().
|
|
714
|
+
const witness = await this.handlerAsUtility().getBlockHashMembershipWitness(anchorBlockHash, blockHash);
|
|
678
715
|
|
|
679
716
|
if (!witness) {
|
|
680
717
|
throw new Error(
|
|
@@ -684,14 +721,15 @@ export class RPCTranslator {
|
|
|
684
721
|
return toForeignCallResult(witness.toNoirRepresentation());
|
|
685
722
|
}
|
|
686
723
|
|
|
687
|
-
|
|
724
|
+
// eslint-disable-next-line camelcase
|
|
725
|
+
async aztec_utl_getLowNullifierMembershipWitness(
|
|
688
726
|
foreignBlockHash: ForeignCallSingle,
|
|
689
727
|
foreignNullifier: ForeignCallSingle,
|
|
690
728
|
) {
|
|
691
729
|
const blockHash = new BlockHash(fromSingle(foreignBlockHash));
|
|
692
730
|
const nullifier = fromSingle(foreignNullifier);
|
|
693
731
|
|
|
694
|
-
const witness = await this.handlerAsUtility().
|
|
732
|
+
const witness = await this.handlerAsUtility().getLowNullifierMembershipWitness(blockHash, nullifier);
|
|
695
733
|
|
|
696
734
|
if (!witness) {
|
|
697
735
|
throw new Error(`Low nullifier witness not found for nullifier ${nullifier} at block ${blockHash}.`);
|
|
@@ -699,33 +737,42 @@ export class RPCTranslator {
|
|
|
699
737
|
return toForeignCallResult(witness.toNoirRepresentation());
|
|
700
738
|
}
|
|
701
739
|
|
|
702
|
-
|
|
740
|
+
// eslint-disable-next-line camelcase
|
|
741
|
+
async aztec_utl_fetchTaggedLogs(foreignPendingTaggedLogArrayBaseSlot: ForeignCallSingle) {
|
|
703
742
|
const pendingTaggedLogArrayBaseSlot = fromSingle(foreignPendingTaggedLogArrayBaseSlot);
|
|
704
743
|
|
|
705
|
-
await this.handlerAsUtility().
|
|
744
|
+
await this.handlerAsUtility().fetchTaggedLogs(pendingTaggedLogArrayBaseSlot);
|
|
706
745
|
|
|
707
746
|
return toForeignCallResult([]);
|
|
708
747
|
}
|
|
709
748
|
|
|
710
|
-
|
|
749
|
+
// eslint-disable-next-line camelcase
|
|
750
|
+
public async aztec_utl_validateAndStoreEnqueuedNotesAndEvents(
|
|
711
751
|
foreignContractAddress: ForeignCallSingle,
|
|
712
752
|
foreignNoteValidationRequestsArrayBaseSlot: ForeignCallSingle,
|
|
713
753
|
foreignEventValidationRequestsArrayBaseSlot: ForeignCallSingle,
|
|
754
|
+
foreignMaxNotePackedLen: ForeignCallSingle,
|
|
755
|
+
foreignMaxEventSerializedLen: ForeignCallSingle,
|
|
714
756
|
) {
|
|
715
757
|
const contractAddress = AztecAddress.fromField(fromSingle(foreignContractAddress));
|
|
716
758
|
const noteValidationRequestsArrayBaseSlot = fromSingle(foreignNoteValidationRequestsArrayBaseSlot);
|
|
717
759
|
const eventValidationRequestsArrayBaseSlot = fromSingle(foreignEventValidationRequestsArrayBaseSlot);
|
|
760
|
+
const maxNotePackedLen = fromSingle(foreignMaxNotePackedLen).toNumber();
|
|
761
|
+
const maxEventSerializedLen = fromSingle(foreignMaxEventSerializedLen).toNumber();
|
|
718
762
|
|
|
719
|
-
await this.handlerAsUtility().
|
|
763
|
+
await this.handlerAsUtility().validateAndStoreEnqueuedNotesAndEvents(
|
|
720
764
|
contractAddress,
|
|
721
765
|
noteValidationRequestsArrayBaseSlot,
|
|
722
766
|
eventValidationRequestsArrayBaseSlot,
|
|
767
|
+
maxNotePackedLen,
|
|
768
|
+
maxEventSerializedLen,
|
|
723
769
|
);
|
|
724
770
|
|
|
725
771
|
return toForeignCallResult([]);
|
|
726
772
|
}
|
|
727
773
|
|
|
728
|
-
|
|
774
|
+
// eslint-disable-next-line camelcase
|
|
775
|
+
public async aztec_utl_bulkRetrieveLogs(
|
|
729
776
|
foreignContractAddress: ForeignCallSingle,
|
|
730
777
|
foreignLogRetrievalRequestsArrayBaseSlot: ForeignCallSingle,
|
|
731
778
|
foreignLogRetrievalResponsesArrayBaseSlot: ForeignCallSingle,
|
|
@@ -734,7 +781,7 @@ export class RPCTranslator {
|
|
|
734
781
|
const logRetrievalRequestsArrayBaseSlot = fromSingle(foreignLogRetrievalRequestsArrayBaseSlot);
|
|
735
782
|
const logRetrievalResponsesArrayBaseSlot = fromSingle(foreignLogRetrievalResponsesArrayBaseSlot);
|
|
736
783
|
|
|
737
|
-
await this.handlerAsUtility().
|
|
784
|
+
await this.handlerAsUtility().bulkRetrieveLogs(
|
|
738
785
|
contractAddress,
|
|
739
786
|
logRetrievalRequestsArrayBaseSlot,
|
|
740
787
|
logRetrievalResponsesArrayBaseSlot,
|
|
@@ -743,7 +790,27 @@ export class RPCTranslator {
|
|
|
743
790
|
return toForeignCallResult([]);
|
|
744
791
|
}
|
|
745
792
|
|
|
746
|
-
|
|
793
|
+
// eslint-disable-next-line camelcase
|
|
794
|
+
public async aztec_utl_utilityResolveMessageContexts(
|
|
795
|
+
foreignContractAddress: ForeignCallSingle,
|
|
796
|
+
foreignMessageContextRequestsArrayBaseSlot: ForeignCallSingle,
|
|
797
|
+
foreignMessageContextResponsesArrayBaseSlot: ForeignCallSingle,
|
|
798
|
+
) {
|
|
799
|
+
const contractAddress = AztecAddress.fromField(fromSingle(foreignContractAddress));
|
|
800
|
+
const messageContextRequestsArrayBaseSlot = fromSingle(foreignMessageContextRequestsArrayBaseSlot);
|
|
801
|
+
const messageContextResponsesArrayBaseSlot = fromSingle(foreignMessageContextResponsesArrayBaseSlot);
|
|
802
|
+
|
|
803
|
+
await this.handlerAsUtility().utilityResolveMessageContexts(
|
|
804
|
+
contractAddress,
|
|
805
|
+
messageContextRequestsArrayBaseSlot,
|
|
806
|
+
messageContextResponsesArrayBaseSlot,
|
|
807
|
+
);
|
|
808
|
+
|
|
809
|
+
return toForeignCallResult([]);
|
|
810
|
+
}
|
|
811
|
+
|
|
812
|
+
// eslint-disable-next-line camelcase
|
|
813
|
+
async aztec_utl_storeCapsule(
|
|
747
814
|
foreignContractAddress: ForeignCallSingle,
|
|
748
815
|
foreignSlot: ForeignCallSingle,
|
|
749
816
|
foreignCapsule: ForeignCallArray,
|
|
@@ -752,12 +819,13 @@ export class RPCTranslator {
|
|
|
752
819
|
const slot = fromSingle(foreignSlot);
|
|
753
820
|
const capsule = fromArray(foreignCapsule);
|
|
754
821
|
|
|
755
|
-
await this.handlerAsUtility().
|
|
822
|
+
await this.handlerAsUtility().storeCapsule(contractAddress, slot, capsule);
|
|
756
823
|
|
|
757
824
|
return toForeignCallResult([]);
|
|
758
825
|
}
|
|
759
826
|
|
|
760
|
-
|
|
827
|
+
// eslint-disable-next-line camelcase
|
|
828
|
+
async aztec_utl_loadCapsule(
|
|
761
829
|
foreignContractAddress: ForeignCallSingle,
|
|
762
830
|
foreignSlot: ForeignCallSingle,
|
|
763
831
|
foreignTSize: ForeignCallSingle,
|
|
@@ -766,7 +834,7 @@ export class RPCTranslator {
|
|
|
766
834
|
const slot = fromSingle(foreignSlot);
|
|
767
835
|
const tSize = fromSingle(foreignTSize).toNumber();
|
|
768
836
|
|
|
769
|
-
const values = await this.handlerAsUtility().
|
|
837
|
+
const values = await this.handlerAsUtility().loadCapsule(contractAddress, slot);
|
|
770
838
|
|
|
771
839
|
// We are going to return a Noir Option struct to represent the possibility of null values. Options are a struct
|
|
772
840
|
// with two fields: `some` (a boolean) and `value` (a field array in this case).
|
|
@@ -779,16 +847,18 @@ export class RPCTranslator {
|
|
|
779
847
|
}
|
|
780
848
|
}
|
|
781
849
|
|
|
782
|
-
|
|
850
|
+
// eslint-disable-next-line camelcase
|
|
851
|
+
async aztec_utl_deleteCapsule(foreignContractAddress: ForeignCallSingle, foreignSlot: ForeignCallSingle) {
|
|
783
852
|
const contractAddress = AztecAddress.fromField(fromSingle(foreignContractAddress));
|
|
784
853
|
const slot = fromSingle(foreignSlot);
|
|
785
854
|
|
|
786
|
-
await this.handlerAsUtility().
|
|
855
|
+
await this.handlerAsUtility().deleteCapsule(contractAddress, slot);
|
|
787
856
|
|
|
788
857
|
return toForeignCallResult([]);
|
|
789
858
|
}
|
|
790
859
|
|
|
791
|
-
|
|
860
|
+
// eslint-disable-next-line camelcase
|
|
861
|
+
async aztec_utl_copyCapsule(
|
|
792
862
|
foreignContractAddress: ForeignCallSingle,
|
|
793
863
|
foreignSrcSlot: ForeignCallSingle,
|
|
794
864
|
foreignDstSlot: ForeignCallSingle,
|
|
@@ -799,7 +869,7 @@ export class RPCTranslator {
|
|
|
799
869
|
const dstSlot = fromSingle(foreignDstSlot);
|
|
800
870
|
const numEntries = fromSingle(foreignNumEntries).toNumber();
|
|
801
871
|
|
|
802
|
-
await this.handlerAsUtility().
|
|
872
|
+
await this.handlerAsUtility().copyCapsule(contractAddress, srcSlot, dstSlot, numEntries);
|
|
803
873
|
|
|
804
874
|
return toForeignCallResult([]);
|
|
805
875
|
}
|
|
@@ -808,7 +878,8 @@ export class RPCTranslator {
|
|
|
808
878
|
// The compiler didn't throw an error, so it took me a while to learn of the existence of this file, and that I need
|
|
809
879
|
// to implement this function here. Isn't there a way to programmatically identify that this is missing, given the
|
|
810
880
|
// existence of a txe_oracle method?
|
|
811
|
-
|
|
881
|
+
// eslint-disable-next-line camelcase
|
|
882
|
+
async aztec_utl_aes128Decrypt(
|
|
812
883
|
foreignCiphertextBVecStorage: ForeignCallArray,
|
|
813
884
|
foreignCiphertextLength: ForeignCallSingle,
|
|
814
885
|
foreignIv: ForeignCallArray,
|
|
@@ -818,14 +889,15 @@ export class RPCTranslator {
|
|
|
818
889
|
const iv = fromUintArray(foreignIv, 8);
|
|
819
890
|
const symKey = fromUintArray(foreignSymKey, 8);
|
|
820
891
|
|
|
821
|
-
const plaintextBuffer = await this.handlerAsUtility().
|
|
892
|
+
const plaintextBuffer = await this.handlerAsUtility().aes128Decrypt(ciphertext, iv, symKey);
|
|
822
893
|
|
|
823
894
|
return toForeignCallResult(
|
|
824
895
|
arrayToBoundedVec(bufferToU8Array(plaintextBuffer), foreignCiphertextBVecStorage.length),
|
|
825
896
|
);
|
|
826
897
|
}
|
|
827
898
|
|
|
828
|
-
|
|
899
|
+
// eslint-disable-next-line camelcase
|
|
900
|
+
async aztec_utl_getSharedSecret(
|
|
829
901
|
foreignAddress: ForeignCallSingle,
|
|
830
902
|
foreignEphPKField0: ForeignCallSingle,
|
|
831
903
|
foreignEphPKField1: ForeignCallSingle,
|
|
@@ -838,44 +910,49 @@ export class RPCTranslator {
|
|
|
838
910
|
fromSingle(foreignEphPKField2),
|
|
839
911
|
]);
|
|
840
912
|
|
|
841
|
-
const secret = await this.handlerAsUtility().
|
|
913
|
+
const secret = await this.handlerAsUtility().getSharedSecret(address, ephPK);
|
|
842
914
|
|
|
843
915
|
return toForeignCallResult(secret.toFields().map(toSingle));
|
|
844
916
|
}
|
|
845
917
|
|
|
846
|
-
|
|
918
|
+
// eslint-disable-next-line camelcase
|
|
919
|
+
aztec_utl_emitOffchainEffect(_foreignData: ForeignCallArray) {
|
|
847
920
|
throw new Error('Offchain effects are not yet supported in the TestEnvironment');
|
|
848
921
|
}
|
|
849
922
|
|
|
850
923
|
// AVM opcodes
|
|
851
924
|
|
|
852
|
-
|
|
925
|
+
// eslint-disable-next-line camelcase
|
|
926
|
+
aztec_avm_emitPublicLog(_foreignMessage: ForeignCallArray) {
|
|
853
927
|
// TODO(#8811): Implement
|
|
854
928
|
return toForeignCallResult([]);
|
|
855
929
|
}
|
|
856
930
|
|
|
857
|
-
|
|
931
|
+
// eslint-disable-next-line camelcase
|
|
932
|
+
async aztec_avm_storageRead(foreignSlot: ForeignCallSingle, foreignContractAddress: ForeignCallSingle) {
|
|
858
933
|
const slot = fromSingle(foreignSlot);
|
|
859
934
|
const contractAddress = AztecAddress.fromField(fromSingle(foreignContractAddress));
|
|
860
935
|
|
|
861
|
-
const value = (await this.handlerAsAvm().
|
|
936
|
+
const value = (await this.handlerAsAvm().storageRead(slot, contractAddress)).value;
|
|
862
937
|
|
|
863
938
|
return toForeignCallResult([toSingle(new Fr(value))]);
|
|
864
939
|
}
|
|
865
940
|
|
|
866
|
-
|
|
941
|
+
// eslint-disable-next-line camelcase
|
|
942
|
+
async aztec_avm_storageWrite(foreignSlot: ForeignCallSingle, foreignValue: ForeignCallSingle) {
|
|
867
943
|
const slot = fromSingle(foreignSlot);
|
|
868
944
|
const value = fromSingle(foreignValue);
|
|
869
945
|
|
|
870
|
-
await this.handlerAsAvm().
|
|
946
|
+
await this.handlerAsAvm().storageWrite(slot, value);
|
|
871
947
|
|
|
872
948
|
return toForeignCallResult([]);
|
|
873
949
|
}
|
|
874
950
|
|
|
875
|
-
|
|
951
|
+
// eslint-disable-next-line camelcase
|
|
952
|
+
async aztec_avm_getContractInstanceDeployer(foreignAddress: ForeignCallSingle) {
|
|
876
953
|
const address = addressFromSingle(foreignAddress);
|
|
877
954
|
|
|
878
|
-
const instance = await this.handlerAsUtility().
|
|
955
|
+
const instance = await this.handlerAsUtility().getContractInstance(address);
|
|
879
956
|
|
|
880
957
|
return toForeignCallResult([
|
|
881
958
|
toSingle(instance.deployer),
|
|
@@ -884,10 +961,11 @@ export class RPCTranslator {
|
|
|
884
961
|
]);
|
|
885
962
|
}
|
|
886
963
|
|
|
887
|
-
|
|
964
|
+
// eslint-disable-next-line camelcase
|
|
965
|
+
async aztec_avm_getContractInstanceClassId(foreignAddress: ForeignCallSingle) {
|
|
888
966
|
const address = addressFromSingle(foreignAddress);
|
|
889
967
|
|
|
890
|
-
const instance = await this.handlerAsUtility().
|
|
968
|
+
const instance = await this.handlerAsUtility().getContractInstance(address);
|
|
891
969
|
|
|
892
970
|
return toForeignCallResult([
|
|
893
971
|
toSingle(instance.currentContractClassId),
|
|
@@ -896,10 +974,11 @@ export class RPCTranslator {
|
|
|
896
974
|
]);
|
|
897
975
|
}
|
|
898
976
|
|
|
899
|
-
|
|
977
|
+
// eslint-disable-next-line camelcase
|
|
978
|
+
async aztec_avm_getContractInstanceInitializationHash(foreignAddress: ForeignCallSingle) {
|
|
900
979
|
const address = addressFromSingle(foreignAddress);
|
|
901
980
|
|
|
902
|
-
const instance = await this.handlerAsUtility().
|
|
981
|
+
const instance = await this.handlerAsUtility().getContractInstance(address);
|
|
903
982
|
|
|
904
983
|
return toForeignCallResult([
|
|
905
984
|
toSingle(instance.initializationHash),
|
|
@@ -908,85 +987,98 @@ export class RPCTranslator {
|
|
|
908
987
|
]);
|
|
909
988
|
}
|
|
910
989
|
|
|
911
|
-
|
|
912
|
-
|
|
990
|
+
// eslint-disable-next-line camelcase
|
|
991
|
+
async aztec_avm_sender() {
|
|
992
|
+
const sender = await this.handlerAsAvm().sender();
|
|
913
993
|
|
|
914
994
|
return toForeignCallResult([toSingle(sender)]);
|
|
915
995
|
}
|
|
916
996
|
|
|
917
|
-
|
|
997
|
+
// eslint-disable-next-line camelcase
|
|
998
|
+
async aztec_avm_emitNullifier(foreignNullifier: ForeignCallSingle) {
|
|
918
999
|
const nullifier = fromSingle(foreignNullifier);
|
|
919
1000
|
|
|
920
|
-
await this.handlerAsAvm().
|
|
1001
|
+
await this.handlerAsAvm().emitNullifier(nullifier);
|
|
921
1002
|
|
|
922
1003
|
return toForeignCallResult([]);
|
|
923
1004
|
}
|
|
924
1005
|
|
|
925
|
-
|
|
1006
|
+
// eslint-disable-next-line camelcase
|
|
1007
|
+
async aztec_avm_emitNoteHash(foreignNoteHash: ForeignCallSingle) {
|
|
926
1008
|
const noteHash = fromSingle(foreignNoteHash);
|
|
927
1009
|
|
|
928
|
-
await this.handlerAsAvm().
|
|
1010
|
+
await this.handlerAsAvm().emitNoteHash(noteHash);
|
|
929
1011
|
|
|
930
1012
|
return toForeignCallResult([]);
|
|
931
1013
|
}
|
|
932
1014
|
|
|
933
|
-
|
|
1015
|
+
// eslint-disable-next-line camelcase
|
|
1016
|
+
async aztec_avm_nullifierExists(foreignSiloedNullifier: ForeignCallSingle) {
|
|
934
1017
|
const siloedNullifier = fromSingle(foreignSiloedNullifier);
|
|
935
1018
|
|
|
936
|
-
const exists = await this.handlerAsAvm().
|
|
1019
|
+
const exists = await this.handlerAsAvm().nullifierExists(siloedNullifier);
|
|
937
1020
|
|
|
938
1021
|
return toForeignCallResult([toSingle(new Fr(exists))]);
|
|
939
1022
|
}
|
|
940
1023
|
|
|
941
|
-
|
|
942
|
-
|
|
1024
|
+
// eslint-disable-next-line camelcase
|
|
1025
|
+
async aztec_avm_address() {
|
|
1026
|
+
const contractAddress = await this.handlerAsAvm().address();
|
|
943
1027
|
|
|
944
1028
|
return toForeignCallResult([toSingle(contractAddress.toField())]);
|
|
945
1029
|
}
|
|
946
1030
|
|
|
947
|
-
|
|
948
|
-
|
|
1031
|
+
// eslint-disable-next-line camelcase
|
|
1032
|
+
async aztec_avm_blockNumber() {
|
|
1033
|
+
const blockNumber = await this.handlerAsAvm().blockNumber();
|
|
949
1034
|
|
|
950
1035
|
return toForeignCallResult([toSingle(new Fr(blockNumber))]);
|
|
951
1036
|
}
|
|
952
1037
|
|
|
953
|
-
|
|
954
|
-
|
|
1038
|
+
// eslint-disable-next-line camelcase
|
|
1039
|
+
async aztec_avm_timestamp() {
|
|
1040
|
+
const timestamp = await this.handlerAsAvm().timestamp();
|
|
955
1041
|
|
|
956
1042
|
return toForeignCallResult([toSingle(new Fr(timestamp))]);
|
|
957
1043
|
}
|
|
958
1044
|
|
|
959
|
-
|
|
960
|
-
|
|
1045
|
+
// eslint-disable-next-line camelcase
|
|
1046
|
+
async aztec_avm_isStaticCall() {
|
|
1047
|
+
const isStaticCall = await this.handlerAsAvm().isStaticCall();
|
|
961
1048
|
|
|
962
1049
|
return toForeignCallResult([toSingle(new Fr(isStaticCall ? 1 : 0))]);
|
|
963
1050
|
}
|
|
964
1051
|
|
|
965
|
-
|
|
966
|
-
|
|
1052
|
+
// eslint-disable-next-line camelcase
|
|
1053
|
+
async aztec_avm_chainId() {
|
|
1054
|
+
const chainId = await this.handlerAsAvm().chainId();
|
|
967
1055
|
|
|
968
1056
|
return toForeignCallResult([toSingle(chainId)]);
|
|
969
1057
|
}
|
|
970
1058
|
|
|
971
|
-
|
|
972
|
-
|
|
1059
|
+
// eslint-disable-next-line camelcase
|
|
1060
|
+
async aztec_avm_version() {
|
|
1061
|
+
const version = await this.handlerAsAvm().version();
|
|
973
1062
|
|
|
974
1063
|
return toForeignCallResult([toSingle(version)]);
|
|
975
1064
|
}
|
|
976
1065
|
|
|
977
|
-
|
|
1066
|
+
// eslint-disable-next-line camelcase
|
|
1067
|
+
aztec_avm_returndataSize() {
|
|
978
1068
|
throw new Error(
|
|
979
1069
|
'Contract calls are forbidden inside a `TestEnvironment::public_context`, use `public_call` instead',
|
|
980
1070
|
);
|
|
981
1071
|
}
|
|
982
1072
|
|
|
983
|
-
|
|
1073
|
+
// eslint-disable-next-line camelcase
|
|
1074
|
+
aztec_avm_returndataCopy(_foreignRdOffset: ForeignCallSingle, _foreignCopySize: ForeignCallSingle) {
|
|
984
1075
|
throw new Error(
|
|
985
1076
|
'Contract calls are forbidden inside a `TestEnvironment::public_context`, use `public_call` instead',
|
|
986
1077
|
);
|
|
987
1078
|
}
|
|
988
1079
|
|
|
989
|
-
|
|
1080
|
+
// eslint-disable-next-line camelcase
|
|
1081
|
+
aztec_avm_call(
|
|
990
1082
|
_foreignL2Gas: ForeignCallSingle,
|
|
991
1083
|
_foreignDaGas: ForeignCallSingle,
|
|
992
1084
|
_foreignAddress: ForeignCallSingle,
|
|
@@ -998,7 +1090,8 @@ export class RPCTranslator {
|
|
|
998
1090
|
);
|
|
999
1091
|
}
|
|
1000
1092
|
|
|
1001
|
-
|
|
1093
|
+
// eslint-disable-next-line camelcase
|
|
1094
|
+
aztec_avm_staticCall(
|
|
1002
1095
|
_foreignL2Gas: ForeignCallSingle,
|
|
1003
1096
|
_foreignDaGas: ForeignCallSingle,
|
|
1004
1097
|
_foreignAddress: ForeignCallSingle,
|
|
@@ -1010,13 +1103,15 @@ export class RPCTranslator {
|
|
|
1010
1103
|
);
|
|
1011
1104
|
}
|
|
1012
1105
|
|
|
1013
|
-
|
|
1106
|
+
// eslint-disable-next-line camelcase
|
|
1107
|
+
aztec_avm_successCopy() {
|
|
1014
1108
|
throw new Error(
|
|
1015
1109
|
'Contract calls are forbidden inside a `TestEnvironment::public_context`, use `public_call` instead',
|
|
1016
1110
|
);
|
|
1017
1111
|
}
|
|
1018
1112
|
|
|
1019
|
-
|
|
1113
|
+
// eslint-disable-next-line camelcase
|
|
1114
|
+
async aztec_txe_privateCallNewFlow(
|
|
1020
1115
|
foreignFrom: ForeignCallSingle,
|
|
1021
1116
|
foreignTargetContractAddress: ForeignCallSingle,
|
|
1022
1117
|
foreignFunctionSelector: ForeignCallSingle,
|
|
@@ -1031,19 +1126,23 @@ export class RPCTranslator {
|
|
|
1031
1126
|
const argsHash = fromSingle(foreignArgsHash);
|
|
1032
1127
|
const isStaticCall = fromSingle(foreignIsStaticCall).toBool();
|
|
1033
1128
|
|
|
1034
|
-
const returnValues = await this.handlerAsTxe().
|
|
1129
|
+
const returnValues = await this.handlerAsTxe().privateCallNewFlow(
|
|
1035
1130
|
from,
|
|
1036
1131
|
targetContractAddress,
|
|
1037
1132
|
functionSelector,
|
|
1038
1133
|
args,
|
|
1039
1134
|
argsHash,
|
|
1040
1135
|
isStaticCall,
|
|
1136
|
+
this.stateHandler.getCurrentJob(),
|
|
1041
1137
|
);
|
|
1042
1138
|
|
|
1139
|
+
// TODO(F-335): Avoid doing the following call here.
|
|
1140
|
+
await this.stateHandler.cycleJob();
|
|
1043
1141
|
return toForeignCallResult([toArray(returnValues)]);
|
|
1044
1142
|
}
|
|
1045
1143
|
|
|
1046
|
-
|
|
1144
|
+
// eslint-disable-next-line camelcase
|
|
1145
|
+
async aztec_txe_executeUtilityFunction(
|
|
1047
1146
|
foreignTargetContractAddress: ForeignCallSingle,
|
|
1048
1147
|
foreignFunctionSelector: ForeignCallSingle,
|
|
1049
1148
|
foreignArgs: ForeignCallArray,
|
|
@@ -1052,16 +1151,20 @@ export class RPCTranslator {
|
|
|
1052
1151
|
const functionSelector = FunctionSelector.fromField(fromSingle(foreignFunctionSelector));
|
|
1053
1152
|
const args = fromArray(foreignArgs);
|
|
1054
1153
|
|
|
1055
|
-
const returnValues = await this.handlerAsTxe().
|
|
1154
|
+
const returnValues = await this.handlerAsTxe().executeUtilityFunction(
|
|
1056
1155
|
targetContractAddress,
|
|
1057
1156
|
functionSelector,
|
|
1058
1157
|
args,
|
|
1158
|
+
this.stateHandler.getCurrentJob(),
|
|
1059
1159
|
);
|
|
1060
1160
|
|
|
1161
|
+
// TODO(F-335): Avoid doing the following call here.
|
|
1162
|
+
await this.stateHandler.cycleJob();
|
|
1061
1163
|
return toForeignCallResult([toArray(returnValues)]);
|
|
1062
1164
|
}
|
|
1063
1165
|
|
|
1064
|
-
|
|
1166
|
+
// eslint-disable-next-line camelcase
|
|
1167
|
+
async aztec_txe_publicCallNewFlow(
|
|
1065
1168
|
foreignFrom: ForeignCallSingle,
|
|
1066
1169
|
foreignAddress: ForeignCallSingle,
|
|
1067
1170
|
foreignCalldata: ForeignCallArray,
|
|
@@ -1072,13 +1175,16 @@ export class RPCTranslator {
|
|
|
1072
1175
|
const calldata = fromArray(foreignCalldata);
|
|
1073
1176
|
const isStaticCall = fromSingle(foreignIsStaticCall).toBool();
|
|
1074
1177
|
|
|
1075
|
-
const returnValues = await this.handlerAsTxe().
|
|
1178
|
+
const returnValues = await this.handlerAsTxe().publicCallNewFlow(from, address, calldata, isStaticCall);
|
|
1076
1179
|
|
|
1180
|
+
// TODO(F-335): Avoid doing the following call here.
|
|
1181
|
+
await this.stateHandler.cycleJob();
|
|
1077
1182
|
return toForeignCallResult([toArray(returnValues)]);
|
|
1078
1183
|
}
|
|
1079
1184
|
|
|
1080
|
-
|
|
1081
|
-
|
|
1185
|
+
// eslint-disable-next-line camelcase
|
|
1186
|
+
async aztec_prv_getSenderForTags() {
|
|
1187
|
+
const sender = await this.handlerAsPrivate().getSenderForTags();
|
|
1082
1188
|
|
|
1083
1189
|
// Return a Noir Option struct with `some` and `value` fields
|
|
1084
1190
|
if (sender === undefined) {
|
|
@@ -1090,19 +1196,21 @@ export class RPCTranslator {
|
|
|
1090
1196
|
}
|
|
1091
1197
|
}
|
|
1092
1198
|
|
|
1093
|
-
|
|
1199
|
+
// eslint-disable-next-line camelcase
|
|
1200
|
+
async aztec_prv_setSenderForTags(foreignSenderForTags: ForeignCallSingle) {
|
|
1094
1201
|
const senderForTags = AztecAddress.fromField(fromSingle(foreignSenderForTags));
|
|
1095
1202
|
|
|
1096
|
-
await this.handlerAsPrivate().
|
|
1203
|
+
await this.handlerAsPrivate().setSenderForTags(senderForTags);
|
|
1097
1204
|
|
|
1098
1205
|
return toForeignCallResult([]);
|
|
1099
1206
|
}
|
|
1100
1207
|
|
|
1101
|
-
|
|
1208
|
+
// eslint-disable-next-line camelcase
|
|
1209
|
+
async aztec_prv_getNextAppTagAsSender(foreignSender: ForeignCallSingle, foreignRecipient: ForeignCallSingle) {
|
|
1102
1210
|
const sender = AztecAddress.fromField(fromSingle(foreignSender));
|
|
1103
1211
|
const recipient = AztecAddress.fromField(fromSingle(foreignRecipient));
|
|
1104
1212
|
|
|
1105
|
-
const nextAppTag = await this.handlerAsPrivate().
|
|
1213
|
+
const nextAppTag = await this.handlerAsPrivate().getNextAppTagAsSender(sender, recipient);
|
|
1106
1214
|
|
|
1107
1215
|
return toForeignCallResult([toSingle(nextAppTag.value)]);
|
|
1108
1216
|
}
|