@aztec/pxe 3.0.0-nightly.20251128 → 3.0.0-nightly.20251201.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/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +2 -2
- package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts.map +1 -1
- package/dest/contract_function_simulator/pxe_oracle_interface.js +1 -1
- package/dest/private_kernel/hints/compute_side_effect_uniqueness_hints.d.ts +3 -0
- package/dest/private_kernel/hints/compute_side_effect_uniqueness_hints.d.ts.map +1 -0
- package/dest/private_kernel/hints/compute_side_effect_uniqueness_hints.js +48 -0
- 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 +4 -1
- package/package.json +16 -16
- package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +1 -1
- package/src/contract_function_simulator/pxe_oracle_interface.ts +1 -1
- package/src/private_kernel/hints/compute_side_effect_uniqueness_hints.ts +173 -0
- package/src/private_kernel/private_kernel_execution_prover.ts +5 -0
|
@@ -12,6 +12,6 @@ export declare class LogRetrievalResponse {
|
|
|
12
12
|
constructor(logPayload: Fr[], txHash: TxHash, uniqueNoteHashesInTx: Fr[], firstNullifierInTx: Fr);
|
|
13
13
|
toFields(): Fr[];
|
|
14
14
|
static toEmptyFields(): Fr[];
|
|
15
|
-
static toSerializedOption(response
|
|
15
|
+
static toSerializedOption(response: LogRetrievalResponse | null): Fr[];
|
|
16
16
|
}
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nX3JldHJpZXZhbF9yZXNwb25zZS5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbnRyYWN0X2Z1bmN0aW9uX3NpbXVsYXRvci9ub2lyLXN0cnVjdHMvbG9nX3JldHJpZXZhbF9yZXNwb25zZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsRUFBRSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDOUMsT0FBTyxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFPL0M7OztHQUdHO0FBQ0gscUJBQWEsb0JBQW9CO0lBRXRCLFVBQVUsRUFBRSxFQUFFLEVBQUU7SUFDaEIsTUFBTSxFQUFFLE1BQU07SUFDZCxvQkFBb0IsRUFBRSxFQUFFLEVBQUU7SUFDMUIsa0JBQWtCLEVBQUUsRUFBRTtJQUovQixZQUNTLFVBQVUsRUFBRSxFQUFFLEVBQUUsRUFDaEIsTUFBTSxFQUFFLE1BQU0sRUFDZCxvQkFBb0IsRUFBRSxFQUFFLEVBQUUsRUFDMUIsa0JBQWtCLEVBQUUsRUFBRSxFQUMzQjtJQUVKLFFBQVEsSUFBSSxFQUFFLEVBQUUsQ0FTZjtJQUVELE1BQU0sQ0FBQyxhQUFhLElBQUksRUFBRSxFQUFFLENBUzNCO0lBRUQsTUFBTSxDQUFDLGtCQUFrQixDQUFDLFFBQVEsRUFBRSxvQkFBb0IsR0FBRyxJQUFJLEdBQUcsRUFBRSxFQUFFLENBTXJFO0NBQ0YifQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"log_retrieval_response.d.ts","sourceRoot":"","sources":["../../../src/contract_function_simulator/noir-structs/log_retrieval_response.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAC9C,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAO/C;;;GAGG;AACH,qBAAa,oBAAoB;IAEtB,UAAU,EAAE,EAAE,EAAE;IAChB,MAAM,EAAE,MAAM;IACd,oBAAoB,EAAE,EAAE,EAAE;IAC1B,kBAAkB,EAAE,EAAE;IAJ/B,YACS,UAAU,EAAE,EAAE,EAAE,EAChB,MAAM,EAAE,MAAM,EACd,oBAAoB,EAAE,EAAE,EAAE,EAC1B,kBAAkB,EAAE,EAAE,EAC3B;IAEJ,QAAQ,IAAI,EAAE,EAAE,CASf;IAED,MAAM,CAAC,aAAa,IAAI,EAAE,EAAE,CAS3B;IAED,MAAM,CAAC,kBAAkB,CAAC,QAAQ,
|
|
1
|
+
{"version":3,"file":"log_retrieval_response.d.ts","sourceRoot":"","sources":["../../../src/contract_function_simulator/noir-structs/log_retrieval_response.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAC9C,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAO/C;;;GAGG;AACH,qBAAa,oBAAoB;IAEtB,UAAU,EAAE,EAAE,EAAE;IAChB,MAAM,EAAE,MAAM;IACd,oBAAoB,EAAE,EAAE,EAAE;IAC1B,kBAAkB,EAAE,EAAE;IAJ/B,YACS,UAAU,EAAE,EAAE,EAAE,EAChB,MAAM,EAAE,MAAM,EACd,oBAAoB,EAAE,EAAE,EAAE,EAC1B,kBAAkB,EAAE,EAAE,EAC3B;IAEJ,QAAQ,IAAI,EAAE,EAAE,CASf;IAED,MAAM,CAAC,aAAa,IAAI,EAAE,EAAE,CAS3B;IAED,MAAM,CAAC,kBAAkB,CAAC,QAAQ,EAAE,oBAAoB,GAAG,IAAI,GAAG,EAAE,EAAE,CAMrE;CACF"}
|
|
@@ -516,7 +516,7 @@ import { NoteValidationRequest } from './noir-structs/note_validation_request.js
|
|
|
516
516
|
} else if (privateLog !== null) {
|
|
517
517
|
return new LogRetrievalResponse(privateLog.logPayload, privateLog.txHash, privateLog.uniqueNoteHashesInTx, privateLog.firstNullifierInTx);
|
|
518
518
|
} else {
|
|
519
|
-
null;
|
|
519
|
+
return null;
|
|
520
520
|
}
|
|
521
521
|
}));
|
|
522
522
|
// Requests are cleared once we're done.
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import { type PrivateCircuitPublicInputs, SideEffectUniquenessHints } from '@aztec/stdlib/kernel';
|
|
2
|
+
export declare function computeSideEffectUniquenessHints(publicInputs: PrivateCircuitPublicInputs): SideEffectUniquenessHints;
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcHV0ZV9zaWRlX2VmZmVjdF91bmlxdWVuZXNzX2hpbnRzLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcHJpdmF0ZV9rZXJuZWwvaGludHMvY29tcHV0ZV9zaWRlX2VmZmVjdF91bmlxdWVuZXNzX2hpbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXdCQSxPQUFPLEVBR0wsS0FBSywwQkFBMEIsRUFFL0IseUJBQXlCLEVBQzFCLE1BQU0sc0JBQXNCLENBQUM7QUFFOUIsd0JBQWdCLGdDQUFnQyxDQUFDLFlBQVksRUFBRSwwQkFBMEIsR0FBRyx5QkFBeUIsQ0F3SHBIIn0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"compute_side_effect_uniqueness_hints.d.ts","sourceRoot":"","sources":["../../../src/private_kernel/hints/compute_side_effect_uniqueness_hints.ts"],"names":[],"mappings":"AAwBA,OAAO,EAGL,KAAK,0BAA0B,EAE/B,yBAAyB,EAC1B,MAAM,sBAAsB,CAAC;AAE9B,wBAAgB,gCAAgC,CAAC,YAAY,EAAE,0BAA0B,GAAG,yBAAyB,CAwHpH"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { GLOBAL_INDEX_CONTRACT_CLASS_LOG_HASH_OFFSET, GLOBAL_INDEX_L2_TO_L1_MSG_OFFSET, GLOBAL_INDEX_NOTE_HASH_OFFSET, GLOBAL_INDEX_NOTE_HASH_READ_REQUEST_OFFSET, GLOBAL_INDEX_NULLIFIER_OFFSET, GLOBAL_INDEX_NULLIFIER_READ_REQUEST_OFFSET, GLOBAL_INDEX_PRIVATE_CALL_REQUEST_OFFSET, GLOBAL_INDEX_PRIVATE_LOG_OFFSET, GLOBAL_INDEX_PUBLIC_CALL_REQUEST_OFFSET, MAX_CONTRACT_CLASS_LOGS_PER_CALL, MAX_ENQUEUED_CALLS_PER_CALL, MAX_L2_TO_L1_MSGS_PER_CALL, MAX_NOTE_HASHES_PER_CALL, MAX_NOTE_HASH_READ_REQUESTS_PER_CALL, MAX_NULLIFIERS_PER_CALL, MAX_NULLIFIER_READ_REQUESTS_PER_CALL, MAX_PRIVATE_CALL_STACK_LENGTH_PER_CALL, MAX_PRIVATE_LOGS_PER_CALL, TOTAL_COUNTED_SIDE_EFFECTS_PER_CALL } from '@aztec/constants';
|
|
2
|
+
import { makeTuple } from '@aztec/foundation/array';
|
|
3
|
+
import { padArrayEnd } from '@aztec/foundation/collection';
|
|
4
|
+
import { SideEffectCounterRange, SideEffectUniquenessHints } from '@aztec/stdlib/kernel';
|
|
5
|
+
export function computeSideEffectUniquenessHints(publicInputs) {
|
|
6
|
+
let sideEffectRanges = [];
|
|
7
|
+
sideEffectRanges = sideEffectRanges.concat(createRangesFromClaimedLengthArray(publicInputs.noteHashReadRequests, GLOBAL_INDEX_NOTE_HASH_READ_REQUEST_OFFSET, createRangeFromCountedItem));
|
|
8
|
+
sideEffectRanges = sideEffectRanges.concat(createRangesFromClaimedLengthArray(publicInputs.nullifierReadRequests, GLOBAL_INDEX_NULLIFIER_READ_REQUEST_OFFSET, createRangeFromCountedItem));
|
|
9
|
+
sideEffectRanges = sideEffectRanges.concat(createRangesFromClaimedLengthArray(publicInputs.noteHashes, GLOBAL_INDEX_NOTE_HASH_OFFSET, createRangeFromCountedItem));
|
|
10
|
+
sideEffectRanges = sideEffectRanges.concat(createRangesFromClaimedLengthArray(publicInputs.nullifiers, GLOBAL_INDEX_NULLIFIER_OFFSET, createRangeFromCountedItem));
|
|
11
|
+
sideEffectRanges = sideEffectRanges.concat(createRangesFromClaimedLengthArray(publicInputs.privateCallRequests, GLOBAL_INDEX_PRIVATE_CALL_REQUEST_OFFSET, createRangeFromPrivateCallRequest));
|
|
12
|
+
sideEffectRanges = sideEffectRanges.concat(createRangesFromClaimedLengthArray(publicInputs.publicCallRequests, GLOBAL_INDEX_PUBLIC_CALL_REQUEST_OFFSET, createRangeFromCountedItem));
|
|
13
|
+
sideEffectRanges = sideEffectRanges.concat(createRangesFromClaimedLengthArray(publicInputs.l2ToL1Msgs, GLOBAL_INDEX_L2_TO_L1_MSG_OFFSET, createRangeFromCountedItem));
|
|
14
|
+
sideEffectRanges = sideEffectRanges.concat(createRangesFromClaimedLengthArray(publicInputs.privateLogs, GLOBAL_INDEX_PRIVATE_LOG_OFFSET, createRangeFromCountedItem));
|
|
15
|
+
sideEffectRanges = sideEffectRanges.concat(createRangesFromClaimedLengthArray(publicInputs.contractClassLogsHashes, GLOBAL_INDEX_CONTRACT_CLASS_LOG_HASH_OFFSET, createRangeFromCountedItem));
|
|
16
|
+
sideEffectRanges.sort((a, b)=>a.start - b.start);
|
|
17
|
+
const sideEffectRangeIndices = makeTuple(TOTAL_COUNTED_SIDE_EFFECTS_PER_CALL, ()=>0);
|
|
18
|
+
for(let i = 0; i < sideEffectRanges.length; i++){
|
|
19
|
+
const range = sideEffectRanges[i];
|
|
20
|
+
sideEffectRangeIndices[range.sideEffectGlobalIndex] = i;
|
|
21
|
+
}
|
|
22
|
+
const hints = SideEffectUniquenessHints.from({
|
|
23
|
+
sideEffectRanges: padArrayEnd(sideEffectRanges, SideEffectCounterRange.empty(), TOTAL_COUNTED_SIDE_EFFECTS_PER_CALL),
|
|
24
|
+
noteHashReadRequestIndices: makeTuple(MAX_NOTE_HASH_READ_REQUESTS_PER_CALL, (i)=>sideEffectRangeIndices[i + GLOBAL_INDEX_NOTE_HASH_READ_REQUEST_OFFSET]),
|
|
25
|
+
nullifierReadRequestIndices: makeTuple(MAX_NULLIFIER_READ_REQUESTS_PER_CALL, (i)=>sideEffectRangeIndices[i + GLOBAL_INDEX_NULLIFIER_READ_REQUEST_OFFSET]),
|
|
26
|
+
noteHashesIndices: makeTuple(MAX_NOTE_HASHES_PER_CALL, (i)=>sideEffectRangeIndices[i + GLOBAL_INDEX_NOTE_HASH_OFFSET]),
|
|
27
|
+
nullifiersIndices: makeTuple(MAX_NULLIFIERS_PER_CALL, (i)=>sideEffectRangeIndices[i + GLOBAL_INDEX_NULLIFIER_OFFSET]),
|
|
28
|
+
privateCallRequestsIndices: makeTuple(MAX_PRIVATE_CALL_STACK_LENGTH_PER_CALL, (i)=>sideEffectRangeIndices[i + GLOBAL_INDEX_PRIVATE_CALL_REQUEST_OFFSET]),
|
|
29
|
+
publicCallRequestsIndices: makeTuple(MAX_ENQUEUED_CALLS_PER_CALL, (i)=>sideEffectRangeIndices[i + GLOBAL_INDEX_PUBLIC_CALL_REQUEST_OFFSET]),
|
|
30
|
+
l2ToL1MsgsIndices: makeTuple(MAX_L2_TO_L1_MSGS_PER_CALL, (i)=>sideEffectRangeIndices[i + GLOBAL_INDEX_L2_TO_L1_MSG_OFFSET]),
|
|
31
|
+
privateLogsIndices: makeTuple(MAX_PRIVATE_LOGS_PER_CALL, (i)=>sideEffectRangeIndices[i + GLOBAL_INDEX_PRIVATE_LOG_OFFSET]),
|
|
32
|
+
contractClassLogsHashesIndices: makeTuple(MAX_CONTRACT_CLASS_LOGS_PER_CALL, (i)=>sideEffectRangeIndices[i + GLOBAL_INDEX_CONTRACT_CLASS_LOG_HASH_OFFSET])
|
|
33
|
+
});
|
|
34
|
+
return hints;
|
|
35
|
+
}
|
|
36
|
+
function createRangesFromClaimedLengthArray(array, globalIndexOffset, rangeConstructor) {
|
|
37
|
+
const ranges = [];
|
|
38
|
+
for(let i = 0; i < array.claimedLength; i++){
|
|
39
|
+
ranges.push(rangeConstructor(array.array[i], globalIndexOffset + i));
|
|
40
|
+
}
|
|
41
|
+
return ranges;
|
|
42
|
+
}
|
|
43
|
+
function createRangeFromCountedItem(item, globalIndex) {
|
|
44
|
+
return new SideEffectCounterRange(item.counter, item.counter, globalIndex);
|
|
45
|
+
}
|
|
46
|
+
function createRangeFromPrivateCallRequest(item, globalIndex) {
|
|
47
|
+
return new SideEffectCounterRange(item.startSideEffectCounter, item.endSideEffectCounter, globalIndex);
|
|
48
|
+
}
|
|
@@ -41,4 +41,4 @@ export declare class PrivateKernelExecutionProver {
|
|
|
41
41
|
private getVkData;
|
|
42
42
|
private createPrivateCallData;
|
|
43
43
|
}
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJpdmF0ZV9rZXJuZWxfZXhlY3V0aW9uX3Byb3Zlci5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3ByaXZhdGVfa2VybmVsL3ByaXZhdGVfa2VybmVsX2V4ZWN1dGlvbl9wcm92ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUUEsT0FBTyxLQUFLLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUMzRSxPQUFPLEVBUUwsS0FBSyxpQ0FBaUMsRUFLdEMsS0FBSyxvQ0FBb0MsRUFFMUMsTUFBTSxzQkFBc0IsQ0FBQztBQUU5QixPQUFPLEVBRUwsS0FBSyxzQkFBc0IsRUFDM0IsU0FBUyxFQUlWLE1BQU0sa0JBQWtCLENBQUM7QUFLMUIsT0FBTyxLQUFLLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQVN0RSxNQUFNLFdBQVcsa0NBQWtDO0lBQ2pELFFBQVEsRUFBRSxPQUFPLENBQUM7SUFDbEIsa0JBQWtCLEVBQUUsT0FBTyxDQUFDO0lBQzVCLFdBQVcsRUFBRSxPQUFPLEdBQUcsaUJBQWlCLEdBQUcsTUFBTSxHQUFHLE1BQU0sQ0FBQztDQUM1RDtBQUVEOzs7OztHQUtHO0FBQ0gscUJBQWEsNEJBQTRCO0lBSXJDLE9BQU8sQ0FBQyxNQUFNO0lBQ2QsT0FBTyxDQUFDLFlBQVk7SUFDcEIsT0FBTyxDQUFDLFVBQVU7SUFMcEIsT0FBTyxDQUFDLEdBQUcsQ0FBdUQ7SUFFbEUsWUFDVSxNQUFNLEVBQUUsbUJBQW1CLEVBQzNCLFlBQVksRUFBRSxtQkFBbUIsRUFDakMsVUFBVSxVQUFRLEVBQ3hCO0lBRUo7Ozs7Ozs7Ozs7T0FVRztJQUNHLGdCQUFnQixDQUNwQixTQUFTLEVBQUUsU0FBUyxFQUNwQixlQUFlLEVBQUUsc0JBQXNCLEVBQ3ZDLEVBQUUsUUFBUSxFQUFFLGtCQUFrQixFQUFFLFdBQVcsRUFBRSxHQUFFLGtDQUk5QyxHQUNBLE9BQU8sQ0FBQyxpQ0FBaUMsQ0FBQyxvQ0FBb0MsQ0FBQyxDQUFDLENBcVJsRjtJQUVEOzs7OztPQUtHO0lBQ0gsT0FBTyxDQUFDLHVCQUF1QjtZQW9CakIsU0FBUztZQVNULHFCQUFxQjtDQWtDcEMifQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"private_kernel_execution_prover.d.ts","sourceRoot":"","sources":["../../src/private_kernel/private_kernel_execution_prover.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,iCAAiC,CAAC;AAC3E,OAAO,EAQL,KAAK,iCAAiC,EAKtC,KAAK,oCAAoC,EAE1C,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EAEL,KAAK,sBAAsB,EAC3B,SAAS,EAIV,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"private_kernel_execution_prover.d.ts","sourceRoot":"","sources":["../../src/private_kernel/private_kernel_execution_prover.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,iCAAiC,CAAC;AAC3E,OAAO,EAQL,KAAK,iCAAiC,EAKtC,KAAK,oCAAoC,EAE1C,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EAEL,KAAK,sBAAsB,EAC3B,SAAS,EAIV,MAAM,kBAAkB,CAAC;AAK1B,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AAStE,MAAM,WAAW,kCAAkC;IACjD,QAAQ,EAAE,OAAO,CAAC;IAClB,kBAAkB,EAAE,OAAO,CAAC;IAC5B,WAAW,EAAE,OAAO,GAAG,iBAAiB,GAAG,MAAM,GAAG,MAAM,CAAC;CAC5D;AAED;;;;;GAKG;AACH,qBAAa,4BAA4B;IAIrC,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,UAAU;IALpB,OAAO,CAAC,GAAG,CAAuD;IAElE,YACU,MAAM,EAAE,mBAAmB,EAC3B,YAAY,EAAE,mBAAmB,EACjC,UAAU,UAAQ,EACxB;IAEJ;;;;;;;;;;OAUG;IACG,gBAAgB,CACpB,SAAS,EAAE,SAAS,EACpB,eAAe,EAAE,sBAAsB,EACvC,EAAE,QAAQ,EAAE,kBAAkB,EAAE,WAAW,EAAE,GAAE,kCAI9C,GACA,OAAO,CAAC,iCAAiC,CAAC,oCAAoC,CAAC,CAAC,CAqRlF;IAED;;;;;OAKG;IACH,OAAO,CAAC,uBAAuB;YAoBjB,SAAS;YAST,qBAAqB;CAkCpC"}
|
|
@@ -11,6 +11,7 @@ import { ChonkProof } from '@aztec/stdlib/proofs';
|
|
|
11
11
|
import { collectNoteHashLeafIndexMap, collectNoteHashNullifierCounterMap, getFinalMinRevertibleSideEffectCounter } from '@aztec/stdlib/tx';
|
|
12
12
|
import { VerificationKeyAsFields, VerificationKeyData, VkData } from '@aztec/stdlib/vks';
|
|
13
13
|
import { PrivateKernelResetPrivateInputsBuilder } from './hints/build_private_kernel_reset_private_inputs.js';
|
|
14
|
+
import { computeSideEffectUniquenessHints } from './hints/compute_side_effect_uniqueness_hints.js';
|
|
14
15
|
const NULL_SIMULATE_OUTPUT = {
|
|
15
16
|
publicInputs: PrivateKernelCircuitPublicInputs.empty(),
|
|
16
17
|
verificationKey: VerificationKeyData.empty(),
|
|
@@ -270,6 +271,7 @@ const NULL_SIMULATE_OUTPUT = {
|
|
|
270
271
|
const functionLeafMembershipWitness = await this.oracle.getFunctionMembershipWitness(currentContractClassId, functionSelector);
|
|
271
272
|
const { artifactHash: contractClassArtifactHash, publicBytecodeCommitment: contractClassPublicBytecodeCommitment } = await this.oracle.getContractClassIdPreimage(currentContractClassId);
|
|
272
273
|
const updatedClassIdHints = await this.oracle.getUpdatedClassIdHints(contractAddress);
|
|
274
|
+
const sideEffectUniquenessHints = computeSideEffectUniquenessHints(publicInputs);
|
|
273
275
|
return PrivateCallData.from({
|
|
274
276
|
publicInputs,
|
|
275
277
|
vk,
|
|
@@ -280,7 +282,8 @@ const NULL_SIMULATE_OUTPUT = {
|
|
|
280
282
|
saltedInitializationHash,
|
|
281
283
|
functionLeafMembershipWitness,
|
|
282
284
|
updatedClassIdHints
|
|
283
|
-
})
|
|
285
|
+
}),
|
|
286
|
+
sideEffectUniquenessHints
|
|
284
287
|
});
|
|
285
288
|
}
|
|
286
289
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@aztec/pxe",
|
|
3
|
-
"version": "3.0.0-nightly.
|
|
3
|
+
"version": "3.0.0-nightly.20251201.2",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"exports": {
|
|
6
6
|
"./server": "./dest/entrypoints/server/index.js",
|
|
@@ -61,19 +61,19 @@
|
|
|
61
61
|
]
|
|
62
62
|
},
|
|
63
63
|
"dependencies": {
|
|
64
|
-
"@aztec/bb-prover": "3.0.0-nightly.
|
|
65
|
-
"@aztec/bb.js": "3.0.0-nightly.
|
|
66
|
-
"@aztec/builder": "3.0.0-nightly.
|
|
67
|
-
"@aztec/constants": "3.0.0-nightly.
|
|
68
|
-
"@aztec/ethereum": "3.0.0-nightly.
|
|
69
|
-
"@aztec/foundation": "3.0.0-nightly.
|
|
70
|
-
"@aztec/key-store": "3.0.0-nightly.
|
|
71
|
-
"@aztec/kv-store": "3.0.0-nightly.
|
|
72
|
-
"@aztec/noir-protocol-circuits-types": "3.0.0-nightly.
|
|
73
|
-
"@aztec/noir-types": "3.0.0-nightly.
|
|
74
|
-
"@aztec/protocol-contracts": "3.0.0-nightly.
|
|
75
|
-
"@aztec/simulator": "3.0.0-nightly.
|
|
76
|
-
"@aztec/stdlib": "3.0.0-nightly.
|
|
64
|
+
"@aztec/bb-prover": "3.0.0-nightly.20251201.2",
|
|
65
|
+
"@aztec/bb.js": "3.0.0-nightly.20251201.2",
|
|
66
|
+
"@aztec/builder": "3.0.0-nightly.20251201.2",
|
|
67
|
+
"@aztec/constants": "3.0.0-nightly.20251201.2",
|
|
68
|
+
"@aztec/ethereum": "3.0.0-nightly.20251201.2",
|
|
69
|
+
"@aztec/foundation": "3.0.0-nightly.20251201.2",
|
|
70
|
+
"@aztec/key-store": "3.0.0-nightly.20251201.2",
|
|
71
|
+
"@aztec/kv-store": "3.0.0-nightly.20251201.2",
|
|
72
|
+
"@aztec/noir-protocol-circuits-types": "3.0.0-nightly.20251201.2",
|
|
73
|
+
"@aztec/noir-types": "3.0.0-nightly.20251201.2",
|
|
74
|
+
"@aztec/protocol-contracts": "3.0.0-nightly.20251201.2",
|
|
75
|
+
"@aztec/simulator": "3.0.0-nightly.20251201.2",
|
|
76
|
+
"@aztec/stdlib": "3.0.0-nightly.20251201.2",
|
|
77
77
|
"koa": "^2.16.1",
|
|
78
78
|
"koa-router": "^13.1.1",
|
|
79
79
|
"lodash.omit": "^4.5.0",
|
|
@@ -82,8 +82,8 @@
|
|
|
82
82
|
"viem": "npm:@aztec/viem@2.38.2"
|
|
83
83
|
},
|
|
84
84
|
"devDependencies": {
|
|
85
|
-
"@aztec/merkle-tree": "3.0.0-nightly.
|
|
86
|
-
"@aztec/noir-test-contracts.js": "3.0.0-nightly.
|
|
85
|
+
"@aztec/merkle-tree": "3.0.0-nightly.20251201.2",
|
|
86
|
+
"@aztec/noir-test-contracts.js": "3.0.0-nightly.20251201.2",
|
|
87
87
|
"@jest/globals": "^30.0.0",
|
|
88
88
|
"@types/jest": "^30.0.0",
|
|
89
89
|
"@types/lodash.omit": "^4.5.7",
|
|
@@ -42,7 +42,7 @@ export class LogRetrievalResponse {
|
|
|
42
42
|
return range(serializationLen).map(_ => Fr.zero());
|
|
43
43
|
}
|
|
44
44
|
|
|
45
|
-
static toSerializedOption(response
|
|
45
|
+
static toSerializedOption(response: LogRetrievalResponse | null): Fr[] {
|
|
46
46
|
if (response) {
|
|
47
47
|
return [new Fr(1), ...response.toFields()];
|
|
48
48
|
} else {
|
|
@@ -0,0 +1,173 @@
|
|
|
1
|
+
import {
|
|
2
|
+
GLOBAL_INDEX_CONTRACT_CLASS_LOG_HASH_OFFSET,
|
|
3
|
+
GLOBAL_INDEX_L2_TO_L1_MSG_OFFSET,
|
|
4
|
+
GLOBAL_INDEX_NOTE_HASH_OFFSET,
|
|
5
|
+
GLOBAL_INDEX_NOTE_HASH_READ_REQUEST_OFFSET,
|
|
6
|
+
GLOBAL_INDEX_NULLIFIER_OFFSET,
|
|
7
|
+
GLOBAL_INDEX_NULLIFIER_READ_REQUEST_OFFSET,
|
|
8
|
+
GLOBAL_INDEX_PRIVATE_CALL_REQUEST_OFFSET,
|
|
9
|
+
GLOBAL_INDEX_PRIVATE_LOG_OFFSET,
|
|
10
|
+
GLOBAL_INDEX_PUBLIC_CALL_REQUEST_OFFSET,
|
|
11
|
+
MAX_CONTRACT_CLASS_LOGS_PER_CALL,
|
|
12
|
+
MAX_ENQUEUED_CALLS_PER_CALL,
|
|
13
|
+
MAX_L2_TO_L1_MSGS_PER_CALL,
|
|
14
|
+
MAX_NOTE_HASHES_PER_CALL,
|
|
15
|
+
MAX_NOTE_HASH_READ_REQUESTS_PER_CALL,
|
|
16
|
+
MAX_NULLIFIERS_PER_CALL,
|
|
17
|
+
MAX_NULLIFIER_READ_REQUESTS_PER_CALL,
|
|
18
|
+
MAX_PRIVATE_CALL_STACK_LENGTH_PER_CALL,
|
|
19
|
+
MAX_PRIVATE_LOGS_PER_CALL,
|
|
20
|
+
TOTAL_COUNTED_SIDE_EFFECTS_PER_CALL,
|
|
21
|
+
} from '@aztec/constants';
|
|
22
|
+
import { makeTuple } from '@aztec/foundation/array';
|
|
23
|
+
import { padArrayEnd } from '@aztec/foundation/collection';
|
|
24
|
+
import type { Serializable } from '@aztec/foundation/serialize';
|
|
25
|
+
import {
|
|
26
|
+
ClaimedLengthArray,
|
|
27
|
+
PrivateCallRequest,
|
|
28
|
+
type PrivateCircuitPublicInputs,
|
|
29
|
+
SideEffectCounterRange,
|
|
30
|
+
SideEffectUniquenessHints,
|
|
31
|
+
} from '@aztec/stdlib/kernel';
|
|
32
|
+
|
|
33
|
+
export function computeSideEffectUniquenessHints(publicInputs: PrivateCircuitPublicInputs): SideEffectUniquenessHints {
|
|
34
|
+
let sideEffectRanges: SideEffectCounterRange[] = [];
|
|
35
|
+
|
|
36
|
+
sideEffectRanges = sideEffectRanges.concat(
|
|
37
|
+
createRangesFromClaimedLengthArray(
|
|
38
|
+
publicInputs.noteHashReadRequests,
|
|
39
|
+
GLOBAL_INDEX_NOTE_HASH_READ_REQUEST_OFFSET,
|
|
40
|
+
createRangeFromCountedItem,
|
|
41
|
+
),
|
|
42
|
+
);
|
|
43
|
+
sideEffectRanges = sideEffectRanges.concat(
|
|
44
|
+
createRangesFromClaimedLengthArray(
|
|
45
|
+
publicInputs.nullifierReadRequests,
|
|
46
|
+
GLOBAL_INDEX_NULLIFIER_READ_REQUEST_OFFSET,
|
|
47
|
+
createRangeFromCountedItem,
|
|
48
|
+
),
|
|
49
|
+
);
|
|
50
|
+
sideEffectRanges = sideEffectRanges.concat(
|
|
51
|
+
createRangesFromClaimedLengthArray(
|
|
52
|
+
publicInputs.noteHashes,
|
|
53
|
+
GLOBAL_INDEX_NOTE_HASH_OFFSET,
|
|
54
|
+
createRangeFromCountedItem,
|
|
55
|
+
),
|
|
56
|
+
);
|
|
57
|
+
sideEffectRanges = sideEffectRanges.concat(
|
|
58
|
+
createRangesFromClaimedLengthArray(
|
|
59
|
+
publicInputs.nullifiers,
|
|
60
|
+
GLOBAL_INDEX_NULLIFIER_OFFSET,
|
|
61
|
+
createRangeFromCountedItem,
|
|
62
|
+
),
|
|
63
|
+
);
|
|
64
|
+
sideEffectRanges = sideEffectRanges.concat(
|
|
65
|
+
createRangesFromClaimedLengthArray(
|
|
66
|
+
publicInputs.privateCallRequests,
|
|
67
|
+
GLOBAL_INDEX_PRIVATE_CALL_REQUEST_OFFSET,
|
|
68
|
+
createRangeFromPrivateCallRequest,
|
|
69
|
+
),
|
|
70
|
+
);
|
|
71
|
+
sideEffectRanges = sideEffectRanges.concat(
|
|
72
|
+
createRangesFromClaimedLengthArray(
|
|
73
|
+
publicInputs.publicCallRequests,
|
|
74
|
+
GLOBAL_INDEX_PUBLIC_CALL_REQUEST_OFFSET,
|
|
75
|
+
createRangeFromCountedItem,
|
|
76
|
+
),
|
|
77
|
+
);
|
|
78
|
+
sideEffectRanges = sideEffectRanges.concat(
|
|
79
|
+
createRangesFromClaimedLengthArray(
|
|
80
|
+
publicInputs.l2ToL1Msgs,
|
|
81
|
+
GLOBAL_INDEX_L2_TO_L1_MSG_OFFSET,
|
|
82
|
+
createRangeFromCountedItem,
|
|
83
|
+
),
|
|
84
|
+
);
|
|
85
|
+
sideEffectRanges = sideEffectRanges.concat(
|
|
86
|
+
createRangesFromClaimedLengthArray(
|
|
87
|
+
publicInputs.privateLogs,
|
|
88
|
+
GLOBAL_INDEX_PRIVATE_LOG_OFFSET,
|
|
89
|
+
createRangeFromCountedItem,
|
|
90
|
+
),
|
|
91
|
+
);
|
|
92
|
+
sideEffectRanges = sideEffectRanges.concat(
|
|
93
|
+
createRangesFromClaimedLengthArray(
|
|
94
|
+
publicInputs.contractClassLogsHashes,
|
|
95
|
+
GLOBAL_INDEX_CONTRACT_CLASS_LOG_HASH_OFFSET,
|
|
96
|
+
createRangeFromCountedItem,
|
|
97
|
+
),
|
|
98
|
+
);
|
|
99
|
+
|
|
100
|
+
sideEffectRanges.sort((a, b) => a.start - b.start);
|
|
101
|
+
|
|
102
|
+
const sideEffectRangeIndices = makeTuple(TOTAL_COUNTED_SIDE_EFFECTS_PER_CALL, () => 0);
|
|
103
|
+
for (let i = 0; i < sideEffectRanges.length; i++) {
|
|
104
|
+
const range = sideEffectRanges[i];
|
|
105
|
+
sideEffectRangeIndices[range.sideEffectGlobalIndex] = i;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
const hints = SideEffectUniquenessHints.from({
|
|
109
|
+
sideEffectRanges: padArrayEnd(
|
|
110
|
+
sideEffectRanges,
|
|
111
|
+
SideEffectCounterRange.empty(),
|
|
112
|
+
TOTAL_COUNTED_SIDE_EFFECTS_PER_CALL,
|
|
113
|
+
),
|
|
114
|
+
noteHashReadRequestIndices: makeTuple(
|
|
115
|
+
MAX_NOTE_HASH_READ_REQUESTS_PER_CALL,
|
|
116
|
+
i => sideEffectRangeIndices[i + GLOBAL_INDEX_NOTE_HASH_READ_REQUEST_OFFSET],
|
|
117
|
+
),
|
|
118
|
+
nullifierReadRequestIndices: makeTuple(
|
|
119
|
+
MAX_NULLIFIER_READ_REQUESTS_PER_CALL,
|
|
120
|
+
i => sideEffectRangeIndices[i + GLOBAL_INDEX_NULLIFIER_READ_REQUEST_OFFSET],
|
|
121
|
+
),
|
|
122
|
+
noteHashesIndices: makeTuple(
|
|
123
|
+
MAX_NOTE_HASHES_PER_CALL,
|
|
124
|
+
i => sideEffectRangeIndices[i + GLOBAL_INDEX_NOTE_HASH_OFFSET],
|
|
125
|
+
),
|
|
126
|
+
nullifiersIndices: makeTuple(
|
|
127
|
+
MAX_NULLIFIERS_PER_CALL,
|
|
128
|
+
i => sideEffectRangeIndices[i + GLOBAL_INDEX_NULLIFIER_OFFSET],
|
|
129
|
+
),
|
|
130
|
+
privateCallRequestsIndices: makeTuple(
|
|
131
|
+
MAX_PRIVATE_CALL_STACK_LENGTH_PER_CALL,
|
|
132
|
+
i => sideEffectRangeIndices[i + GLOBAL_INDEX_PRIVATE_CALL_REQUEST_OFFSET],
|
|
133
|
+
),
|
|
134
|
+
publicCallRequestsIndices: makeTuple(
|
|
135
|
+
MAX_ENQUEUED_CALLS_PER_CALL,
|
|
136
|
+
i => sideEffectRangeIndices[i + GLOBAL_INDEX_PUBLIC_CALL_REQUEST_OFFSET],
|
|
137
|
+
),
|
|
138
|
+
l2ToL1MsgsIndices: makeTuple(
|
|
139
|
+
MAX_L2_TO_L1_MSGS_PER_CALL,
|
|
140
|
+
i => sideEffectRangeIndices[i + GLOBAL_INDEX_L2_TO_L1_MSG_OFFSET],
|
|
141
|
+
),
|
|
142
|
+
privateLogsIndices: makeTuple(
|
|
143
|
+
MAX_PRIVATE_LOGS_PER_CALL,
|
|
144
|
+
i => sideEffectRangeIndices[i + GLOBAL_INDEX_PRIVATE_LOG_OFFSET],
|
|
145
|
+
),
|
|
146
|
+
contractClassLogsHashesIndices: makeTuple(
|
|
147
|
+
MAX_CONTRACT_CLASS_LOGS_PER_CALL,
|
|
148
|
+
i => sideEffectRangeIndices[i + GLOBAL_INDEX_CONTRACT_CLASS_LOG_HASH_OFFSET],
|
|
149
|
+
),
|
|
150
|
+
});
|
|
151
|
+
|
|
152
|
+
return hints;
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
function createRangesFromClaimedLengthArray<T extends Serializable, N extends number>(
|
|
156
|
+
array: ClaimedLengthArray<T, N>,
|
|
157
|
+
globalIndexOffset: number,
|
|
158
|
+
rangeConstructor: (item: T, globalIndex: number) => SideEffectCounterRange,
|
|
159
|
+
): SideEffectCounterRange[] {
|
|
160
|
+
const ranges = [];
|
|
161
|
+
for (let i = 0; i < array.claimedLength; i++) {
|
|
162
|
+
ranges.push(rangeConstructor(array.array[i], globalIndexOffset + i));
|
|
163
|
+
}
|
|
164
|
+
return ranges;
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
function createRangeFromCountedItem(item: { counter: number }, globalIndex: number): SideEffectCounterRange {
|
|
168
|
+
return new SideEffectCounterRange(item.counter, item.counter, globalIndex);
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
function createRangeFromPrivateCallRequest(item: PrivateCallRequest, globalIndex: number): SideEffectCounterRange {
|
|
172
|
+
return new SideEffectCounterRange(item.startSideEffectCounter, item.endSideEffectCounter, globalIndex);
|
|
173
|
+
}
|
|
@@ -35,6 +35,7 @@ import {
|
|
|
35
35
|
import { VerificationKeyAsFields, VerificationKeyData, VkData } from '@aztec/stdlib/vks';
|
|
36
36
|
|
|
37
37
|
import { PrivateKernelResetPrivateInputsBuilder } from './hints/build_private_kernel_reset_private_inputs.js';
|
|
38
|
+
import { computeSideEffectUniquenessHints } from './hints/compute_side_effect_uniqueness_hints.js';
|
|
38
39
|
import type { PrivateKernelOracle } from './private_kernel_oracle.js';
|
|
39
40
|
|
|
40
41
|
const NULL_SIMULATE_OUTPUT: PrivateKernelSimulateOutput<PrivateKernelCircuitPublicInputs> = {
|
|
@@ -415,6 +416,9 @@ export class PrivateKernelExecutionProver {
|
|
|
415
416
|
await this.oracle.getContractClassIdPreimage(currentContractClassId);
|
|
416
417
|
|
|
417
418
|
const updatedClassIdHints = await this.oracle.getUpdatedClassIdHints(contractAddress);
|
|
419
|
+
|
|
420
|
+
const sideEffectUniquenessHints = computeSideEffectUniquenessHints(publicInputs);
|
|
421
|
+
|
|
418
422
|
return PrivateCallData.from({
|
|
419
423
|
publicInputs,
|
|
420
424
|
vk,
|
|
@@ -426,6 +430,7 @@ export class PrivateKernelExecutionProver {
|
|
|
426
430
|
functionLeafMembershipWitness,
|
|
427
431
|
updatedClassIdHints,
|
|
428
432
|
}),
|
|
433
|
+
sideEffectUniquenessHints,
|
|
429
434
|
});
|
|
430
435
|
}
|
|
431
436
|
}
|