@aztec/txe 4.1.2 → 4.2.0-aztecnr-rc.2
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 +8 -6
- package/dest/oracle/interfaces.d.ts +28 -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 -21
- package/dest/oracle/txe_oracle_top_level_context.d.ts.map +1 -1
- package/dest/oracle/txe_oracle_top_level_context.js +33 -27
- package/dest/rpc_translator.d.ts +87 -82
- package/dest/rpc_translator.d.ts.map +1 -1
- package/dest/rpc_translator.js +272 -151
- package/dest/state_machine/index.d.ts +6 -3
- package/dest/state_machine/index.d.ts.map +1 -1
- package/dest/state_machine/index.js +8 -4
- package/dest/state_machine/synchronizer.d.ts +5 -5
- package/dest/state_machine/synchronizer.d.ts.map +1 -1
- package/dest/state_machine/synchronizer.js +3 -3
- package/dest/txe_session.d.ts +4 -3
- package/dest/txe_session.d.ts.map +1 -1
- package/dest/txe_session.js +19 -10
- package/package.json +15 -15
- package/src/index.ts +8 -5
- package/src/oracle/interfaces.ts +27 -31
- package/src/oracle/txe_oracle_public_context.ts +12 -12
- package/src/oracle/txe_oracle_top_level_context.ts +34 -25
- package/src/rpc_translator.ts +316 -173
- package/src/state_machine/index.ts +8 -1
- package/src/state_machine/synchronizer.ts +4 -4
- package/src/txe_session.ts +24 -5
package/dest/rpc_translator.js
CHANGED
|
@@ -61,59 +61,69 @@ export class RPCTranslator {
|
|
|
61
61
|
return this.oracleHandler;
|
|
62
62
|
}
|
|
63
63
|
// TXE session state transition functions - these get handled by the state handler
|
|
64
|
-
|
|
64
|
+
// eslint-disable-next-line camelcase
|
|
65
|
+
async aztec_txe_setTopLevelTXEContext() {
|
|
65
66
|
await this.stateHandler.enterTopLevelState();
|
|
66
67
|
return toForeignCallResult([]);
|
|
67
68
|
}
|
|
68
|
-
|
|
69
|
+
// eslint-disable-next-line camelcase
|
|
70
|
+
async aztec_txe_setPrivateTXEContext(foreignContractAddressIsSome, foreignContractAddressValue, foreignAnchorBlockNumberIsSome, foreignAnchorBlockNumberValue) {
|
|
69
71
|
const contractAddress = fromSingle(foreignContractAddressIsSome).toBool() ? AztecAddress.fromField(fromSingle(foreignContractAddressValue)) : undefined;
|
|
70
72
|
const anchorBlockNumber = fromSingle(foreignAnchorBlockNumberIsSome).toBool() ? BlockNumber(fromSingle(foreignAnchorBlockNumberValue).toNumber()) : undefined;
|
|
71
73
|
const privateContextInputs = await this.stateHandler.enterPrivateState(contractAddress, anchorBlockNumber);
|
|
72
74
|
return toForeignCallResult(privateContextInputs.toFields().map(toSingle));
|
|
73
75
|
}
|
|
74
|
-
|
|
76
|
+
// eslint-disable-next-line camelcase
|
|
77
|
+
async aztec_txe_setPublicTXEContext(foreignContractAddressIsSome, foreignContractAddressValue) {
|
|
75
78
|
const contractAddress = fromSingle(foreignContractAddressIsSome).toBool() ? AztecAddress.fromField(fromSingle(foreignContractAddressValue)) : undefined;
|
|
76
79
|
await this.stateHandler.enterPublicState(contractAddress);
|
|
77
80
|
return toForeignCallResult([]);
|
|
78
81
|
}
|
|
79
|
-
|
|
82
|
+
// eslint-disable-next-line camelcase
|
|
83
|
+
async aztec_txe_setUtilityTXEContext(foreignContractAddressIsSome, foreignContractAddressValue) {
|
|
80
84
|
const contractAddress = fromSingle(foreignContractAddressIsSome).toBool() ? AztecAddress.fromField(fromSingle(foreignContractAddressValue)) : undefined;
|
|
81
85
|
await this.stateHandler.enterUtilityState(contractAddress);
|
|
82
86
|
return toForeignCallResult([]);
|
|
83
87
|
}
|
|
84
88
|
// Other oracles - these get handled by the oracle handler
|
|
85
89
|
// TXE-specific oracles
|
|
86
|
-
|
|
87
|
-
|
|
90
|
+
// eslint-disable-next-line camelcase
|
|
91
|
+
aztec_txe_getDefaultAddress() {
|
|
92
|
+
const defaultAddress = this.handlerAsTxe().getDefaultAddress();
|
|
88
93
|
return toForeignCallResult([
|
|
89
94
|
toSingle(defaultAddress)
|
|
90
95
|
]);
|
|
91
96
|
}
|
|
92
|
-
|
|
93
|
-
|
|
97
|
+
// eslint-disable-next-line camelcase
|
|
98
|
+
async aztec_txe_getNextBlockNumber() {
|
|
99
|
+
const nextBlockNumber = await this.handlerAsTxe().getNextBlockNumber();
|
|
94
100
|
return toForeignCallResult([
|
|
95
101
|
toSingle(nextBlockNumber)
|
|
96
102
|
]);
|
|
97
103
|
}
|
|
98
|
-
|
|
99
|
-
|
|
104
|
+
// eslint-disable-next-line camelcase
|
|
105
|
+
async aztec_txe_getNextBlockTimestamp() {
|
|
106
|
+
const nextBlockTimestamp = await this.handlerAsTxe().getNextBlockTimestamp();
|
|
100
107
|
return toForeignCallResult([
|
|
101
108
|
toSingle(nextBlockTimestamp)
|
|
102
109
|
]);
|
|
103
110
|
}
|
|
104
|
-
|
|
111
|
+
// eslint-disable-next-line camelcase
|
|
112
|
+
async aztec_txe_advanceBlocksBy(foreignBlocks) {
|
|
105
113
|
const blocks = fromSingle(foreignBlocks).toNumber();
|
|
106
|
-
await this.handlerAsTxe().
|
|
114
|
+
await this.handlerAsTxe().advanceBlocksBy(blocks);
|
|
107
115
|
return toForeignCallResult([]);
|
|
108
116
|
}
|
|
109
|
-
|
|
117
|
+
// eslint-disable-next-line camelcase
|
|
118
|
+
aztec_txe_advanceTimestampBy(foreignDuration) {
|
|
110
119
|
const duration = fromSingle(foreignDuration).toBigInt();
|
|
111
|
-
this.handlerAsTxe().
|
|
120
|
+
this.handlerAsTxe().advanceTimestampBy(duration);
|
|
112
121
|
return toForeignCallResult([]);
|
|
113
122
|
}
|
|
114
|
-
|
|
123
|
+
// eslint-disable-next-line camelcase
|
|
124
|
+
async aztec_txe_deploy(artifact, instance, foreignSecret) {
|
|
115
125
|
const secret = fromSingle(foreignSecret);
|
|
116
|
-
await this.handlerAsTxe().
|
|
126
|
+
await this.handlerAsTxe().deploy(artifact, instance, secret);
|
|
117
127
|
return toForeignCallResult([
|
|
118
128
|
toArray([
|
|
119
129
|
instance.salt,
|
|
@@ -124,55 +134,63 @@ export class RPCTranslator {
|
|
|
124
134
|
])
|
|
125
135
|
]);
|
|
126
136
|
}
|
|
127
|
-
|
|
137
|
+
// eslint-disable-next-line camelcase
|
|
138
|
+
async aztec_txe_createAccount(foreignSecret) {
|
|
128
139
|
const secret = fromSingle(foreignSecret);
|
|
129
|
-
const completeAddress = await this.handlerAsTxe().
|
|
140
|
+
const completeAddress = await this.handlerAsTxe().createAccount(secret);
|
|
130
141
|
return toForeignCallResult([
|
|
131
142
|
toSingle(completeAddress.address),
|
|
132
143
|
...completeAddress.publicKeys.toFields().map(toSingle)
|
|
133
144
|
]);
|
|
134
145
|
}
|
|
135
|
-
|
|
146
|
+
// eslint-disable-next-line camelcase
|
|
147
|
+
async aztec_txe_addAccount(artifact, instance, foreignSecret) {
|
|
136
148
|
const secret = fromSingle(foreignSecret);
|
|
137
|
-
const completeAddress = await this.handlerAsTxe().
|
|
149
|
+
const completeAddress = await this.handlerAsTxe().addAccount(artifact, instance, secret);
|
|
138
150
|
return toForeignCallResult([
|
|
139
151
|
toSingle(completeAddress.address),
|
|
140
152
|
...completeAddress.publicKeys.toFields().map(toSingle)
|
|
141
153
|
]);
|
|
142
154
|
}
|
|
143
|
-
|
|
155
|
+
// eslint-disable-next-line camelcase
|
|
156
|
+
async aztec_txe_addAuthWitness(foreignAddress, foreignMessageHash) {
|
|
144
157
|
const address = addressFromSingle(foreignAddress);
|
|
145
158
|
const messageHash = fromSingle(foreignMessageHash);
|
|
146
|
-
await this.handlerAsTxe().
|
|
159
|
+
await this.handlerAsTxe().addAuthWitness(address, messageHash);
|
|
147
160
|
return toForeignCallResult([]);
|
|
148
161
|
}
|
|
149
162
|
// PXE oracles
|
|
150
|
-
|
|
163
|
+
// eslint-disable-next-line camelcase
|
|
164
|
+
aztec_utl_assertCompatibleOracleVersion(foreignVersion) {
|
|
151
165
|
const version = fromSingle(foreignVersion).toNumber();
|
|
152
|
-
this.handlerAsMisc().
|
|
166
|
+
this.handlerAsMisc().assertCompatibleOracleVersion(version);
|
|
153
167
|
return toForeignCallResult([]);
|
|
154
168
|
}
|
|
155
|
-
|
|
156
|
-
|
|
169
|
+
// eslint-disable-next-line camelcase
|
|
170
|
+
aztec_utl_getRandomField() {
|
|
171
|
+
const randomField = this.handlerAsMisc().getRandomField();
|
|
157
172
|
return toForeignCallResult([
|
|
158
173
|
toSingle(randomField)
|
|
159
174
|
]);
|
|
160
175
|
}
|
|
161
|
-
|
|
162
|
-
|
|
176
|
+
// eslint-disable-next-line camelcase
|
|
177
|
+
async aztec_txe_getLastBlockTimestamp() {
|
|
178
|
+
const timestamp = await this.handlerAsTxe().getLastBlockTimestamp();
|
|
163
179
|
return toForeignCallResult([
|
|
164
180
|
toSingle(new Fr(timestamp))
|
|
165
181
|
]);
|
|
166
182
|
}
|
|
167
|
-
|
|
168
|
-
|
|
183
|
+
// eslint-disable-next-line camelcase
|
|
184
|
+
async aztec_txe_getLastTxEffects() {
|
|
185
|
+
const { txHash, noteHashes, nullifiers } = await this.handlerAsTxe().getLastTxEffects();
|
|
169
186
|
return toForeignCallResult([
|
|
170
187
|
toSingle(txHash.hash),
|
|
171
188
|
...arrayToBoundedVec(toArray(noteHashes), MAX_NOTE_HASHES_PER_TX),
|
|
172
189
|
...arrayToBoundedVec(toArray(nullifiers), MAX_NULLIFIERS_PER_TX)
|
|
173
190
|
]);
|
|
174
191
|
}
|
|
175
|
-
|
|
192
|
+
// eslint-disable-next-line camelcase
|
|
193
|
+
async aztec_txe_getPrivateEvents(foreignSelector, foreignContractAddress, foreignScope) {
|
|
176
194
|
const selector = EventSelector.fromField(fromSingle(foreignSelector));
|
|
177
195
|
const contractAddress = addressFromSingle(foreignContractAddress);
|
|
178
196
|
const scope = addressFromSingle(foreignScope);
|
|
@@ -182,7 +200,7 @@ export class RPCTranslator {
|
|
|
182
200
|
// We cycle job to commit the stores after the contract sync.
|
|
183
201
|
await this.stateHandler.cycleJob();
|
|
184
202
|
}
|
|
185
|
-
const events = await this.handlerAsTxe().
|
|
203
|
+
const events = await this.handlerAsTxe().getPrivateEvents(selector, contractAddress, scope);
|
|
186
204
|
if (events.length > MAX_PRIVATE_EVENTS_PER_TXE_QUERY) {
|
|
187
205
|
throw new Error(`Array of length ${events.length} larger than maxLen ${MAX_PRIVATE_EVENTS_PER_TXE_QUERY}`);
|
|
188
206
|
}
|
|
@@ -200,48 +218,54 @@ export class RPCTranslator {
|
|
|
200
218
|
toSingle(queryLength)
|
|
201
219
|
]);
|
|
202
220
|
}
|
|
203
|
-
|
|
221
|
+
// eslint-disable-next-line camelcase
|
|
222
|
+
aztec_prv_setHashPreimage(foreignValues, foreignHash) {
|
|
204
223
|
const values = fromArray(foreignValues);
|
|
205
224
|
const hash = fromSingle(foreignHash);
|
|
206
|
-
this.handlerAsPrivate().
|
|
225
|
+
this.handlerAsPrivate().setHashPreimage(values, hash);
|
|
207
226
|
return toForeignCallResult([]);
|
|
208
227
|
}
|
|
209
|
-
|
|
228
|
+
// eslint-disable-next-line camelcase
|
|
229
|
+
async aztec_prv_getHashPreimage(foreignHash) {
|
|
210
230
|
const hash = fromSingle(foreignHash);
|
|
211
|
-
const returns = await this.handlerAsPrivate().
|
|
231
|
+
const returns = await this.handlerAsPrivate().getHashPreimage(hash);
|
|
212
232
|
return toForeignCallResult([
|
|
213
233
|
toArray(returns)
|
|
214
234
|
]);
|
|
215
235
|
}
|
|
216
236
|
// When the argument is a slice, noir automatically adds a length field to oracle call.
|
|
217
237
|
// When the argument is an array, we add the field length manually to the signature.
|
|
218
|
-
|
|
238
|
+
// eslint-disable-next-line camelcase
|
|
239
|
+
async aztec_utl_log(foreignLevel, foreignMessage, _foreignLength, foreignFields) {
|
|
219
240
|
const level = fromSingle(foreignLevel).toNumber();
|
|
220
241
|
const message = fromArray(foreignMessage).map((field)=>String.fromCharCode(field.toNumber())).join('');
|
|
221
242
|
const fields = fromArray(foreignFields);
|
|
222
|
-
await this.handlerAsMisc().
|
|
243
|
+
await this.handlerAsMisc().log(level, message, fields);
|
|
223
244
|
return toForeignCallResult([]);
|
|
224
245
|
}
|
|
225
|
-
|
|
246
|
+
// eslint-disable-next-line camelcase
|
|
247
|
+
async aztec_utl_getFromPublicStorage(foreignBlockHash, foreignContractAddress, foreignStartStorageSlot, foreignNumberOfElements) {
|
|
226
248
|
const blockHash = new BlockHash(fromSingle(foreignBlockHash));
|
|
227
249
|
const contractAddress = addressFromSingle(foreignContractAddress);
|
|
228
250
|
const startStorageSlot = fromSingle(foreignStartStorageSlot);
|
|
229
251
|
const numberOfElements = fromSingle(foreignNumberOfElements).toNumber();
|
|
230
|
-
const values = await this.handlerAsUtility().
|
|
252
|
+
const values = await this.handlerAsUtility().getFromPublicStorage(blockHash, contractAddress, startStorageSlot, numberOfElements);
|
|
231
253
|
return toForeignCallResult([
|
|
232
254
|
toArray(values)
|
|
233
255
|
]);
|
|
234
256
|
}
|
|
235
|
-
|
|
257
|
+
// eslint-disable-next-line camelcase
|
|
258
|
+
async aztec_utl_getPublicDataWitness(foreignBlockHash, foreignLeafSlot) {
|
|
236
259
|
const blockHash = new BlockHash(fromSingle(foreignBlockHash));
|
|
237
260
|
const leafSlot = fromSingle(foreignLeafSlot);
|
|
238
|
-
const witness = await this.handlerAsUtility().
|
|
261
|
+
const witness = await this.handlerAsUtility().getPublicDataWitness(blockHash, leafSlot);
|
|
239
262
|
if (!witness) {
|
|
240
263
|
throw new Error(`Public data witness not found for slot ${leafSlot} at block ${blockHash.toString()}.`);
|
|
241
264
|
}
|
|
242
265
|
return toForeignCallResult(witness.toNoirRepresentation());
|
|
243
266
|
}
|
|
244
|
-
|
|
267
|
+
// eslint-disable-next-line camelcase
|
|
268
|
+
async aztec_utl_getNotes(foreignOwnerIsSome, foreignOwnerValue, foreignStorageSlot, foreignNumSelects, foreignSelectByIndexes, foreignSelectByOffsets, foreignSelectByLengths, foreignSelectValues, foreignSelectComparators, foreignSortByIndexes, foreignSortByOffsets, foreignSortByLengths, foreignSortOrder, foreignLimit, foreignOffset, foreignStatus, foreignMaxNotes, foreignPackedHintedNoteLength) {
|
|
245
269
|
// Parse Option<AztecAddress>: ownerIsSome is 0 for None, 1 for Some
|
|
246
270
|
const owner = fromSingle(foreignOwnerIsSome).toBool() ? AztecAddress.fromField(fromSingle(foreignOwnerValue)) : undefined;
|
|
247
271
|
const storageSlot = fromSingle(foreignStorageSlot);
|
|
@@ -260,7 +284,7 @@ export class RPCTranslator {
|
|
|
260
284
|
const status = fromSingle(foreignStatus).toNumber();
|
|
261
285
|
const maxNotes = fromSingle(foreignMaxNotes).toNumber();
|
|
262
286
|
const packedHintedNoteLength = fromSingle(foreignPackedHintedNoteLength).toNumber();
|
|
263
|
-
const noteDatas = await this.handlerAsUtility().
|
|
287
|
+
const noteDatas = await this.handlerAsUtility().getNotes(owner, storageSlot, numSelects, selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, limit, offset, status);
|
|
264
288
|
const returnDataAsArrayOfArrays = noteDatas.map((noteData)=>packAsHintedNote({
|
|
265
289
|
contractAddress: noteData.contractAddress,
|
|
266
290
|
owner: noteData.owner,
|
|
@@ -275,7 +299,8 @@ export class RPCTranslator {
|
|
|
275
299
|
// At last we convert the array of arrays to a bounded vec of arrays
|
|
276
300
|
return toForeignCallResult(arrayOfArraysToBoundedVecOfArrays(returnDataAsArrayOfForeignCallSingleArrays, maxNotes, packedHintedNoteLength));
|
|
277
301
|
}
|
|
278
|
-
|
|
302
|
+
// eslint-disable-next-line camelcase
|
|
303
|
+
aztec_prv_notifyCreatedNote(foreignOwner, foreignStorageSlot, foreignRandomness, foreignNoteTypeId, foreignNote, foreignNoteHash, foreignCounter) {
|
|
279
304
|
const owner = addressFromSingle(foreignOwner);
|
|
280
305
|
const storageSlot = fromSingle(foreignStorageSlot);
|
|
281
306
|
const randomness = fromSingle(foreignRandomness);
|
|
@@ -283,39 +308,44 @@ export class RPCTranslator {
|
|
|
283
308
|
const note = fromArray(foreignNote);
|
|
284
309
|
const noteHash = fromSingle(foreignNoteHash);
|
|
285
310
|
const counter = fromSingle(foreignCounter).toNumber();
|
|
286
|
-
this.handlerAsPrivate().
|
|
311
|
+
this.handlerAsPrivate().notifyCreatedNote(owner, storageSlot, randomness, noteTypeId, note, noteHash, counter);
|
|
287
312
|
return toForeignCallResult([]);
|
|
288
313
|
}
|
|
289
|
-
|
|
314
|
+
// eslint-disable-next-line camelcase
|
|
315
|
+
async aztec_prv_notifyNullifiedNote(foreignInnerNullifier, foreignNoteHash, foreignCounter) {
|
|
290
316
|
const innerNullifier = fromSingle(foreignInnerNullifier);
|
|
291
317
|
const noteHash = fromSingle(foreignNoteHash);
|
|
292
318
|
const counter = fromSingle(foreignCounter).toNumber();
|
|
293
|
-
await this.handlerAsPrivate().
|
|
319
|
+
await this.handlerAsPrivate().notifyNullifiedNote(innerNullifier, noteHash, counter);
|
|
294
320
|
return toForeignCallResult([]);
|
|
295
321
|
}
|
|
296
|
-
|
|
322
|
+
// eslint-disable-next-line camelcase
|
|
323
|
+
async aztec_prv_notifyCreatedNullifier(foreignInnerNullifier) {
|
|
297
324
|
const innerNullifier = fromSingle(foreignInnerNullifier);
|
|
298
|
-
await this.handlerAsPrivate().
|
|
325
|
+
await this.handlerAsPrivate().notifyCreatedNullifier(innerNullifier);
|
|
299
326
|
return toForeignCallResult([]);
|
|
300
327
|
}
|
|
301
|
-
|
|
328
|
+
// eslint-disable-next-line camelcase
|
|
329
|
+
async aztec_prv_isNullifierPending(foreignInnerNullifier, foreignContractAddress) {
|
|
302
330
|
const innerNullifier = fromSingle(foreignInnerNullifier);
|
|
303
331
|
const contractAddress = addressFromSingle(foreignContractAddress);
|
|
304
|
-
const isPending = await this.handlerAsPrivate().
|
|
332
|
+
const isPending = await this.handlerAsPrivate().isNullifierPending(innerNullifier, contractAddress);
|
|
305
333
|
return toForeignCallResult([
|
|
306
334
|
toSingle(new Fr(isPending))
|
|
307
335
|
]);
|
|
308
336
|
}
|
|
309
|
-
|
|
337
|
+
// eslint-disable-next-line camelcase
|
|
338
|
+
async aztec_utl_doesNullifierExist(foreignInnerNullifier) {
|
|
310
339
|
const innerNullifier = fromSingle(foreignInnerNullifier);
|
|
311
|
-
const exists = await this.handlerAsUtility().
|
|
340
|
+
const exists = await this.handlerAsUtility().doesNullifierExist(innerNullifier);
|
|
312
341
|
return toForeignCallResult([
|
|
313
342
|
toSingle(new Fr(exists))
|
|
314
343
|
]);
|
|
315
344
|
}
|
|
316
|
-
|
|
345
|
+
// eslint-disable-next-line camelcase
|
|
346
|
+
async aztec_utl_getContractInstance(foreignAddress) {
|
|
317
347
|
const address = addressFromSingle(foreignAddress);
|
|
318
|
-
const instance = await this.handlerAsUtility().
|
|
348
|
+
const instance = await this.handlerAsUtility().getContractInstance(address);
|
|
319
349
|
return toForeignCallResult([
|
|
320
350
|
instance.salt,
|
|
321
351
|
instance.deployer.toField(),
|
|
@@ -324,9 +354,10 @@ export class RPCTranslator {
|
|
|
324
354
|
...instance.publicKeys.toFields()
|
|
325
355
|
].map(toSingle));
|
|
326
356
|
}
|
|
327
|
-
|
|
357
|
+
// eslint-disable-next-line camelcase
|
|
358
|
+
async aztec_utl_getPublicKeysAndPartialAddress(foreignAddress) {
|
|
328
359
|
const address = addressFromSingle(foreignAddress);
|
|
329
|
-
const result = await this.handlerAsUtility().
|
|
360
|
+
const result = await this.handlerAsUtility().getPublicKeysAndPartialAddress(address);
|
|
330
361
|
// We are going to return a Noir Option struct to represent the possibility of null values. Options are a struct
|
|
331
362
|
// with two fields: `some` (a boolean) and `value` (a field array in this case).
|
|
332
363
|
if (result === undefined) {
|
|
@@ -346,26 +377,30 @@ export class RPCTranslator {
|
|
|
346
377
|
]);
|
|
347
378
|
}
|
|
348
379
|
}
|
|
349
|
-
|
|
380
|
+
// eslint-disable-next-line camelcase
|
|
381
|
+
async aztec_utl_getKeyValidationRequest(foreignPkMHash) {
|
|
350
382
|
const pkMHash = fromSingle(foreignPkMHash);
|
|
351
|
-
const keyValidationRequest = await this.handlerAsUtility().
|
|
383
|
+
const keyValidationRequest = await this.handlerAsUtility().getKeyValidationRequest(pkMHash);
|
|
352
384
|
return toForeignCallResult(keyValidationRequest.toFields().map(toSingle));
|
|
353
385
|
}
|
|
354
|
-
|
|
386
|
+
// eslint-disable-next-line camelcase
|
|
387
|
+
aztec_prv_callPrivateFunction(_foreignTargetContractAddress, _foreignFunctionSelector, _foreignArgsHash, _foreignSideEffectCounter, _foreignIsStaticCall) {
|
|
355
388
|
throw new Error('Contract calls are forbidden inside a `TestEnvironment::private_context`, use `private_call` instead');
|
|
356
389
|
}
|
|
357
|
-
|
|
390
|
+
// eslint-disable-next-line camelcase
|
|
391
|
+
async aztec_utl_getNullifierMembershipWitness(foreignBlockHash, foreignNullifier) {
|
|
358
392
|
const blockHash = new BlockHash(fromSingle(foreignBlockHash));
|
|
359
393
|
const nullifier = fromSingle(foreignNullifier);
|
|
360
|
-
const witness = await this.handlerAsUtility().
|
|
394
|
+
const witness = await this.handlerAsUtility().getNullifierMembershipWitness(blockHash, nullifier);
|
|
361
395
|
if (!witness) {
|
|
362
396
|
throw new Error(`Nullifier membership witness not found at block ${blockHash}.`);
|
|
363
397
|
}
|
|
364
398
|
return toForeignCallResult(witness.toNoirRepresentation());
|
|
365
399
|
}
|
|
366
|
-
|
|
400
|
+
// eslint-disable-next-line camelcase
|
|
401
|
+
async aztec_utl_getAuthWitness(foreignMessageHash) {
|
|
367
402
|
const messageHash = fromSingle(foreignMessageHash);
|
|
368
|
-
const authWitness = await this.handlerAsUtility().
|
|
403
|
+
const authWitness = await this.handlerAsUtility().getAuthWitness(messageHash);
|
|
369
404
|
if (!authWitness) {
|
|
370
405
|
throw new Error(`Auth witness not found for message hash ${messageHash}.`);
|
|
371
406
|
}
|
|
@@ -373,92 +408,118 @@ export class RPCTranslator {
|
|
|
373
408
|
toArray(authWitness)
|
|
374
409
|
]);
|
|
375
410
|
}
|
|
376
|
-
|
|
411
|
+
// eslint-disable-next-line camelcase
|
|
412
|
+
aztec_prv_assertValidPublicCalldata(_foreignCalldataHash) {
|
|
377
413
|
throw new Error('Enqueueing public calls is not supported in TestEnvironment::private_context');
|
|
378
414
|
}
|
|
379
|
-
|
|
415
|
+
// eslint-disable-next-line camelcase
|
|
416
|
+
aztec_prv_notifyRevertiblePhaseStart(_foreignMinRevertibleSideEffectCounter) {
|
|
380
417
|
throw new Error('Enqueueing public calls is not supported in TestEnvironment::private_context');
|
|
381
418
|
}
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
}
|
|
385
|
-
async privateIsSideEffectCounterRevertible(foreignSideEffectCounter) {
|
|
419
|
+
// eslint-disable-next-line camelcase
|
|
420
|
+
async aztec_prv_isExecutionInRevertiblePhase(foreignSideEffectCounter) {
|
|
386
421
|
const sideEffectCounter = fromSingle(foreignSideEffectCounter).toNumber();
|
|
387
|
-
const isRevertible = await this.handlerAsPrivate().
|
|
422
|
+
const isRevertible = await this.handlerAsPrivate().isExecutionInRevertiblePhase(sideEffectCounter);
|
|
388
423
|
return toForeignCallResult([
|
|
389
424
|
toSingle(new Fr(isRevertible))
|
|
390
425
|
]);
|
|
391
426
|
}
|
|
392
|
-
|
|
393
|
-
|
|
427
|
+
// eslint-disable-next-line camelcase
|
|
428
|
+
aztec_utl_getUtilityContext() {
|
|
429
|
+
const context = this.handlerAsUtility().getUtilityContext();
|
|
394
430
|
return toForeignCallResult(context.toNoirRepresentation());
|
|
395
431
|
}
|
|
396
|
-
|
|
432
|
+
// eslint-disable-next-line camelcase
|
|
433
|
+
async aztec_utl_getBlockHeader(foreignBlockNumber) {
|
|
397
434
|
const blockNumber = BlockNumber(fromSingle(foreignBlockNumber).toNumber());
|
|
398
|
-
const header = await this.handlerAsUtility().
|
|
435
|
+
const header = await this.handlerAsUtility().getBlockHeader(blockNumber);
|
|
399
436
|
if (!header) {
|
|
400
437
|
throw new Error(`Block header not found for block ${blockNumber}.`);
|
|
401
438
|
}
|
|
402
439
|
return toForeignCallResult(header.toFields().map(toSingle));
|
|
403
440
|
}
|
|
404
|
-
|
|
441
|
+
// eslint-disable-next-line camelcase
|
|
442
|
+
async aztec_utl_getNoteHashMembershipWitness(foreignAnchorBlockHash, foreignNoteHash) {
|
|
405
443
|
const blockHash = new BlockHash(fromSingle(foreignAnchorBlockHash));
|
|
406
444
|
const noteHash = fromSingle(foreignNoteHash);
|
|
407
|
-
const witness = await this.handlerAsUtility().
|
|
445
|
+
const witness = await this.handlerAsUtility().getNoteHashMembershipWitness(blockHash, noteHash);
|
|
408
446
|
if (!witness) {
|
|
409
447
|
throw new Error(`Note hash ${noteHash} not found in the note hash tree at block ${blockHash.toString()}.`);
|
|
410
448
|
}
|
|
411
449
|
return toForeignCallResult(witness.toNoirRepresentation());
|
|
412
450
|
}
|
|
413
|
-
|
|
451
|
+
// eslint-disable-next-line camelcase
|
|
452
|
+
async aztec_utl_getBlockHashMembershipWitness(foreignAnchorBlockHash, foreignBlockHash) {
|
|
414
453
|
const anchorBlockHash = new BlockHash(fromSingle(foreignAnchorBlockHash));
|
|
415
454
|
const blockHash = new BlockHash(fromSingle(foreignBlockHash));
|
|
416
|
-
const witness = await this.handlerAsUtility().
|
|
455
|
+
const witness = await this.handlerAsUtility().getBlockHashMembershipWitness(anchorBlockHash, blockHash);
|
|
417
456
|
if (!witness) {
|
|
418
457
|
throw new Error(`Block hash ${blockHash.toString()} not found in the archive tree at anchor block ${anchorBlockHash.toString()}.`);
|
|
419
458
|
}
|
|
420
459
|
return toForeignCallResult(witness.toNoirRepresentation());
|
|
421
460
|
}
|
|
422
|
-
|
|
461
|
+
// eslint-disable-next-line camelcase
|
|
462
|
+
async aztec_utl_getLowNullifierMembershipWitness(foreignBlockHash, foreignNullifier) {
|
|
423
463
|
const blockHash = new BlockHash(fromSingle(foreignBlockHash));
|
|
424
464
|
const nullifier = fromSingle(foreignNullifier);
|
|
425
|
-
const witness = await this.handlerAsUtility().
|
|
465
|
+
const witness = await this.handlerAsUtility().getLowNullifierMembershipWitness(blockHash, nullifier);
|
|
426
466
|
if (!witness) {
|
|
427
467
|
throw new Error(`Low nullifier witness not found for nullifier ${nullifier} at block ${blockHash}.`);
|
|
428
468
|
}
|
|
429
469
|
return toForeignCallResult(witness.toNoirRepresentation());
|
|
430
470
|
}
|
|
431
|
-
|
|
471
|
+
// eslint-disable-next-line camelcase
|
|
472
|
+
async aztec_utl_getPendingTaggedLogs(foreignPendingTaggedLogArrayBaseSlot, foreignScope) {
|
|
432
473
|
const pendingTaggedLogArrayBaseSlot = fromSingle(foreignPendingTaggedLogArrayBaseSlot);
|
|
433
|
-
|
|
474
|
+
const scope = AztecAddress.fromField(fromSingle(foreignScope));
|
|
475
|
+
await this.handlerAsUtility().getPendingTaggedLogs(pendingTaggedLogArrayBaseSlot, scope);
|
|
434
476
|
return toForeignCallResult([]);
|
|
435
477
|
}
|
|
436
|
-
|
|
478
|
+
// eslint-disable-next-line camelcase
|
|
479
|
+
async aztec_utl_validateAndStoreEnqueuedNotesAndEvents(foreignContractAddress, foreignNoteValidationRequestsArrayBaseSlot, foreignEventValidationRequestsArrayBaseSlot, foreignMaxNotePackedLen, foreignMaxEventSerializedLen, foreignScope) {
|
|
437
480
|
const contractAddress = AztecAddress.fromField(fromSingle(foreignContractAddress));
|
|
438
481
|
const noteValidationRequestsArrayBaseSlot = fromSingle(foreignNoteValidationRequestsArrayBaseSlot);
|
|
439
482
|
const eventValidationRequestsArrayBaseSlot = fromSingle(foreignEventValidationRequestsArrayBaseSlot);
|
|
440
|
-
|
|
483
|
+
const maxNotePackedLen = fromSingle(foreignMaxNotePackedLen).toNumber();
|
|
484
|
+
const maxEventSerializedLen = fromSingle(foreignMaxEventSerializedLen).toNumber();
|
|
485
|
+
const scope = AztecAddress.fromField(fromSingle(foreignScope));
|
|
486
|
+
await this.handlerAsUtility().validateAndStoreEnqueuedNotesAndEvents(contractAddress, noteValidationRequestsArrayBaseSlot, eventValidationRequestsArrayBaseSlot, maxNotePackedLen, maxEventSerializedLen, scope);
|
|
441
487
|
return toForeignCallResult([]);
|
|
442
488
|
}
|
|
443
|
-
|
|
489
|
+
// eslint-disable-next-line camelcase
|
|
490
|
+
async aztec_utl_getLogsByTag(foreignContractAddress, foreignLogRetrievalRequestsArrayBaseSlot, foreignLogRetrievalResponsesArrayBaseSlot, foreignScope) {
|
|
444
491
|
const contractAddress = AztecAddress.fromField(fromSingle(foreignContractAddress));
|
|
445
492
|
const logRetrievalRequestsArrayBaseSlot = fromSingle(foreignLogRetrievalRequestsArrayBaseSlot);
|
|
446
493
|
const logRetrievalResponsesArrayBaseSlot = fromSingle(foreignLogRetrievalResponsesArrayBaseSlot);
|
|
447
|
-
|
|
494
|
+
const scope = AztecAddress.fromField(fromSingle(foreignScope));
|
|
495
|
+
await this.handlerAsUtility().getLogsByTag(contractAddress, logRetrievalRequestsArrayBaseSlot, logRetrievalResponsesArrayBaseSlot, scope);
|
|
496
|
+
return toForeignCallResult([]);
|
|
497
|
+
}
|
|
498
|
+
// eslint-disable-next-line camelcase
|
|
499
|
+
async aztec_utl_getMessageContextsByTxHash(foreignContractAddress, foreignMessageContextRequestsArrayBaseSlot, foreignMessageContextResponsesArrayBaseSlot, foreignScope) {
|
|
500
|
+
const contractAddress = AztecAddress.fromField(fromSingle(foreignContractAddress));
|
|
501
|
+
const messageContextRequestsArrayBaseSlot = fromSingle(foreignMessageContextRequestsArrayBaseSlot);
|
|
502
|
+
const messageContextResponsesArrayBaseSlot = fromSingle(foreignMessageContextResponsesArrayBaseSlot);
|
|
503
|
+
const scope = AztecAddress.fromField(fromSingle(foreignScope));
|
|
504
|
+
await this.handlerAsUtility().getMessageContextsByTxHash(contractAddress, messageContextRequestsArrayBaseSlot, messageContextResponsesArrayBaseSlot, scope);
|
|
448
505
|
return toForeignCallResult([]);
|
|
449
506
|
}
|
|
450
|
-
|
|
507
|
+
// eslint-disable-next-line camelcase
|
|
508
|
+
aztec_utl_setCapsule(foreignContractAddress, foreignSlot, foreignCapsule, foreignScope) {
|
|
451
509
|
const contractAddress = AztecAddress.fromField(fromSingle(foreignContractAddress));
|
|
452
510
|
const slot = fromSingle(foreignSlot);
|
|
453
511
|
const capsule = fromArray(foreignCapsule);
|
|
454
|
-
|
|
512
|
+
const scope = AztecAddress.fromField(fromSingle(foreignScope));
|
|
513
|
+
this.handlerAsUtility().setCapsule(contractAddress, slot, capsule, scope);
|
|
455
514
|
return toForeignCallResult([]);
|
|
456
515
|
}
|
|
457
|
-
|
|
516
|
+
// eslint-disable-next-line camelcase
|
|
517
|
+
async aztec_utl_getCapsule(foreignContractAddress, foreignSlot, foreignTSize, foreignScope) {
|
|
458
518
|
const contractAddress = AztecAddress.fromField(fromSingle(foreignContractAddress));
|
|
459
519
|
const slot = fromSingle(foreignSlot);
|
|
460
520
|
const tSize = fromSingle(foreignTSize).toNumber();
|
|
461
|
-
const
|
|
521
|
+
const scope = AztecAddress.fromField(fromSingle(foreignScope));
|
|
522
|
+
const values = await this.handlerAsUtility().getCapsule(contractAddress, slot, scope);
|
|
462
523
|
// We are going to return a Noir Option struct to represent the possibility of null values. Options are a struct
|
|
463
524
|
// with two fields: `some` (a boolean) and `value` (a field array in this case).
|
|
464
525
|
if (values === null) {
|
|
@@ -475,203 +536,261 @@ export class RPCTranslator {
|
|
|
475
536
|
]);
|
|
476
537
|
}
|
|
477
538
|
}
|
|
478
|
-
|
|
539
|
+
// eslint-disable-next-line camelcase
|
|
540
|
+
aztec_utl_deleteCapsule(foreignContractAddress, foreignSlot, foreignScope) {
|
|
479
541
|
const contractAddress = AztecAddress.fromField(fromSingle(foreignContractAddress));
|
|
480
542
|
const slot = fromSingle(foreignSlot);
|
|
481
|
-
|
|
543
|
+
const scope = AztecAddress.fromField(fromSingle(foreignScope));
|
|
544
|
+
this.handlerAsUtility().deleteCapsule(contractAddress, slot, scope);
|
|
482
545
|
return toForeignCallResult([]);
|
|
483
546
|
}
|
|
484
|
-
|
|
547
|
+
// eslint-disable-next-line camelcase
|
|
548
|
+
async aztec_utl_copyCapsule(foreignContractAddress, foreignSrcSlot, foreignDstSlot, foreignNumEntries, foreignScope) {
|
|
485
549
|
const contractAddress = AztecAddress.fromField(fromSingle(foreignContractAddress));
|
|
486
550
|
const srcSlot = fromSingle(foreignSrcSlot);
|
|
487
551
|
const dstSlot = fromSingle(foreignDstSlot);
|
|
488
552
|
const numEntries = fromSingle(foreignNumEntries).toNumber();
|
|
489
|
-
|
|
553
|
+
const scope = AztecAddress.fromField(fromSingle(foreignScope));
|
|
554
|
+
await this.handlerAsUtility().copyCapsule(contractAddress, srcSlot, dstSlot, numEntries, scope);
|
|
490
555
|
return toForeignCallResult([]);
|
|
491
556
|
}
|
|
492
557
|
// TODO: I forgot to add a corresponding function here, when I introduced an oracle method to txe_oracle.ts.
|
|
493
558
|
// 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
|
|
494
559
|
// to implement this function here. Isn't there a way to programmatically identify that this is missing, given the
|
|
495
560
|
// existence of a txe_oracle method?
|
|
496
|
-
|
|
561
|
+
// eslint-disable-next-line camelcase
|
|
562
|
+
async aztec_utl_decryptAes128(foreignCiphertextBVecStorage, foreignCiphertextLength, foreignIv, foreignSymKey) {
|
|
497
563
|
const ciphertext = fromUintBoundedVec(foreignCiphertextBVecStorage, foreignCiphertextLength, 8);
|
|
498
564
|
const iv = fromUintArray(foreignIv, 8);
|
|
499
565
|
const symKey = fromUintArray(foreignSymKey, 8);
|
|
500
|
-
|
|
501
|
-
|
|
566
|
+
// Noir Option<BoundedVec> is encoded as [is_some: Field, storage: Field[], length: Field].
|
|
567
|
+
try {
|
|
568
|
+
const plaintextBuffer = await this.handlerAsUtility().decryptAes128(ciphertext, iv, symKey);
|
|
569
|
+
const [storage, length] = arrayToBoundedVec(bufferToU8Array(plaintextBuffer), foreignCiphertextBVecStorage.length);
|
|
570
|
+
return toForeignCallResult([
|
|
571
|
+
toSingle(new Fr(1)),
|
|
572
|
+
storage,
|
|
573
|
+
length
|
|
574
|
+
]);
|
|
575
|
+
} catch {
|
|
576
|
+
const zeroStorage = toArray(Array(foreignCiphertextBVecStorage.length).fill(new Fr(0)));
|
|
577
|
+
return toForeignCallResult([
|
|
578
|
+
toSingle(new Fr(0)),
|
|
579
|
+
zeroStorage,
|
|
580
|
+
toSingle(new Fr(0))
|
|
581
|
+
]);
|
|
582
|
+
}
|
|
502
583
|
}
|
|
503
|
-
|
|
584
|
+
// eslint-disable-next-line camelcase
|
|
585
|
+
async aztec_utl_getSharedSecret(foreignAddress, foreignEphPKField0, foreignEphPKField1, foreignEphPKField2, foreignContractAddress) {
|
|
504
586
|
const address = AztecAddress.fromField(fromSingle(foreignAddress));
|
|
505
587
|
const ephPK = Point.fromFields([
|
|
506
588
|
fromSingle(foreignEphPKField0),
|
|
507
589
|
fromSingle(foreignEphPKField1),
|
|
508
590
|
fromSingle(foreignEphPKField2)
|
|
509
591
|
]);
|
|
510
|
-
const
|
|
511
|
-
|
|
592
|
+
const contractAddress = AztecAddress.fromField(fromSingle(foreignContractAddress));
|
|
593
|
+
const secret = await this.handlerAsUtility().getSharedSecret(address, ephPK, contractAddress);
|
|
594
|
+
return toForeignCallResult([
|
|
595
|
+
toSingle(secret)
|
|
596
|
+
]);
|
|
597
|
+
}
|
|
598
|
+
// eslint-disable-next-line camelcase
|
|
599
|
+
aztec_utl_setContractSyncCacheInvalid(foreignContractAddress, foreignScopes, foreignScopeCount) {
|
|
600
|
+
const contractAddress = addressFromSingle(foreignContractAddress);
|
|
601
|
+
const count = fromSingle(foreignScopeCount).toNumber();
|
|
602
|
+
const scopes = fromArray(foreignScopes).slice(0, count).map((f)=>new AztecAddress(f));
|
|
603
|
+
this.handlerAsUtility().setContractSyncCacheInvalid(contractAddress, scopes);
|
|
604
|
+
return Promise.resolve(toForeignCallResult([]));
|
|
512
605
|
}
|
|
513
|
-
|
|
606
|
+
// eslint-disable-next-line camelcase
|
|
607
|
+
aztec_utl_emitOffchainEffect(_foreignData) {
|
|
514
608
|
throw new Error('Offchain effects are not yet supported in the TestEnvironment');
|
|
515
609
|
}
|
|
516
610
|
// AVM opcodes
|
|
517
|
-
|
|
611
|
+
// eslint-disable-next-line camelcase
|
|
612
|
+
aztec_avm_emitPublicLog(_foreignMessage) {
|
|
518
613
|
// TODO(#8811): Implement
|
|
519
614
|
return toForeignCallResult([]);
|
|
520
615
|
}
|
|
521
|
-
|
|
616
|
+
// eslint-disable-next-line camelcase
|
|
617
|
+
async aztec_avm_storageRead(foreignSlot, foreignContractAddress) {
|
|
522
618
|
const slot = fromSingle(foreignSlot);
|
|
523
619
|
const contractAddress = AztecAddress.fromField(fromSingle(foreignContractAddress));
|
|
524
|
-
const value = (await this.handlerAsAvm().
|
|
620
|
+
const value = (await this.handlerAsAvm().storageRead(slot, contractAddress)).value;
|
|
525
621
|
return toForeignCallResult([
|
|
526
622
|
toSingle(new Fr(value))
|
|
527
623
|
]);
|
|
528
624
|
}
|
|
529
|
-
|
|
625
|
+
// eslint-disable-next-line camelcase
|
|
626
|
+
async aztec_avm_storageWrite(foreignSlot, foreignValue) {
|
|
530
627
|
const slot = fromSingle(foreignSlot);
|
|
531
628
|
const value = fromSingle(foreignValue);
|
|
532
|
-
await this.handlerAsAvm().
|
|
629
|
+
await this.handlerAsAvm().storageWrite(slot, value);
|
|
533
630
|
return toForeignCallResult([]);
|
|
534
631
|
}
|
|
535
|
-
|
|
632
|
+
// eslint-disable-next-line camelcase
|
|
633
|
+
async aztec_avm_getContractInstanceDeployer(foreignAddress) {
|
|
536
634
|
const address = addressFromSingle(foreignAddress);
|
|
537
|
-
const instance = await this.handlerAsUtility().
|
|
635
|
+
const instance = await this.handlerAsUtility().getContractInstance(address);
|
|
538
636
|
return toForeignCallResult([
|
|
539
637
|
toSingle(instance.deployer),
|
|
540
638
|
// AVM requires an extra boolean indicating the instance was found
|
|
541
639
|
toSingle(new Fr(1))
|
|
542
640
|
]);
|
|
543
641
|
}
|
|
544
|
-
|
|
642
|
+
// eslint-disable-next-line camelcase
|
|
643
|
+
async aztec_avm_getContractInstanceClassId(foreignAddress) {
|
|
545
644
|
const address = addressFromSingle(foreignAddress);
|
|
546
|
-
const instance = await this.handlerAsUtility().
|
|
645
|
+
const instance = await this.handlerAsUtility().getContractInstance(address);
|
|
547
646
|
return toForeignCallResult([
|
|
548
647
|
toSingle(instance.currentContractClassId),
|
|
549
648
|
// AVM requires an extra boolean indicating the instance was found
|
|
550
649
|
toSingle(new Fr(1))
|
|
551
650
|
]);
|
|
552
651
|
}
|
|
553
|
-
|
|
652
|
+
// eslint-disable-next-line camelcase
|
|
653
|
+
async aztec_avm_getContractInstanceInitializationHash(foreignAddress) {
|
|
554
654
|
const address = addressFromSingle(foreignAddress);
|
|
555
|
-
const instance = await this.handlerAsUtility().
|
|
655
|
+
const instance = await this.handlerAsUtility().getContractInstance(address);
|
|
556
656
|
return toForeignCallResult([
|
|
557
657
|
toSingle(instance.initializationHash),
|
|
558
658
|
// AVM requires an extra boolean indicating the instance was found
|
|
559
659
|
toSingle(new Fr(1))
|
|
560
660
|
]);
|
|
561
661
|
}
|
|
562
|
-
|
|
563
|
-
|
|
662
|
+
// eslint-disable-next-line camelcase
|
|
663
|
+
async aztec_avm_sender() {
|
|
664
|
+
const sender = await this.handlerAsAvm().sender();
|
|
564
665
|
return toForeignCallResult([
|
|
565
666
|
toSingle(sender)
|
|
566
667
|
]);
|
|
567
668
|
}
|
|
568
|
-
|
|
669
|
+
// eslint-disable-next-line camelcase
|
|
670
|
+
async aztec_avm_emitNullifier(foreignNullifier) {
|
|
569
671
|
const nullifier = fromSingle(foreignNullifier);
|
|
570
|
-
await this.handlerAsAvm().
|
|
672
|
+
await this.handlerAsAvm().emitNullifier(nullifier);
|
|
571
673
|
return toForeignCallResult([]);
|
|
572
674
|
}
|
|
573
|
-
|
|
675
|
+
// eslint-disable-next-line camelcase
|
|
676
|
+
async aztec_avm_emitNoteHash(foreignNoteHash) {
|
|
574
677
|
const noteHash = fromSingle(foreignNoteHash);
|
|
575
|
-
await this.handlerAsAvm().
|
|
678
|
+
await this.handlerAsAvm().emitNoteHash(noteHash);
|
|
576
679
|
return toForeignCallResult([]);
|
|
577
680
|
}
|
|
578
|
-
|
|
681
|
+
// eslint-disable-next-line camelcase
|
|
682
|
+
async aztec_avm_nullifierExists(foreignSiloedNullifier) {
|
|
579
683
|
const siloedNullifier = fromSingle(foreignSiloedNullifier);
|
|
580
|
-
const exists = await this.handlerAsAvm().
|
|
684
|
+
const exists = await this.handlerAsAvm().nullifierExists(siloedNullifier);
|
|
581
685
|
return toForeignCallResult([
|
|
582
686
|
toSingle(new Fr(exists))
|
|
583
687
|
]);
|
|
584
688
|
}
|
|
585
|
-
|
|
586
|
-
|
|
689
|
+
// eslint-disable-next-line camelcase
|
|
690
|
+
async aztec_avm_address() {
|
|
691
|
+
const contractAddress = await this.handlerAsAvm().address();
|
|
587
692
|
return toForeignCallResult([
|
|
588
693
|
toSingle(contractAddress.toField())
|
|
589
694
|
]);
|
|
590
695
|
}
|
|
591
|
-
|
|
592
|
-
|
|
696
|
+
// eslint-disable-next-line camelcase
|
|
697
|
+
async aztec_avm_blockNumber() {
|
|
698
|
+
const blockNumber = await this.handlerAsAvm().blockNumber();
|
|
593
699
|
return toForeignCallResult([
|
|
594
700
|
toSingle(new Fr(blockNumber))
|
|
595
701
|
]);
|
|
596
702
|
}
|
|
597
|
-
|
|
598
|
-
|
|
703
|
+
// eslint-disable-next-line camelcase
|
|
704
|
+
async aztec_avm_timestamp() {
|
|
705
|
+
const timestamp = await this.handlerAsAvm().timestamp();
|
|
599
706
|
return toForeignCallResult([
|
|
600
707
|
toSingle(new Fr(timestamp))
|
|
601
708
|
]);
|
|
602
709
|
}
|
|
603
|
-
|
|
604
|
-
|
|
710
|
+
// eslint-disable-next-line camelcase
|
|
711
|
+
async aztec_avm_isStaticCall() {
|
|
712
|
+
const isStaticCall = await this.handlerAsAvm().isStaticCall();
|
|
605
713
|
return toForeignCallResult([
|
|
606
714
|
toSingle(new Fr(isStaticCall ? 1 : 0))
|
|
607
715
|
]);
|
|
608
716
|
}
|
|
609
|
-
|
|
610
|
-
|
|
717
|
+
// eslint-disable-next-line camelcase
|
|
718
|
+
async aztec_avm_chainId() {
|
|
719
|
+
const chainId = await this.handlerAsAvm().chainId();
|
|
611
720
|
return toForeignCallResult([
|
|
612
721
|
toSingle(chainId)
|
|
613
722
|
]);
|
|
614
723
|
}
|
|
615
|
-
|
|
616
|
-
|
|
724
|
+
// eslint-disable-next-line camelcase
|
|
725
|
+
async aztec_avm_version() {
|
|
726
|
+
const version = await this.handlerAsAvm().version();
|
|
617
727
|
return toForeignCallResult([
|
|
618
728
|
toSingle(version)
|
|
619
729
|
]);
|
|
620
730
|
}
|
|
621
|
-
|
|
731
|
+
// eslint-disable-next-line camelcase
|
|
732
|
+
aztec_avm_returndataSize() {
|
|
622
733
|
throw new Error('Contract calls are forbidden inside a `TestEnvironment::public_context`, use `public_call` instead');
|
|
623
734
|
}
|
|
624
|
-
|
|
735
|
+
// eslint-disable-next-line camelcase
|
|
736
|
+
aztec_avm_returndataCopy(_foreignRdOffset, _foreignCopySize) {
|
|
625
737
|
throw new Error('Contract calls are forbidden inside a `TestEnvironment::public_context`, use `public_call` instead');
|
|
626
738
|
}
|
|
627
|
-
|
|
739
|
+
// eslint-disable-next-line camelcase
|
|
740
|
+
aztec_avm_call(_foreignL2Gas, _foreignDaGas, _foreignAddress, _foreignLength, _foreignArgs) {
|
|
628
741
|
throw new Error('Contract calls are forbidden inside a `TestEnvironment::public_context`, use `public_call` instead');
|
|
629
742
|
}
|
|
630
|
-
|
|
743
|
+
// eslint-disable-next-line camelcase
|
|
744
|
+
aztec_avm_staticCall(_foreignL2Gas, _foreignDaGas, _foreignAddress, _foreignLength, _foreignArgs) {
|
|
631
745
|
throw new Error('Contract calls are forbidden inside a `TestEnvironment::public_context`, use `public_call` instead');
|
|
632
746
|
}
|
|
633
|
-
|
|
747
|
+
// eslint-disable-next-line camelcase
|
|
748
|
+
aztec_avm_successCopy() {
|
|
634
749
|
throw new Error('Contract calls are forbidden inside a `TestEnvironment::public_context`, use `public_call` instead');
|
|
635
750
|
}
|
|
636
|
-
|
|
751
|
+
// eslint-disable-next-line camelcase
|
|
752
|
+
async aztec_txe_privateCallNewFlow(foreignFrom, foreignTargetContractAddress, foreignFunctionSelector, foreignArgs, foreignArgsHash, foreignIsStaticCall) {
|
|
637
753
|
const from = addressFromSingle(foreignFrom);
|
|
638
754
|
const targetContractAddress = addressFromSingle(foreignTargetContractAddress);
|
|
639
755
|
const functionSelector = FunctionSelector.fromField(fromSingle(foreignFunctionSelector));
|
|
640
756
|
const args = fromArray(foreignArgs);
|
|
641
757
|
const argsHash = fromSingle(foreignArgsHash);
|
|
642
758
|
const isStaticCall = fromSingle(foreignIsStaticCall).toBool();
|
|
643
|
-
const returnValues = await this.handlerAsTxe().
|
|
759
|
+
const returnValues = await this.handlerAsTxe().privateCallNewFlow(from, targetContractAddress, functionSelector, args, argsHash, isStaticCall, this.stateHandler.getCurrentJob());
|
|
644
760
|
// TODO(F-335): Avoid doing the following call here.
|
|
645
761
|
await this.stateHandler.cycleJob();
|
|
646
762
|
return toForeignCallResult([
|
|
647
763
|
toArray(returnValues)
|
|
648
764
|
]);
|
|
649
765
|
}
|
|
650
|
-
|
|
766
|
+
// eslint-disable-next-line camelcase
|
|
767
|
+
async aztec_txe_executeUtilityFunction(foreignTargetContractAddress, foreignFunctionSelector, foreignArgs) {
|
|
651
768
|
const targetContractAddress = addressFromSingle(foreignTargetContractAddress);
|
|
652
769
|
const functionSelector = FunctionSelector.fromField(fromSingle(foreignFunctionSelector));
|
|
653
770
|
const args = fromArray(foreignArgs);
|
|
654
|
-
const returnValues = await this.handlerAsTxe().
|
|
771
|
+
const returnValues = await this.handlerAsTxe().executeUtilityFunction(targetContractAddress, functionSelector, args, this.stateHandler.getCurrentJob());
|
|
655
772
|
// TODO(F-335): Avoid doing the following call here.
|
|
656
773
|
await this.stateHandler.cycleJob();
|
|
657
774
|
return toForeignCallResult([
|
|
658
775
|
toArray(returnValues)
|
|
659
776
|
]);
|
|
660
777
|
}
|
|
661
|
-
|
|
778
|
+
// eslint-disable-next-line camelcase
|
|
779
|
+
async aztec_txe_publicCallNewFlow(foreignFrom, foreignAddress, foreignCalldata, foreignIsStaticCall) {
|
|
662
780
|
const from = addressFromSingle(foreignFrom);
|
|
663
781
|
const address = addressFromSingle(foreignAddress);
|
|
664
782
|
const calldata = fromArray(foreignCalldata);
|
|
665
783
|
const isStaticCall = fromSingle(foreignIsStaticCall).toBool();
|
|
666
|
-
const returnValues = await this.handlerAsTxe().
|
|
784
|
+
const returnValues = await this.handlerAsTxe().publicCallNewFlow(from, address, calldata, isStaticCall);
|
|
667
785
|
// TODO(F-335): Avoid doing the following call here.
|
|
668
786
|
await this.stateHandler.cycleJob();
|
|
669
787
|
return toForeignCallResult([
|
|
670
788
|
toArray(returnValues)
|
|
671
789
|
]);
|
|
672
790
|
}
|
|
673
|
-
|
|
674
|
-
|
|
791
|
+
// eslint-disable-next-line camelcase
|
|
792
|
+
async aztec_prv_getSenderForTags() {
|
|
793
|
+
const sender = await this.handlerAsPrivate().getSenderForTags();
|
|
675
794
|
// Return a Noir Option struct with `some` and `value` fields
|
|
676
795
|
if (sender === undefined) {
|
|
677
796
|
// No sender found, return Option with some=0 and value=0
|
|
@@ -687,15 +806,17 @@ export class RPCTranslator {
|
|
|
687
806
|
]);
|
|
688
807
|
}
|
|
689
808
|
}
|
|
690
|
-
|
|
809
|
+
// eslint-disable-next-line camelcase
|
|
810
|
+
async aztec_prv_setSenderForTags(foreignSenderForTags) {
|
|
691
811
|
const senderForTags = AztecAddress.fromField(fromSingle(foreignSenderForTags));
|
|
692
|
-
await this.handlerAsPrivate().
|
|
812
|
+
await this.handlerAsPrivate().setSenderForTags(senderForTags);
|
|
693
813
|
return toForeignCallResult([]);
|
|
694
814
|
}
|
|
695
|
-
|
|
815
|
+
// eslint-disable-next-line camelcase
|
|
816
|
+
async aztec_prv_getNextAppTagAsSender(foreignSender, foreignRecipient) {
|
|
696
817
|
const sender = AztecAddress.fromField(fromSingle(foreignSender));
|
|
697
818
|
const recipient = AztecAddress.fromField(fromSingle(foreignRecipient));
|
|
698
|
-
const nextAppTag = await this.handlerAsPrivate().
|
|
819
|
+
const nextAppTag = await this.handlerAsPrivate().getNextAppTagAsSender(sender, recipient);
|
|
699
820
|
return toForeignCallResult([
|
|
700
821
|
toSingle(nextAppTag.value)
|
|
701
822
|
]);
|