@aztec/pxe 0.0.1-commit.f2ce05ee → 0.0.1-commit.f5d02921e
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/block_synchronizer/block_synchronizer.d.ts +1 -1
- package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
- package/dest/block_synchronizer/block_synchronizer.js +6 -0
- package/dest/config/index.d.ts +2 -2
- package/dest/config/index.d.ts.map +1 -1
- package/dest/config/index.js +1 -1
- package/dest/config/package_info.js +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.d.ts +60 -30
- package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.js +199 -72
- package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +7 -7
- package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
- package/dest/contract_function_simulator/execution_tagging_index_cache.js +19 -11
- package/dest/contract_function_simulator/index.d.ts +2 -1
- package/dest/contract_function_simulator/index.d.ts.map +1 -1
- package/dest/contract_function_simulator/index.js +1 -0
- package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +3 -5
- 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 -9
- package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +1 -1
- package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts.map +1 -1
- package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +1 -3
- package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +3 -6
- 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 +5 -10
- package/dest/contract_function_simulator/oracle/interfaces.d.ts +50 -45
- package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts +9 -0
- package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts.map +1 -0
- package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.js +38 -0
- package/dest/contract_function_simulator/oracle/oracle.d.ts +64 -44
- package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/oracle.js +187 -97
- package/dest/contract_function_simulator/oracle/private_execution.js +5 -3
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +54 -80
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/private_execution_oracle.js +98 -85
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +90 -52
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +213 -116
- package/dest/contract_logging.d.ts +27 -0
- package/dest/contract_logging.d.ts.map +1 -0
- package/dest/contract_logging.js +38 -0
- package/dest/contract_sync/contract_sync_service.d.ts +10 -5
- package/dest/contract_sync/contract_sync_service.d.ts.map +1 -1
- package/dest/contract_sync/contract_sync_service.js +72 -30
- package/dest/contract_sync/helpers.d.ts +3 -2
- package/dest/contract_sync/helpers.d.ts.map +1 -1
- package/dest/contract_sync/helpers.js +9 -4
- package/dest/debug/pxe_debug_utils.d.ts +5 -4
- package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
- package/dest/debug/pxe_debug_utils.js +4 -4
- 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 +9 -1
- 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 +1 -1
- package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
- package/dest/entrypoints/client/lazy/utils.js +9 -1
- package/dest/entrypoints/server/index.d.ts +3 -1
- package/dest/entrypoints/server/index.d.ts.map +1 -1
- package/dest/entrypoints/server/index.js +2 -0
- package/dest/entrypoints/server/utils.js +9 -1
- package/dest/events/event_service.d.ts +3 -2
- package/dest/events/event_service.d.ts.map +1 -1
- package/dest/events/event_service.js +16 -4
- package/dest/logs/log_service.d.ts +6 -6
- package/dest/logs/log_service.d.ts.map +1 -1
- package/dest/logs/log_service.js +31 -40
- package/dest/messages/message_context_service.d.ts +17 -0
- package/dest/messages/message_context_service.d.ts.map +1 -0
- package/dest/messages/message_context_service.js +36 -0
- package/dest/notes/note_service.d.ts +5 -4
- package/dest/notes/note_service.d.ts.map +1 -1
- package/dest/notes/note_service.js +17 -7
- 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 +2 -2
- package/dest/oracle_version.js +3 -3
- package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
- package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
- package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
- package/dest/private_kernel/hints/index.d.ts +1 -1
- package/dest/private_kernel/hints/index.js +1 -1
- package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +4 -3
- package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -1
- package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.js +129 -68
- package/dest/private_kernel/hints/test_utils.d.ts +122 -0
- package/dest/private_kernel/hints/test_utils.d.ts.map +1 -0
- package/dest/private_kernel/hints/test_utils.js +203 -0
- package/dest/private_kernel/private_kernel_execution_prover.d.ts +1 -1
- package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
- package/dest/private_kernel/private_kernel_execution_prover.js +19 -11
- package/dest/private_kernel/private_kernel_oracle.d.ts +6 -2
- package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
- package/dest/private_kernel/private_kernel_oracle.js +7 -3
- package/dest/pxe.d.ts +63 -24
- package/dest/pxe.d.ts.map +1 -1
- package/dest/pxe.js +105 -74
- package/dest/storage/capsule_store/capsule_service.d.ts +22 -0
- package/dest/storage/capsule_store/capsule_service.d.ts.map +1 -0
- package/dest/storage/capsule_store/capsule_service.js +50 -0
- package/dest/storage/capsule_store/capsule_store.d.ts +9 -9
- package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -1
- package/dest/storage/capsule_store/capsule_store.js +33 -28
- package/dest/storage/capsule_store/index.d.ts +2 -1
- package/dest/storage/capsule_store/index.d.ts.map +1 -1
- package/dest/storage/capsule_store/index.js +1 -0
- package/dest/storage/contract_store/contract_store.d.ts +42 -15
- package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
- package/dest/storage/contract_store/contract_store.js +140 -64
- package/dest/storage/metadata.d.ts +1 -1
- package/dest/storage/metadata.js +1 -1
- package/dest/storage/note_store/note_store.d.ts +3 -3
- package/dest/storage/note_store/note_store.d.ts.map +1 -1
- package/dest/storage/note_store/note_store.js +3 -4
- package/dest/storage/tagging_store/recipient_tagging_store.d.ts +6 -6
- package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
- package/dest/storage/tagging_store/sender_tagging_store.d.ts +29 -28
- package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
- package/dest/storage/tagging_store/sender_tagging_store.js +141 -115
- package/dest/tagging/get_all_logs_by_tags.d.ts +1 -1
- package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -1
- package/dest/tagging/get_all_logs_by_tags.js +17 -3
- package/dest/tagging/index.d.ts +3 -3
- package/dest/tagging/index.d.ts.map +1 -1
- package/dest/tagging/index.js +1 -1
- package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +4 -5
- package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +1 -1
- package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +7 -7
- package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +2 -2
- package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +6 -7
- package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +1 -1
- package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +12 -11
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +4 -8
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +13 -7
- package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +4 -3
- 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 +20 -10
- package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +5 -7
- package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -1
- package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +36 -24
- package/package.json +16 -16
- package/src/access_scopes.ts +9 -0
- package/src/block_synchronizer/block_synchronizer.ts +6 -0
- package/src/config/index.ts +1 -1
- package/src/config/package_info.ts +1 -1
- package/src/contract_function_simulator/contract_function_simulator.ts +358 -133
- package/src/contract_function_simulator/execution_tagging_index_cache.ts +19 -14
- package/src/contract_function_simulator/index.ts +1 -0
- package/src/contract_function_simulator/noir-structs/event_validation_request.ts +8 -8
- package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +1 -4
- package/src/contract_function_simulator/noir-structs/note_validation_request.ts +3 -9
- package/src/contract_function_simulator/oracle/interfaces.ts +63 -54
- package/src/contract_function_simulator/oracle/legacy_oracle_mappings.ts +98 -0
- package/src/contract_function_simulator/oracle/oracle.ts +223 -139
- package/src/contract_function_simulator/oracle/private_execution.ts +4 -4
- package/src/contract_function_simulator/oracle/private_execution_oracle.ts +122 -177
- package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +375 -131
- package/src/contract_logging.ts +52 -0
- package/src/contract_sync/contract_sync_service.ts +108 -45
- package/src/contract_sync/helpers.ts +9 -3
- package/src/debug/pxe_debug_utils.ts +11 -9
- package/src/entrypoints/client/bundle/index.ts +3 -0
- package/src/entrypoints/client/bundle/utils.ts +9 -1
- package/src/entrypoints/client/lazy/index.ts +3 -0
- package/src/entrypoints/client/lazy/utils.ts +9 -1
- package/src/entrypoints/server/index.ts +2 -0
- package/src/entrypoints/server/utils.ts +7 -7
- package/src/events/event_service.ts +17 -4
- package/src/logs/log_service.ts +61 -63
- package/src/messages/message_context_service.ts +44 -0
- package/src/notes/note_service.ts +20 -8
- package/src/notes_filter.ts +26 -0
- package/src/oracle_version.ts +3 -3
- package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
- package/src/private_kernel/hints/index.ts +1 -1
- package/src/private_kernel/hints/private_kernel_reset_private_inputs_builder.ts +164 -117
- package/src/private_kernel/hints/test_utils.ts +325 -0
- package/src/private_kernel/private_kernel_execution_prover.ts +19 -12
- package/src/private_kernel/private_kernel_oracle.ts +7 -7
- package/src/pxe.ts +190 -117
- package/src/storage/capsule_store/capsule_service.ts +91 -0
- package/src/storage/capsule_store/capsule_store.ts +34 -26
- package/src/storage/capsule_store/index.ts +1 -0
- package/src/storage/contract_store/contract_store.ts +170 -71
- package/src/storage/metadata.ts +1 -1
- package/src/storage/note_store/note_store.ts +8 -5
- package/src/storage/tagging_store/recipient_tagging_store.ts +9 -5
- package/src/storage/tagging_store/sender_tagging_store.ts +185 -138
- package/src/tagging/get_all_logs_by_tags.ts +28 -4
- package/src/tagging/index.ts +2 -2
- package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +7 -10
- package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +2 -2
- package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +10 -15
- package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +23 -10
- package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +26 -11
- package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +27 -26
- 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
|
@@ -6,7 +6,7 @@ import { toACVMWitness } from '@aztec/simulator/client';
|
|
|
6
6
|
import { FunctionSelector, countArgumentsSize } from '@aztec/stdlib/abi';
|
|
7
7
|
import { siloNullifier } from '@aztec/stdlib/hash';
|
|
8
8
|
import { PrivateContextInputs } from '@aztec/stdlib/kernel';
|
|
9
|
-
import {
|
|
9
|
+
import { ExtendedDirectionalAppTaggingSecret } from '@aztec/stdlib/logs';
|
|
10
10
|
import { Tag } from '@aztec/stdlib/logs';
|
|
11
11
|
import { Note } from '@aztec/stdlib/note';
|
|
12
12
|
import { CallContext, CountedContractClassLog, NoteAndSlot } from '@aztec/stdlib/tx';
|
|
@@ -18,35 +18,48 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
|
|
|
18
18
|
/**
|
|
19
19
|
* The execution oracle for the private part of a transaction.
|
|
20
20
|
*/ export class PrivateExecutionOracle extends UtilityExecutionOracle {
|
|
21
|
+
isPrivate = true;
|
|
22
|
+
/**
|
|
23
|
+
* New notes created during this execution.
|
|
24
|
+
* It's possible that a note in this list has been nullified (in the same or other executions) and doesn't exist in
|
|
25
|
+
* the ExecutionNoteCache and the final proof data. But we still include those notes in the execution result because
|
|
26
|
+
* their commitments are still in the public inputs of this execution.
|
|
27
|
+
* This information is only for references (currently used for tests), and is not used for any sort of constrains.
|
|
28
|
+
* Users can also use this to get a clearer idea of what's happened during a simulation.
|
|
29
|
+
*/ newNotes = [];
|
|
30
|
+
noteHashNullifierCounterMap = new Map();
|
|
31
|
+
contractClassLogs = [];
|
|
32
|
+
nestedExecutionResults = [];
|
|
21
33
|
argsHash;
|
|
22
34
|
txContext;
|
|
23
35
|
callContext;
|
|
24
|
-
anchorBlockHeader;
|
|
25
36
|
utilityExecutor;
|
|
26
37
|
executionCache;
|
|
27
38
|
noteCache;
|
|
28
39
|
taggingIndexCache;
|
|
29
40
|
senderTaggingStore;
|
|
30
|
-
contractSyncService;
|
|
31
41
|
totalPublicCalldataCount;
|
|
32
42
|
sideEffectCounter;
|
|
33
43
|
senderForTags;
|
|
34
44
|
simulator;
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
45
|
+
constructor(args){
|
|
46
|
+
super({
|
|
47
|
+
...args,
|
|
48
|
+
contractAddress: args.callContext.contractAddress,
|
|
49
|
+
log: args.log ?? createLogger('simulator:client_execution_context')
|
|
50
|
+
});
|
|
51
|
+
this.argsHash = args.argsHash;
|
|
52
|
+
this.txContext = args.txContext;
|
|
53
|
+
this.callContext = args.callContext;
|
|
54
|
+
this.utilityExecutor = args.utilityExecutor;
|
|
55
|
+
this.executionCache = args.executionCache;
|
|
56
|
+
this.noteCache = args.noteCache;
|
|
57
|
+
this.taggingIndexCache = args.taggingIndexCache;
|
|
58
|
+
this.senderTaggingStore = args.senderTaggingStore;
|
|
59
|
+
this.totalPublicCalldataCount = args.totalPublicCalldataCount ?? 0;
|
|
60
|
+
this.sideEffectCounter = args.sideEffectCounter ?? 0;
|
|
61
|
+
this.senderForTags = args.senderForTags;
|
|
62
|
+
this.simulator = args.simulator;
|
|
50
63
|
}
|
|
51
64
|
getPrivateContextInputs() {
|
|
52
65
|
return new PrivateContextInputs(this.callContext, this.anchorBlockHeader, this.txContext, this.sideEffectCounter);
|
|
@@ -87,14 +100,9 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
|
|
|
87
100
|
return this.contractClassLogs;
|
|
88
101
|
}
|
|
89
102
|
/**
|
|
90
|
-
*
|
|
91
|
-
*/
|
|
92
|
-
return this.
|
|
93
|
-
}
|
|
94
|
-
/**
|
|
95
|
-
* Returns the pre-tags that were used in this execution (and that need to be stored in the db).
|
|
96
|
-
*/ getUsedPreTags() {
|
|
97
|
-
return this.taggingIndexCache.getUsedPreTags();
|
|
103
|
+
* Returns the tagging index ranges that were used in this execution (and that need to be stored in the db).
|
|
104
|
+
*/ getUsedTaggingIndexRanges() {
|
|
105
|
+
return this.taggingIndexCache.getUsedTaggingIndexRanges();
|
|
98
106
|
}
|
|
99
107
|
/**
|
|
100
108
|
* Return the nested execution results during this execution.
|
|
@@ -110,7 +118,7 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
|
|
|
110
118
|
*
|
|
111
119
|
* The value persists through nested calls, meaning all calls down the stack will use the same
|
|
112
120
|
* 'senderForTags' value (unless it is replaced).
|
|
113
|
-
*/
|
|
121
|
+
*/ getSenderForTags() {
|
|
114
122
|
return Promise.resolve(this.senderForTags);
|
|
115
123
|
}
|
|
116
124
|
/**
|
|
@@ -123,7 +131,7 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
|
|
|
123
131
|
* Account contracts typically set this value before calling other contracts. The value persists
|
|
124
132
|
* through nested calls, meaning all calls down the stack will use the same 'senderForTags'
|
|
125
133
|
* value (unless it is replaced by another call to this setter).
|
|
126
|
-
*/
|
|
134
|
+
*/ setSenderForTags(senderForTags) {
|
|
127
135
|
this.senderForTags = senderForTags;
|
|
128
136
|
return Promise.resolve();
|
|
129
137
|
}
|
|
@@ -132,20 +140,20 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
|
|
|
132
140
|
* @param sender - The address sending the log
|
|
133
141
|
* @param recipient - The address receiving the log
|
|
134
142
|
* @returns An app tag to be used in a log.
|
|
135
|
-
*/ async
|
|
136
|
-
const
|
|
137
|
-
const index = await this.#getIndexToUseForSecret(
|
|
138
|
-
this.
|
|
139
|
-
this.taggingIndexCache.setLastUsedIndex(
|
|
143
|
+
*/ async getNextAppTagAsSender(sender, recipient) {
|
|
144
|
+
const extendedSecret = await this.#calculateExtendedDirectionalAppTaggingSecret(this.contractAddress, sender, recipient);
|
|
145
|
+
const index = await this.#getIndexToUseForSecret(extendedSecret);
|
|
146
|
+
this.logger.debug(`Incrementing tagging index for sender: ${sender}, recipient: ${recipient}, contract: ${this.contractAddress} to ${index}`);
|
|
147
|
+
this.taggingIndexCache.setLastUsedIndex(extendedSecret, index);
|
|
140
148
|
return Tag.compute({
|
|
141
|
-
|
|
149
|
+
extendedSecret,
|
|
142
150
|
index
|
|
143
151
|
});
|
|
144
152
|
}
|
|
145
|
-
async #
|
|
153
|
+
async #calculateExtendedDirectionalAppTaggingSecret(contractAddress, sender, recipient) {
|
|
146
154
|
const senderCompleteAddress = await this.getCompleteAddressOrFail(sender);
|
|
147
155
|
const senderIvsk = await this.keyStore.getMasterIncomingViewingSecretKey(sender);
|
|
148
|
-
return
|
|
156
|
+
return ExtendedDirectionalAppTaggingSecret.compute(senderCompleteAddress, senderIvsk, recipient, contractAddress, recipient);
|
|
149
157
|
}
|
|
150
158
|
async #getIndexToUseForSecret(secret) {
|
|
151
159
|
// If we have the tagging index in the cache, we use it. If not we obtain it from the execution data provider.
|
|
@@ -156,7 +164,7 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
|
|
|
156
164
|
// This is a tagging secret we've not yet used in this tx, so first sync our store to make sure its indices
|
|
157
165
|
// are up to date. We do this here because this store is not synced as part of the global sync because
|
|
158
166
|
// that'd be wasteful as most tagging secrets are not used in each tx.
|
|
159
|
-
await syncSenderTaggingIndexes(secret, this.
|
|
167
|
+
await syncSenderTaggingIndexes(secret, this.aztecNode, this.senderTaggingStore, await this.anchorBlockHeader.hash(), this.jobId);
|
|
160
168
|
const lastUsedIndex = await this.senderTaggingStore.getLastUsedIndex(secret, this.jobId);
|
|
161
169
|
// If lastUsedIndex is undefined, we've never used this secret, so start from 0
|
|
162
170
|
// Otherwise, the next index to use is one past the last used index
|
|
@@ -167,29 +175,29 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
|
|
|
167
175
|
* Store values in the execution cache.
|
|
168
176
|
* @param values - Values to store.
|
|
169
177
|
* @returns The hash of the values.
|
|
170
|
-
*/
|
|
178
|
+
*/ setHashPreimage(values, hash) {
|
|
171
179
|
return this.executionCache.store(values, hash);
|
|
172
180
|
}
|
|
173
181
|
/**
|
|
174
182
|
* Gets values from the execution cache.
|
|
175
183
|
* @param hash - Hash of the values.
|
|
176
184
|
* @returns The values.
|
|
177
|
-
*/
|
|
185
|
+
*/ getHashPreimage(hash) {
|
|
178
186
|
const preimage = this.executionCache.getPreimage(hash);
|
|
179
187
|
if (!preimage) {
|
|
180
188
|
throw new Error(`Preimage for hash ${hash.toString()} not found in cache`);
|
|
181
189
|
}
|
|
182
190
|
return Promise.resolve(preimage);
|
|
183
191
|
}
|
|
184
|
-
async
|
|
192
|
+
async doesNullifierExist(innerNullifier) {
|
|
185
193
|
// This oracle must be overridden because while utility execution can only meaningfully check if a nullifier exists
|
|
186
194
|
// in the synched block, during private execution there's also the possibility of it being pending, i.e. created
|
|
187
195
|
// in the current transaction.
|
|
188
|
-
this.
|
|
196
|
+
this.logger.debug(`Checking existence of inner nullifier ${innerNullifier}`, {
|
|
189
197
|
contractAddress: this.contractAddress
|
|
190
198
|
});
|
|
191
199
|
const nullifier = (await siloNullifier(this.contractAddress, innerNullifier)).toBigInt();
|
|
192
|
-
return this.noteCache.getNullifiers(this.contractAddress).has(nullifier) || await super.
|
|
200
|
+
return this.noteCache.getNullifiers(this.contractAddress).has(nullifier) || await super.doesNullifierExist(innerNullifier);
|
|
193
201
|
}
|
|
194
202
|
/**
|
|
195
203
|
* Gets some notes for a storage slot.
|
|
@@ -211,7 +219,7 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
|
|
|
211
219
|
* @param offset - The starting index for pagination.
|
|
212
220
|
* @param status - The status of notes to fetch.
|
|
213
221
|
* @returns Array of note data.
|
|
214
|
-
*/ async
|
|
222
|
+
*/ async getNotes(owner, storageSlot, numSelects, selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, limit, offset, status) {
|
|
215
223
|
// Nullified pending notes are already removed from the list.
|
|
216
224
|
const pendingNotes = this.noteCache.getNotes(this.callContext.contractAddress, owner, storageSlot);
|
|
217
225
|
const pendingNullifiers = this.noteCache.getNullifiers(this.callContext.contractAddress);
|
|
@@ -242,7 +250,7 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
|
|
|
242
250
|
limit,
|
|
243
251
|
offset
|
|
244
252
|
});
|
|
245
|
-
this.
|
|
253
|
+
this.logger.debug(`Returning ${notes.length} notes for ${this.callContext.contractAddress} at ${storageSlot}: ${notes.map((n)=>`${n.noteNonce.toString()}:[${n.note.items.map((i)=>i.toString()).join(',')}]`).join(', ')}`);
|
|
246
254
|
return notes;
|
|
247
255
|
}
|
|
248
256
|
/**
|
|
@@ -255,8 +263,8 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
|
|
|
255
263
|
* @param noteItems - The items to be included in a Note.
|
|
256
264
|
* @param noteHash - A hash of the new note.
|
|
257
265
|
* @returns
|
|
258
|
-
*/
|
|
259
|
-
this.
|
|
266
|
+
*/ notifyCreatedNote(owner, storageSlot, randomness, noteTypeId, noteItems, noteHash, counter) {
|
|
267
|
+
this.logger.debug(`Notified of new note with inner hash ${noteHash}`, {
|
|
260
268
|
contractAddress: this.callContext.contractAddress,
|
|
261
269
|
storageSlot,
|
|
262
270
|
randomness,
|
|
@@ -287,7 +295,7 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
|
|
|
287
295
|
* within the current transaction/execution.
|
|
288
296
|
* @param innerNullifier - The pending nullifier to add in the list (not yet siloed by contract address).
|
|
289
297
|
* @param noteHash - A hash of the new note.
|
|
290
|
-
*/ async
|
|
298
|
+
*/ async notifyNullifiedNote(innerNullifier, noteHash, counter) {
|
|
291
299
|
const nullifiedNoteHashCounter = await this.noteCache.nullifyNote(this.callContext.contractAddress, innerNullifier, noteHash);
|
|
292
300
|
if (nullifiedNoteHashCounter !== undefined) {
|
|
293
301
|
this.noteHashNullifierCounterMap.set(nullifiedNoteHashCounter, counter);
|
|
@@ -298,19 +306,19 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
|
|
|
298
306
|
* within the current transaction/execution.
|
|
299
307
|
* @param innerNullifier - The pending nullifier to add in the list (not yet siloed by contract address).
|
|
300
308
|
* @param noteHash - A hash of the new note.
|
|
301
|
-
*/
|
|
302
|
-
this.
|
|
309
|
+
*/ notifyCreatedNullifier(innerNullifier) {
|
|
310
|
+
this.logger.debug(`Notified of new inner nullifier ${innerNullifier}`, {
|
|
303
311
|
contractAddress: this.contractAddress
|
|
304
312
|
});
|
|
305
313
|
return this.noteCache.nullifierCreated(this.callContext.contractAddress, innerNullifier);
|
|
306
314
|
}
|
|
307
315
|
/**
|
|
308
|
-
* Check if a nullifier has been emitted in the same transaction, i.e. if
|
|
316
|
+
* Check if a nullifier has been emitted in the same transaction, i.e. if notifyCreatedNullifier has been
|
|
309
317
|
* called for this inner nullifier from the contract with the specified address.
|
|
310
318
|
* @param innerNullifier - The inner nullifier to check.
|
|
311
319
|
* @param contractAddress - Address of the contract that emitted the nullifier.
|
|
312
320
|
* @returns A boolean indicating whether the nullifier is pending or not.
|
|
313
|
-
*/ async
|
|
321
|
+
*/ async isNullifierPending(innerNullifier, contractAddress) {
|
|
314
322
|
const siloedNullifier = await siloNullifier(contractAddress, innerNullifier);
|
|
315
323
|
const isNullifierPending = this.noteCache.getNullifiers(contractAddress).has(siloedNullifier.toBigInt());
|
|
316
324
|
return Promise.resolve(isNullifierPending);
|
|
@@ -321,10 +329,10 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
|
|
|
321
329
|
* keep the preimage in ts for later.
|
|
322
330
|
* @param log - The contract class log to be emitted.
|
|
323
331
|
* @param counter - The contract class log's counter.
|
|
324
|
-
*/
|
|
332
|
+
*/ notifyCreatedContractClassLog(log, counter) {
|
|
325
333
|
this.contractClassLogs.push(new CountedContractClassLog(log, counter));
|
|
326
334
|
const text = log.toBuffer().toString('hex');
|
|
327
|
-
this.
|
|
335
|
+
this.logger.verbose(`Emitted log from ContractClassRegistry: "${text.length > 100 ? text.slice(0, 100) + '...' : text}"`);
|
|
328
336
|
}
|
|
329
337
|
#checkValidStaticCall(childExecutionResult) {
|
|
330
338
|
if (childExecutionResult.publicInputs.noteHashes.claimedLength > 0 || childExecutionResult.publicInputs.nullifiers.claimedLength > 0 || childExecutionResult.publicInputs.l2ToL1Msgs.claimedLength > 0 || childExecutionResult.publicInputs.privateLogs.claimedLength > 0 || childExecutionResult.publicInputs.contractClassLogsHashes.claimedLength > 0) {
|
|
@@ -339,20 +347,50 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
|
|
|
339
347
|
* @param sideEffectCounter - The side effect counter at the start of the call.
|
|
340
348
|
* @param isStaticCall - Whether the call is a static call.
|
|
341
349
|
* @returns The execution result.
|
|
342
|
-
*/ async
|
|
350
|
+
*/ async callPrivateFunction(targetContractAddress, functionSelector, argsHash, sideEffectCounter, isStaticCall) {
|
|
343
351
|
if (!this.simulator) {
|
|
344
352
|
// In practice it is only when creating inline private contexts in a Noir test using TXE that we create an
|
|
345
353
|
// instance of this class without a simulator.
|
|
346
354
|
throw new Error('No simulator provided, cannot perform a nested private call');
|
|
347
355
|
}
|
|
348
356
|
const simulatorSetupTimer = new Timer();
|
|
349
|
-
this.
|
|
357
|
+
this.logger.debug(`Calling private function ${targetContractAddress}:${functionSelector} from ${this.callContext.contractAddress}`);
|
|
350
358
|
isStaticCall = isStaticCall || this.callContext.isStaticCall;
|
|
351
|
-
await this.contractSyncService.ensureContractSynced(targetContractAddress, functionSelector, this.utilityExecutor, this.anchorBlockHeader, this.jobId);
|
|
359
|
+
await this.contractSyncService.ensureContractSynced(targetContractAddress, functionSelector, this.utilityExecutor, this.anchorBlockHeader, this.jobId, this.scopes);
|
|
352
360
|
const targetArtifact = await this.contractStore.getFunctionArtifactWithDebugMetadata(targetContractAddress, functionSelector);
|
|
353
361
|
const derivedTxContext = this.txContext.clone();
|
|
354
362
|
const derivedCallContext = await this.deriveCallContext(targetContractAddress, targetArtifact, isStaticCall);
|
|
355
|
-
const privateExecutionOracle = new PrivateExecutionOracle(
|
|
363
|
+
const privateExecutionOracle = new PrivateExecutionOracle({
|
|
364
|
+
argsHash,
|
|
365
|
+
txContext: derivedTxContext,
|
|
366
|
+
callContext: derivedCallContext,
|
|
367
|
+
anchorBlockHeader: this.anchorBlockHeader,
|
|
368
|
+
utilityExecutor: this.utilityExecutor,
|
|
369
|
+
authWitnesses: this.authWitnesses,
|
|
370
|
+
capsules: this.capsules,
|
|
371
|
+
executionCache: this.executionCache,
|
|
372
|
+
noteCache: this.noteCache,
|
|
373
|
+
taggingIndexCache: this.taggingIndexCache,
|
|
374
|
+
contractStore: this.contractStore,
|
|
375
|
+
noteStore: this.noteStore,
|
|
376
|
+
keyStore: this.keyStore,
|
|
377
|
+
addressStore: this.addressStore,
|
|
378
|
+
aztecNode: this.aztecNode,
|
|
379
|
+
senderTaggingStore: this.senderTaggingStore,
|
|
380
|
+
recipientTaggingStore: this.recipientTaggingStore,
|
|
381
|
+
senderAddressBookStore: this.senderAddressBookStore,
|
|
382
|
+
capsuleService: this.capsuleService,
|
|
383
|
+
privateEventStore: this.privateEventStore,
|
|
384
|
+
messageContextService: this.messageContextService,
|
|
385
|
+
contractSyncService: this.contractSyncService,
|
|
386
|
+
jobId: this.jobId,
|
|
387
|
+
totalPublicCalldataCount: this.totalPublicCalldataCount,
|
|
388
|
+
sideEffectCounter,
|
|
389
|
+
log: this.logger,
|
|
390
|
+
scopes: this.scopes,
|
|
391
|
+
senderForTags: this.senderForTags,
|
|
392
|
+
simulator: this.simulator
|
|
393
|
+
});
|
|
356
394
|
const setupTime = simulatorSetupTimer.ms();
|
|
357
395
|
const childExecutionResult = await executePrivateFunction(this.simulator, privateExecutionOracle, targetArtifact, targetContractAddress, functionSelector);
|
|
358
396
|
if (isStaticCall) {
|
|
@@ -369,7 +407,7 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
|
|
|
369
407
|
returnsHash: publicInputs.returnsHash
|
|
370
408
|
};
|
|
371
409
|
}
|
|
372
|
-
|
|
410
|
+
/** Validates the calldata preimage exists in the cache and checks cumulative calldata size is within limits. */ assertValidPublicCalldata(calldataHash) {
|
|
373
411
|
const calldata = this.executionCache.getPreimage(calldataHash);
|
|
374
412
|
if (!calldata) {
|
|
375
413
|
throw new Error('Calldata for public call not found in cache');
|
|
@@ -378,31 +416,12 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
|
|
|
378
416
|
if (this.totalPublicCalldataCount > MAX_FR_CALLDATA_TO_ALL_ENQUEUED_CALLS) {
|
|
379
417
|
throw new Error(`Too many total args to all enqueued public calls! (> ${MAX_FR_CALLDATA_TO_ALL_ENQUEUED_CALLS})`);
|
|
380
418
|
}
|
|
381
|
-
}
|
|
382
|
-
/**
|
|
383
|
-
* Verify relevant information when a public function is enqueued.
|
|
384
|
-
* @param targetContractAddress - The address of the contract to call.
|
|
385
|
-
* @param calldataHash - The hash of the function selector and arguments.
|
|
386
|
-
* @param sideEffectCounter - The side effect counter at the start of the call.
|
|
387
|
-
* @param isStaticCall - Whether the call is a static call.
|
|
388
|
-
*/ privateNotifyEnqueuedPublicFunctionCall(_targetContractAddress, calldataHash, _sideEffectCounter, _isStaticCall) {
|
|
389
|
-
this.#onNewPublicFunctionCall(calldataHash);
|
|
390
|
-
return Promise.resolve();
|
|
391
|
-
}
|
|
392
|
-
/**
|
|
393
|
-
* Verify relevant information when a public teardown function is set.
|
|
394
|
-
* @param targetContractAddress - The address of the contract to call.
|
|
395
|
-
* @param argsHash - The arguments hash to pass to the function.
|
|
396
|
-
* @param sideEffectCounter - The side effect counter at the start of the call.
|
|
397
|
-
* @param isStaticCall - Whether the call is a static call.
|
|
398
|
-
*/ privateNotifySetPublicTeardownFunctionCall(_targetContractAddress, calldataHash, _sideEffectCounter, _isStaticCall) {
|
|
399
|
-
this.#onNewPublicFunctionCall(calldataHash);
|
|
400
419
|
return Promise.resolve();
|
|
401
420
|
}
|
|
402
|
-
|
|
421
|
+
notifyRevertiblePhaseStart(minRevertibleSideEffectCounter) {
|
|
403
422
|
return this.noteCache.setMinRevertibleSideEffectCounter(minRevertibleSideEffectCounter);
|
|
404
423
|
}
|
|
405
|
-
|
|
424
|
+
isExecutionInRevertiblePhase(sideEffectCounter) {
|
|
406
425
|
return Promise.resolve(this.noteCache.isSideEffectCounterRevertible(sideEffectCounter));
|
|
407
426
|
}
|
|
408
427
|
/**
|
|
@@ -417,10 +436,4 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
|
|
|
417
436
|
getDebugFunctionName() {
|
|
418
437
|
return this.contractStore.getDebugFunctionName(this.contractAddress, this.callContext.functionSelector);
|
|
419
438
|
}
|
|
420
|
-
utilityEmitOffchainEffect(data) {
|
|
421
|
-
this.offchainEffects.push({
|
|
422
|
-
data
|
|
423
|
-
});
|
|
424
|
-
return Promise.resolve();
|
|
425
|
-
}
|
|
426
439
|
}
|