@aztec/pxe 0.0.1-commit.96dac018d → 0.0.1-commit.993d52e
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/package_info.js +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.js +3 -3
- 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 +3 -3
- package/dest/contract_function_simulator/noir-structs/event_validation_request.js +1 -1
- package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +1 -1
- package/dest/contract_function_simulator/noir-structs/note_validation_request.js +1 -1
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +1 -1
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/private_execution_oracle.js +18 -10
- package/dest/logs/log_service.d.ts +1 -1
- package/dest/logs/log_service.d.ts.map +1 -1
- package/dest/logs/log_service.js +4 -4
- package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +3 -4
- package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -1
- package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.js +64 -125
- package/dest/private_kernel/private_kernel_execution_prover.d.ts +1 -1
- package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
- package/dest/private_kernel/private_kernel_execution_prover.js +5 -13
- package/dest/storage/tagging_store/recipient_tagging_store.d.ts +6 -6
- package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
- package/dest/storage/tagging_store/sender_tagging_store.d.ts +5 -5
- package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
- package/dest/storage/tagging_store/sender_tagging_store.js +4 -4
- package/dest/tagging/index.d.ts +2 -2
- package/dest/tagging/index.d.ts.map +1 -1
- package/dest/tagging/index.js +1 -1
- package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +4 -5
- package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +1 -1
- package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +3 -3
- package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +6 -7
- package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +1 -1
- package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +12 -11
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +4 -8
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +3 -6
- package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +4 -7
- 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 +14 -15
- package/package.json +16 -16
- package/src/config/package_info.ts +1 -1
- package/src/contract_function_simulator/contract_function_simulator.ts +10 -3
- package/src/contract_function_simulator/execution_tagging_index_cache.ts +5 -5
- package/src/contract_function_simulator/noir-structs/event_validation_request.ts +1 -1
- package/src/contract_function_simulator/noir-structs/note_validation_request.ts +1 -1
- package/src/contract_function_simulator/oracle/private_execution_oracle.ts +23 -11
- package/src/logs/log_service.ts +10 -5
- package/src/private_kernel/hints/private_kernel_reset_private_inputs_builder.ts +110 -157
- package/src/private_kernel/private_kernel_execution_prover.ts +6 -13
- package/src/storage/tagging_store/recipient_tagging_store.ts +9 -5
- package/src/storage/tagging_store/sender_tagging_store.ts +8 -8
- package/src/tagging/index.ts +1 -1
- package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +3 -6
- package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +10 -15
- package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +4 -9
- package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +11 -20
- package/dest/private_kernel/hints/test_utils.d.ts +0 -122
- package/dest/private_kernel/hints/test_utils.d.ts.map +0 -1
- package/dest/private_kernel/hints/test_utils.js +0 -203
- package/src/private_kernel/hints/test_utils.ts +0 -325
|
@@ -1,325 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
MAX_KEY_VALIDATION_REQUESTS_PER_CALL,
|
|
3
|
-
MAX_KEY_VALIDATION_REQUESTS_PER_TX,
|
|
4
|
-
MAX_NOTE_HASHES_PER_CALL,
|
|
5
|
-
MAX_NOTE_HASHES_PER_TX,
|
|
6
|
-
MAX_NOTE_HASH_READ_REQUESTS_PER_CALL,
|
|
7
|
-
MAX_NOTE_HASH_READ_REQUESTS_PER_TX,
|
|
8
|
-
MAX_NULLIFIERS_PER_CALL,
|
|
9
|
-
MAX_NULLIFIERS_PER_TX,
|
|
10
|
-
MAX_NULLIFIER_READ_REQUESTS_PER_CALL,
|
|
11
|
-
MAX_NULLIFIER_READ_REQUESTS_PER_TX,
|
|
12
|
-
MAX_PRIVATE_LOGS_PER_CALL,
|
|
13
|
-
MAX_PRIVATE_LOGS_PER_TX,
|
|
14
|
-
} from '@aztec/constants';
|
|
15
|
-
import { makeTuple } from '@aztec/foundation/array';
|
|
16
|
-
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
17
|
-
import { Point } from '@aztec/foundation/curves/grumpkin';
|
|
18
|
-
import type { Serializable } from '@aztec/foundation/serialize';
|
|
19
|
-
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
20
|
-
import {
|
|
21
|
-
ClaimedLengthArray,
|
|
22
|
-
KeyValidationRequest,
|
|
23
|
-
KeyValidationRequestAndSeparator,
|
|
24
|
-
NoteHash,
|
|
25
|
-
Nullifier,
|
|
26
|
-
PrivateCircuitPublicInputs,
|
|
27
|
-
PrivateKernelCircuitPublicInputs,
|
|
28
|
-
type PrivateKernelSimulateOutput,
|
|
29
|
-
ReadRequest,
|
|
30
|
-
ScopedKeyValidationRequestAndSeparator,
|
|
31
|
-
ScopedNoteHash,
|
|
32
|
-
ScopedNullifier,
|
|
33
|
-
ScopedReadRequest,
|
|
34
|
-
} from '@aztec/stdlib/kernel';
|
|
35
|
-
import { PrivateLogData, ScopedPrivateLogData } from '@aztec/stdlib/kernel';
|
|
36
|
-
import { PrivateLog } from '@aztec/stdlib/logs';
|
|
37
|
-
import { PrivateCallExecutionResult } from '@aztec/stdlib/tx';
|
|
38
|
-
import { VerificationKeyData } from '@aztec/stdlib/vks';
|
|
39
|
-
|
|
40
|
-
const DEFAULT_CONTRACT_ADDRESS = AztecAddress.fromBigInt(987654n);
|
|
41
|
-
|
|
42
|
-
/**
|
|
43
|
-
* Builds a ClaimedLengthArray from a list of items, padding to the required size.
|
|
44
|
-
*/
|
|
45
|
-
function makeClaimed<T extends Serializable, N extends number>(items: T[], emptyFactory: { empty(): T }, maxSize: N) {
|
|
46
|
-
const padded = makeTuple(maxSize, i => items[i] ?? emptyFactory.empty());
|
|
47
|
-
return new ClaimedLengthArray<T, typeof maxSize>(padded, items.length);
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
/** Builder for PrivateKernelCircuitPublicInputs with fluent API for adding side effects. */
|
|
51
|
-
export class PrivateKernelCircuitPublicInputsBuilder {
|
|
52
|
-
private noteHashes: ScopedNoteHash[] = [];
|
|
53
|
-
private nullifiers: ScopedNullifier[] = [];
|
|
54
|
-
private noteHashReadRequests: ScopedReadRequest[] = [];
|
|
55
|
-
private nullifierReadRequests: ScopedReadRequest[] = [];
|
|
56
|
-
private keyValidationRequests: ScopedKeyValidationRequestAndSeparator[] = [];
|
|
57
|
-
private privateLogs: ScopedPrivateLogData[] = [];
|
|
58
|
-
private nextCounter: number;
|
|
59
|
-
|
|
60
|
-
constructor(
|
|
61
|
-
private contractAddress: AztecAddress = DEFAULT_CONTRACT_ADDRESS,
|
|
62
|
-
startCounter = 1,
|
|
63
|
-
) {
|
|
64
|
-
this.nextCounter = startCounter;
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
private getCounter(sideEffectCounter?: number): number {
|
|
68
|
-
if (sideEffectCounter !== undefined) {
|
|
69
|
-
this.nextCounter = sideEffectCounter + 1;
|
|
70
|
-
return sideEffectCounter;
|
|
71
|
-
}
|
|
72
|
-
return this.nextCounter++;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
/** Adds a note hash to the accumulated data. Defaults are generated randomly. */
|
|
76
|
-
addNoteHash(opts?: { value?: Fr; counter?: number; contractAddress?: AztecAddress }): this {
|
|
77
|
-
const value = opts?.value ?? Fr.random();
|
|
78
|
-
const counter = this.getCounter(opts?.counter);
|
|
79
|
-
const addr = opts?.contractAddress ?? this.contractAddress;
|
|
80
|
-
this.noteHashes.push(new NoteHash(value, counter).scope(addr));
|
|
81
|
-
return this;
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
/** Adds a nullifier to the accumulated data. Defaults are generated randomly. */
|
|
85
|
-
addNullifier(opts?: { value?: Fr; noteHash?: Fr; counter?: number; contractAddress?: AztecAddress }): this {
|
|
86
|
-
const value = opts?.value ?? Fr.random();
|
|
87
|
-
const noteHash = opts?.noteHash ?? Fr.ZERO;
|
|
88
|
-
const counter = this.getCounter(opts?.counter);
|
|
89
|
-
const addr = opts?.contractAddress ?? this.contractAddress;
|
|
90
|
-
this.nullifiers.push(new Nullifier(value, noteHash, counter).scope(addr));
|
|
91
|
-
return this;
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
/** Adds a pending note hash read request (non-empty contract address, can match a pending note hash). */
|
|
95
|
-
addPendingNoteHashReadRequest(opts?: { value?: Fr; counter?: number; contractAddress?: AztecAddress }): this {
|
|
96
|
-
const value = opts?.value ?? Fr.random();
|
|
97
|
-
const counter = this.getCounter(opts?.counter);
|
|
98
|
-
const addr = opts?.contractAddress ?? this.contractAddress;
|
|
99
|
-
this.noteHashReadRequests.push(new ScopedReadRequest(new ReadRequest(value, counter), addr));
|
|
100
|
-
return this;
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
/** Adds a settled note hash read request (empty contract address, resolved against the note hash tree). */
|
|
104
|
-
addSettledNoteHashReadRequest(opts?: { value?: Fr; counter?: number }): this {
|
|
105
|
-
const value = opts?.value ?? Fr.random();
|
|
106
|
-
const counter = this.getCounter(opts?.counter);
|
|
107
|
-
this.noteHashReadRequests.push(new ScopedReadRequest(new ReadRequest(value, counter), AztecAddress.ZERO));
|
|
108
|
-
return this;
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
/** Adds a pending nullifier read request (non-empty contract address, can match a pending nullifier). */
|
|
112
|
-
addPendingNullifierReadRequest(opts?: { value?: Fr; counter?: number; contractAddress?: AztecAddress }): this {
|
|
113
|
-
const value = opts?.value ?? Fr.random();
|
|
114
|
-
const counter = this.getCounter(opts?.counter);
|
|
115
|
-
const addr = opts?.contractAddress ?? this.contractAddress;
|
|
116
|
-
this.nullifierReadRequests.push(new ScopedReadRequest(new ReadRequest(value, counter), addr));
|
|
117
|
-
return this;
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
/** Adds a settled nullifier read request (empty contract address, resolved against the nullifier tree). */
|
|
121
|
-
addSettledNullifierReadRequest(opts?: { value?: Fr; counter?: number }): this {
|
|
122
|
-
const value = opts?.value ?? Fr.random();
|
|
123
|
-
const counter = this.getCounter(opts?.counter);
|
|
124
|
-
this.nullifierReadRequests.push(new ScopedReadRequest(new ReadRequest(value, counter), AztecAddress.ZERO));
|
|
125
|
-
return this;
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
/** Adds a key validation request to validation requests. */
|
|
129
|
-
addKeyValidationRequest(opts?: { contractAddress?: AztecAddress }): this {
|
|
130
|
-
const addr = opts?.contractAddress ?? this.contractAddress;
|
|
131
|
-
this.keyValidationRequests.push(
|
|
132
|
-
new ScopedKeyValidationRequestAndSeparator(
|
|
133
|
-
new KeyValidationRequestAndSeparator(
|
|
134
|
-
new KeyValidationRequest(new Point(Fr.random(), Fr.random(), false), Fr.random()),
|
|
135
|
-
Fr.random(),
|
|
136
|
-
),
|
|
137
|
-
addr,
|
|
138
|
-
),
|
|
139
|
-
);
|
|
140
|
-
return this;
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
/** Adds a private log to the accumulated data. Defaults are generated randomly. */
|
|
144
|
-
addPrivateLog(opts?: { noteHashCounter?: number; counter?: number; contractAddress?: AztecAddress }): this {
|
|
145
|
-
const noteHashCounter = opts?.noteHashCounter ?? 0;
|
|
146
|
-
const counter = this.getCounter(opts?.counter);
|
|
147
|
-
const addr = opts?.contractAddress ?? this.contractAddress;
|
|
148
|
-
this.privateLogs.push(
|
|
149
|
-
new ScopedPrivateLogData(new PrivateLogData(PrivateLog.empty(), noteHashCounter, counter), addr),
|
|
150
|
-
);
|
|
151
|
-
return this;
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
/** Builds the PrivateKernelCircuitPublicInputs with all added side effects. */
|
|
155
|
-
build(): PrivateKernelCircuitPublicInputs {
|
|
156
|
-
const publicInputs = PrivateKernelCircuitPublicInputs.empty();
|
|
157
|
-
publicInputs.end.noteHashes = makeClaimed(this.noteHashes, ScopedNoteHash, MAX_NOTE_HASHES_PER_TX);
|
|
158
|
-
publicInputs.end.nullifiers = makeClaimed(this.nullifiers, ScopedNullifier, MAX_NULLIFIERS_PER_TX);
|
|
159
|
-
publicInputs.end.privateLogs = makeClaimed(this.privateLogs, ScopedPrivateLogData, MAX_PRIVATE_LOGS_PER_TX);
|
|
160
|
-
publicInputs.validationRequests.noteHashReadRequests = makeClaimed(
|
|
161
|
-
this.noteHashReadRequests,
|
|
162
|
-
ScopedReadRequest,
|
|
163
|
-
MAX_NOTE_HASH_READ_REQUESTS_PER_TX,
|
|
164
|
-
);
|
|
165
|
-
publicInputs.validationRequests.nullifierReadRequests = makeClaimed(
|
|
166
|
-
this.nullifierReadRequests,
|
|
167
|
-
ScopedReadRequest,
|
|
168
|
-
MAX_NULLIFIER_READ_REQUESTS_PER_TX,
|
|
169
|
-
);
|
|
170
|
-
publicInputs.validationRequests.scopedKeyValidationRequestsAndSeparators = makeClaimed(
|
|
171
|
-
this.keyValidationRequests,
|
|
172
|
-
ScopedKeyValidationRequestAndSeparator,
|
|
173
|
-
MAX_KEY_VALIDATION_REQUESTS_PER_TX,
|
|
174
|
-
);
|
|
175
|
-
return publicInputs;
|
|
176
|
-
}
|
|
177
|
-
}
|
|
178
|
-
|
|
179
|
-
/** Builder for PrivateCircuitPublicInputs (call-level) with fluent API for adding side effects. */
|
|
180
|
-
export class PrivateCircuitPublicInputsBuilder {
|
|
181
|
-
private noteHashes: NoteHash[] = [];
|
|
182
|
-
private nullifiers: Nullifier[] = [];
|
|
183
|
-
private noteHashReadRequests: ScopedReadRequest[] = [];
|
|
184
|
-
private nullifierReadRequests: ScopedReadRequest[] = [];
|
|
185
|
-
private keyValidationRequests: KeyValidationRequestAndSeparator[] = [];
|
|
186
|
-
private privateLogs: PrivateLogData[] = [];
|
|
187
|
-
private nextCounter: number;
|
|
188
|
-
|
|
189
|
-
constructor(
|
|
190
|
-
private contractAddress: AztecAddress = DEFAULT_CONTRACT_ADDRESS,
|
|
191
|
-
startCounter = 1,
|
|
192
|
-
) {
|
|
193
|
-
this.nextCounter = startCounter;
|
|
194
|
-
}
|
|
195
|
-
|
|
196
|
-
private getCounter(sideEffectCounter?: number): number {
|
|
197
|
-
if (sideEffectCounter !== undefined) {
|
|
198
|
-
this.nextCounter = sideEffectCounter + 1;
|
|
199
|
-
return sideEffectCounter;
|
|
200
|
-
}
|
|
201
|
-
return this.nextCounter++;
|
|
202
|
-
}
|
|
203
|
-
|
|
204
|
-
/** Adds a note hash. Defaults are generated randomly. */
|
|
205
|
-
addNoteHash(opts?: { value?: Fr; counter?: number }): this {
|
|
206
|
-
const value = opts?.value ?? Fr.random();
|
|
207
|
-
const counter = this.getCounter(opts?.counter);
|
|
208
|
-
this.noteHashes.push(new NoteHash(value, counter));
|
|
209
|
-
return this;
|
|
210
|
-
}
|
|
211
|
-
|
|
212
|
-
/** Adds a nullifier. Defaults are generated randomly. */
|
|
213
|
-
addNullifier(opts?: { value?: Fr; noteHash?: Fr; counter?: number }): this {
|
|
214
|
-
const value = opts?.value ?? Fr.random();
|
|
215
|
-
const noteHash = opts?.noteHash ?? Fr.ZERO;
|
|
216
|
-
const counter = this.getCounter(opts?.counter);
|
|
217
|
-
this.nullifiers.push(new Nullifier(value, noteHash, counter));
|
|
218
|
-
return this;
|
|
219
|
-
}
|
|
220
|
-
|
|
221
|
-
/** Adds a pending note hash read request (non-empty contract address, can match a pending note hash). */
|
|
222
|
-
addPendingNoteHashReadRequest(opts?: { value?: Fr; counter?: number }): this {
|
|
223
|
-
const value = opts?.value ?? Fr.random();
|
|
224
|
-
const counter = this.getCounter(opts?.counter);
|
|
225
|
-
this.noteHashReadRequests.push(new ScopedReadRequest(new ReadRequest(value, counter), this.contractAddress));
|
|
226
|
-
return this;
|
|
227
|
-
}
|
|
228
|
-
|
|
229
|
-
/** Adds a settled note hash read request (empty contract address, resolved against the note hash tree). */
|
|
230
|
-
addSettledNoteHashReadRequest(opts?: { value?: Fr; counter?: number }): this {
|
|
231
|
-
const value = opts?.value ?? Fr.random();
|
|
232
|
-
const counter = this.getCounter(opts?.counter);
|
|
233
|
-
this.noteHashReadRequests.push(new ScopedReadRequest(new ReadRequest(value, counter), AztecAddress.ZERO));
|
|
234
|
-
return this;
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
/** Adds a pending nullifier read request (non-empty contract address, can match a pending nullifier). */
|
|
238
|
-
addPendingNullifierReadRequest(opts?: { value?: Fr; counter?: number }): this {
|
|
239
|
-
const value = opts?.value ?? Fr.random();
|
|
240
|
-
const counter = this.getCounter(opts?.counter);
|
|
241
|
-
this.nullifierReadRequests.push(new ScopedReadRequest(new ReadRequest(value, counter), this.contractAddress));
|
|
242
|
-
return this;
|
|
243
|
-
}
|
|
244
|
-
|
|
245
|
-
/** Adds a settled nullifier read request (empty contract address, resolved against the nullifier tree). */
|
|
246
|
-
addSettledNullifierReadRequest(opts?: { value?: Fr; counter?: number }): this {
|
|
247
|
-
const value = opts?.value ?? Fr.random();
|
|
248
|
-
const counter = this.getCounter(opts?.counter);
|
|
249
|
-
this.nullifierReadRequests.push(new ScopedReadRequest(new ReadRequest(value, counter), AztecAddress.ZERO));
|
|
250
|
-
return this;
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
/** Adds a key validation request. */
|
|
254
|
-
addKeyValidationRequest(): this {
|
|
255
|
-
this.keyValidationRequests.push(
|
|
256
|
-
new KeyValidationRequestAndSeparator(
|
|
257
|
-
new KeyValidationRequest(new Point(Fr.random(), Fr.random(), false), Fr.random()),
|
|
258
|
-
Fr.random(),
|
|
259
|
-
),
|
|
260
|
-
);
|
|
261
|
-
return this;
|
|
262
|
-
}
|
|
263
|
-
|
|
264
|
-
/** Adds a private log. Defaults are generated randomly. */
|
|
265
|
-
addPrivateLog(opts?: { noteHashCounter?: number; counter?: number }): this {
|
|
266
|
-
const noteHashCounter = opts?.noteHashCounter ?? 0;
|
|
267
|
-
const counter = this.getCounter(opts?.counter);
|
|
268
|
-
this.privateLogs.push(new PrivateLogData(PrivateLog.empty(), noteHashCounter, counter));
|
|
269
|
-
return this;
|
|
270
|
-
}
|
|
271
|
-
|
|
272
|
-
/** Builds the PrivateCircuitPublicInputs with all added side effects. */
|
|
273
|
-
build(): PrivateCircuitPublicInputs {
|
|
274
|
-
const publicInputs = PrivateCircuitPublicInputs.empty();
|
|
275
|
-
publicInputs.callContext.contractAddress = this.contractAddress;
|
|
276
|
-
publicInputs.noteHashes = makeClaimed(this.noteHashes, NoteHash, MAX_NOTE_HASHES_PER_CALL);
|
|
277
|
-
publicInputs.nullifiers = makeClaimed(this.nullifiers, Nullifier, MAX_NULLIFIERS_PER_CALL);
|
|
278
|
-
publicInputs.privateLogs = makeClaimed(this.privateLogs, PrivateLogData, MAX_PRIVATE_LOGS_PER_CALL);
|
|
279
|
-
publicInputs.noteHashReadRequests = makeClaimed(
|
|
280
|
-
this.noteHashReadRequests,
|
|
281
|
-
ScopedReadRequest,
|
|
282
|
-
MAX_NOTE_HASH_READ_REQUESTS_PER_CALL,
|
|
283
|
-
);
|
|
284
|
-
publicInputs.nullifierReadRequests = makeClaimed(
|
|
285
|
-
this.nullifierReadRequests,
|
|
286
|
-
ScopedReadRequest,
|
|
287
|
-
MAX_NULLIFIER_READ_REQUESTS_PER_CALL,
|
|
288
|
-
);
|
|
289
|
-
publicInputs.keyValidationRequestsAndSeparators = makeClaimed(
|
|
290
|
-
this.keyValidationRequests,
|
|
291
|
-
KeyValidationRequestAndSeparator,
|
|
292
|
-
MAX_KEY_VALIDATION_REQUESTS_PER_CALL,
|
|
293
|
-
);
|
|
294
|
-
return publicInputs;
|
|
295
|
-
}
|
|
296
|
-
}
|
|
297
|
-
|
|
298
|
-
/** Wraps a PrivateKernelCircuitPublicInputs in a PrivateKernelSimulateOutput. */
|
|
299
|
-
export function makeKernelOutput(
|
|
300
|
-
publicInputs?: PrivateKernelCircuitPublicInputs,
|
|
301
|
-
): PrivateKernelSimulateOutput<PrivateKernelCircuitPublicInputs> {
|
|
302
|
-
return {
|
|
303
|
-
publicInputs: publicInputs ?? PrivateKernelCircuitPublicInputs.empty(),
|
|
304
|
-
verificationKey: VerificationKeyData.empty(),
|
|
305
|
-
outputWitness: new Map(),
|
|
306
|
-
bytecode: Buffer.from([]),
|
|
307
|
-
};
|
|
308
|
-
}
|
|
309
|
-
|
|
310
|
-
/** Wraps a PrivateCircuitPublicInputs in a PrivateCallExecutionResult. */
|
|
311
|
-
export function makeExecutionResult(publicInputs?: PrivateCircuitPublicInputs): PrivateCallExecutionResult {
|
|
312
|
-
return new PrivateCallExecutionResult(
|
|
313
|
-
Buffer.alloc(0),
|
|
314
|
-
Buffer.alloc(0),
|
|
315
|
-
new Map(),
|
|
316
|
-
publicInputs ?? PrivateCircuitPublicInputs.empty(),
|
|
317
|
-
[],
|
|
318
|
-
new Map(),
|
|
319
|
-
[],
|
|
320
|
-
[],
|
|
321
|
-
[],
|
|
322
|
-
[],
|
|
323
|
-
[],
|
|
324
|
-
);
|
|
325
|
-
}
|