@aztec/pxe 0.0.1-commit.c949de6bc → 0.0.1-commit.cbf2c2d5d
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/config/index.d.ts +2 -2
- package/dest/config/index.d.ts.map +1 -1
- package/dest/config/index.js +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.d.ts +9 -3
- package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.js +28 -6
- package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +5 -5
- package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
- package/dest/contract_function_simulator/execution_tagging_index_cache.js +17 -9
- package/dest/contract_function_simulator/index.d.ts +2 -1
- package/dest/contract_function_simulator/index.d.ts.map +1 -1
- package/dest/contract_function_simulator/index.js +1 -0
- package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +2 -3
- package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts.map +1 -1
- package/dest/contract_function_simulator/noir-structs/event_validation_request.js +5 -4
- package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +1 -1
- package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts.map +1 -1
- package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +1 -3
- package/dest/contract_function_simulator/noir-structs/message_tx_context.d.ts +16 -0
- package/dest/contract_function_simulator/noir-structs/message_tx_context.d.ts.map +1 -0
- package/dest/contract_function_simulator/noir-structs/message_tx_context.js +57 -0
- package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +2 -4
- package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
- package/dest/contract_function_simulator/noir-structs/note_validation_request.js +3 -5
- package/dest/contract_function_simulator/oracle/interfaces.d.ts +50 -45
- package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts +9 -0
- package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts.map +1 -0
- package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.js +42 -0
- package/dest/contract_function_simulator/oracle/oracle.d.ts +45 -44
- package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/oracle.js +163 -94
- package/dest/contract_function_simulator/oracle/private_execution.js +5 -3
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +22 -47
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/private_execution_oracle.js +30 -62
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +53 -35
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +101 -43
- package/dest/contract_sync/contract_sync_service.d.ts +5 -3
- package/dest/contract_sync/contract_sync_service.d.ts.map +1 -1
- package/dest/contract_sync/contract_sync_service.js +47 -30
- package/dest/messages/message_context_service.d.ts +17 -0
- package/dest/messages/message_context_service.d.ts.map +1 -0
- package/dest/messages/message_context_service.js +36 -0
- package/dest/oracle_version.d.ts +2 -2
- package/dest/oracle_version.js +3 -3
- package/dest/pxe.d.ts +8 -4
- package/dest/pxe.d.ts.map +1 -1
- package/dest/pxe.js +39 -22
- package/dest/storage/metadata.d.ts +1 -1
- package/dest/storage/metadata.js +1 -1
- package/dest/storage/tagging_store/sender_tagging_store.d.ts +26 -25
- package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
- package/dest/storage/tagging_store/sender_tagging_store.js +141 -115
- package/dest/tagging/index.d.ts +2 -2
- package/dest/tagging/index.d.ts.map +1 -1
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +1 -1
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +10 -1
- package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +4 -3
- package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -1
- package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +20 -10
- package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +2 -1
- package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -1
- package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +24 -11
- package/package.json +16 -16
- package/src/config/index.ts +1 -1
- package/src/contract_function_simulator/contract_function_simulator.ts +39 -7
- package/src/contract_function_simulator/execution_tagging_index_cache.ts +16 -11
- package/src/contract_function_simulator/index.ts +1 -0
- package/src/contract_function_simulator/noir-structs/event_validation_request.ts +8 -5
- package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +1 -4
- package/src/contract_function_simulator/noir-structs/message_tx_context.ts +55 -0
- package/src/contract_function_simulator/noir-structs/note_validation_request.ts +3 -6
- package/src/contract_function_simulator/oracle/interfaces.ts +54 -54
- package/src/contract_function_simulator/oracle/legacy_oracle_mappings.ts +135 -0
- package/src/contract_function_simulator/oracle/oracle.ts +176 -138
- package/src/contract_function_simulator/oracle/private_execution.ts +4 -4
- package/src/contract_function_simulator/oracle/private_execution_oracle.ts +32 -80
- package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +136 -53
- package/src/contract_sync/contract_sync_service.ts +67 -38
- package/src/messages/message_context_service.ts +45 -0
- package/src/oracle_version.ts +3 -3
- package/src/pxe.ts +57 -21
- package/src/storage/metadata.ts +1 -1
- package/src/storage/tagging_store/sender_tagging_store.ts +182 -135
- package/src/tagging/index.ts +1 -1
- package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +19 -1
- package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +26 -11
- package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +19 -9
|
@@ -6,6 +6,7 @@ import { FunctionSelector, NoteSelector } from '@aztec/stdlib/abi';
|
|
|
6
6
|
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
7
7
|
import { BlockHash } from '@aztec/stdlib/block';
|
|
8
8
|
import { ContractClassLog, ContractClassLogFields } from '@aztec/stdlib/logs';
|
|
9
|
+
import { buildLegacyOracleCallbacks } from './legacy_oracle_mappings.js';
|
|
9
10
|
import { packAsHintedNote } from './note_packing_utils.js';
|
|
10
11
|
export class UnavailableOracleError extends Error {
|
|
11
12
|
constructor(oracleName){
|
|
@@ -48,11 +49,11 @@ export class UnavailableOracleError extends Error {
|
|
|
48
49
|
];
|
|
49
50
|
// Get all the oracle function names
|
|
50
51
|
const oracleNames = Object.getOwnPropertyNames(Oracle.prototype).filter((name)=>!excludedProps.includes(name));
|
|
51
|
-
// Validate oracle names - these must be prefixed with either "
|
|
52
|
+
// Validate oracle names - these must be prefixed with either "aztec_prv_" or "aztec_utl_" to indicate their scope
|
|
52
53
|
// and must correspond to a function on the Oracle class.
|
|
53
54
|
oracleNames.forEach((name)=>{
|
|
54
|
-
if (!name.startsWith('
|
|
55
|
-
throw new Error(`Oracle function "${name}" must be prefixed with either "
|
|
55
|
+
if (!name.startsWith('aztec_prv_') && !name.startsWith('aztec_utl_')) {
|
|
56
|
+
throw new Error(`Oracle function "${name}" must be prefixed with either "aztec_prv_" or "aztec_utl_" to indicate its scope`);
|
|
56
57
|
}
|
|
57
58
|
const method = this[name];
|
|
58
59
|
if (typeof method !== 'function') {
|
|
@@ -60,42 +61,53 @@ export class UnavailableOracleError extends Error {
|
|
|
60
61
|
}
|
|
61
62
|
});
|
|
62
63
|
// Build callback object and return it
|
|
63
|
-
|
|
64
|
+
const callback = oracleNames.reduce((acc, name)=>{
|
|
64
65
|
const method = this[name];
|
|
65
66
|
acc[name] = method.bind(this);
|
|
66
67
|
return acc;
|
|
67
68
|
}, {});
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
69
|
+
return {
|
|
70
|
+
...callback,
|
|
71
|
+
...buildLegacyOracleCallbacks(this)
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
// eslint-disable-next-line camelcase
|
|
75
|
+
aztec_utl_assertCompatibleOracleVersion([version]) {
|
|
76
|
+
this.handlerAsMisc().assertCompatibleOracleVersion(Fr.fromString(version).toNumber());
|
|
71
77
|
return Promise.resolve([]);
|
|
72
78
|
}
|
|
73
|
-
|
|
74
|
-
|
|
79
|
+
// eslint-disable-next-line camelcase
|
|
80
|
+
aztec_utl_getRandomField() {
|
|
81
|
+
const val = this.handlerAsMisc().getRandomField();
|
|
75
82
|
return Promise.resolve([
|
|
76
83
|
toACVMField(val)
|
|
77
84
|
]);
|
|
78
85
|
}
|
|
79
|
-
|
|
80
|
-
|
|
86
|
+
// eslint-disable-next-line camelcase
|
|
87
|
+
aztec_prv_storeInExecutionCache(values, [hash]) {
|
|
88
|
+
this.handlerAsPrivate().storeInExecutionCache(values.map(Fr.fromString), Fr.fromString(hash));
|
|
81
89
|
return Promise.resolve([]);
|
|
82
90
|
}
|
|
83
|
-
|
|
84
|
-
|
|
91
|
+
// eslint-disable-next-line camelcase
|
|
92
|
+
async aztec_prv_loadFromExecutionCache([returnsHash]) {
|
|
93
|
+
const values = await this.handlerAsPrivate().loadFromExecutionCache(Fr.fromString(returnsHash));
|
|
85
94
|
return [
|
|
86
95
|
values.map(toACVMField)
|
|
87
96
|
];
|
|
88
97
|
}
|
|
89
|
-
|
|
90
|
-
|
|
98
|
+
// eslint-disable-next-line camelcase
|
|
99
|
+
aztec_utl_getUtilityContext() {
|
|
100
|
+
const context = this.handlerAsUtility().getUtilityContext();
|
|
91
101
|
return Promise.resolve(context.toNoirRepresentation());
|
|
92
102
|
}
|
|
93
|
-
|
|
94
|
-
|
|
103
|
+
// eslint-disable-next-line camelcase
|
|
104
|
+
async aztec_utl_getKeyValidationRequest([pkMHash]) {
|
|
105
|
+
const keyValidationRequest = await this.handlerAsUtility().getKeyValidationRequest(Fr.fromString(pkMHash));
|
|
95
106
|
return keyValidationRequest.toFields().map(toACVMField);
|
|
96
107
|
}
|
|
97
|
-
|
|
98
|
-
|
|
108
|
+
// eslint-disable-next-line camelcase
|
|
109
|
+
async aztec_utl_getContractInstance([address]) {
|
|
110
|
+
const instance = await this.handlerAsUtility().getContractInstance(AztecAddress.fromField(Fr.fromString(address)));
|
|
99
111
|
return [
|
|
100
112
|
instance.salt,
|
|
101
113
|
instance.deployer,
|
|
@@ -104,62 +116,69 @@ export class UnavailableOracleError extends Error {
|
|
|
104
116
|
...instance.publicKeys.toFields()
|
|
105
117
|
].map(toACVMField);
|
|
106
118
|
}
|
|
107
|
-
|
|
119
|
+
// eslint-disable-next-line camelcase
|
|
120
|
+
async aztec_utl_getNoteHashMembershipWitness([anchorBlockHash], [noteHash]) {
|
|
108
121
|
const parsedAnchorBlockHash = BlockHash.fromString(anchorBlockHash);
|
|
109
122
|
const parsedNoteHash = Fr.fromString(noteHash);
|
|
110
|
-
const witness = await this.handlerAsUtility().
|
|
123
|
+
const witness = await this.handlerAsUtility().getNoteHashMembershipWitness(parsedAnchorBlockHash, parsedNoteHash);
|
|
111
124
|
if (!witness) {
|
|
112
125
|
throw new Error(`Note hash ${noteHash} not found in the note hash tree at anchor block hash ${parsedAnchorBlockHash.toString()}.`);
|
|
113
126
|
}
|
|
114
127
|
return witness.toNoirRepresentation();
|
|
115
128
|
}
|
|
116
|
-
|
|
129
|
+
// eslint-disable-next-line camelcase
|
|
130
|
+
async aztec_utl_getBlockHashMembershipWitness([anchorBlockHash], [blockHash]) {
|
|
117
131
|
const parsedAnchorBlockHash = BlockHash.fromString(anchorBlockHash);
|
|
118
132
|
const parsedBlockHash = BlockHash.fromString(blockHash);
|
|
119
|
-
const witness = await this.handlerAsUtility().
|
|
133
|
+
const witness = await this.handlerAsUtility().getBlockHashMembershipWitness(parsedAnchorBlockHash, parsedBlockHash);
|
|
120
134
|
if (!witness) {
|
|
121
135
|
throw new Error(`Block hash ${parsedBlockHash.toString()} not found in the archive tree at anchor block ${parsedAnchorBlockHash.toString()}.`);
|
|
122
136
|
}
|
|
123
137
|
return witness.toNoirRepresentation();
|
|
124
138
|
}
|
|
125
|
-
|
|
139
|
+
// eslint-disable-next-line camelcase
|
|
140
|
+
async aztec_utl_getNullifierMembershipWitness([blockHash], [nullifier]) {
|
|
126
141
|
const parsedBlockHash = BlockHash.fromString(blockHash);
|
|
127
142
|
const parsedNullifier = Fr.fromString(nullifier);
|
|
128
|
-
const witness = await this.handlerAsUtility().
|
|
143
|
+
const witness = await this.handlerAsUtility().getNullifierMembershipWitness(parsedBlockHash, parsedNullifier);
|
|
129
144
|
if (!witness) {
|
|
130
145
|
throw new Error(`Nullifier witness not found for nullifier ${parsedNullifier} at block hash ${parsedBlockHash.toString()}.`);
|
|
131
146
|
}
|
|
132
147
|
return witness.toNoirRepresentation();
|
|
133
148
|
}
|
|
134
|
-
|
|
149
|
+
// eslint-disable-next-line camelcase
|
|
150
|
+
async aztec_utl_getLowNullifierMembershipWitness([blockHash], [nullifier]) {
|
|
135
151
|
const parsedBlockHash = BlockHash.fromString(blockHash);
|
|
136
152
|
const parsedNullifier = Fr.fromString(nullifier);
|
|
137
|
-
const witness = await this.handlerAsUtility().
|
|
153
|
+
const witness = await this.handlerAsUtility().getLowNullifierMembershipWitness(parsedBlockHash, parsedNullifier);
|
|
138
154
|
if (!witness) {
|
|
139
155
|
throw new Error(`Low nullifier witness not found for nullifier ${parsedNullifier} at block hash ${parsedBlockHash.toString()}.`);
|
|
140
156
|
}
|
|
141
157
|
return witness.toNoirRepresentation();
|
|
142
158
|
}
|
|
143
|
-
|
|
159
|
+
// eslint-disable-next-line camelcase
|
|
160
|
+
async aztec_utl_getPublicDataWitness([blockHash], [leafSlot]) {
|
|
144
161
|
const parsedBlockHash = BlockHash.fromString(blockHash);
|
|
145
162
|
const parsedLeafSlot = Fr.fromString(leafSlot);
|
|
146
|
-
const witness = await this.handlerAsUtility().
|
|
163
|
+
const witness = await this.handlerAsUtility().getPublicDataWitness(parsedBlockHash, parsedLeafSlot);
|
|
147
164
|
if (!witness) {
|
|
148
165
|
throw new Error(`Public data witness not found for slot ${parsedLeafSlot} at block hash ${parsedBlockHash.toString()}.`);
|
|
149
166
|
}
|
|
150
167
|
return witness.toNoirRepresentation();
|
|
151
168
|
}
|
|
152
|
-
|
|
169
|
+
// eslint-disable-next-line camelcase
|
|
170
|
+
async aztec_utl_getBlockHeader([blockNumber]) {
|
|
153
171
|
const parsedBlockNumber = Fr.fromString(blockNumber).toNumber();
|
|
154
|
-
const header = await this.handlerAsUtility().
|
|
172
|
+
const header = await this.handlerAsUtility().getBlockHeader(BlockNumber(parsedBlockNumber));
|
|
155
173
|
if (!header) {
|
|
156
174
|
throw new Error(`Block header not found for block ${parsedBlockNumber}.`);
|
|
157
175
|
}
|
|
158
176
|
return header.toFields().map(toACVMField);
|
|
159
177
|
}
|
|
160
|
-
|
|
178
|
+
// eslint-disable-next-line camelcase
|
|
179
|
+
async aztec_utl_getAuthWitness([messageHash]) {
|
|
161
180
|
const messageHashField = Fr.fromString(messageHash);
|
|
162
|
-
const witness = await this.handlerAsUtility().
|
|
181
|
+
const witness = await this.handlerAsUtility().getAuthWitness(messageHashField);
|
|
163
182
|
if (!witness) {
|
|
164
183
|
throw new Error(`Unknown auth witness for message hash ${messageHashField}`);
|
|
165
184
|
}
|
|
@@ -167,9 +186,10 @@ export class UnavailableOracleError extends Error {
|
|
|
167
186
|
witness.map(toACVMField)
|
|
168
187
|
];
|
|
169
188
|
}
|
|
170
|
-
|
|
189
|
+
// eslint-disable-next-line camelcase
|
|
190
|
+
async aztec_utl_tryGetPublicKeysAndPartialAddress([address]) {
|
|
171
191
|
const parsedAddress = AztecAddress.fromField(Fr.fromString(address));
|
|
172
|
-
const result = await this.handlerAsUtility().
|
|
192
|
+
const result = await this.handlerAsUtility().tryGetPublicKeysAndPartialAddress(parsedAddress);
|
|
173
193
|
// We are going to return a Noir Option struct to represent the possibility of null values. Options are a struct
|
|
174
194
|
// with two fields: `some` (a boolean) and `value` (a field array in this case).
|
|
175
195
|
if (result === undefined) {
|
|
@@ -189,10 +209,11 @@ export class UnavailableOracleError extends Error {
|
|
|
189
209
|
];
|
|
190
210
|
}
|
|
191
211
|
}
|
|
192
|
-
|
|
212
|
+
// eslint-disable-next-line camelcase
|
|
213
|
+
async aztec_utl_getNotes([ownerSome], [ownerValue], [storageSlot], [numSelects], selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, [limit], [offset], [status], [maxNotes], [packedHintedNoteLength]) {
|
|
193
214
|
// Parse Option<AztecAddress>: ownerSome is 0 for None, 1 for Some
|
|
194
215
|
const owner = Fr.fromString(ownerSome).toNumber() === 1 ? AztecAddress.fromString(ownerValue) : undefined;
|
|
195
|
-
const noteDatas = await this.handlerAsUtility().
|
|
216
|
+
const noteDatas = await this.handlerAsUtility().getNotes(owner, Fr.fromString(storageSlot), +numSelects, selectByIndexes.map((s)=>+s), selectByOffsets.map((s)=>+s), selectByLengths.map((s)=>+s), selectValues.map(Fr.fromString), selectComparators.map((s)=>+s), sortByIndexes.map((s)=>+s), sortByOffsets.map((s)=>+s), sortByLengths.map((s)=>+s), sortOrder.map((s)=>+s), +limit, +offset, +status);
|
|
196
217
|
const returnDataAsArrayOfPackedHintedNotes = noteDatas.map((noteData)=>packAsHintedNote({
|
|
197
218
|
contractAddress: noteData.contractAddress,
|
|
198
219
|
owner: noteData.owner,
|
|
@@ -207,57 +228,67 @@ export class UnavailableOracleError extends Error {
|
|
|
207
228
|
// At last we convert the array of arrays to a bounded vec of arrays
|
|
208
229
|
return arrayOfArraysToBoundedVecOfArrays(returnDataAsArrayOfACVMFieldArrays, +maxNotes, +packedHintedNoteLength);
|
|
209
230
|
}
|
|
210
|
-
|
|
211
|
-
|
|
231
|
+
// eslint-disable-next-line camelcase
|
|
232
|
+
aztec_prv_notifyCreatedNote([owner], [storageSlot], [randomness], [noteTypeId], note, [noteHash], [counter]) {
|
|
233
|
+
this.handlerAsPrivate().notifyCreatedNote(AztecAddress.fromString(owner), Fr.fromString(storageSlot), Fr.fromString(randomness), NoteSelector.fromField(Fr.fromString(noteTypeId)), note.map(Fr.fromString), Fr.fromString(noteHash), +counter);
|
|
212
234
|
return Promise.resolve([]);
|
|
213
235
|
}
|
|
214
|
-
|
|
215
|
-
|
|
236
|
+
// eslint-disable-next-line camelcase
|
|
237
|
+
async aztec_prv_notifyNullifiedNote([innerNullifier], [noteHash], [counter]) {
|
|
238
|
+
await this.handlerAsPrivate().notifyNullifiedNote(Fr.fromString(innerNullifier), Fr.fromString(noteHash), +counter);
|
|
216
239
|
return [];
|
|
217
240
|
}
|
|
218
|
-
|
|
219
|
-
|
|
241
|
+
// eslint-disable-next-line camelcase
|
|
242
|
+
async aztec_prv_notifyCreatedNullifier([innerNullifier]) {
|
|
243
|
+
await this.handlerAsPrivate().notifyCreatedNullifier(Fr.fromString(innerNullifier));
|
|
220
244
|
return [];
|
|
221
245
|
}
|
|
222
|
-
|
|
223
|
-
|
|
246
|
+
// eslint-disable-next-line camelcase
|
|
247
|
+
async aztec_prv_isNullifierPending([innerNullifier], [contractAddress]) {
|
|
248
|
+
const isPending = await this.handlerAsPrivate().isNullifierPending(Fr.fromString(innerNullifier), AztecAddress.fromString(contractAddress));
|
|
224
249
|
return [
|
|
225
250
|
toACVMField(isPending)
|
|
226
251
|
];
|
|
227
252
|
}
|
|
228
|
-
|
|
229
|
-
|
|
253
|
+
// eslint-disable-next-line camelcase
|
|
254
|
+
async aztec_utl_checkNullifierExists([innerNullifier]) {
|
|
255
|
+
const exists = await this.handlerAsUtility().checkNullifierExists(Fr.fromString(innerNullifier));
|
|
230
256
|
return [
|
|
231
257
|
toACVMField(exists)
|
|
232
258
|
];
|
|
233
259
|
}
|
|
234
|
-
|
|
235
|
-
|
|
260
|
+
// eslint-disable-next-line camelcase
|
|
261
|
+
async aztec_utl_getL1ToL2MembershipWitness([contractAddress], [messageHash], [secret]) {
|
|
262
|
+
const message = await this.handlerAsUtility().getL1ToL2MembershipWitness(AztecAddress.fromString(contractAddress), Fr.fromString(messageHash), Fr.fromString(secret));
|
|
236
263
|
return message.toNoirRepresentation();
|
|
237
264
|
}
|
|
238
|
-
|
|
239
|
-
|
|
265
|
+
// eslint-disable-next-line camelcase
|
|
266
|
+
async aztec_utl_storageRead([blockHash], [contractAddress], [startStorageSlot], [numberOfElements]) {
|
|
267
|
+
const values = await this.handlerAsUtility().storageRead(BlockHash.fromString(blockHash), new AztecAddress(Fr.fromString(contractAddress)), Fr.fromString(startStorageSlot), +numberOfElements);
|
|
240
268
|
return [
|
|
241
269
|
values.map(toACVMField)
|
|
242
270
|
];
|
|
243
271
|
}
|
|
244
|
-
|
|
272
|
+
// eslint-disable-next-line camelcase
|
|
273
|
+
aztec_prv_notifyCreatedContractClassLog([contractAddress], message, [length], [counter]) {
|
|
245
274
|
const logFields = new ContractClassLogFields(message.map(Fr.fromString));
|
|
246
275
|
const log = new ContractClassLog(new AztecAddress(Fr.fromString(contractAddress)), logFields, +length);
|
|
247
|
-
this.handlerAsPrivate().
|
|
276
|
+
this.handlerAsPrivate().notifyCreatedContractClassLog(log, +counter);
|
|
248
277
|
return Promise.resolve([]);
|
|
249
278
|
}
|
|
250
|
-
|
|
279
|
+
// eslint-disable-next-line camelcase
|
|
280
|
+
async aztec_utl_log(level, message, _ignoredFieldsSize, fields) {
|
|
251
281
|
const levelFr = Fr.fromString(level[0]);
|
|
252
282
|
const messageStr = message.map((acvmField)=>String.fromCharCode(Fr.fromString(acvmField).toNumber())).join('');
|
|
253
283
|
const fieldsFr = fields.map(Fr.fromString);
|
|
254
|
-
await this.handlerAsMisc().
|
|
284
|
+
await this.handlerAsMisc().log(levelFr.toNumber(), messageStr, fieldsFr);
|
|
255
285
|
return [];
|
|
256
286
|
}
|
|
257
287
|
// This function's name is directly hardcoded in `circuit_recorder.ts`. Don't forget to update it there if you
|
|
258
288
|
// change the name here.
|
|
259
|
-
|
|
260
|
-
|
|
289
|
+
// eslint-disable-next-line camelcase
|
|
290
|
+
async aztec_prv_callPrivateFunction([contractAddress], [functionSelector], [argsHash], [sideEffectCounter], [isStaticCall]) {
|
|
291
|
+
const { endSideEffectCounter, returnsHash } = await this.handlerAsPrivate().callPrivateFunction(AztecAddress.fromField(Fr.fromString(contractAddress)), FunctionSelector.fromField(Fr.fromString(functionSelector)), Fr.fromString(argsHash), Fr.fromString(sideEffectCounter).toNumber(), Fr.fromString(isStaticCall).toBool());
|
|
261
292
|
return [
|
|
262
293
|
[
|
|
263
294
|
endSideEffectCounter,
|
|
@@ -265,48 +296,58 @@ export class UnavailableOracleError extends Error {
|
|
|
265
296
|
].map(toACVMField)
|
|
266
297
|
];
|
|
267
298
|
}
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
}
|
|
272
|
-
async privateNotifySetPublicTeardownFunctionCall([contractAddress], [calldataHash], [sideEffectCounter], [isStaticCall]) {
|
|
273
|
-
await this.handlerAsPrivate().privateNotifySetPublicTeardownFunctionCall(AztecAddress.fromString(contractAddress), Fr.fromString(calldataHash), Fr.fromString(sideEffectCounter).toNumber(), Fr.fromString(isStaticCall).toBool());
|
|
299
|
+
// eslint-disable-next-line camelcase
|
|
300
|
+
async aztec_prv_validatePublicCalldata([calldataHash]) {
|
|
301
|
+
await this.handlerAsPrivate().validatePublicCalldata(Fr.fromString(calldataHash));
|
|
274
302
|
return [];
|
|
275
303
|
}
|
|
276
|
-
|
|
277
|
-
|
|
304
|
+
// eslint-disable-next-line camelcase
|
|
305
|
+
async aztec_prv_notifyRevertiblePhaseStart([minRevertibleSideEffectCounter]) {
|
|
306
|
+
await this.handlerAsPrivate().notifyRevertiblePhaseStart(Fr.fromString(minRevertibleSideEffectCounter).toNumber());
|
|
278
307
|
return Promise.resolve([]);
|
|
279
308
|
}
|
|
280
|
-
|
|
281
|
-
|
|
309
|
+
// eslint-disable-next-line camelcase
|
|
310
|
+
async aztec_prv_inRevertiblePhase([sideEffectCounter]) {
|
|
311
|
+
const isRevertible = await this.handlerAsPrivate().inRevertiblePhase(Fr.fromString(sideEffectCounter).toNumber());
|
|
282
312
|
return Promise.resolve([
|
|
283
313
|
toACVMField(isRevertible)
|
|
284
314
|
]);
|
|
285
315
|
}
|
|
286
|
-
|
|
287
|
-
|
|
316
|
+
// eslint-disable-next-line camelcase
|
|
317
|
+
async aztec_prv_getNextAppTagAsSender([sender], [recipient]) {
|
|
318
|
+
const tag = await this.handlerAsPrivate().getNextAppTagAsSender(AztecAddress.fromString(sender), AztecAddress.fromString(recipient));
|
|
288
319
|
return [
|
|
289
320
|
toACVMField(tag.value)
|
|
290
321
|
];
|
|
291
322
|
}
|
|
292
|
-
|
|
293
|
-
|
|
323
|
+
// eslint-disable-next-line camelcase
|
|
324
|
+
async aztec_utl_fetchTaggedLogs([pendingTaggedLogArrayBaseSlot]) {
|
|
325
|
+
await this.handlerAsUtility().fetchTaggedLogs(Fr.fromString(pendingTaggedLogArrayBaseSlot));
|
|
294
326
|
return [];
|
|
295
327
|
}
|
|
296
|
-
|
|
297
|
-
|
|
328
|
+
// eslint-disable-next-line camelcase
|
|
329
|
+
async aztec_utl_validateAndStoreEnqueuedNotesAndEvents([contractAddress], [noteValidationRequestsArrayBaseSlot], [eventValidationRequestsArrayBaseSlot], [maxNotePackedLen], [maxEventSerializedLen]) {
|
|
330
|
+
await this.handlerAsUtility().validateAndStoreEnqueuedNotesAndEvents(AztecAddress.fromString(contractAddress), Fr.fromString(noteValidationRequestsArrayBaseSlot), Fr.fromString(eventValidationRequestsArrayBaseSlot), Fr.fromString(maxNotePackedLen).toNumber(), Fr.fromString(maxEventSerializedLen).toNumber());
|
|
298
331
|
return [];
|
|
299
332
|
}
|
|
300
|
-
|
|
301
|
-
|
|
333
|
+
// eslint-disable-next-line camelcase
|
|
334
|
+
async aztec_utl_bulkRetrieveLogs([contractAddress], [logRetrievalRequestsArrayBaseSlot], [logRetrievalResponsesArrayBaseSlot]) {
|
|
335
|
+
await this.handlerAsUtility().bulkRetrieveLogs(AztecAddress.fromString(contractAddress), Fr.fromString(logRetrievalRequestsArrayBaseSlot), Fr.fromString(logRetrievalResponsesArrayBaseSlot));
|
|
302
336
|
return [];
|
|
303
337
|
}
|
|
304
|
-
|
|
305
|
-
|
|
338
|
+
// eslint-disable-next-line camelcase
|
|
339
|
+
async aztec_utl_utilityResolveMessageContexts([contractAddress], [messageContextRequestsArrayBaseSlot], [messageContextResponsesArrayBaseSlot]) {
|
|
340
|
+
await this.handlerAsUtility().utilityResolveMessageContexts(AztecAddress.fromString(contractAddress), Fr.fromString(messageContextRequestsArrayBaseSlot), Fr.fromString(messageContextResponsesArrayBaseSlot));
|
|
306
341
|
return [];
|
|
307
342
|
}
|
|
308
|
-
|
|
309
|
-
|
|
343
|
+
// eslint-disable-next-line camelcase
|
|
344
|
+
async aztec_utl_storeCapsule([contractAddress], [slot], capsule) {
|
|
345
|
+
await this.handlerAsUtility().storeCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(slot), capsule.map(Fr.fromString));
|
|
346
|
+
return [];
|
|
347
|
+
}
|
|
348
|
+
// eslint-disable-next-line camelcase
|
|
349
|
+
async aztec_utl_loadCapsule([contractAddress], [slot], [tSize]) {
|
|
350
|
+
const values = await this.handlerAsUtility().loadCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(slot));
|
|
310
351
|
// We are going to return a Noir Option struct to represent the possibility of null values. Options are a struct
|
|
311
352
|
// with two fields: `some` (a boolean) and `value` (a field array in this case).
|
|
312
353
|
if (values === null) {
|
|
@@ -323,35 +364,62 @@ export class UnavailableOracleError extends Error {
|
|
|
323
364
|
];
|
|
324
365
|
}
|
|
325
366
|
}
|
|
326
|
-
|
|
327
|
-
|
|
367
|
+
// eslint-disable-next-line camelcase
|
|
368
|
+
async aztec_utl_deleteCapsule([contractAddress], [slot]) {
|
|
369
|
+
await this.handlerAsUtility().deleteCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(slot));
|
|
328
370
|
return [];
|
|
329
371
|
}
|
|
330
|
-
|
|
331
|
-
|
|
372
|
+
// eslint-disable-next-line camelcase
|
|
373
|
+
async aztec_utl_copyCapsule([contractAddress], [srcSlot], [dstSlot], [numEntries]) {
|
|
374
|
+
await this.handlerAsUtility().copyCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(srcSlot), Fr.fromString(dstSlot), Fr.fromString(numEntries).toNumber());
|
|
332
375
|
return [];
|
|
333
376
|
}
|
|
334
|
-
|
|
377
|
+
// eslint-disable-next-line camelcase
|
|
378
|
+
async aztec_utl_tryAes128Decrypt(ciphertextBVecStorage, [ciphertextLength], iv, symKey) {
|
|
335
379
|
const ciphertext = fromUintBoundedVec(ciphertextBVecStorage, ciphertextLength, 8);
|
|
336
380
|
const ivBuffer = fromUintArray(iv, 8);
|
|
337
381
|
const symKeyBuffer = fromUintArray(symKey, 8);
|
|
338
|
-
|
|
339
|
-
|
|
382
|
+
// Noir Option<BoundedVec> is encoded as [is_some: Field, storage: Field[], length: Field].
|
|
383
|
+
try {
|
|
384
|
+
const plaintext = await this.handlerAsUtility().aes128Decrypt(ciphertext, ivBuffer, symKeyBuffer);
|
|
385
|
+
const [storage, length] = bufferToBoundedVec(plaintext, ciphertextBVecStorage.length);
|
|
386
|
+
return [
|
|
387
|
+
toACVMField(1),
|
|
388
|
+
storage,
|
|
389
|
+
length
|
|
390
|
+
];
|
|
391
|
+
} catch {
|
|
392
|
+
const zeroStorage = Array(ciphertextBVecStorage.length).fill(toACVMField(0));
|
|
393
|
+
return [
|
|
394
|
+
toACVMField(0),
|
|
395
|
+
zeroStorage,
|
|
396
|
+
toACVMField(0)
|
|
397
|
+
];
|
|
398
|
+
}
|
|
340
399
|
}
|
|
341
|
-
|
|
342
|
-
|
|
400
|
+
// eslint-disable-next-line camelcase
|
|
401
|
+
async aztec_utl_getSharedSecret([address], [ephPKField0], [ephPKField1], [ephPKField2]) {
|
|
402
|
+
const secret = await this.handlerAsUtility().getSharedSecret(AztecAddress.fromField(Fr.fromString(address)), Point.fromFields([
|
|
343
403
|
ephPKField0,
|
|
344
404
|
ephPKField1,
|
|
345
405
|
ephPKField2
|
|
346
406
|
].map(Fr.fromString)));
|
|
347
407
|
return secret.toFields().map(toACVMField);
|
|
348
408
|
}
|
|
349
|
-
|
|
350
|
-
|
|
409
|
+
// eslint-disable-next-line camelcase
|
|
410
|
+
aztec_utl_invalidateContractSyncCache([contractAddress], scopes, [scopeCount]) {
|
|
411
|
+
const scopeAddresses = scopes.slice(0, +scopeCount).map((s)=>AztecAddress.fromField(Fr.fromString(s)));
|
|
412
|
+
this.handlerAsUtility().invalidateContractSyncCache(AztecAddress.fromField(Fr.fromString(contractAddress)), scopeAddresses);
|
|
413
|
+
return Promise.resolve([]);
|
|
414
|
+
}
|
|
415
|
+
// eslint-disable-next-line camelcase
|
|
416
|
+
async aztec_utl_emitOffchainEffect(data) {
|
|
417
|
+
await this.handlerAsUtility().emitOffchainEffect(data.map(Fr.fromString));
|
|
351
418
|
return [];
|
|
352
419
|
}
|
|
353
|
-
|
|
354
|
-
|
|
420
|
+
// eslint-disable-next-line camelcase
|
|
421
|
+
async aztec_prv_getSenderForTags() {
|
|
422
|
+
const sender = await this.handlerAsPrivate().getSenderForTags();
|
|
355
423
|
// Return [1, address] for Some(address), [0, 0] for None
|
|
356
424
|
return sender ? [
|
|
357
425
|
toACVMField(1n),
|
|
@@ -361,8 +429,9 @@ export class UnavailableOracleError extends Error {
|
|
|
361
429
|
toACVMField(0n)
|
|
362
430
|
];
|
|
363
431
|
}
|
|
364
|
-
|
|
365
|
-
|
|
432
|
+
// eslint-disable-next-line camelcase
|
|
433
|
+
async aztec_prv_setSenderForTags([senderForTags]) {
|
|
434
|
+
await this.handlerAsPrivate().setSenderForTags(AztecAddress.fromField(Fr.fromString(senderForTags)));
|
|
366
435
|
return [];
|
|
367
436
|
}
|
|
368
437
|
}
|
|
@@ -45,11 +45,11 @@ import { Oracle } from './oracle.js';
|
|
|
45
45
|
appCircuitName: functionName
|
|
46
46
|
});
|
|
47
47
|
const contractClassLogs = privateExecutionOracle.getContractClassLogs();
|
|
48
|
-
const rawReturnValues = await privateExecutionOracle.
|
|
48
|
+
const rawReturnValues = await privateExecutionOracle.loadFromExecutionCache(publicInputs.returnsHash);
|
|
49
49
|
const newNotes = privateExecutionOracle.getNewNotes();
|
|
50
50
|
const noteHashNullifierCounterMap = privateExecutionOracle.getNoteHashNullifierCounterMap();
|
|
51
51
|
const offchainEffects = privateExecutionOracle.getOffchainEffects();
|
|
52
|
-
const
|
|
52
|
+
const taggingIndexRanges = privateExecutionOracle.getUsedTaggingIndexRanges();
|
|
53
53
|
const nestedExecutionResults = privateExecutionOracle.getNestedExecutionResults();
|
|
54
54
|
let timerSubtractionList = nestedExecutionResults;
|
|
55
55
|
let witgenTime = duration;
|
|
@@ -59,7 +59,9 @@ import { Oracle } from './oracle.js';
|
|
|
59
59
|
timerSubtractionList = timerSubtractionList.flatMap((nested)=>nested.nestedExecutionResults ?? []);
|
|
60
60
|
}
|
|
61
61
|
log.debug(`Returning from call to ${contractAddress.toString()}:${functionSelector}`);
|
|
62
|
-
return new PrivateCallExecutionResult(artifact.bytecode, Buffer.from(artifact.verificationKey, 'base64'), partialWitness, publicInputs, newNotes, noteHashNullifierCounterMap, rawReturnValues, offchainEffects
|
|
62
|
+
return new PrivateCallExecutionResult(artifact.bytecode, Buffer.from(artifact.verificationKey, 'base64'), partialWitness, publicInputs, newNotes, noteHashNullifierCounterMap, rawReturnValues, offchainEffects.map((e)=>({
|
|
63
|
+
data: e.data
|
|
64
|
+
})), taggingIndexRanges, nestedExecutionResults, contractClassLogs, {
|
|
63
65
|
timings: {
|
|
64
66
|
witgen: witgenTime,
|
|
65
67
|
oracles: acirExecutionResult.oracles
|