@aztec/pxe 0.0.1-commit.6230efd → 0.0.1-commit.643667a5cb
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 +199 -84
- 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 +44 -50
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/private_execution_oracle.js +83 -54
- 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 +131 -110
- 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 +31 -8
- 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 +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 -24
- package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
- package/dest/private_kernel/private_kernel_oracle.js +94 -2
- package/dest/pxe.d.ts +76 -58
- package/dest/pxe.d.ts.map +1 -1
- package/dest/pxe.js +149 -138
- 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 +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 +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 +359 -146
- 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 +119 -137
- package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +198 -115
- 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 +23 -16
- package/src/entrypoints/client/lazy/index.ts +3 -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 +280 -209
- 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 +186 -96
- 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
|
@@ -2,22 +2,26 @@ import {
|
|
|
2
2
|
AVM_EMITNOTEHASH_BASE_L2_GAS,
|
|
3
3
|
AVM_EMITNULLIFIER_BASE_L2_GAS,
|
|
4
4
|
AVM_SENDL2TOL1MSG_BASE_L2_GAS,
|
|
5
|
-
|
|
6
|
-
DA_GAS_PER_BYTE,
|
|
5
|
+
DA_GAS_PER_FIELD,
|
|
7
6
|
FIXED_AVM_STARTUP_L2_GAS,
|
|
8
|
-
FIXED_DA_GAS,
|
|
9
|
-
FIXED_L2_GAS,
|
|
10
7
|
L2_GAS_PER_CONTRACT_CLASS_LOG,
|
|
8
|
+
L2_GAS_PER_L2_TO_L1_MSG,
|
|
9
|
+
L2_GAS_PER_NOTE_HASH,
|
|
10
|
+
L2_GAS_PER_NULLIFIER,
|
|
11
11
|
L2_GAS_PER_PRIVATE_LOG,
|
|
12
12
|
MAX_CONTRACT_CLASS_LOGS_PER_TX,
|
|
13
13
|
MAX_ENQUEUED_CALLS_PER_TX,
|
|
14
14
|
MAX_L2_TO_L1_MSGS_PER_TX,
|
|
15
15
|
MAX_NOTE_HASHES_PER_TX,
|
|
16
|
+
MAX_NOTE_HASH_READ_REQUESTS_PER_TX,
|
|
16
17
|
MAX_NULLIFIERS_PER_TX,
|
|
18
|
+
MAX_NULLIFIER_READ_REQUESTS_PER_TX,
|
|
17
19
|
MAX_PRIVATE_LOGS_PER_TX,
|
|
20
|
+
PRIVATE_TX_L2_GAS_OVERHEAD,
|
|
21
|
+
PUBLIC_TX_L2_GAS_OVERHEAD,
|
|
22
|
+
TX_DA_GAS_OVERHEAD,
|
|
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,68 +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 this.contractStore.syncPrivateState(contractAddress, selector, privateSyncCall =>
|
|
140
|
-
this.runUtility(privateSyncCall, [], anchorBlockHeader, scopes),
|
|
141
|
-
);
|
|
142
|
-
|
|
143
|
-
await verifyCurrentClassId(contractAddress, this.aztecNode, this.contractStore, anchorBlockHeader);
|
|
144
|
-
|
|
145
195
|
const entryPointArtifact = await this.contractStore.getFunctionArtifactWithDebugMetadata(contractAddress, selector);
|
|
146
196
|
|
|
147
197
|
if (entryPointArtifact.functionType !== FunctionType.PRIVATE) {
|
|
@@ -168,37 +218,37 @@ export class ContractFunctionSimulator {
|
|
|
168
218
|
const noteCache = new ExecutionNoteCache(protocolNullifier);
|
|
169
219
|
const taggingIndexCache = new ExecutionTaggingIndexCache();
|
|
170
220
|
|
|
171
|
-
const privateExecutionOracle = new PrivateExecutionOracle(
|
|
172
|
-
request.firstCallArgsHash,
|
|
173
|
-
request.txContext,
|
|
221
|
+
const privateExecutionOracle = new PrivateExecutionOracle({
|
|
222
|
+
argsHash: request.firstCallArgsHash,
|
|
223
|
+
txContext: request.txContext,
|
|
174
224
|
callContext,
|
|
175
225
|
anchorBlockHeader,
|
|
176
|
-
async call => {
|
|
177
|
-
await this.runUtility(call, [], anchorBlockHeader,
|
|
226
|
+
utilityExecutor: async (call, execScopes) => {
|
|
227
|
+
await this.runUtility(call, [], anchorBlockHeader, execScopes, jobId);
|
|
178
228
|
},
|
|
179
|
-
request.authWitnesses,
|
|
180
|
-
request.capsules,
|
|
181
|
-
HashedValuesCache.create(request.argsOfCalls),
|
|
229
|
+
authWitnesses: request.authWitnesses,
|
|
230
|
+
capsules: request.capsules,
|
|
231
|
+
executionCache: HashedValuesCache.create(request.argsOfCalls),
|
|
182
232
|
noteCache,
|
|
183
233
|
taggingIndexCache,
|
|
184
|
-
this.contractStore,
|
|
185
|
-
this.noteStore,
|
|
186
|
-
this.keyStore,
|
|
187
|
-
this.addressStore,
|
|
188
|
-
this.aztecNode,
|
|
189
|
-
this.
|
|
190
|
-
this.
|
|
191
|
-
this.
|
|
192
|
-
this.
|
|
193
|
-
this.
|
|
194
|
-
this.
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
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,
|
|
198
248
|
scopes,
|
|
199
249
|
senderForTags,
|
|
200
|
-
this.simulator,
|
|
201
|
-
);
|
|
250
|
+
simulator: this.simulator,
|
|
251
|
+
});
|
|
202
252
|
|
|
203
253
|
const setupTime = simulatorSetupTimer.ms();
|
|
204
254
|
|
|
@@ -215,8 +265,9 @@ export class ContractFunctionSimulator {
|
|
|
215
265
|
request.functionSelector,
|
|
216
266
|
);
|
|
217
267
|
const simulatorTeardownTimer = new Timer();
|
|
218
|
-
|
|
219
|
-
|
|
268
|
+
|
|
269
|
+
noteCache.finish();
|
|
270
|
+
const firstNullifierHint = noteCache.getNonceGenerator();
|
|
220
271
|
|
|
221
272
|
const publicCallRequests = collectNested([executionResult], r =>
|
|
222
273
|
r.publicInputs.publicCallRequests
|
|
@@ -261,34 +312,32 @@ export class ContractFunctionSimulator {
|
|
|
261
312
|
call: FunctionCall,
|
|
262
313
|
authwits: AuthWitness[],
|
|
263
314
|
anchorBlockHeader: BlockHeader,
|
|
264
|
-
scopes
|
|
315
|
+
scopes: AccessScopes,
|
|
316
|
+
jobId: string,
|
|
265
317
|
): Promise<Fr[]> {
|
|
266
|
-
await verifyCurrentClassId(call.to, this.aztecNode, this.contractStore, anchorBlockHeader);
|
|
267
|
-
|
|
268
318
|
const entryPointArtifact = await this.contractStore.getFunctionArtifactWithDebugMetadata(call.to, call.selector);
|
|
269
319
|
|
|
270
320
|
if (entryPointArtifact.functionType !== FunctionType.UTILITY) {
|
|
271
321
|
throw new Error(`Cannot run ${entryPointArtifact.functionType} function as utility`);
|
|
272
322
|
}
|
|
273
323
|
|
|
274
|
-
const oracle = new UtilityExecutionOracle(
|
|
275
|
-
call.to,
|
|
276
|
-
authwits,
|
|
277
|
-
[],
|
|
324
|
+
const oracle = new UtilityExecutionOracle({
|
|
325
|
+
contractAddress: call.to,
|
|
326
|
+
authWitnesses: authwits,
|
|
327
|
+
capsules: [],
|
|
278
328
|
anchorBlockHeader,
|
|
279
|
-
this.contractStore,
|
|
280
|
-
this.noteStore,
|
|
281
|
-
this.keyStore,
|
|
282
|
-
this.addressStore,
|
|
283
|
-
this.aztecNode,
|
|
284
|
-
this.
|
|
285
|
-
this.
|
|
286
|
-
this.
|
|
287
|
-
this.
|
|
288
|
-
|
|
289
|
-
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,
|
|
290
339
|
scopes,
|
|
291
|
-
);
|
|
340
|
+
});
|
|
292
341
|
|
|
293
342
|
try {
|
|
294
343
|
this.log.verbose(`Executing utility function ${entryPointArtifact.name}`, {
|
|
@@ -312,7 +361,7 @@ export class ContractFunctionSimulator {
|
|
|
312
361
|
);
|
|
313
362
|
});
|
|
314
363
|
|
|
315
|
-
this.log.verbose(`Utility
|
|
364
|
+
this.log.verbose(`Utility execution for ${call.to}.${call.selector} completed`);
|
|
316
365
|
return witnessMapToFields(acirExecutionResult.returnWitness);
|
|
317
366
|
} catch (err) {
|
|
318
367
|
throw createSimulationError(err instanceof Error ? err : new Error('Unknown error during private execution'));
|
|
@@ -326,7 +375,12 @@ export class ContractFunctionSimulator {
|
|
|
326
375
|
*/
|
|
327
376
|
getStats() {
|
|
328
377
|
const nodeRPCCalls =
|
|
329
|
-
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
|
+
};
|
|
330
384
|
|
|
331
385
|
return { nodeRPCCalls };
|
|
332
386
|
}
|
|
@@ -349,24 +403,33 @@ class OrderedSideEffect<T> {
|
|
|
349
403
|
* (allowing state overrides) and is much faster, while still generating a valid
|
|
350
404
|
* output that can be sent to the node for public simulation
|
|
351
405
|
* @param privateExecutionResult - The result of the private execution.
|
|
352
|
-
* @param
|
|
353
|
-
*
|
|
354
|
-
* @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).
|
|
355
410
|
* @returns The simulated proving result.
|
|
356
411
|
*/
|
|
357
412
|
export async function generateSimulatedProvingResult(
|
|
358
413
|
privateExecutionResult: PrivateExecutionResult,
|
|
359
|
-
|
|
360
|
-
|
|
414
|
+
debugFunctionNameGetter: (contractAddress: AztecAddress, functionSelector: FunctionSelector) => Promise<string>,
|
|
415
|
+
node: AztecNode,
|
|
416
|
+
minRevertibleSideEffectCounterOverride?: number,
|
|
361
417
|
): Promise<PrivateKernelExecutionProofOutput<PrivateKernelTailCircuitPublicInputs>> {
|
|
362
|
-
const
|
|
363
|
-
const nullifiers: OrderedSideEffect<Fr>[] = [];
|
|
364
|
-
const taggedPrivateLogs: OrderedSideEffect<PrivateLog>[] = [];
|
|
418
|
+
const taggedPrivateLogs: OrderedSideEffect<PrivateLogData>[] = [];
|
|
365
419
|
const l2ToL1Messages: OrderedSideEffect<ScopedL2ToL1Message>[] = [];
|
|
366
420
|
const contractClassLogsHashes: OrderedSideEffect<ScopedLogHash>[] = [];
|
|
367
421
|
const publicCallRequests: OrderedSideEffect<PublicCallRequest>[] = [];
|
|
368
422
|
const executionSteps: PrivateExecutionStep[] = [];
|
|
369
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
|
+
|
|
370
433
|
let publicTeardownCallRequest;
|
|
371
434
|
|
|
372
435
|
const executions = [privateExecutionResult.entrypoint];
|
|
@@ -377,35 +440,25 @@ export async function generateSimulatedProvingResult(
|
|
|
377
440
|
|
|
378
441
|
const { contractAddress } = execution.publicInputs.callContext;
|
|
379
442
|
|
|
380
|
-
|
|
381
|
-
execution.publicInputs.noteHashes
|
|
382
|
-
.getActiveItems()
|
|
383
|
-
.filter(noteHash => !noteHash.isEmpty())
|
|
384
|
-
.map(
|
|
385
|
-
async noteHash =>
|
|
386
|
-
new OrderedSideEffect(await siloNoteHash(contractAddress, noteHash.value), noteHash.counter),
|
|
387
|
-
),
|
|
388
|
-
);
|
|
389
|
-
|
|
390
|
-
const nullifiersFromExecution = await Promise.all(
|
|
391
|
-
execution.publicInputs.nullifiers
|
|
443
|
+
scopedNoteHashes.push(
|
|
444
|
+
...execution.publicInputs.noteHashes
|
|
392
445
|
.getActiveItems()
|
|
393
|
-
.
|
|
394
|
-
|
|
395
|
-
new OrderedSideEffect(await siloNullifier(contractAddress, nullifier.value), nullifier.counter),
|
|
396
|
-
),
|
|
446
|
+
.filter(nh => !nh.isEmpty())
|
|
447
|
+
.map(nh => nh.scope(contractAddress)),
|
|
397
448
|
);
|
|
449
|
+
scopedNullifiers.push(...execution.publicInputs.nullifiers.getActiveItems().map(n => n.scope(contractAddress)));
|
|
398
450
|
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
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
|
+
)),
|
|
404
458
|
);
|
|
405
459
|
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
nullifiers.push(...nullifiersFromExecution);
|
|
460
|
+
noteHashReadRequests.push(...execution.publicInputs.noteHashReadRequests.getActiveItems());
|
|
461
|
+
nullifierReadRequests.push(...execution.publicInputs.nullifierReadRequests.getActiveItems());
|
|
409
462
|
l2ToL1Messages.push(
|
|
410
463
|
...execution.publicInputs.l2ToL1Msgs
|
|
411
464
|
.getActiveItems()
|
|
@@ -434,7 +487,7 @@ export async function generateSimulatedProvingResult(
|
|
|
434
487
|
: execution.publicInputs.publicTeardownCallRequest;
|
|
435
488
|
|
|
436
489
|
executionSteps.push({
|
|
437
|
-
functionName: await
|
|
490
|
+
functionName: await debugFunctionNameGetter(
|
|
438
491
|
execution.publicInputs.callContext.contractAddress,
|
|
439
492
|
execution.publicInputs.callContext.functionSelector,
|
|
440
493
|
),
|
|
@@ -445,6 +498,47 @@ export async function generateSimulatedProvingResult(
|
|
|
445
498
|
});
|
|
446
499
|
}
|
|
447
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
|
+
|
|
448
542
|
const constantData = new TxConstantData(
|
|
449
543
|
privateExecutionResult.entrypoint.publicInputs.anchorBlockHeader,
|
|
450
544
|
privateExecutionResult.entrypoint.publicInputs.txContext,
|
|
@@ -461,23 +555,23 @@ export async function generateSimulatedProvingResult(
|
|
|
461
555
|
const getEffect = <T>(orderedSideEffect: OrderedSideEffect<T>) => orderedSideEffect.sideEffect;
|
|
462
556
|
|
|
463
557
|
const isPrivateOnlyTx = privateExecutionResult.publicFunctionCalldata.length === 0;
|
|
464
|
-
const minRevertibleSideEffectCounter = getFinalMinRevertibleSideEffectCounter(privateExecutionResult);
|
|
465
558
|
|
|
466
559
|
const [nonRevertibleNullifiers, revertibleNullifiers] = splitOrderedSideEffects(
|
|
467
|
-
|
|
560
|
+
siloedNullifiers,
|
|
468
561
|
minRevertibleSideEffectCounter,
|
|
469
562
|
);
|
|
470
|
-
|
|
563
|
+
const nonceGenerator = privateExecutionResult.firstNullifier;
|
|
564
|
+
if (nonRevertibleNullifiers.length === 0) {
|
|
565
|
+
nonRevertibleNullifiers.push(nonceGenerator);
|
|
566
|
+
} else if (!nonRevertibleNullifiers[0].equals(nonceGenerator)) {
|
|
471
567
|
throw new Error('The first non revertible nullifier should be equal to the nonce generator. This is a bug!');
|
|
472
|
-
} else {
|
|
473
|
-
nonRevertibleNullifiers.unshift(nonceGenerator);
|
|
474
568
|
}
|
|
475
569
|
|
|
476
570
|
if (isPrivateOnlyTx) {
|
|
477
571
|
// We must make the note hashes unique by using the
|
|
478
572
|
// nonce generator and their index in the tx.
|
|
479
573
|
const uniqueNoteHashes = await Promise.all(
|
|
480
|
-
siloedNoteHashes.
|
|
574
|
+
siloedNoteHashes.map(async (orderedSideEffect, i) => {
|
|
481
575
|
const siloedNoteHash = orderedSideEffect.sideEffect;
|
|
482
576
|
const nonce = await computeNoteHashNonce(nonceGenerator, i);
|
|
483
577
|
const uniqueNoteHash = await computeUniqueNoteHash(nonce, siloedNoteHash);
|
|
@@ -492,26 +586,32 @@ export async function generateSimulatedProvingResult(
|
|
|
492
586
|
ScopedL2ToL1Message.empty(),
|
|
493
587
|
MAX_L2_TO_L1_MSGS_PER_TX,
|
|
494
588
|
),
|
|
495
|
-
padArrayEnd(
|
|
589
|
+
padArrayEnd(filteredPrivateLogs.sort(sortByCounter).map(getEffect), PrivateLog.empty(), MAX_PRIVATE_LOGS_PER_TX),
|
|
496
590
|
padArrayEnd(
|
|
497
591
|
contractClassLogsHashes.sort(sortByCounter).map(getEffect),
|
|
498
592
|
ScopedLogHash.empty(),
|
|
499
593
|
MAX_CONTRACT_CLASS_LOGS_PER_TX,
|
|
500
594
|
),
|
|
501
595
|
);
|
|
502
|
-
gasUsed = meterGasUsed(accumulatedDataForRollup);
|
|
596
|
+
gasUsed = meterGasUsed(accumulatedDataForRollup, isPrivateOnlyTx);
|
|
503
597
|
inputsForRollup = new PartialPrivateTailPublicInputsForRollup(accumulatedDataForRollup);
|
|
504
598
|
} else {
|
|
505
599
|
const [nonRevertibleNoteHashes, revertibleNoteHashes] = splitOrderedSideEffects(
|
|
506
|
-
siloedNoteHashes
|
|
600
|
+
siloedNoteHashes,
|
|
507
601
|
minRevertibleSideEffectCounter,
|
|
508
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
|
+
);
|
|
509
609
|
const [nonRevertibleL2ToL1Messages, revertibleL2ToL1Messages] = splitOrderedSideEffects(
|
|
510
610
|
l2ToL1Messages.sort(sortByCounter),
|
|
511
611
|
minRevertibleSideEffectCounter,
|
|
512
612
|
);
|
|
513
613
|
const [nonRevertibleTaggedPrivateLogs, revertibleTaggedPrivateLogs] = splitOrderedSideEffects(
|
|
514
|
-
|
|
614
|
+
filteredPrivateLogs,
|
|
515
615
|
minRevertibleSideEffectCounter,
|
|
516
616
|
);
|
|
517
617
|
const [nonRevertibleContractClassLogHashes, revertibleContractClassLogHashes] = splitOrderedSideEffects(
|
|
@@ -524,7 +624,7 @@ export async function generateSimulatedProvingResult(
|
|
|
524
624
|
);
|
|
525
625
|
|
|
526
626
|
const nonRevertibleData = new PrivateToPublicAccumulatedData(
|
|
527
|
-
padArrayEnd(
|
|
627
|
+
padArrayEnd(nonRevertibleUniqueNoteHashes, Fr.ZERO, MAX_NOTE_HASHES_PER_TX),
|
|
528
628
|
padArrayEnd(nonRevertibleNullifiers, Fr.ZERO, MAX_NULLIFIERS_PER_TX),
|
|
529
629
|
padArrayEnd(nonRevertibleL2ToL1Messages, ScopedL2ToL1Message.empty(), MAX_L2_TO_L1_MSGS_PER_TX),
|
|
530
630
|
padArrayEnd(nonRevertibleTaggedPrivateLogs, PrivateLog.empty(), MAX_PRIVATE_LOGS_PER_TX),
|
|
@@ -540,9 +640,9 @@ export async function generateSimulatedProvingResult(
|
|
|
540
640
|
padArrayEnd(revertibleContractClassLogHashes, ScopedLogHash.empty(), MAX_CONTRACT_CLASS_LOGS_PER_TX),
|
|
541
641
|
padArrayEnd(revertiblePublicCallRequests, PublicCallRequest.empty(), MAX_ENQUEUED_CALLS_PER_TX),
|
|
542
642
|
);
|
|
543
|
-
gasUsed = meterGasUsed(revertibleData).add(meterGasUsed(nonRevertibleData));
|
|
643
|
+
gasUsed = meterGasUsed(revertibleData, isPrivateOnlyTx).add(meterGasUsed(nonRevertibleData, isPrivateOnlyTx));
|
|
544
644
|
if (publicTeardownCallRequest) {
|
|
545
|
-
gasUsed.add(privateExecutionResult.entrypoint.publicInputs.txContext.gasSettings.teardownGasLimits);
|
|
645
|
+
gasUsed = gasUsed.add(privateExecutionResult.entrypoint.publicInputs.txContext.gasSettings.teardownGasLimits);
|
|
546
646
|
}
|
|
547
647
|
|
|
548
648
|
inputsForPublic = new PartialPrivateTailPublicInputsForPublic(
|
|
@@ -554,9 +654,14 @@ export async function generateSimulatedProvingResult(
|
|
|
554
654
|
|
|
555
655
|
const publicInputs = new PrivateKernelTailCircuitPublicInputs(
|
|
556
656
|
constantData,
|
|
557
|
-
/*gasUsed=*/ gasUsed.add(
|
|
657
|
+
/*gasUsed=*/ gasUsed.add(
|
|
658
|
+
Gas.from({
|
|
659
|
+
l2Gas: isPrivateOnlyTx ? PRIVATE_TX_L2_GAS_OVERHEAD : PUBLIC_TX_L2_GAS_OVERHEAD,
|
|
660
|
+
daGas: TX_DA_GAS_OVERHEAD,
|
|
661
|
+
}),
|
|
662
|
+
),
|
|
558
663
|
/*feePayer=*/ AztecAddress.zero(),
|
|
559
|
-
/*
|
|
664
|
+
/*expirationTimestamp=*/ 0n,
|
|
560
665
|
hasPublicCalls ? inputsForPublic : undefined,
|
|
561
666
|
!hasPublicCalls ? inputsForRollup : undefined,
|
|
562
667
|
);
|
|
@@ -568,11 +673,116 @@ export async function generateSimulatedProvingResult(
|
|
|
568
673
|
};
|
|
569
674
|
}
|
|
570
675
|
|
|
676
|
+
/**
|
|
677
|
+
* Squashes transient note hashes and nullifiers, mimicking the behavior
|
|
678
|
+
* of the reset kernels. Returns the filtered (surviving) scoped items and private logs.
|
|
679
|
+
*/
|
|
680
|
+
function squashTransientSideEffects(
|
|
681
|
+
taggedPrivateLogs: OrderedSideEffect<PrivateLogData>[],
|
|
682
|
+
scopedNoteHashesCLA: ClaimedLengthArray<ScopedNoteHash, typeof MAX_NOTE_HASHES_PER_TX>,
|
|
683
|
+
scopedNullifiersCLA: ClaimedLengthArray<ScopedNullifier, typeof MAX_NULLIFIERS_PER_TX>,
|
|
684
|
+
noteHashNullifierCounterMap: Map<number, number>,
|
|
685
|
+
minRevertibleSideEffectCounter: number,
|
|
686
|
+
) {
|
|
687
|
+
const { numTransientData, hints: transientDataHints } = buildTransientDataHints(
|
|
688
|
+
scopedNoteHashesCLA,
|
|
689
|
+
scopedNullifiersCLA,
|
|
690
|
+
/*futureNoteHashReads=*/ [],
|
|
691
|
+
/*futureNullifierReads=*/ [],
|
|
692
|
+
noteHashNullifierCounterMap,
|
|
693
|
+
minRevertibleSideEffectCounter,
|
|
694
|
+
);
|
|
695
|
+
|
|
696
|
+
const squashedNoteHashCounters = new Set<number>();
|
|
697
|
+
const squashedNullifierCounters = new Set<number>();
|
|
698
|
+
for (let i = 0; i < numTransientData; i++) {
|
|
699
|
+
const hint = transientDataHints[i];
|
|
700
|
+
squashedNoteHashCounters.add(scopedNoteHashesCLA.array[hint.noteHashIndex].counter);
|
|
701
|
+
squashedNullifierCounters.add(scopedNullifiersCLA.array[hint.nullifierIndex].counter);
|
|
702
|
+
}
|
|
703
|
+
|
|
704
|
+
return {
|
|
705
|
+
filteredNoteHashes: scopedNoteHashesCLA.getActiveItems().filter(nh => !squashedNoteHashCounters.has(nh.counter)),
|
|
706
|
+
filteredNullifiers: scopedNullifiersCLA.getActiveItems().filter(n => !squashedNullifierCounters.has(n.counter)),
|
|
707
|
+
filteredPrivateLogs: taggedPrivateLogs
|
|
708
|
+
.filter(item => !squashedNoteHashCounters.has(item.sideEffect.noteHashCounter))
|
|
709
|
+
.map(item => new OrderedSideEffect(item.sideEffect.log, item.counter)),
|
|
710
|
+
};
|
|
711
|
+
}
|
|
712
|
+
|
|
713
|
+
/**
|
|
714
|
+
* Verifies settled read requests by checking membership in the note hash and nullifier trees
|
|
715
|
+
* at the tx's anchor block, mimicking the behavior of the kernels
|
|
716
|
+
*/
|
|
717
|
+
async function verifyReadRequests(
|
|
718
|
+
node: Pick<AztecNode, 'getNoteHashMembershipWitness' | 'getNullifierMembershipWitness'>,
|
|
719
|
+
anchorBlockHash: BlockParameter,
|
|
720
|
+
noteHashReadRequests: ScopedReadRequest[],
|
|
721
|
+
nullifierReadRequests: ScopedReadRequest[],
|
|
722
|
+
scopedNoteHashesCLA: ClaimedLengthArray<ScopedNoteHash, typeof MAX_NOTE_HASHES_PER_TX>,
|
|
723
|
+
scopedNullifiersCLA: ClaimedLengthArray<ScopedNullifier, typeof MAX_NULLIFIERS_PER_TX>,
|
|
724
|
+
) {
|
|
725
|
+
const noteHashReadRequestsCLA = new ClaimedLengthArray<ScopedReadRequest, typeof MAX_NOTE_HASH_READ_REQUESTS_PER_TX>(
|
|
726
|
+
padArrayEnd(noteHashReadRequests, ScopedReadRequest.empty(), MAX_NOTE_HASH_READ_REQUESTS_PER_TX),
|
|
727
|
+
noteHashReadRequests.length,
|
|
728
|
+
);
|
|
729
|
+
const nullifierReadRequestsCLA = new ClaimedLengthArray<ScopedReadRequest, typeof MAX_NULLIFIER_READ_REQUESTS_PER_TX>(
|
|
730
|
+
padArrayEnd(nullifierReadRequests, ScopedReadRequest.empty(), MAX_NULLIFIER_READ_REQUESTS_PER_TX),
|
|
731
|
+
nullifierReadRequests.length,
|
|
732
|
+
);
|
|
733
|
+
|
|
734
|
+
const noteHashResetActions = getNoteHashReadRequestResetActions(
|
|
735
|
+
noteHashReadRequestsCLA,
|
|
736
|
+
scopedNoteHashesCLA,
|
|
737
|
+
/*futureNoteHashes=*/ [],
|
|
738
|
+
);
|
|
739
|
+
const nullifierResetActions = getNullifierReadRequestResetActions(
|
|
740
|
+
nullifierReadRequestsCLA,
|
|
741
|
+
scopedNullifiersCLA,
|
|
742
|
+
/*futureNullifiers=*/ [],
|
|
743
|
+
);
|
|
744
|
+
|
|
745
|
+
const settledNoteHashReads: { index: number; value: Fr }[] = [];
|
|
746
|
+
for (let i = 0; i < noteHashResetActions.actions.length; i++) {
|
|
747
|
+
if (noteHashResetActions.actions[i] === ReadRequestActionEnum.READ_AS_SETTLED) {
|
|
748
|
+
settledNoteHashReads.push({ index: i, value: noteHashReadRequests[i].value });
|
|
749
|
+
}
|
|
750
|
+
}
|
|
751
|
+
|
|
752
|
+
const settledNullifierReads: { index: number; value: Fr }[] = [];
|
|
753
|
+
for (let i = 0; i < nullifierResetActions.actions.length; i++) {
|
|
754
|
+
if (nullifierResetActions.actions[i] === ReadRequestActionEnum.READ_AS_SETTLED) {
|
|
755
|
+
settledNullifierReads.push({ index: i, value: nullifierReadRequests[i].value });
|
|
756
|
+
}
|
|
757
|
+
}
|
|
758
|
+
|
|
759
|
+
const [noteHashWitnesses, nullifierWitnesses] = await Promise.all([
|
|
760
|
+
Promise.all(settledNoteHashReads.map(({ value }) => node.getNoteHashMembershipWitness(anchorBlockHash, value))),
|
|
761
|
+
Promise.all(settledNullifierReads.map(({ value }) => node.getNullifierMembershipWitness(anchorBlockHash, value))),
|
|
762
|
+
]);
|
|
763
|
+
|
|
764
|
+
for (let i = 0; i < settledNoteHashReads.length; i++) {
|
|
765
|
+
if (!noteHashWitnesses[i]) {
|
|
766
|
+
throw new Error(
|
|
767
|
+
`Note hash read request at index ${settledNoteHashReads[i].index} is reading an unknown note hash: ${settledNoteHashReads[i].value}`,
|
|
768
|
+
);
|
|
769
|
+
}
|
|
770
|
+
}
|
|
771
|
+
|
|
772
|
+
for (let i = 0; i < settledNullifierReads.length; i++) {
|
|
773
|
+
if (!nullifierWitnesses[i]) {
|
|
774
|
+
throw new Error(
|
|
775
|
+
`Nullifier read request at index ${settledNullifierReads[i].index} is reading an unknown nullifier: ${settledNullifierReads[i].value}`,
|
|
776
|
+
);
|
|
777
|
+
}
|
|
778
|
+
}
|
|
779
|
+
}
|
|
780
|
+
|
|
571
781
|
function splitOrderedSideEffects<T>(effects: OrderedSideEffect<T>[], minRevertibleSideEffectCounter: number) {
|
|
572
782
|
const revertibleSideEffects: T[] = [];
|
|
573
783
|
const nonRevertibleSideEffects: T[] = [];
|
|
574
784
|
effects.forEach(effect => {
|
|
575
|
-
if (effect.counter < minRevertibleSideEffectCounter) {
|
|
785
|
+
if (minRevertibleSideEffectCounter === 0 || effect.counter < minRevertibleSideEffectCounter) {
|
|
576
786
|
nonRevertibleSideEffects.push(effect.sideEffect);
|
|
577
787
|
} else {
|
|
578
788
|
revertibleSideEffects.push(effect.sideEffect);
|
|
@@ -581,21 +791,24 @@ function splitOrderedSideEffects<T>(effects: OrderedSideEffect<T>[], minRevertib
|
|
|
581
791
|
return [nonRevertibleSideEffects, revertibleSideEffects];
|
|
582
792
|
}
|
|
583
793
|
|
|
584
|
-
function meterGasUsed(data: PrivateToRollupAccumulatedData | PrivateToPublicAccumulatedData) {
|
|
794
|
+
function meterGasUsed(data: PrivateToRollupAccumulatedData | PrivateToPublicAccumulatedData, isPrivateOnlyTx: boolean) {
|
|
585
795
|
let meteredDAFields = 0;
|
|
586
796
|
let meteredL2Gas = 0;
|
|
587
797
|
|
|
588
798
|
const numNoteHashes = arrayNonEmptyLength(data.noteHashes, hash => hash.isEmpty());
|
|
589
799
|
meteredDAFields += numNoteHashes;
|
|
590
|
-
|
|
800
|
+
const noteHashBaseGas = isPrivateOnlyTx ? L2_GAS_PER_NOTE_HASH : AVM_EMITNOTEHASH_BASE_L2_GAS;
|
|
801
|
+
meteredL2Gas += numNoteHashes * noteHashBaseGas;
|
|
591
802
|
|
|
592
803
|
const numNullifiers = arrayNonEmptyLength(data.nullifiers, nullifier => nullifier.isEmpty());
|
|
593
804
|
meteredDAFields += numNullifiers;
|
|
594
|
-
|
|
805
|
+
const nullifierBaseGas = isPrivateOnlyTx ? L2_GAS_PER_NULLIFIER : AVM_EMITNULLIFIER_BASE_L2_GAS;
|
|
806
|
+
meteredL2Gas += numNullifiers * nullifierBaseGas;
|
|
595
807
|
|
|
596
808
|
const numL2toL1Messages = arrayNonEmptyLength(data.l2ToL1Msgs, msg => msg.isEmpty());
|
|
597
809
|
meteredDAFields += numL2toL1Messages;
|
|
598
|
-
|
|
810
|
+
const l2ToL1MessageBaseGas = isPrivateOnlyTx ? L2_GAS_PER_L2_TO_L1_MSG : AVM_SENDL2TOL1MSG_BASE_L2_GAS;
|
|
811
|
+
meteredL2Gas += numL2toL1Messages * l2ToL1MessageBaseGas;
|
|
599
812
|
|
|
600
813
|
const numPrivatelogs = arrayNonEmptyLength(data.privateLogs, log => log.isEmpty());
|
|
601
814
|
// Every private log emits its length as an additional field
|
|
@@ -610,7 +823,7 @@ function meterGasUsed(data: PrivateToRollupAccumulatedData | PrivateToPublicAccu
|
|
|
610
823
|
);
|
|
611
824
|
meteredL2Gas += numContractClassLogs * L2_GAS_PER_CONTRACT_CLASS_LOG;
|
|
612
825
|
|
|
613
|
-
const meteredDAGas = meteredDAFields *
|
|
826
|
+
const meteredDAGas = meteredDAFields * DA_GAS_PER_FIELD;
|
|
614
827
|
|
|
615
828
|
if ((data as PrivateToPublicAccumulatedData).publicCallRequests) {
|
|
616
829
|
const dataForPublic = data as PrivateToPublicAccumulatedData;
|