@aztec/pxe 0.0.1-commit.d431d1c → 0.0.1-commit.dbf9cec
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/access_scopes.d.ts +9 -0
- package/dest/access_scopes.d.ts.map +1 -0
- package/dest/access_scopes.js +6 -0
- package/dest/bin/check_oracle_version.js +1 -1
- package/dest/block_synchronizer/block_synchronizer.d.ts +9 -5
- package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
- package/dest/block_synchronizer/block_synchronizer.js +62 -16
- package/dest/config/index.d.ts +3 -1
- package/dest/config/index.d.ts.map +1 -1
- package/dest/config/index.js +17 -0
- package/dest/config/package_info.js +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.d.ts +54 -30
- package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.js +175 -74
- 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.d.ts +1 -1
- package/dest/contract_function_simulator/noir-structs/event_validation_request.js +2 -2
- package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +3 -3
- 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 +2 -2
- package/dest/contract_function_simulator/oracle/interfaces.d.ts +15 -12
- package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/oracle.d.ts +7 -5
- package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/oracle.js +51 -29
- package/dest/contract_function_simulator/oracle/private_execution.d.ts +2 -22
- package/dest/contract_function_simulator/oracle/private_execution.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/private_execution.js +0 -37
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +44 -36
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/private_execution_oracle.js +86 -30
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +62 -30
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +107 -88
- package/dest/contract_logging.d.ts +22 -0
- package/dest/contract_logging.d.ts.map +1 -0
- package/dest/contract_logging.js +23 -0
- package/dest/contract_sync/contract_sync_service.d.ts +43 -0
- package/dest/contract_sync/contract_sync_service.d.ts.map +1 -0
- package/dest/contract_sync/contract_sync_service.js +97 -0
- package/dest/contract_sync/helpers.d.ts +29 -0
- package/dest/contract_sync/helpers.d.ts.map +1 -0
- package/dest/contract_sync/helpers.js +55 -0
- package/dest/debug/pxe_debug_utils.d.ts +24 -10
- package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
- package/dest/debug/pxe_debug_utils.js +28 -17
- package/dest/entrypoints/client/bundle/index.d.ts +4 -1
- package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
- package/dest/entrypoints/client/bundle/index.js +3 -0
- package/dest/entrypoints/client/bundle/utils.d.ts +1 -1
- package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
- package/dest/entrypoints/client/bundle/utils.js +21 -7
- package/dest/entrypoints/client/lazy/index.d.ts +4 -1
- package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
- package/dest/entrypoints/client/lazy/index.js +3 -0
- package/dest/entrypoints/client/lazy/utils.d.ts +2 -2
- package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
- package/dest/entrypoints/client/lazy/utils.js +22 -8
- package/dest/entrypoints/pxe_creation_options.d.ts +3 -2
- package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
- package/dest/entrypoints/server/index.d.ts +4 -1
- package/dest/entrypoints/server/index.d.ts.map +1 -1
- package/dest/entrypoints/server/index.js +3 -0
- package/dest/entrypoints/server/utils.d.ts +1 -1
- package/dest/entrypoints/server/utils.d.ts.map +1 -1
- package/dest/entrypoints/server/utils.js +28 -9
- package/dest/events/event_service.d.ts +5 -6
- package/dest/events/event_service.d.ts.map +1 -1
- package/dest/events/event_service.js +6 -7
- package/dest/job_coordinator/job_coordinator.d.ts +3 -2
- package/dest/job_coordinator/job_coordinator.d.ts.map +1 -1
- package/dest/job_coordinator/job_coordinator.js +3 -2
- package/dest/logs/log_service.d.ts +7 -5
- package/dest/logs/log_service.d.ts.map +1 -1
- package/dest/logs/log_service.js +28 -32
- package/dest/notes/note_service.d.ts +9 -8
- package/dest/notes/note_service.d.ts.map +1 -1
- package/dest/notes/note_service.js +17 -16
- package/dest/notes_filter.d.ts +25 -0
- package/dest/notes_filter.d.ts.map +1 -0
- package/dest/notes_filter.js +4 -0
- package/dest/oracle_version.d.ts +3 -3
- package/dest/oracle_version.d.ts.map +1 -1
- package/dest/oracle_version.js +4 -3
- package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
- package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
- package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
- package/dest/private_kernel/hints/index.d.ts +1 -1
- package/dest/private_kernel/hints/index.js +1 -1
- package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +4 -3
- 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 +129 -68
- package/dest/private_kernel/hints/test_utils.d.ts +122 -0
- package/dest/private_kernel/hints/test_utils.d.ts.map +1 -0
- package/dest/private_kernel/hints/test_utils.js +203 -0
- package/dest/private_kernel/private_kernel_execution_prover.d.ts +3 -2
- package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
- package/dest/private_kernel/private_kernel_execution_prover.js +21 -13
- package/dest/private_kernel/private_kernel_oracle.d.ts +8 -4
- package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
- package/dest/private_kernel/private_kernel_oracle.js +7 -3
- package/dest/pxe.d.ts +69 -23
- package/dest/pxe.d.ts.map +1 -1
- package/dest/pxe.js +104 -67
- package/dest/storage/address_store/address_store.d.ts +1 -1
- package/dest/storage/address_store/address_store.d.ts.map +1 -1
- package/dest/storage/address_store/address_store.js +12 -11
- package/dest/storage/anchor_block_store/anchor_block_store.d.ts +9 -1
- package/dest/storage/anchor_block_store/anchor_block_store.d.ts.map +1 -1
- package/dest/storage/anchor_block_store/anchor_block_store.js +8 -1
- package/dest/storage/capsule_store/capsule_store.js +6 -8
- package/dest/storage/contract_store/contract_store.d.ts +42 -16
- package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
- package/dest/storage/contract_store/contract_store.js +157 -84
- package/dest/storage/metadata.d.ts +1 -1
- package/dest/storage/metadata.js +1 -1
- package/dest/storage/note_store/note_store.d.ts +47 -49
- package/dest/storage/note_store/note_store.d.ts.map +1 -1
- package/dest/storage/note_store/note_store.js +278 -252
- package/dest/storage/note_store/stored_note.d.ts +16 -0
- package/dest/storage/note_store/stored_note.d.ts.map +1 -0
- package/dest/storage/note_store/stored_note.js +43 -0
- package/dest/storage/private_event_store/private_event_store.d.ts +17 -4
- package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
- package/dest/storage/private_event_store/private_event_store.js +198 -147
- package/dest/storage/private_event_store/stored_private_event.d.ts +23 -0
- package/dest/storage/private_event_store/stored_private_event.d.ts.map +1 -0
- package/dest/storage/private_event_store/stored_private_event.js +56 -0
- 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/recipient_tagging_store.js +31 -19
- package/dest/storage/tagging_store/sender_address_book_store.d.ts +1 -1
- package/dest/storage/tagging_store/sender_address_book_store.d.ts.map +1 -1
- package/dest/storage/tagging_store/sender_address_book_store.js +20 -14
- 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 +184 -114
- package/dest/tagging/get_all_logs_by_tags.d.ts +24 -0
- package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -0
- package/dest/tagging/get_all_logs_by_tags.js +60 -0
- package/dest/tagging/index.d.ts +3 -2
- package/dest/tagging/index.d.ts.map +1 -1
- package/dest/tagging/index.js +2 -1
- package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +5 -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 +7 -7
- package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +2 -2
- package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +7 -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 +16 -12
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +5 -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/get_status_change_of_pending.d.ts +1 -1
- 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 +5 -8
- package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +5 -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 +20 -18
- package/package.json +25 -16
- package/src/access_scopes.ts +9 -0
- package/src/bin/check_oracle_version.ts +1 -0
- package/src/block_synchronizer/block_synchronizer.ts +76 -33
- package/src/config/index.ts +14 -0
- package/src/config/package_info.ts +1 -1
- package/src/contract_function_simulator/contract_function_simulator.ts +324 -137
- package/src/contract_function_simulator/execution_tagging_index_cache.ts +5 -5
- package/src/contract_function_simulator/noir-structs/event_validation_request.ts +2 -2
- package/src/contract_function_simulator/noir-structs/note_validation_request.ts +2 -2
- package/src/contract_function_simulator/oracle/interfaces.ts +20 -11
- package/src/contract_function_simulator/oracle/oracle.ts +56 -26
- package/src/contract_function_simulator/oracle/private_execution.ts +1 -60
- package/src/contract_function_simulator/oracle/private_execution_oracle.ts +126 -110
- package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +172 -95
- package/src/contract_logging.ts +39 -0
- package/src/contract_sync/contract_sync_service.ts +152 -0
- package/src/contract_sync/helpers.ts +98 -0
- package/src/debug/pxe_debug_utils.ts +63 -18
- package/src/entrypoints/client/bundle/index.ts +3 -0
- package/src/entrypoints/client/bundle/utils.ts +16 -15
- package/src/entrypoints/client/lazy/index.ts +3 -0
- package/src/entrypoints/client/lazy/utils.ts +17 -15
- package/src/entrypoints/pxe_creation_options.ts +2 -1
- package/src/entrypoints/server/index.ts +3 -0
- package/src/entrypoints/server/utils.ts +22 -26
- package/src/events/event_service.ts +5 -7
- package/src/job_coordinator/job_coordinator.ts +4 -3
- package/src/logs/log_service.ts +48 -39
- package/src/notes/note_service.ts +24 -22
- package/src/notes_filter.ts +26 -0
- package/src/oracle_version.ts +4 -3
- package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
- package/src/private_kernel/hints/index.ts +1 -1
- package/src/private_kernel/hints/private_kernel_reset_private_inputs_builder.ts +164 -117
- package/src/private_kernel/hints/test_utils.ts +325 -0
- package/src/private_kernel/private_kernel_execution_prover.ts +25 -15
- package/src/private_kernel/private_kernel_oracle.ts +9 -9
- package/src/pxe.ts +211 -112
- package/src/storage/address_store/address_store.ts +15 -15
- package/src/storage/anchor_block_store/anchor_block_store.ts +8 -0
- package/src/storage/capsule_store/capsule_store.ts +8 -8
- package/src/storage/contract_store/contract_store.ts +186 -96
- package/src/storage/metadata.ts +1 -1
- package/src/storage/note_store/note_store.ts +321 -318
- package/src/storage/note_store/stored_note.ts +48 -0
- package/src/storage/private_event_store/private_event_store.ts +250 -190
- package/src/storage/private_event_store/stored_private_event.ts +73 -0
- package/src/storage/tagging_store/recipient_tagging_store.ts +38 -24
- package/src/storage/tagging_store/sender_address_book_store.ts +20 -14
- package/src/storage/tagging_store/sender_tagging_store.ts +214 -130
- package/src/tagging/get_all_logs_by_tags.ts +92 -0
- package/src/tagging/index.ts +2 -1
- package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +17 -10
- package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +2 -2
- package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +17 -16
- package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +6 -9
- package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +5 -17
- package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +23 -23
- package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
- package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
- package/dest/tree_membership/tree_membership_service.d.ts +0 -50
- package/dest/tree_membership/tree_membership_service.d.ts.map +0 -1
- package/dest/tree_membership/tree_membership_service.js +0 -75
- package/src/tree_membership/tree_membership_service.ts +0 -97
|
@@ -0,0 +1,325 @@
|
|
|
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
|
+
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { vkAsFieldsMegaHonk } from '@aztec/foundation/crypto/keys';
|
|
2
2
|
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
3
|
-
import { createLogger } from '@aztec/foundation/log';
|
|
3
|
+
import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
|
|
4
4
|
import { pushTestData } from '@aztec/foundation/testing';
|
|
5
5
|
import { Timer } from '@aztec/foundation/timer';
|
|
6
6
|
import { getVKTreeRoot } from '@aztec/noir-protocol-circuits-types/vk-tree';
|
|
@@ -56,13 +56,16 @@ export interface PrivateKernelExecutionProverConfig {
|
|
|
56
56
|
* inform state tree updates.
|
|
57
57
|
*/
|
|
58
58
|
export class PrivateKernelExecutionProver {
|
|
59
|
-
private log
|
|
59
|
+
private log: Logger;
|
|
60
60
|
|
|
61
61
|
constructor(
|
|
62
62
|
private oracle: PrivateKernelOracle,
|
|
63
63
|
private proofCreator: PrivateKernelProver,
|
|
64
64
|
private fakeProofs = false,
|
|
65
|
-
|
|
65
|
+
bindings?: LoggerBindings,
|
|
66
|
+
) {
|
|
67
|
+
this.log = createLogger('pxe:private-kernel-execution-prover', bindings);
|
|
68
|
+
}
|
|
66
69
|
|
|
67
70
|
/**
|
|
68
71
|
* Generate a proof for a given transaction request and execution result.
|
|
@@ -113,6 +116,7 @@ export class PrivateKernelExecutionProver {
|
|
|
113
116
|
splitCounter,
|
|
114
117
|
);
|
|
115
118
|
while (resetBuilder.needsReset()) {
|
|
119
|
+
// Inner reset: without siloing.
|
|
116
120
|
const witgenTimer = new Timer();
|
|
117
121
|
const privateInputs = await resetBuilder.build(this.oracle);
|
|
118
122
|
output = generateWitnesses
|
|
@@ -213,16 +217,24 @@ export class PrivateKernelExecutionProver {
|
|
|
213
217
|
firstIteration = false;
|
|
214
218
|
}
|
|
215
219
|
|
|
216
|
-
//
|
|
217
|
-
|
|
220
|
+
// Final reset: include siloing of note hashes, nullifiers and private logs.
|
|
221
|
+
const finalResetBuilder = new PrivateKernelResetPrivateInputsBuilder(
|
|
218
222
|
output,
|
|
219
223
|
[],
|
|
220
224
|
noteHashNullifierCounterMap,
|
|
221
225
|
splitCounter,
|
|
222
226
|
);
|
|
223
|
-
|
|
227
|
+
if (!finalResetBuilder.needsReset()) {
|
|
228
|
+
// The final reset must be performed exactly once, because each tx has at least one nullifier that requires
|
|
229
|
+
// siloing, and siloing cannot be done multiple times.
|
|
230
|
+
// While, in theory, it might be possible to silo note hashes first and then run another reset to silo nullifiers
|
|
231
|
+
// and/or private logs, we currently don't have standalone dimensions for the arrays that require siloing. As a
|
|
232
|
+
// result, all necessary siloing must be done together in a single reset.
|
|
233
|
+
// Refer to the possible combinations of dimensions in private_kernel_reset_config.json.
|
|
234
|
+
throw new Error('Nothing to reset for the final reset.');
|
|
235
|
+
} else {
|
|
224
236
|
const witgenTimer = new Timer();
|
|
225
|
-
const privateInputs = await
|
|
237
|
+
const privateInputs = await finalResetBuilder.build(this.oracle);
|
|
226
238
|
output = generateWitnesses
|
|
227
239
|
? await this.proofCreator.generateResetOutput(privateInputs)
|
|
228
240
|
: await this.proofCreator.simulateReset(privateInputs);
|
|
@@ -236,8 +248,6 @@ export class PrivateKernelExecutionProver {
|
|
|
236
248
|
witgen: witgenTimer.ms(),
|
|
237
249
|
},
|
|
238
250
|
});
|
|
239
|
-
|
|
240
|
-
resetBuilder = new PrivateKernelResetPrivateInputsBuilder(output, [], noteHashNullifierCounterMap, splitCounter);
|
|
241
251
|
}
|
|
242
252
|
|
|
243
253
|
if (output.publicInputs.feePayer.isZero() && skipFeeEnforcement) {
|
|
@@ -257,20 +267,20 @@ export class PrivateKernelExecutionProver {
|
|
|
257
267
|
// TODO: Enable padding once we better understand the final amounts to pad to.
|
|
258
268
|
const paddedSideEffectAmounts = PaddedSideEffectAmounts.empty();
|
|
259
269
|
|
|
260
|
-
// Use the aggregated
|
|
261
|
-
// TODO: Call `
|
|
262
|
-
const
|
|
270
|
+
// Use the aggregated expirationTimestamp set throughout the tx execution.
|
|
271
|
+
// TODO: Call `computeTxExpirationTimestamp` to round the value down and reduce precision, improving privacy.
|
|
272
|
+
const expirationTimestampUpperBound = previousKernelData.publicInputs.expirationTimestamp;
|
|
263
273
|
const anchorBlockTimestamp = previousKernelData.publicInputs.constants.anchorBlockHeader.globalVariables.timestamp;
|
|
264
|
-
if (
|
|
274
|
+
if (expirationTimestampUpperBound <= anchorBlockTimestamp) {
|
|
265
275
|
throw new Error(
|
|
266
|
-
`Include-by timestamp must be greater than the anchor block timestamp. Anchor block timestamp: ${anchorBlockTimestamp}. Include-by timestamp: ${
|
|
276
|
+
`Include-by timestamp must be greater than the anchor block timestamp. Anchor block timestamp: ${anchorBlockTimestamp}. Include-by timestamp: ${expirationTimestampUpperBound}.`,
|
|
267
277
|
);
|
|
268
278
|
}
|
|
269
279
|
|
|
270
280
|
const privateInputs = new PrivateKernelTailCircuitPrivateInputs(
|
|
271
281
|
previousKernelData,
|
|
272
282
|
paddedSideEffectAmounts,
|
|
273
|
-
|
|
283
|
+
expirationTimestampUpperBound,
|
|
274
284
|
);
|
|
275
285
|
|
|
276
286
|
const witgenTimer = new Timer();
|
|
@@ -7,12 +7,8 @@ import { getVKIndex, getVKSiblingPath } from '@aztec/noir-protocol-circuits-type
|
|
|
7
7
|
import { ProtocolContractAddress } from '@aztec/protocol-contracts';
|
|
8
8
|
import type { FunctionSelector } from '@aztec/stdlib/abi';
|
|
9
9
|
import type { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
10
|
-
import {
|
|
11
|
-
import {
|
|
12
|
-
type ContractInstanceWithAddress,
|
|
13
|
-
computeContractClassIdPreimage,
|
|
14
|
-
computeSaltedInitializationHash,
|
|
15
|
-
} from '@aztec/stdlib/contract';
|
|
10
|
+
import { BlockHash } from '@aztec/stdlib/block';
|
|
11
|
+
import { type ContractInstanceWithAddress, computeSaltedInitializationHash } from '@aztec/stdlib/contract';
|
|
16
12
|
import { DelayedPublicMutableValues, DelayedPublicMutableValuesWithHash } from '@aztec/stdlib/delayed-public-mutable';
|
|
17
13
|
import { computePublicDataTreeLeafSlot } from '@aztec/stdlib/hash';
|
|
18
14
|
import type { AztecNode } from '@aztec/stdlib/interfaces/client';
|
|
@@ -30,7 +26,7 @@ export class PrivateKernelOracle {
|
|
|
30
26
|
private contractStore: ContractStore,
|
|
31
27
|
private keyStore: KeyStore,
|
|
32
28
|
private node: AztecNode,
|
|
33
|
-
private blockHash:
|
|
29
|
+
private blockHash: BlockHash,
|
|
34
30
|
) {}
|
|
35
31
|
|
|
36
32
|
/** Retrieves the preimage of a contract address from the registered contract instances db. */
|
|
@@ -49,11 +45,15 @@ export class PrivateKernelOracle {
|
|
|
49
45
|
|
|
50
46
|
/** Retrieves the preimage of a contract class id from the contract classes db. */
|
|
51
47
|
public async getContractClassIdPreimage(contractClassId: Fr) {
|
|
52
|
-
const contractClass = await this.contractStore.
|
|
48
|
+
const contractClass = await this.contractStore.getContractClassWithPreimage(contractClassId);
|
|
53
49
|
if (!contractClass) {
|
|
54
50
|
throw new Error(`Contract class not found when getting class id preimage. Class id: ${contractClassId}.`);
|
|
55
51
|
}
|
|
56
|
-
return
|
|
52
|
+
return {
|
|
53
|
+
artifactHash: contractClass.artifactHash,
|
|
54
|
+
privateFunctionsRoot: contractClass.privateFunctionsRoot,
|
|
55
|
+
publicBytecodeCommitment: contractClass.publicBytecodeCommitment,
|
|
56
|
+
};
|
|
57
57
|
}
|
|
58
58
|
|
|
59
59
|
/** Returns a membership witness with the sibling path and leaf index in our private functions tree. */
|