@aztec/pxe 0.0.1-commit.c7c42ec → 0.0.1-commit.cf93bcc56
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 +13 -5
- package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
- package/dest/block_synchronizer/block_synchronizer.js +74 -20
- 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/benchmarked_node.d.ts +9 -0
- package/dest/contract_function_simulator/benchmarked_node.d.ts.map +1 -0
- package/dest/contract_function_simulator/benchmarked_node.js +77 -0
- package/dest/contract_function_simulator/contract_function_simulator.d.ts +57 -34
- package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.js +195 -77
- package/dest/contract_function_simulator/execution_note_cache.d.ts +18 -9
- package/dest/contract_function_simulator/execution_note_cache.d.ts.map +1 -1
- package/dest/contract_function_simulator/execution_note_cache.js +45 -28
- package/dest/contract_function_simulator/index.d.ts +2 -2
- package/dest/contract_function_simulator/index.d.ts.map +1 -1
- package/dest/contract_function_simulator/index.js +1 -1
- package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +4 -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 +7 -4
- 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/noir-structs/utility_context.d.ts +4 -10
- package/dest/contract_function_simulator/noir-structs/utility_context.d.ts.map +1 -1
- package/dest/contract_function_simulator/noir-structs/utility_context.js +7 -18
- package/dest/contract_function_simulator/oracle/interfaces.d.ts +17 -13
- package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts +3 -1
- package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +6 -6
- package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/note_packing_utils.js +8 -8
- package/dest/contract_function_simulator/oracle/oracle.d.ts +12 -10
- package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/oracle.js +67 -44
- package/dest/contract_function_simulator/oracle/private_execution.d.ts +2 -26
- package/dest/contract_function_simulator/oracle/private_execution.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/private_execution.js +1 -37
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +45 -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 +92 -53
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +67 -33
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +132 -108
- 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 +3 -1
- package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
- package/dest/entrypoints/client/bundle/index.js +2 -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 +31 -8
- package/dest/entrypoints/client/lazy/index.d.ts +3 -1
- package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
- package/dest/entrypoints/client/lazy/index.js +2 -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 +32 -9
- package/dest/entrypoints/pxe_creation_options.d.ts +5 -3
- package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
- package/dest/entrypoints/server/index.d.ts +5 -1
- package/dest/entrypoints/server/index.d.ts.map +1 -1
- package/dest/entrypoints/server/index.js +4 -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 +39 -16
- package/dest/events/event_service.d.ts +6 -6
- package/dest/events/event_service.d.ts.map +1 -1
- package/dest/events/event_service.js +19 -22
- package/dest/events/private_event_filter_validator.d.ts +5 -5
- package/dest/events/private_event_filter_validator.d.ts.map +1 -1
- package/dest/events/private_event_filter_validator.js +5 -6
- package/dest/job_coordinator/job_coordinator.d.ts +75 -0
- package/dest/job_coordinator/job_coordinator.d.ts.map +1 -0
- package/dest/job_coordinator/job_coordinator.js +94 -0
- package/dest/logs/log_service.d.ts +8 -5
- package/dest/logs/log_service.d.ts.map +1 -1
- package/dest/logs/log_service.js +28 -30
- package/dest/notes/note_service.d.ts +10 -9
- package/dest/notes/note_service.d.ts.map +1 -1
- package/dest/notes/note_service.js +34 -38
- 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 +3 -3
- package/dest/private_kernel/hints/index.d.ts.map +1 -1
- package/dest/private_kernel/hints/index.js +2 -2
- package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +28 -0
- package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -0
- package/dest/private_kernel/hints/{build_private_kernel_reset_private_inputs.js → private_kernel_reset_private_inputs_builder.js} +16 -10
- 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 +12 -13
- package/dest/private_kernel/private_kernel_oracle.d.ts +24 -28
- package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
- package/dest/private_kernel/private_kernel_oracle.js +90 -2
- package/dest/pxe.d.ts +76 -58
- package/dest/pxe.d.ts.map +1 -1
- package/dest/pxe.js +131 -121
- 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.d.ts +24 -9
- package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -1
- package/dest/storage/capsule_store/capsule_store.js +130 -23
- package/dest/storage/contract_store/contract_store.d.ts +1 -1
- package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
- package/dest/storage/contract_store/contract_store.js +27 -18
- package/dest/storage/metadata.d.ts +1 -1
- package/dest/storage/metadata.js +1 -1
- package/dest/storage/note_store/note_store.d.ts +50 -51
- package/dest/storage/note_store/note_store.d.ts.map +1 -1
- package/dest/storage/note_store/note_store.js +284 -263
- 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 +47 -7
- package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
- package/dest/storage/private_event_store/private_event_store.js +231 -73
- 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 +15 -8
- package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
- package/dest/storage/tagging_store/recipient_tagging_store.js +88 -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 +19 -9
- package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
- package/dest/storage/tagging_store/sender_tagging_store.js +253 -101
- package/dest/tagging/constants.d.ts +2 -0
- package/dest/tagging/constants.d.ts.map +1 -0
- package/dest/tagging/constants.js +10 -0
- 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 -10
- package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +3 -2
- 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 +12 -12
- package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +2 -2
- package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +3 -2
- 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 +5 -2
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +3 -2
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +8 -8
- 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 -2
- 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 +10 -5
- package/package.json +27 -18
- package/src/access_scopes.ts +9 -0
- package/src/bin/check_oracle_version.ts +1 -0
- package/src/block_synchronizer/block_synchronizer.ts +93 -32
- package/src/config/index.ts +14 -0
- package/src/config/package_info.ts +1 -1
- package/src/contract_function_simulator/benchmarked_node.ts +103 -0
- package/src/contract_function_simulator/contract_function_simulator.ts +348 -133
- package/src/contract_function_simulator/execution_note_cache.ts +44 -25
- package/src/contract_function_simulator/index.ts +1 -1
- package/src/contract_function_simulator/noir-structs/event_validation_request.ts +6 -2
- package/src/contract_function_simulator/noir-structs/note_validation_request.ts +2 -2
- package/src/contract_function_simulator/noir-structs/utility_context.ts +6 -25
- package/src/contract_function_simulator/oracle/interfaces.ts +22 -12
- package/src/contract_function_simulator/oracle/note_packing_utils.ts +10 -10
- package/src/contract_function_simulator/oracle/oracle.ts +79 -47
- package/src/contract_function_simulator/oracle/private_execution.ts +1 -69
- package/src/contract_function_simulator/oracle/private_execution_oracle.ts +129 -132
- package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +197 -115
- 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 +2 -0
- package/src/entrypoints/client/bundle/utils.ts +23 -16
- package/src/entrypoints/client/lazy/index.ts +2 -0
- package/src/entrypoints/client/lazy/utils.ts +24 -17
- package/src/entrypoints/pxe_creation_options.ts +4 -2
- package/src/entrypoints/server/index.ts +4 -0
- package/src/entrypoints/server/utils.ts +33 -41
- package/src/events/event_service.ts +19 -25
- package/src/events/private_event_filter_validator.ts +3 -5
- package/src/job_coordinator/job_coordinator.ts +150 -0
- package/src/logs/log_service.ts +40 -34
- package/src/notes/note_service.ts +41 -45
- 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 +2 -2
- package/src/private_kernel/hints/{build_private_kernel_reset_private_inputs.ts → private_kernel_reset_private_inputs_builder.ts} +39 -28
- package/src/private_kernel/private_kernel_execution_prover.ts +15 -14
- package/src/private_kernel/private_kernel_oracle.ts +116 -36
- package/src/pxe.ts +257 -180
- 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 +159 -23
- package/src/storage/contract_store/contract_store.ts +26 -15
- package/src/storage/metadata.ts +1 -1
- package/src/storage/note_store/note_store.ts +326 -320
- package/src/storage/note_store/stored_note.ts +48 -0
- package/src/storage/private_event_store/private_event_store.ts +301 -79
- package/src/storage/private_event_store/stored_private_event.ts +73 -0
- package/src/storage/tagging_store/recipient_tagging_store.ts +106 -20
- package/src/storage/tagging_store/sender_address_book_store.ts +20 -14
- package/src/storage/tagging_store/sender_tagging_store.ts +294 -109
- package/src/tagging/constants.ts +10 -0
- package/src/tagging/get_all_logs_by_tags.ts +92 -0
- package/src/tagging/index.ts +2 -11
- package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +25 -11
- package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +2 -2
- package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +7 -1
- package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +10 -7
- package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +5 -13
- package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +16 -4
- package/dest/contract_function_simulator/proxied_node.d.ts +0 -9
- package/dest/contract_function_simulator/proxied_node.d.ts.map +0 -1
- package/dest/contract_function_simulator/proxied_node.js +0 -27
- package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts +0 -28
- package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts.map +0 -1
- 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/private_kernel/private_kernel_oracle_impl.d.ts +0 -46
- package/dest/private_kernel/private_kernel_oracle_impl.d.ts.map +0 -1
- package/dest/private_kernel/private_kernel_oracle_impl.js +0 -86
- package/dest/public_storage/public_storage_service.d.ts +0 -24
- package/dest/public_storage/public_storage_service.d.ts.map +0 -1
- package/dest/public_storage/public_storage_service.js +0 -26
- package/dest/tree_membership/tree_membership_service.d.ts +0 -52
- package/dest/tree_membership/tree_membership_service.d.ts.map +0 -1
- package/dest/tree_membership/tree_membership_service.js +0 -84
- package/src/contract_function_simulator/proxied_node.ts +0 -33
- package/src/private_kernel/private_kernel_oracle_impl.ts +0 -133
- package/src/public_storage/public_storage_service.ts +0 -33
- package/src/tree_membership/tree_membership_service.ts +0 -112
|
@@ -8,16 +8,20 @@ import {
|
|
|
8
8
|
FIXED_DA_GAS,
|
|
9
9
|
FIXED_L2_GAS,
|
|
10
10
|
L2_GAS_PER_CONTRACT_CLASS_LOG,
|
|
11
|
+
L2_GAS_PER_L2_TO_L1_MSG,
|
|
12
|
+
L2_GAS_PER_NOTE_HASH,
|
|
13
|
+
L2_GAS_PER_NULLIFIER,
|
|
11
14
|
L2_GAS_PER_PRIVATE_LOG,
|
|
12
15
|
MAX_CONTRACT_CLASS_LOGS_PER_TX,
|
|
13
16
|
MAX_ENQUEUED_CALLS_PER_TX,
|
|
14
17
|
MAX_L2_TO_L1_MSGS_PER_TX,
|
|
15
18
|
MAX_NOTE_HASHES_PER_TX,
|
|
19
|
+
MAX_NOTE_HASH_READ_REQUESTS_PER_TX,
|
|
16
20
|
MAX_NULLIFIERS_PER_TX,
|
|
21
|
+
MAX_NULLIFIER_READ_REQUESTS_PER_TX,
|
|
17
22
|
MAX_PRIVATE_LOGS_PER_TX,
|
|
18
23
|
} from '@aztec/constants';
|
|
19
24
|
import { arrayNonEmptyLength, padArrayEnd } from '@aztec/foundation/collection';
|
|
20
|
-
import { poseidon2Hash } from '@aztec/foundation/crypto/poseidon';
|
|
21
25
|
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
22
26
|
import { type Logger, createLogger } from '@aztec/foundation/log';
|
|
23
27
|
import { Timer } from '@aztec/foundation/timer';
|
|
@@ -37,25 +41,36 @@ import type { FunctionCall } from '@aztec/stdlib/abi';
|
|
|
37
41
|
import { FunctionSelector, FunctionType } from '@aztec/stdlib/abi';
|
|
38
42
|
import type { AuthWitness } from '@aztec/stdlib/auth-witness';
|
|
39
43
|
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
44
|
+
import type { BlockParameter } from '@aztec/stdlib/block';
|
|
40
45
|
import { Gas } from '@aztec/stdlib/gas';
|
|
41
46
|
import {
|
|
42
47
|
computeNoteHashNonce,
|
|
43
48
|
computeProtocolNullifier,
|
|
49
|
+
computeSiloedPrivateLogFirstField,
|
|
44
50
|
computeUniqueNoteHash,
|
|
45
51
|
siloNoteHash,
|
|
46
52
|
siloNullifier,
|
|
47
53
|
} from '@aztec/stdlib/hash';
|
|
48
54
|
import type { AztecNode } from '@aztec/stdlib/interfaces/server';
|
|
49
55
|
import {
|
|
56
|
+
ClaimedLengthArray,
|
|
50
57
|
PartialPrivateTailPublicInputsForPublic,
|
|
51
58
|
PartialPrivateTailPublicInputsForRollup,
|
|
52
59
|
type PrivateExecutionStep,
|
|
53
60
|
type PrivateKernelExecutionProofOutput,
|
|
54
61
|
PrivateKernelTailCircuitPublicInputs,
|
|
62
|
+
PrivateLogData,
|
|
55
63
|
PrivateToPublicAccumulatedData,
|
|
56
64
|
PrivateToRollupAccumulatedData,
|
|
57
65
|
PublicCallRequest,
|
|
66
|
+
ReadRequestActionEnum,
|
|
58
67
|
ScopedLogHash,
|
|
68
|
+
ScopedNoteHash,
|
|
69
|
+
ScopedNullifier,
|
|
70
|
+
ScopedReadRequest,
|
|
71
|
+
buildTransientDataHints,
|
|
72
|
+
getNoteHashReadRequestResetActions,
|
|
73
|
+
getNullifierReadRequestResetActions,
|
|
59
74
|
} from '@aztec/stdlib/kernel';
|
|
60
75
|
import { PrivateLog } from '@aztec/stdlib/logs';
|
|
61
76
|
import { ScopedL2ToL1Message } from '@aztec/stdlib/messaging';
|
|
@@ -68,11 +83,13 @@ import {
|
|
|
68
83
|
TxConstantData,
|
|
69
84
|
TxExecutionRequest,
|
|
70
85
|
collectNested,
|
|
86
|
+
collectNoteHashNullifierCounterMap,
|
|
71
87
|
getFinalMinRevertibleSideEffectCounter,
|
|
72
88
|
} from '@aztec/stdlib/tx';
|
|
73
89
|
|
|
90
|
+
import type { AccessScopes } from '../access_scopes.js';
|
|
91
|
+
import type { ContractSyncService } from '../contract_sync/contract_sync_service.js';
|
|
74
92
|
import type { AddressStore } from '../storage/address_store/address_store.js';
|
|
75
|
-
import type { AnchorBlockStore } from '../storage/anchor_block_store/anchor_block_store.js';
|
|
76
93
|
import type { CapsuleStore } from '../storage/capsule_store/capsule_store.js';
|
|
77
94
|
import type { ContractStore } from '../storage/contract_store/contract_store.js';
|
|
78
95
|
import type { NoteStore } from '../storage/note_store/note_store.js';
|
|
@@ -80,64 +97,101 @@ import type { PrivateEventStore } from '../storage/private_event_store/private_e
|
|
|
80
97
|
import type { RecipientTaggingStore } from '../storage/tagging_store/recipient_tagging_store.js';
|
|
81
98
|
import type { SenderAddressBookStore } from '../storage/tagging_store/sender_address_book_store.js';
|
|
82
99
|
import type { SenderTaggingStore } from '../storage/tagging_store/sender_tagging_store.js';
|
|
100
|
+
import type { BenchmarkedNode } from './benchmarked_node.js';
|
|
83
101
|
import { ExecutionNoteCache } from './execution_note_cache.js';
|
|
84
102
|
import { ExecutionTaggingIndexCache } from './execution_tagging_index_cache.js';
|
|
85
103
|
import { HashedValuesCache } from './hashed_values_cache.js';
|
|
86
104
|
import { Oracle } from './oracle/oracle.js';
|
|
87
|
-
import { executePrivateFunction
|
|
105
|
+
import { executePrivateFunction } from './oracle/private_execution.js';
|
|
88
106
|
import { PrivateExecutionOracle } from './oracle/private_execution_oracle.js';
|
|
89
107
|
import { UtilityExecutionOracle } from './oracle/utility_execution_oracle.js';
|
|
90
|
-
|
|
108
|
+
|
|
109
|
+
/** Options for ContractFunctionSimulator.run. */
|
|
110
|
+
export type ContractSimulatorRunOpts = {
|
|
111
|
+
/** The address of the contract (should match request.origin). */
|
|
112
|
+
contractAddress: AztecAddress;
|
|
113
|
+
/** The function selector of the entry point. */
|
|
114
|
+
selector: FunctionSelector;
|
|
115
|
+
/** The address calling the function. Can be replaced to simulate a call from another contract or account. */
|
|
116
|
+
msgSender?: AztecAddress;
|
|
117
|
+
/** The block header to use as base state for this run. */
|
|
118
|
+
anchorBlockHeader: BlockHeader;
|
|
119
|
+
/** The address used as a tagging sender when emitting private logs. */
|
|
120
|
+
senderForTags?: AztecAddress;
|
|
121
|
+
/** The accounts whose notes we can access in this call. */
|
|
122
|
+
scopes: AccessScopes;
|
|
123
|
+
/** The job ID for staged writes. */
|
|
124
|
+
jobId: string;
|
|
125
|
+
};
|
|
126
|
+
|
|
127
|
+
/** Args for ContractFunctionSimulator constructor. */
|
|
128
|
+
export type ContractFunctionSimulatorArgs = {
|
|
129
|
+
contractStore: ContractStore;
|
|
130
|
+
noteStore: NoteStore;
|
|
131
|
+
keyStore: KeyStore;
|
|
132
|
+
addressStore: AddressStore;
|
|
133
|
+
aztecNode: AztecNode;
|
|
134
|
+
senderTaggingStore: SenderTaggingStore;
|
|
135
|
+
recipientTaggingStore: RecipientTaggingStore;
|
|
136
|
+
senderAddressBookStore: SenderAddressBookStore;
|
|
137
|
+
capsuleStore: CapsuleStore;
|
|
138
|
+
privateEventStore: PrivateEventStore;
|
|
139
|
+
simulator: CircuitSimulator;
|
|
140
|
+
contractSyncService: ContractSyncService;
|
|
141
|
+
};
|
|
91
142
|
|
|
92
143
|
/**
|
|
93
144
|
* The contract function simulator.
|
|
94
145
|
*/
|
|
95
146
|
export class ContractFunctionSimulator {
|
|
96
|
-
private log: Logger;
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
147
|
+
private readonly log: Logger;
|
|
148
|
+
private readonly contractStore: ContractStore;
|
|
149
|
+
private readonly noteStore: NoteStore;
|
|
150
|
+
private readonly keyStore: KeyStore;
|
|
151
|
+
private readonly addressStore: AddressStore;
|
|
152
|
+
private readonly aztecNode: AztecNode;
|
|
153
|
+
private readonly senderTaggingStore: SenderTaggingStore;
|
|
154
|
+
private readonly recipientTaggingStore: RecipientTaggingStore;
|
|
155
|
+
private readonly senderAddressBookStore: SenderAddressBookStore;
|
|
156
|
+
private readonly capsuleStore: CapsuleStore;
|
|
157
|
+
private readonly privateEventStore: PrivateEventStore;
|
|
158
|
+
private readonly simulator: CircuitSimulator;
|
|
159
|
+
private readonly contractSyncService: ContractSyncService;
|
|
160
|
+
|
|
161
|
+
constructor(args: ContractFunctionSimulatorArgs) {
|
|
162
|
+
this.contractStore = args.contractStore;
|
|
163
|
+
this.noteStore = args.noteStore;
|
|
164
|
+
this.keyStore = args.keyStore;
|
|
165
|
+
this.addressStore = args.addressStore;
|
|
166
|
+
this.aztecNode = args.aztecNode;
|
|
167
|
+
this.senderTaggingStore = args.senderTaggingStore;
|
|
168
|
+
this.recipientTaggingStore = args.recipientTaggingStore;
|
|
169
|
+
this.senderAddressBookStore = args.senderAddressBookStore;
|
|
170
|
+
this.capsuleStore = args.capsuleStore;
|
|
171
|
+
this.privateEventStore = args.privateEventStore;
|
|
172
|
+
this.simulator = args.simulator;
|
|
173
|
+
this.contractSyncService = args.contractSyncService;
|
|
112
174
|
this.log = createLogger('simulator');
|
|
113
175
|
}
|
|
114
176
|
|
|
115
177
|
/**
|
|
116
178
|
* Runs a private function.
|
|
117
179
|
* @param request - The transaction request.
|
|
118
|
-
* @param entryPointArtifact - The artifact of the entry point function.
|
|
119
|
-
* @param contractAddress - The address of the contract (should match request.origin)
|
|
120
|
-
* @param msgSender - The address calling the function. This can be replaced to simulate a call from another contract
|
|
121
|
-
* or a specific account.
|
|
122
|
-
* @param anchorBlockHeader - The block header to use as base state for this run.
|
|
123
|
-
* @param senderForTags - The address that is used as a tagging sender when emitting private logs. Returned from
|
|
124
|
-
* the `privateGetSenderForTags` oracle.
|
|
125
|
-
* @param scopes - The accounts whose notes we can access in this call. Currently optional and will default to all.
|
|
126
|
-
* @returns The result of the execution.
|
|
127
180
|
*/
|
|
128
181
|
public async run(
|
|
129
182
|
request: TxExecutionRequest,
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
183
|
+
{
|
|
184
|
+
contractAddress,
|
|
185
|
+
selector,
|
|
186
|
+
msgSender = AztecAddress.fromField(Fr.MAX_FIELD_VALUE),
|
|
187
|
+
anchorBlockHeader,
|
|
188
|
+
senderForTags,
|
|
189
|
+
scopes,
|
|
190
|
+
jobId,
|
|
191
|
+
}: ContractSimulatorRunOpts,
|
|
136
192
|
): Promise<PrivateExecutionResult> {
|
|
137
193
|
const simulatorSetupTimer = new Timer();
|
|
138
194
|
|
|
139
|
-
await verifyCurrentClassId(contractAddress, this.aztecNode, this.contractStore, anchorBlockHeader);
|
|
140
|
-
|
|
141
195
|
const entryPointArtifact = await this.contractStore.getFunctionArtifactWithDebugMetadata(contractAddress, selector);
|
|
142
196
|
|
|
143
197
|
if (entryPointArtifact.functionType !== FunctionType.PRIVATE) {
|
|
@@ -164,34 +218,37 @@ export class ContractFunctionSimulator {
|
|
|
164
218
|
const noteCache = new ExecutionNoteCache(protocolNullifier);
|
|
165
219
|
const taggingIndexCache = new ExecutionTaggingIndexCache();
|
|
166
220
|
|
|
167
|
-
const privateExecutionOracle = new PrivateExecutionOracle(
|
|
168
|
-
request.firstCallArgsHash,
|
|
169
|
-
request.txContext,
|
|
221
|
+
const privateExecutionOracle = new PrivateExecutionOracle({
|
|
222
|
+
argsHash: request.firstCallArgsHash,
|
|
223
|
+
txContext: request.txContext,
|
|
170
224
|
callContext,
|
|
171
225
|
anchorBlockHeader,
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
226
|
+
utilityExecutor: async (call, execScopes) => {
|
|
227
|
+
await this.runUtility(call, [], anchorBlockHeader, execScopes, jobId);
|
|
228
|
+
},
|
|
229
|
+
authWitnesses: request.authWitnesses,
|
|
230
|
+
capsules: request.capsules,
|
|
231
|
+
executionCache: HashedValuesCache.create(request.argsOfCalls),
|
|
175
232
|
noteCache,
|
|
176
233
|
taggingIndexCache,
|
|
177
|
-
this.contractStore,
|
|
178
|
-
this.noteStore,
|
|
179
|
-
this.keyStore,
|
|
180
|
-
this.addressStore,
|
|
181
|
-
this.aztecNode,
|
|
182
|
-
this.
|
|
183
|
-
this.
|
|
184
|
-
this.
|
|
185
|
-
this.
|
|
186
|
-
this.
|
|
187
|
-
this.
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
234
|
+
contractStore: this.contractStore,
|
|
235
|
+
noteStore: this.noteStore,
|
|
236
|
+
keyStore: this.keyStore,
|
|
237
|
+
addressStore: this.addressStore,
|
|
238
|
+
aztecNode: this.aztecNode,
|
|
239
|
+
senderTaggingStore: this.senderTaggingStore,
|
|
240
|
+
recipientTaggingStore: this.recipientTaggingStore,
|
|
241
|
+
senderAddressBookStore: this.senderAddressBookStore,
|
|
242
|
+
capsuleStore: this.capsuleStore,
|
|
243
|
+
privateEventStore: this.privateEventStore,
|
|
244
|
+
contractSyncService: this.contractSyncService,
|
|
245
|
+
jobId,
|
|
246
|
+
totalPublicCalldataCount: 0,
|
|
247
|
+
sideEffectCounter: startSideEffectCounter,
|
|
191
248
|
scopes,
|
|
192
249
|
senderForTags,
|
|
193
|
-
this.simulator,
|
|
194
|
-
);
|
|
250
|
+
simulator: this.simulator,
|
|
251
|
+
});
|
|
195
252
|
|
|
196
253
|
const setupTime = simulatorSetupTimer.ms();
|
|
197
254
|
|
|
@@ -208,8 +265,9 @@ export class ContractFunctionSimulator {
|
|
|
208
265
|
request.functionSelector,
|
|
209
266
|
);
|
|
210
267
|
const simulatorTeardownTimer = new Timer();
|
|
211
|
-
|
|
212
|
-
|
|
268
|
+
|
|
269
|
+
noteCache.finish();
|
|
270
|
+
const firstNullifierHint = noteCache.getNonceGenerator();
|
|
213
271
|
|
|
214
272
|
const publicCallRequests = collectNested([executionResult], r =>
|
|
215
273
|
r.publicInputs.publicCallRequests
|
|
@@ -254,34 +312,32 @@ export class ContractFunctionSimulator {
|
|
|
254
312
|
call: FunctionCall,
|
|
255
313
|
authwits: AuthWitness[],
|
|
256
314
|
anchorBlockHeader: BlockHeader,
|
|
257
|
-
scopes
|
|
315
|
+
scopes: AccessScopes,
|
|
316
|
+
jobId: string,
|
|
258
317
|
): Promise<Fr[]> {
|
|
259
|
-
await verifyCurrentClassId(call.to, this.aztecNode, this.contractStore, anchorBlockHeader);
|
|
260
|
-
|
|
261
318
|
const entryPointArtifact = await this.contractStore.getFunctionArtifactWithDebugMetadata(call.to, call.selector);
|
|
262
319
|
|
|
263
320
|
if (entryPointArtifact.functionType !== FunctionType.UTILITY) {
|
|
264
321
|
throw new Error(`Cannot run ${entryPointArtifact.functionType} function as utility`);
|
|
265
322
|
}
|
|
266
323
|
|
|
267
|
-
const oracle = new UtilityExecutionOracle(
|
|
268
|
-
call.to,
|
|
269
|
-
authwits,
|
|
270
|
-
[],
|
|
324
|
+
const oracle = new UtilityExecutionOracle({
|
|
325
|
+
contractAddress: call.to,
|
|
326
|
+
authWitnesses: authwits,
|
|
327
|
+
capsules: [],
|
|
271
328
|
anchorBlockHeader,
|
|
272
|
-
this.contractStore,
|
|
273
|
-
this.noteStore,
|
|
274
|
-
this.keyStore,
|
|
275
|
-
this.addressStore,
|
|
276
|
-
this.aztecNode,
|
|
277
|
-
this.
|
|
278
|
-
this.
|
|
279
|
-
this.
|
|
280
|
-
this.
|
|
281
|
-
|
|
282
|
-
undefined,
|
|
329
|
+
contractStore: this.contractStore,
|
|
330
|
+
noteStore: this.noteStore,
|
|
331
|
+
keyStore: this.keyStore,
|
|
332
|
+
addressStore: this.addressStore,
|
|
333
|
+
aztecNode: this.aztecNode,
|
|
334
|
+
recipientTaggingStore: this.recipientTaggingStore,
|
|
335
|
+
senderAddressBookStore: this.senderAddressBookStore,
|
|
336
|
+
capsuleStore: this.capsuleStore,
|
|
337
|
+
privateEventStore: this.privateEventStore,
|
|
338
|
+
jobId,
|
|
283
339
|
scopes,
|
|
284
|
-
);
|
|
340
|
+
});
|
|
285
341
|
|
|
286
342
|
try {
|
|
287
343
|
this.log.verbose(`Executing utility function ${entryPointArtifact.name}`, {
|
|
@@ -319,7 +375,12 @@ export class ContractFunctionSimulator {
|
|
|
319
375
|
*/
|
|
320
376
|
getStats() {
|
|
321
377
|
const nodeRPCCalls =
|
|
322
|
-
typeof (this.aztecNode as
|
|
378
|
+
typeof (this.aztecNode as BenchmarkedNode).getStats === 'function'
|
|
379
|
+
? (this.aztecNode as BenchmarkedNode).getStats()
|
|
380
|
+
: {
|
|
381
|
+
perMethod: {},
|
|
382
|
+
roundTrips: { roundTrips: 0, totalBlockingTime: 0, roundTripDurations: [], roundTripMethods: [] },
|
|
383
|
+
};
|
|
323
384
|
|
|
324
385
|
return { nodeRPCCalls };
|
|
325
386
|
}
|
|
@@ -342,24 +403,33 @@ class OrderedSideEffect<T> {
|
|
|
342
403
|
* (allowing state overrides) and is much faster, while still generating a valid
|
|
343
404
|
* output that can be sent to the node for public simulation
|
|
344
405
|
* @param privateExecutionResult - The result of the private execution.
|
|
345
|
-
* @param
|
|
346
|
-
*
|
|
347
|
-
* @param
|
|
406
|
+
* @param debugFunctionNameGetter - A provider for contract data in order to get function names and debug info.
|
|
407
|
+
* @param node - AztecNode for verifying settled read requests against the note hash and nullifier trees.
|
|
408
|
+
* @param minRevertibleSideEffectCounterOverride - Optional override for the min revertible side effect counter.
|
|
409
|
+
* Used by TXE to simulate account contract behavior (setting the counter before app execution).
|
|
348
410
|
* @returns The simulated proving result.
|
|
349
411
|
*/
|
|
350
412
|
export async function generateSimulatedProvingResult(
|
|
351
413
|
privateExecutionResult: PrivateExecutionResult,
|
|
352
|
-
|
|
353
|
-
|
|
414
|
+
debugFunctionNameGetter: (contractAddress: AztecAddress, functionSelector: FunctionSelector) => Promise<string>,
|
|
415
|
+
node: AztecNode,
|
|
416
|
+
minRevertibleSideEffectCounterOverride?: number,
|
|
354
417
|
): Promise<PrivateKernelExecutionProofOutput<PrivateKernelTailCircuitPublicInputs>> {
|
|
355
|
-
const
|
|
356
|
-
const nullifiers: OrderedSideEffect<Fr>[] = [];
|
|
357
|
-
const taggedPrivateLogs: OrderedSideEffect<PrivateLog>[] = [];
|
|
418
|
+
const taggedPrivateLogs: OrderedSideEffect<PrivateLogData>[] = [];
|
|
358
419
|
const l2ToL1Messages: OrderedSideEffect<ScopedL2ToL1Message>[] = [];
|
|
359
420
|
const contractClassLogsHashes: OrderedSideEffect<ScopedLogHash>[] = [];
|
|
360
421
|
const publicCallRequests: OrderedSideEffect<PublicCallRequest>[] = [];
|
|
361
422
|
const executionSteps: PrivateExecutionStep[] = [];
|
|
362
423
|
|
|
424
|
+
// Unsiloed scoped arrays — used for squashing, read request verification,
|
|
425
|
+
// and siloed at the end only for the surviving items
|
|
426
|
+
const scopedNoteHashes: ScopedNoteHash[] = [];
|
|
427
|
+
const scopedNullifiers: ScopedNullifier[] = [];
|
|
428
|
+
|
|
429
|
+
// Read requests for verification
|
|
430
|
+
const noteHashReadRequests: ScopedReadRequest[] = [];
|
|
431
|
+
const nullifierReadRequests: ScopedReadRequest[] = [];
|
|
432
|
+
|
|
363
433
|
let publicTeardownCallRequest;
|
|
364
434
|
|
|
365
435
|
const executions = [privateExecutionResult.entrypoint];
|
|
@@ -370,35 +440,25 @@ export async function generateSimulatedProvingResult(
|
|
|
370
440
|
|
|
371
441
|
const { contractAddress } = execution.publicInputs.callContext;
|
|
372
442
|
|
|
373
|
-
|
|
374
|
-
execution.publicInputs.noteHashes
|
|
375
|
-
.getActiveItems()
|
|
376
|
-
.filter(noteHash => !noteHash.isEmpty())
|
|
377
|
-
.map(
|
|
378
|
-
async noteHash =>
|
|
379
|
-
new OrderedSideEffect(await siloNoteHash(contractAddress, noteHash.value), noteHash.counter),
|
|
380
|
-
),
|
|
381
|
-
);
|
|
382
|
-
|
|
383
|
-
const nullifiersFromExecution = await Promise.all(
|
|
384
|
-
execution.publicInputs.nullifiers
|
|
443
|
+
scopedNoteHashes.push(
|
|
444
|
+
...execution.publicInputs.noteHashes
|
|
385
445
|
.getActiveItems()
|
|
386
|
-
.
|
|
387
|
-
|
|
388
|
-
new OrderedSideEffect(await siloNullifier(contractAddress, nullifier.value), nullifier.counter),
|
|
389
|
-
),
|
|
446
|
+
.filter(nh => !nh.isEmpty())
|
|
447
|
+
.map(nh => nh.scope(contractAddress)),
|
|
390
448
|
);
|
|
449
|
+
scopedNullifiers.push(...execution.publicInputs.nullifiers.getActiveItems().map(n => n.scope(contractAddress)));
|
|
391
450
|
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
451
|
+
taggedPrivateLogs.push(
|
|
452
|
+
...(await Promise.all(
|
|
453
|
+
execution.publicInputs.privateLogs.getActiveItems().map(async metadata => {
|
|
454
|
+
metadata.log.fields[0] = await computeSiloedPrivateLogFirstField(contractAddress, metadata.log.fields[0]);
|
|
455
|
+
return new OrderedSideEffect(metadata, metadata.counter);
|
|
456
|
+
}),
|
|
457
|
+
)),
|
|
397
458
|
);
|
|
398
459
|
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
nullifiers.push(...nullifiersFromExecution);
|
|
460
|
+
noteHashReadRequests.push(...execution.publicInputs.noteHashReadRequests.getActiveItems());
|
|
461
|
+
nullifierReadRequests.push(...execution.publicInputs.nullifierReadRequests.getActiveItems());
|
|
402
462
|
l2ToL1Messages.push(
|
|
403
463
|
...execution.publicInputs.l2ToL1Msgs
|
|
404
464
|
.getActiveItems()
|
|
@@ -427,7 +487,7 @@ export async function generateSimulatedProvingResult(
|
|
|
427
487
|
: execution.publicInputs.publicTeardownCallRequest;
|
|
428
488
|
|
|
429
489
|
executionSteps.push({
|
|
430
|
-
functionName: await
|
|
490
|
+
functionName: await debugFunctionNameGetter(
|
|
431
491
|
execution.publicInputs.callContext.contractAddress,
|
|
432
492
|
execution.publicInputs.callContext.functionSelector,
|
|
433
493
|
),
|
|
@@ -438,6 +498,47 @@ export async function generateSimulatedProvingResult(
|
|
|
438
498
|
});
|
|
439
499
|
}
|
|
440
500
|
|
|
501
|
+
const noteHashNullifierCounterMap = collectNoteHashNullifierCounterMap(privateExecutionResult);
|
|
502
|
+
const minRevertibleSideEffectCounter =
|
|
503
|
+
minRevertibleSideEffectCounterOverride ?? getFinalMinRevertibleSideEffectCounter(privateExecutionResult);
|
|
504
|
+
|
|
505
|
+
const scopedNoteHashesCLA = new ClaimedLengthArray<ScopedNoteHash, typeof MAX_NOTE_HASHES_PER_TX>(
|
|
506
|
+
padArrayEnd(scopedNoteHashes, ScopedNoteHash.empty(), MAX_NOTE_HASHES_PER_TX),
|
|
507
|
+
scopedNoteHashes.length,
|
|
508
|
+
);
|
|
509
|
+
const scopedNullifiersCLA = new ClaimedLengthArray<ScopedNullifier, typeof MAX_NULLIFIERS_PER_TX>(
|
|
510
|
+
padArrayEnd(scopedNullifiers, ScopedNullifier.empty(), MAX_NULLIFIERS_PER_TX),
|
|
511
|
+
scopedNullifiers.length,
|
|
512
|
+
);
|
|
513
|
+
|
|
514
|
+
const { filteredNoteHashes, filteredNullifiers, filteredPrivateLogs } = squashTransientSideEffects(
|
|
515
|
+
taggedPrivateLogs,
|
|
516
|
+
scopedNoteHashesCLA,
|
|
517
|
+
scopedNullifiersCLA,
|
|
518
|
+
noteHashNullifierCounterMap,
|
|
519
|
+
minRevertibleSideEffectCounter,
|
|
520
|
+
);
|
|
521
|
+
|
|
522
|
+
await verifyReadRequests(
|
|
523
|
+
node,
|
|
524
|
+
await privateExecutionResult.entrypoint.publicInputs.anchorBlockHeader.hash(),
|
|
525
|
+
noteHashReadRequests,
|
|
526
|
+
nullifierReadRequests,
|
|
527
|
+
scopedNoteHashesCLA,
|
|
528
|
+
scopedNullifiersCLA,
|
|
529
|
+
);
|
|
530
|
+
|
|
531
|
+
const siloedNoteHashes = await Promise.all(
|
|
532
|
+
filteredNoteHashes
|
|
533
|
+
.sort((a, b) => a.counter - b.counter)
|
|
534
|
+
.map(async nh => new OrderedSideEffect(await siloNoteHash(nh.contractAddress, nh.value), nh.counter)),
|
|
535
|
+
);
|
|
536
|
+
const siloedNullifiers = await Promise.all(
|
|
537
|
+
filteredNullifiers
|
|
538
|
+
.sort((a, b) => a.counter - b.counter)
|
|
539
|
+
.map(async n => new OrderedSideEffect(await siloNullifier(n.contractAddress, n.value), n.counter)),
|
|
540
|
+
);
|
|
541
|
+
|
|
441
542
|
const constantData = new TxConstantData(
|
|
442
543
|
privateExecutionResult.entrypoint.publicInputs.anchorBlockHeader,
|
|
443
544
|
privateExecutionResult.entrypoint.publicInputs.txContext,
|
|
@@ -454,23 +555,23 @@ export async function generateSimulatedProvingResult(
|
|
|
454
555
|
const getEffect = <T>(orderedSideEffect: OrderedSideEffect<T>) => orderedSideEffect.sideEffect;
|
|
455
556
|
|
|
456
557
|
const isPrivateOnlyTx = privateExecutionResult.publicFunctionCalldata.length === 0;
|
|
457
|
-
const minRevertibleSideEffectCounter = getFinalMinRevertibleSideEffectCounter(privateExecutionResult);
|
|
458
558
|
|
|
459
559
|
const [nonRevertibleNullifiers, revertibleNullifiers] = splitOrderedSideEffects(
|
|
460
|
-
|
|
560
|
+
siloedNullifiers,
|
|
461
561
|
minRevertibleSideEffectCounter,
|
|
462
562
|
);
|
|
463
|
-
|
|
563
|
+
const nonceGenerator = privateExecutionResult.firstNullifier;
|
|
564
|
+
if (nonRevertibleNullifiers.length === 0) {
|
|
565
|
+
nonRevertibleNullifiers.push(nonceGenerator);
|
|
566
|
+
} else if (!nonRevertibleNullifiers[0].equals(nonceGenerator)) {
|
|
464
567
|
throw new Error('The first non revertible nullifier should be equal to the nonce generator. This is a bug!');
|
|
465
|
-
} else {
|
|
466
|
-
nonRevertibleNullifiers.unshift(nonceGenerator);
|
|
467
568
|
}
|
|
468
569
|
|
|
469
570
|
if (isPrivateOnlyTx) {
|
|
470
571
|
// We must make the note hashes unique by using the
|
|
471
572
|
// nonce generator and their index in the tx.
|
|
472
573
|
const uniqueNoteHashes = await Promise.all(
|
|
473
|
-
siloedNoteHashes.
|
|
574
|
+
siloedNoteHashes.map(async (orderedSideEffect, i) => {
|
|
474
575
|
const siloedNoteHash = orderedSideEffect.sideEffect;
|
|
475
576
|
const nonce = await computeNoteHashNonce(nonceGenerator, i);
|
|
476
577
|
const uniqueNoteHash = await computeUniqueNoteHash(nonce, siloedNoteHash);
|
|
@@ -485,26 +586,32 @@ export async function generateSimulatedProvingResult(
|
|
|
485
586
|
ScopedL2ToL1Message.empty(),
|
|
486
587
|
MAX_L2_TO_L1_MSGS_PER_TX,
|
|
487
588
|
),
|
|
488
|
-
padArrayEnd(
|
|
589
|
+
padArrayEnd(filteredPrivateLogs.sort(sortByCounter).map(getEffect), PrivateLog.empty(), MAX_PRIVATE_LOGS_PER_TX),
|
|
489
590
|
padArrayEnd(
|
|
490
591
|
contractClassLogsHashes.sort(sortByCounter).map(getEffect),
|
|
491
592
|
ScopedLogHash.empty(),
|
|
492
593
|
MAX_CONTRACT_CLASS_LOGS_PER_TX,
|
|
493
594
|
),
|
|
494
595
|
);
|
|
495
|
-
gasUsed = meterGasUsed(accumulatedDataForRollup);
|
|
596
|
+
gasUsed = meterGasUsed(accumulatedDataForRollup, isPrivateOnlyTx);
|
|
496
597
|
inputsForRollup = new PartialPrivateTailPublicInputsForRollup(accumulatedDataForRollup);
|
|
497
598
|
} else {
|
|
498
599
|
const [nonRevertibleNoteHashes, revertibleNoteHashes] = splitOrderedSideEffects(
|
|
499
|
-
siloedNoteHashes
|
|
600
|
+
siloedNoteHashes,
|
|
500
601
|
minRevertibleSideEffectCounter,
|
|
501
602
|
);
|
|
603
|
+
const nonRevertibleUniqueNoteHashes = await Promise.all(
|
|
604
|
+
nonRevertibleNoteHashes.map(async (noteHash, i) => {
|
|
605
|
+
const nonce = await computeNoteHashNonce(nonceGenerator, i);
|
|
606
|
+
return await computeUniqueNoteHash(nonce, noteHash);
|
|
607
|
+
}),
|
|
608
|
+
);
|
|
502
609
|
const [nonRevertibleL2ToL1Messages, revertibleL2ToL1Messages] = splitOrderedSideEffects(
|
|
503
610
|
l2ToL1Messages.sort(sortByCounter),
|
|
504
611
|
minRevertibleSideEffectCounter,
|
|
505
612
|
);
|
|
506
613
|
const [nonRevertibleTaggedPrivateLogs, revertibleTaggedPrivateLogs] = splitOrderedSideEffects(
|
|
507
|
-
|
|
614
|
+
filteredPrivateLogs,
|
|
508
615
|
minRevertibleSideEffectCounter,
|
|
509
616
|
);
|
|
510
617
|
const [nonRevertibleContractClassLogHashes, revertibleContractClassLogHashes] = splitOrderedSideEffects(
|
|
@@ -517,7 +624,7 @@ export async function generateSimulatedProvingResult(
|
|
|
517
624
|
);
|
|
518
625
|
|
|
519
626
|
const nonRevertibleData = new PrivateToPublicAccumulatedData(
|
|
520
|
-
padArrayEnd(
|
|
627
|
+
padArrayEnd(nonRevertibleUniqueNoteHashes, Fr.ZERO, MAX_NOTE_HASHES_PER_TX),
|
|
521
628
|
padArrayEnd(nonRevertibleNullifiers, Fr.ZERO, MAX_NULLIFIERS_PER_TX),
|
|
522
629
|
padArrayEnd(nonRevertibleL2ToL1Messages, ScopedL2ToL1Message.empty(), MAX_L2_TO_L1_MSGS_PER_TX),
|
|
523
630
|
padArrayEnd(nonRevertibleTaggedPrivateLogs, PrivateLog.empty(), MAX_PRIVATE_LOGS_PER_TX),
|
|
@@ -533,9 +640,9 @@ export async function generateSimulatedProvingResult(
|
|
|
533
640
|
padArrayEnd(revertibleContractClassLogHashes, ScopedLogHash.empty(), MAX_CONTRACT_CLASS_LOGS_PER_TX),
|
|
534
641
|
padArrayEnd(revertiblePublicCallRequests, PublicCallRequest.empty(), MAX_ENQUEUED_CALLS_PER_TX),
|
|
535
642
|
);
|
|
536
|
-
gasUsed = meterGasUsed(revertibleData).add(meterGasUsed(nonRevertibleData));
|
|
643
|
+
gasUsed = meterGasUsed(revertibleData, isPrivateOnlyTx).add(meterGasUsed(nonRevertibleData, isPrivateOnlyTx));
|
|
537
644
|
if (publicTeardownCallRequest) {
|
|
538
|
-
gasUsed.add(privateExecutionResult.entrypoint.publicInputs.txContext.gasSettings.teardownGasLimits);
|
|
645
|
+
gasUsed = gasUsed.add(privateExecutionResult.entrypoint.publicInputs.txContext.gasSettings.teardownGasLimits);
|
|
539
646
|
}
|
|
540
647
|
|
|
541
648
|
inputsForPublic = new PartialPrivateTailPublicInputsForPublic(
|
|
@@ -549,7 +656,7 @@ export async function generateSimulatedProvingResult(
|
|
|
549
656
|
constantData,
|
|
550
657
|
/*gasUsed=*/ gasUsed.add(Gas.from({ l2Gas: FIXED_L2_GAS, daGas: FIXED_DA_GAS })),
|
|
551
658
|
/*feePayer=*/ AztecAddress.zero(),
|
|
552
|
-
/*
|
|
659
|
+
/*expirationTimestamp=*/ 0n,
|
|
553
660
|
hasPublicCalls ? inputsForPublic : undefined,
|
|
554
661
|
!hasPublicCalls ? inputsForRollup : undefined,
|
|
555
662
|
);
|
|
@@ -561,11 +668,116 @@ export async function generateSimulatedProvingResult(
|
|
|
561
668
|
};
|
|
562
669
|
}
|
|
563
670
|
|
|
671
|
+
/**
|
|
672
|
+
* Squashes transient note hashes and nullifiers, mimicking the behavior
|
|
673
|
+
* of the reset kernels. Returns the filtered (surviving) scoped items and private logs.
|
|
674
|
+
*/
|
|
675
|
+
function squashTransientSideEffects(
|
|
676
|
+
taggedPrivateLogs: OrderedSideEffect<PrivateLogData>[],
|
|
677
|
+
scopedNoteHashesCLA: ClaimedLengthArray<ScopedNoteHash, typeof MAX_NOTE_HASHES_PER_TX>,
|
|
678
|
+
scopedNullifiersCLA: ClaimedLengthArray<ScopedNullifier, typeof MAX_NULLIFIERS_PER_TX>,
|
|
679
|
+
noteHashNullifierCounterMap: Map<number, number>,
|
|
680
|
+
minRevertibleSideEffectCounter: number,
|
|
681
|
+
) {
|
|
682
|
+
const { numTransientData, hints: transientDataHints } = buildTransientDataHints(
|
|
683
|
+
scopedNoteHashesCLA,
|
|
684
|
+
scopedNullifiersCLA,
|
|
685
|
+
/*futureNoteHashReads=*/ [],
|
|
686
|
+
/*futureNullifierReads=*/ [],
|
|
687
|
+
noteHashNullifierCounterMap,
|
|
688
|
+
minRevertibleSideEffectCounter,
|
|
689
|
+
);
|
|
690
|
+
|
|
691
|
+
const squashedNoteHashCounters = new Set<number>();
|
|
692
|
+
const squashedNullifierCounters = new Set<number>();
|
|
693
|
+
for (let i = 0; i < numTransientData; i++) {
|
|
694
|
+
const hint = transientDataHints[i];
|
|
695
|
+
squashedNoteHashCounters.add(scopedNoteHashesCLA.array[hint.noteHashIndex].counter);
|
|
696
|
+
squashedNullifierCounters.add(scopedNullifiersCLA.array[hint.nullifierIndex].counter);
|
|
697
|
+
}
|
|
698
|
+
|
|
699
|
+
return {
|
|
700
|
+
filteredNoteHashes: scopedNoteHashesCLA.getActiveItems().filter(nh => !squashedNoteHashCounters.has(nh.counter)),
|
|
701
|
+
filteredNullifiers: scopedNullifiersCLA.getActiveItems().filter(n => !squashedNullifierCounters.has(n.counter)),
|
|
702
|
+
filteredPrivateLogs: taggedPrivateLogs
|
|
703
|
+
.filter(item => !squashedNoteHashCounters.has(item.sideEffect.noteHashCounter))
|
|
704
|
+
.map(item => new OrderedSideEffect(item.sideEffect.log, item.counter)),
|
|
705
|
+
};
|
|
706
|
+
}
|
|
707
|
+
|
|
708
|
+
/**
|
|
709
|
+
* Verifies settled read requests by checking membership in the note hash and nullifier trees
|
|
710
|
+
* at the tx's anchor block, mimicking the behavior of the kernels
|
|
711
|
+
*/
|
|
712
|
+
async function verifyReadRequests(
|
|
713
|
+
node: Pick<AztecNode, 'getNoteHashMembershipWitness' | 'getNullifierMembershipWitness'>,
|
|
714
|
+
anchorBlockHash: BlockParameter,
|
|
715
|
+
noteHashReadRequests: ScopedReadRequest[],
|
|
716
|
+
nullifierReadRequests: ScopedReadRequest[],
|
|
717
|
+
scopedNoteHashesCLA: ClaimedLengthArray<ScopedNoteHash, typeof MAX_NOTE_HASHES_PER_TX>,
|
|
718
|
+
scopedNullifiersCLA: ClaimedLengthArray<ScopedNullifier, typeof MAX_NULLIFIERS_PER_TX>,
|
|
719
|
+
) {
|
|
720
|
+
const noteHashReadRequestsCLA = new ClaimedLengthArray<ScopedReadRequest, typeof MAX_NOTE_HASH_READ_REQUESTS_PER_TX>(
|
|
721
|
+
padArrayEnd(noteHashReadRequests, ScopedReadRequest.empty(), MAX_NOTE_HASH_READ_REQUESTS_PER_TX),
|
|
722
|
+
noteHashReadRequests.length,
|
|
723
|
+
);
|
|
724
|
+
const nullifierReadRequestsCLA = new ClaimedLengthArray<ScopedReadRequest, typeof MAX_NULLIFIER_READ_REQUESTS_PER_TX>(
|
|
725
|
+
padArrayEnd(nullifierReadRequests, ScopedReadRequest.empty(), MAX_NULLIFIER_READ_REQUESTS_PER_TX),
|
|
726
|
+
nullifierReadRequests.length,
|
|
727
|
+
);
|
|
728
|
+
|
|
729
|
+
const noteHashResetActions = getNoteHashReadRequestResetActions(
|
|
730
|
+
noteHashReadRequestsCLA,
|
|
731
|
+
scopedNoteHashesCLA,
|
|
732
|
+
/*futureNoteHashes=*/ [],
|
|
733
|
+
);
|
|
734
|
+
const nullifierResetActions = getNullifierReadRequestResetActions(
|
|
735
|
+
nullifierReadRequestsCLA,
|
|
736
|
+
scopedNullifiersCLA,
|
|
737
|
+
/*futureNullifiers=*/ [],
|
|
738
|
+
);
|
|
739
|
+
|
|
740
|
+
const settledNoteHashReads: { index: number; value: Fr }[] = [];
|
|
741
|
+
for (let i = 0; i < noteHashResetActions.actions.length; i++) {
|
|
742
|
+
if (noteHashResetActions.actions[i] === ReadRequestActionEnum.READ_AS_SETTLED) {
|
|
743
|
+
settledNoteHashReads.push({ index: i, value: noteHashReadRequests[i].value });
|
|
744
|
+
}
|
|
745
|
+
}
|
|
746
|
+
|
|
747
|
+
const settledNullifierReads: { index: number; value: Fr }[] = [];
|
|
748
|
+
for (let i = 0; i < nullifierResetActions.actions.length; i++) {
|
|
749
|
+
if (nullifierResetActions.actions[i] === ReadRequestActionEnum.READ_AS_SETTLED) {
|
|
750
|
+
settledNullifierReads.push({ index: i, value: nullifierReadRequests[i].value });
|
|
751
|
+
}
|
|
752
|
+
}
|
|
753
|
+
|
|
754
|
+
const [noteHashWitnesses, nullifierWitnesses] = await Promise.all([
|
|
755
|
+
Promise.all(settledNoteHashReads.map(({ value }) => node.getNoteHashMembershipWitness(anchorBlockHash, value))),
|
|
756
|
+
Promise.all(settledNullifierReads.map(({ value }) => node.getNullifierMembershipWitness(anchorBlockHash, value))),
|
|
757
|
+
]);
|
|
758
|
+
|
|
759
|
+
for (let i = 0; i < settledNoteHashReads.length; i++) {
|
|
760
|
+
if (!noteHashWitnesses[i]) {
|
|
761
|
+
throw new Error(
|
|
762
|
+
`Note hash read request at index ${settledNoteHashReads[i].index} is reading an unknown note hash: ${settledNoteHashReads[i].value}`,
|
|
763
|
+
);
|
|
764
|
+
}
|
|
765
|
+
}
|
|
766
|
+
|
|
767
|
+
for (let i = 0; i < settledNullifierReads.length; i++) {
|
|
768
|
+
if (!nullifierWitnesses[i]) {
|
|
769
|
+
throw new Error(
|
|
770
|
+
`Nullifier read request at index ${settledNullifierReads[i].index} is reading an unknown nullifier: ${settledNullifierReads[i].value}`,
|
|
771
|
+
);
|
|
772
|
+
}
|
|
773
|
+
}
|
|
774
|
+
}
|
|
775
|
+
|
|
564
776
|
function splitOrderedSideEffects<T>(effects: OrderedSideEffect<T>[], minRevertibleSideEffectCounter: number) {
|
|
565
777
|
const revertibleSideEffects: T[] = [];
|
|
566
778
|
const nonRevertibleSideEffects: T[] = [];
|
|
567
779
|
effects.forEach(effect => {
|
|
568
|
-
if (effect.counter < minRevertibleSideEffectCounter) {
|
|
780
|
+
if (minRevertibleSideEffectCounter === 0 || effect.counter < minRevertibleSideEffectCounter) {
|
|
569
781
|
nonRevertibleSideEffects.push(effect.sideEffect);
|
|
570
782
|
} else {
|
|
571
783
|
revertibleSideEffects.push(effect.sideEffect);
|
|
@@ -574,21 +786,24 @@ function splitOrderedSideEffects<T>(effects: OrderedSideEffect<T>[], minRevertib
|
|
|
574
786
|
return [nonRevertibleSideEffects, revertibleSideEffects];
|
|
575
787
|
}
|
|
576
788
|
|
|
577
|
-
function meterGasUsed(data: PrivateToRollupAccumulatedData | PrivateToPublicAccumulatedData) {
|
|
789
|
+
function meterGasUsed(data: PrivateToRollupAccumulatedData | PrivateToPublicAccumulatedData, isPrivateOnlyTx: boolean) {
|
|
578
790
|
let meteredDAFields = 0;
|
|
579
791
|
let meteredL2Gas = 0;
|
|
580
792
|
|
|
581
793
|
const numNoteHashes = arrayNonEmptyLength(data.noteHashes, hash => hash.isEmpty());
|
|
582
794
|
meteredDAFields += numNoteHashes;
|
|
583
|
-
|
|
795
|
+
const noteHashBaseGas = isPrivateOnlyTx ? L2_GAS_PER_NOTE_HASH : AVM_EMITNOTEHASH_BASE_L2_GAS;
|
|
796
|
+
meteredL2Gas += numNoteHashes * noteHashBaseGas;
|
|
584
797
|
|
|
585
798
|
const numNullifiers = arrayNonEmptyLength(data.nullifiers, nullifier => nullifier.isEmpty());
|
|
586
799
|
meteredDAFields += numNullifiers;
|
|
587
|
-
|
|
800
|
+
const nullifierBaseGas = isPrivateOnlyTx ? L2_GAS_PER_NULLIFIER : AVM_EMITNULLIFIER_BASE_L2_GAS;
|
|
801
|
+
meteredL2Gas += numNullifiers * nullifierBaseGas;
|
|
588
802
|
|
|
589
803
|
const numL2toL1Messages = arrayNonEmptyLength(data.l2ToL1Msgs, msg => msg.isEmpty());
|
|
590
804
|
meteredDAFields += numL2toL1Messages;
|
|
591
|
-
|
|
805
|
+
const l2ToL1MessageBaseGas = isPrivateOnlyTx ? L2_GAS_PER_L2_TO_L1_MSG : AVM_SENDL2TOL1MSG_BASE_L2_GAS;
|
|
806
|
+
meteredL2Gas += numL2toL1Messages * l2ToL1MessageBaseGas;
|
|
592
807
|
|
|
593
808
|
const numPrivatelogs = arrayNonEmptyLength(data.privateLogs, log => log.isEmpty());
|
|
594
809
|
// Every private log emits its length as an additional field
|