@aztec/txe 5.0.0-private.20260318 → 5.0.0-rc.1
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/AuthRegistry-CPGFQR26.js +3 -0
- package/dest/AuthRegistry-CPGFQR26.js.map +7 -0
- package/dest/ContractClassRegistry-EHVIHGEK.js +3 -0
- package/dest/ContractClassRegistry-EHVIHGEK.js.map +7 -0
- package/dest/ContractInstanceRegistry-DWZDXHRG.js +3 -0
- package/dest/ContractInstanceRegistry-DWZDXHRG.js.map +7 -0
- package/dest/FeeJuice-MI32ZO7B.js +3 -0
- package/dest/FeeJuice-MI32ZO7B.js.map +7 -0
- package/dest/HandshakeRegistry-3KSP3ITH.js +3 -0
- package/dest/HandshakeRegistry-3KSP3ITH.js.map +7 -0
- package/dest/MultiCallEntrypoint-IU7HYFYE.js +3 -0
- package/dest/MultiCallEntrypoint-IU7HYFYE.js.map +7 -0
- package/dest/SchnorrAccount-6TUE7JX4.js +3 -0
- package/dest/SchnorrAccount-6TUE7JX4.js.map +7 -0
- package/dest/SchnorrInitializerlessAccount-S3DU2DJK.js +3 -0
- package/dest/SchnorrInitializerlessAccount-S3DU2DJK.js.map +7 -0
- package/dest/bin/check_txe_oracle_version.d.ts +2 -0
- package/dest/bin/check_txe_oracle_version.d.ts.map +1 -0
- package/dest/bin/check_txe_oracle_version.js +61 -0
- package/dest/bin/index.js +3 -30
- package/dest/bin/index.js.map +7 -0
- package/dest/bin/oracle_test_server.d.ts +3 -0
- package/dest/bin/oracle_test_server.d.ts.map +1 -0
- package/dest/bin/oracle_test_server.js +41 -0
- package/dest/chunk-5U25VAFR.js +265 -0
- package/dest/chunk-5U25VAFR.js.map +7 -0
- package/dest/chunk-BJVAAXNA.js +3 -0
- package/dest/chunk-BJVAAXNA.js.map +7 -0
- package/dest/chunk-UPW55EJX.js +304 -0
- package/dest/chunk-UPW55EJX.js.map +7 -0
- package/dest/constants.d.ts +5 -1
- package/dest/constants.d.ts.map +1 -1
- package/dest/constants.js +8 -0
- package/dest/dispatcher_pool.d.ts +67 -0
- package/dest/dispatcher_pool.d.ts.map +1 -0
- package/dest/dispatcher_pool.js +286 -0
- package/dest/index.d.ts +51 -7
- package/dest/index.d.ts.map +1 -1
- package/dest/index.js +70 -190
- package/dest/metafile.json +38829 -0
- package/dest/msgpackr_fr_extension.d.ts +2 -0
- package/dest/msgpackr_fr_extension.d.ts.map +1 -0
- package/dest/msgpackr_fr_extension.js +21 -0
- package/dest/oracle/interfaces.d.ts +33 -8
- package/dest/oracle/interfaces.d.ts.map +1 -1
- package/dest/oracle/test-resolver/fixtures.d.ts +43 -0
- package/dest/oracle/test-resolver/fixtures.d.ts.map +1 -0
- package/dest/oracle/test-resolver/fixtures.js +39 -0
- package/dest/oracle/test-resolver/index.d.ts +9 -0
- package/dest/oracle/test-resolver/index.d.ts.map +1 -0
- package/dest/oracle/test-resolver/index.js +33 -0
- package/dest/oracle/test-resolver/resolver.d.ts +34 -0
- package/dest/oracle/test-resolver/resolver.d.ts.map +1 -0
- package/dest/oracle/test-resolver/resolver.js +114 -0
- package/dest/oracle/txe_oracle_public_context.d.ts +26 -2
- package/dest/oracle/txe_oracle_public_context.d.ts.map +1 -1
- package/dest/oracle/txe_oracle_public_context.js +43 -1
- package/dest/oracle/txe_oracle_registry.d.ts +14 -0
- package/dest/oracle/txe_oracle_registry.d.ts.map +1 -0
- package/dest/oracle/txe_oracle_registry.js +562 -0
- package/dest/oracle/txe_oracle_top_level_context.d.ts +32 -18
- package/dest/oracle/txe_oracle_top_level_context.d.ts.map +1 -1
- package/dest/oracle/txe_oracle_top_level_context.js +151 -55
- package/dest/oracle/txe_oracle_version.d.ts +17 -0
- package/dest/oracle/txe_oracle_version.d.ts.map +1 -0
- package/dest/oracle/txe_oracle_version.js +14 -0
- package/dest/oracle/txe_private_execution_oracle.d.ts +17 -0
- package/dest/oracle/txe_private_execution_oracle.d.ts.map +1 -0
- package/dest/oracle/txe_private_execution_oracle.js +15 -0
- package/dest/rpc_server.d.ts +14 -0
- package/dest/rpc_server.d.ts.map +1 -0
- package/dest/rpc_server.js +78 -0
- package/dest/rpc_translator.d.ts +103 -230
- package/dest/rpc_translator.d.ts.map +1 -1
- package/dest/rpc_translator.js +697 -616
- package/dest/server.bundle.js +3 -0
- package/dest/server.bundle.js.map +7 -0
- package/dest/state_machine/archiver.d.ts +4 -3
- package/dest/state_machine/archiver.d.ts.map +1 -1
- package/dest/state_machine/archiver.js +26 -15
- package/dest/state_machine/dummy_p2p_client.d.ts +14 -7
- package/dest/state_machine/dummy_p2p_client.d.ts.map +1 -1
- package/dest/state_machine/dummy_p2p_client.js +19 -4
- package/dest/state_machine/global_variable_builder.d.ts +9 -4
- package/dest/state_machine/global_variable_builder.d.ts.map +1 -1
- package/dest/state_machine/global_variable_builder.js +9 -3
- package/dest/state_machine/index.d.ts +4 -2
- package/dest/state_machine/index.d.ts.map +1 -1
- package/dest/state_machine/index.js +11 -3
- package/dest/state_machine/mock_epoch_cache.d.ts +16 -3
- package/dest/state_machine/mock_epoch_cache.d.ts.map +1 -1
- package/dest/state_machine/mock_epoch_cache.js +29 -2
- package/dest/state_machine/synchronizer.js +1 -1
- package/dest/txe_session.d.ts +85 -17
- package/dest/txe_session.d.ts.map +1 -1
- package/dest/txe_session.js +245 -40
- package/dest/utils/encoding.d.ts +191 -0
- package/dest/utils/encoding.d.ts.map +1 -0
- package/dest/{util → utils}/encoding.js +7 -2
- package/dest/{util → utils}/expected_failure_error.d.ts +1 -1
- package/dest/utils/expected_failure_error.d.ts.map +1 -0
- package/dest/{util → utils}/txe_account_store.d.ts +1 -1
- package/dest/utils/txe_account_store.d.ts.map +1 -0
- package/dest/utils/txe_artifact_resolver.d.ts +37 -0
- package/dest/utils/txe_artifact_resolver.d.ts.map +1 -0
- package/dest/utils/txe_artifact_resolver.js +161 -0
- package/dest/utils/txe_public_contract_data_source.d.ts +20 -0
- package/dest/utils/txe_public_contract_data_source.d.ts.map +1 -0
- package/dest/{util → utils}/txe_public_contract_data_source.js +1 -3
- package/dest/worker.bundle.js +3 -0
- package/dest/worker.bundle.js.map +7 -0
- package/dest/worker.d.ts +2 -0
- package/dest/worker.d.ts.map +1 -0
- package/dest/worker.js +92 -0
- package/package.json +38 -21
- package/src/bin/check_txe_oracle_version.ts +70 -0
- package/src/bin/index.ts +11 -2
- package/src/bin/oracle_test_server.ts +51 -0
- package/src/constants.ts +10 -0
- package/src/dispatcher_pool.ts +317 -0
- package/src/index.ts +97 -227
- package/src/msgpackr_fr_extension.ts +23 -0
- package/src/oracle/interfaces.ts +29 -7
- package/src/oracle/test-resolver/fixtures.ts +84 -0
- package/src/oracle/test-resolver/index.ts +45 -0
- package/src/oracle/test-resolver/resolver.ts +165 -0
- package/src/oracle/txe_oracle_public_context.ts +60 -0
- package/src/oracle/txe_oracle_registry.ts +401 -0
- package/src/oracle/txe_oracle_top_level_context.ts +185 -64
- package/src/oracle/txe_oracle_version.ts +17 -0
- package/src/oracle/txe_private_execution_oracle.ts +30 -0
- package/src/rpc_server.ts +87 -0
- package/src/rpc_translator.ts +767 -892
- package/src/state_machine/archiver.ts +38 -16
- package/src/state_machine/dummy_p2p_client.ts +35 -11
- package/src/state_machine/global_variable_builder.ts +18 -3
- package/src/state_machine/index.ts +17 -5
- package/src/state_machine/mock_epoch_cache.ts +38 -3
- package/src/state_machine/synchronizer.ts +1 -1
- package/src/txe_session.ts +437 -50
- package/src/{util → utils}/encoding.ts +8 -2
- package/src/utils/txe_artifact_resolver.ts +217 -0
- package/src/{util → utils}/txe_public_contract_data_source.ts +0 -2
- package/src/worker.ts +98 -0
- package/dest/util/encoding.d.ts +0 -720
- package/dest/util/encoding.d.ts.map +0 -1
- package/dest/util/expected_failure_error.d.ts.map +0 -1
- package/dest/util/txe_account_store.d.ts.map +0 -1
- package/dest/util/txe_public_contract_data_source.d.ts +0 -20
- package/dest/util/txe_public_contract_data_source.d.ts.map +0 -1
- /package/dest/{util → utils}/expected_failure_error.js +0 -0
- /package/dest/{util → utils}/txe_account_store.js +0 -0
- /package/src/{util → utils}/expected_failure_error.ts +0 -0
- /package/src/{util → utils}/txe_account_store.ts +0 -0
package/dest/rpc_translator.js
CHANGED
|
@@ -1,13 +1,4 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { MAX_NOTE_HASHES_PER_TX, MAX_NULLIFIERS_PER_TX } from '@aztec/constants';
|
|
3
|
-
import { BlockNumber } from '@aztec/foundation/branded-types';
|
|
4
|
-
import { packAsHintedNote } from '@aztec/pxe/simulator';
|
|
5
|
-
import { EventSelector, FunctionSelector, NoteSelector } from '@aztec/stdlib/abi';
|
|
6
|
-
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
7
|
-
import { BlockHash } from '@aztec/stdlib/block';
|
|
8
|
-
import { addressFromSingle, arrayOfArraysToBoundedVecOfArrays, arrayToBoundedVec, bufferToU8Array, fromArray, fromSingle, fromUintArray, fromUintBoundedVec, toArray, toForeignCallResult, toSingle } from './util/encoding.js';
|
|
9
|
-
const MAX_EVENT_LEN = 10; // This is MAX_MESSAGE_CONTENT_LEN - PRIVATE_EVENT_MSG_PLAINTEXT_RESERVED_FIELDS_LEN
|
|
10
|
-
const MAX_PRIVATE_EVENTS_PER_TXE_QUERY = 5;
|
|
1
|
+
import { callTxeHandler } from './oracle/txe_oracle_registry.js';
|
|
11
2
|
export class UnavailableOracleError extends Error {
|
|
12
3
|
constructor(oracleName){
|
|
13
4
|
super(`${oracleName} oracles not available with the current handler`);
|
|
@@ -60,732 +51,822 @@ export class RPCTranslator {
|
|
|
60
51
|
}
|
|
61
52
|
return this.oracleHandler;
|
|
62
53
|
}
|
|
54
|
+
// eslint-disable-next-line camelcase
|
|
55
|
+
aztec_txe_assertCompatibleOracleVersion(...inputs) {
|
|
56
|
+
return callTxeHandler({
|
|
57
|
+
oracle: 'aztec_txe_assertCompatibleOracleVersion',
|
|
58
|
+
inputs,
|
|
59
|
+
handler: ([major, minor])=>{
|
|
60
|
+
this.stateHandler.setTxeOracleVersion(major, minor);
|
|
61
|
+
}
|
|
62
|
+
});
|
|
63
|
+
}
|
|
63
64
|
// TXE session state transition functions - these get handled by the state handler
|
|
64
65
|
// eslint-disable-next-line camelcase
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
66
|
+
aztec_txe_setTopLevelTXEContext() {
|
|
67
|
+
return callTxeHandler({
|
|
68
|
+
oracle: 'aztec_txe_setTopLevelTXEContext',
|
|
69
|
+
inputs: [],
|
|
70
|
+
handler: ()=>this.stateHandler.enterTopLevelState()
|
|
71
|
+
});
|
|
68
72
|
}
|
|
69
73
|
// eslint-disable-next-line camelcase
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
74
|
+
aztec_txe_setPrivateTXEContext(...inputs) {
|
|
75
|
+
return callTxeHandler({
|
|
76
|
+
oracle: 'aztec_txe_setPrivateTXEContext',
|
|
77
|
+
inputs,
|
|
78
|
+
handler: ([contractAddress, anchorBlockNumber, gasSettings])=>this.stateHandler.enterPrivateState(contractAddress, anchorBlockNumber, gasSettings)
|
|
79
|
+
});
|
|
75
80
|
}
|
|
76
81
|
// eslint-disable-next-line camelcase
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
82
|
+
aztec_txe_setPublicTXEContext(...inputs) {
|
|
83
|
+
return callTxeHandler({
|
|
84
|
+
oracle: 'aztec_txe_setPublicTXEContext',
|
|
85
|
+
inputs,
|
|
86
|
+
handler: ([contractAddress])=>this.stateHandler.enterPublicState(contractAddress)
|
|
87
|
+
});
|
|
81
88
|
}
|
|
82
89
|
// eslint-disable-next-line camelcase
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
90
|
+
aztec_txe_setUtilityTXEContext(...inputs) {
|
|
91
|
+
return callTxeHandler({
|
|
92
|
+
oracle: 'aztec_txe_setUtilityTXEContext',
|
|
93
|
+
inputs,
|
|
94
|
+
handler: ([contractAddress])=>this.stateHandler.enterUtilityState(contractAddress)
|
|
95
|
+
});
|
|
87
96
|
}
|
|
88
97
|
// Other oracles - these get handled by the oracle handler
|
|
89
98
|
// TXE-specific oracles
|
|
90
99
|
// eslint-disable-next-line camelcase
|
|
91
100
|
aztec_txe_getDefaultAddress() {
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
101
|
+
return callTxeHandler({
|
|
102
|
+
oracle: 'aztec_txe_getDefaultAddress',
|
|
103
|
+
inputs: [],
|
|
104
|
+
handler: ()=>this.handlerAsTxe().getDefaultAddress()
|
|
105
|
+
});
|
|
96
106
|
}
|
|
97
107
|
// eslint-disable-next-line camelcase
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
108
|
+
aztec_txe_getNextBlockNumber() {
|
|
109
|
+
return callTxeHandler({
|
|
110
|
+
oracle: 'aztec_txe_getNextBlockNumber',
|
|
111
|
+
inputs: [],
|
|
112
|
+
handler: ()=>this.handlerAsTxe().getNextBlockNumber()
|
|
113
|
+
});
|
|
103
114
|
}
|
|
104
115
|
// eslint-disable-next-line camelcase
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
116
|
+
aztec_txe_getNextBlockTimestamp() {
|
|
117
|
+
return callTxeHandler({
|
|
118
|
+
oracle: 'aztec_txe_getNextBlockTimestamp',
|
|
119
|
+
inputs: [],
|
|
120
|
+
handler: ()=>this.handlerAsTxe().getNextBlockTimestamp()
|
|
121
|
+
});
|
|
110
122
|
}
|
|
111
123
|
// eslint-disable-next-line camelcase
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
124
|
+
aztec_txe_advanceBlocksBy(...inputs) {
|
|
125
|
+
return callTxeHandler({
|
|
126
|
+
oracle: 'aztec_txe_advanceBlocksBy',
|
|
127
|
+
inputs,
|
|
128
|
+
handler: ([blocks])=>this.handlerAsTxe().advanceBlocksBy(blocks)
|
|
129
|
+
});
|
|
116
130
|
}
|
|
117
131
|
// eslint-disable-next-line camelcase
|
|
118
|
-
aztec_txe_advanceTimestampBy(
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
132
|
+
aztec_txe_advanceTimestampBy(...inputs) {
|
|
133
|
+
return callTxeHandler({
|
|
134
|
+
oracle: 'aztec_txe_advanceTimestampBy',
|
|
135
|
+
inputs,
|
|
136
|
+
handler: ([duration])=>this.handlerAsTxe().advanceTimestampBy(duration)
|
|
137
|
+
});
|
|
122
138
|
}
|
|
123
139
|
// eslint-disable-next-line camelcase
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
instance.deployer.toField(),
|
|
131
|
-
instance.currentContractClassId,
|
|
132
|
-
instance.initializationHash,
|
|
133
|
-
...instance.publicKeys.toFields()
|
|
134
|
-
])
|
|
135
|
-
]);
|
|
140
|
+
aztec_txe_deploy(...inputs) {
|
|
141
|
+
return callTxeHandler({
|
|
142
|
+
oracle: 'aztec_txe_deploy',
|
|
143
|
+
inputs,
|
|
144
|
+
handler: ([contractPath, initializer, _, args, secret, salt, deployer])=>this.handlerAsTxe().deploy(contractPath, initializer, args, secret, salt, deployer)
|
|
145
|
+
});
|
|
136
146
|
}
|
|
137
147
|
// eslint-disable-next-line camelcase
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
]);
|
|
148
|
+
aztec_txe_createAccount(...inputs) {
|
|
149
|
+
return callTxeHandler({
|
|
150
|
+
oracle: 'aztec_txe_createAccount',
|
|
151
|
+
inputs,
|
|
152
|
+
handler: ([secret])=>this.handlerAsTxe().createAccount(secret)
|
|
153
|
+
});
|
|
145
154
|
}
|
|
146
155
|
// eslint-disable-next-line camelcase
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
]);
|
|
156
|
+
aztec_txe_addAccount(...inputs) {
|
|
157
|
+
return callTxeHandler({
|
|
158
|
+
oracle: 'aztec_txe_addAccount',
|
|
159
|
+
inputs,
|
|
160
|
+
handler: ([secret])=>this.handlerAsTxe().addAccount(secret)
|
|
161
|
+
});
|
|
154
162
|
}
|
|
155
163
|
// eslint-disable-next-line camelcase
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
164
|
+
aztec_txe_addAuthWitness(...inputs) {
|
|
165
|
+
return callTxeHandler({
|
|
166
|
+
oracle: 'aztec_txe_addAuthWitness',
|
|
167
|
+
inputs,
|
|
168
|
+
handler: ([address, messageHash])=>this.handlerAsTxe().addAuthWitness(address, messageHash)
|
|
169
|
+
});
|
|
161
170
|
}
|
|
162
171
|
// PXE oracles
|
|
163
172
|
// eslint-disable-next-line camelcase
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
173
|
+
aztec_misc_assertCompatibleOracleVersion(...inputs) {
|
|
174
|
+
return callTxeHandler({
|
|
175
|
+
oracle: 'aztec_misc_assertCompatibleOracleVersion',
|
|
176
|
+
inputs,
|
|
177
|
+
handler: ([major, minor])=>this.handlerAsMisc().assertCompatibleOracleVersion(major, minor)
|
|
178
|
+
});
|
|
168
179
|
}
|
|
169
180
|
// eslint-disable-next-line camelcase
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
181
|
+
aztec_misc_getRandomField() {
|
|
182
|
+
return callTxeHandler({
|
|
183
|
+
oracle: 'aztec_misc_getRandomField',
|
|
184
|
+
inputs: [],
|
|
185
|
+
handler: ()=>this.handlerAsMisc().getRandomField()
|
|
186
|
+
});
|
|
175
187
|
}
|
|
176
188
|
// eslint-disable-next-line camelcase
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
189
|
+
aztec_txe_getLastBlockTimestamp() {
|
|
190
|
+
return callTxeHandler({
|
|
191
|
+
oracle: 'aztec_txe_getLastBlockTimestamp',
|
|
192
|
+
inputs: [],
|
|
193
|
+
handler: ()=>this.handlerAsTxe().getLastBlockTimestamp()
|
|
194
|
+
});
|
|
182
195
|
}
|
|
183
196
|
// eslint-disable-next-line camelcase
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
]);
|
|
197
|
+
aztec_txe_getLastTxEffects() {
|
|
198
|
+
return callTxeHandler({
|
|
199
|
+
oracle: 'aztec_txe_getLastTxEffects',
|
|
200
|
+
inputs: [],
|
|
201
|
+
handler: ()=>this.handlerAsTxe().getLastTxEffects()
|
|
202
|
+
});
|
|
191
203
|
}
|
|
192
204
|
// eslint-disable-next-line camelcase
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
await this.handlerAsTxe().syncContractNonOracleMethod(contractAddress, scope, this.stateHandler.getCurrentJob());
|
|
200
|
-
// We cycle job to commit the stores after the contract sync.
|
|
201
|
-
await this.stateHandler.cycleJob();
|
|
202
|
-
}
|
|
203
|
-
const events = await this.handlerAsTxe().getPrivateEvents(selector, contractAddress, scope);
|
|
204
|
-
if (events.length > MAX_PRIVATE_EVENTS_PER_TXE_QUERY) {
|
|
205
|
-
throw new Error(`Array of length ${events.length} larger than maxLen ${MAX_PRIVATE_EVENTS_PER_TXE_QUERY}`);
|
|
206
|
-
}
|
|
207
|
-
if (events.some((e)=>e.length > MAX_EVENT_LEN)) {
|
|
208
|
-
throw new Error(`Some private event has length larger than maxLen ${MAX_EVENT_LEN}`);
|
|
209
|
-
}
|
|
210
|
-
// This is a workaround as Noir does not currently let us return nested structs with arrays. We instead return a raw
|
|
211
|
-
// multidimensional array in get_private_events_oracle and create the BoundedVecs here.
|
|
212
|
-
const rawArrayStorage = events.map((e)=>e.concat(Array(MAX_EVENT_LEN - e.length).fill(new Fr(0)))).concat(Array(MAX_PRIVATE_EVENTS_PER_TXE_QUERY - events.length).fill(Array(MAX_EVENT_LEN).fill(new Fr(0)))).flat();
|
|
213
|
-
const eventLengths = events.map((e)=>new Fr(e.length)).concat(Array(MAX_PRIVATE_EVENTS_PER_TXE_QUERY - events.length).fill(new Fr(0)));
|
|
214
|
-
const queryLength = new Fr(events.length);
|
|
215
|
-
return toForeignCallResult([
|
|
216
|
-
toArray(rawArrayStorage),
|
|
217
|
-
toArray(eventLengths),
|
|
218
|
-
toSingle(queryLength)
|
|
219
|
-
]);
|
|
220
|
-
}
|
|
221
|
-
// eslint-disable-next-line camelcase
|
|
222
|
-
aztec_prv_storeInExecutionCache(foreignValues, foreignHash) {
|
|
223
|
-
const values = fromArray(foreignValues);
|
|
224
|
-
const hash = fromSingle(foreignHash);
|
|
225
|
-
this.handlerAsPrivate().storeInExecutionCache(values, hash);
|
|
226
|
-
return toForeignCallResult([]);
|
|
227
|
-
}
|
|
228
|
-
// eslint-disable-next-line camelcase
|
|
229
|
-
async aztec_prv_loadFromExecutionCache(foreignHash) {
|
|
230
|
-
const hash = fromSingle(foreignHash);
|
|
231
|
-
const returns = await this.handlerAsPrivate().loadFromExecutionCache(hash);
|
|
232
|
-
return toForeignCallResult([
|
|
233
|
-
toArray(returns)
|
|
234
|
-
]);
|
|
235
|
-
}
|
|
236
|
-
// When the argument is a slice, noir automatically adds a length field to oracle call.
|
|
237
|
-
// When the argument is an array, we add the field length manually to the signature.
|
|
238
|
-
// eslint-disable-next-line camelcase
|
|
239
|
-
async aztec_utl_log(foreignLevel, foreignMessage, _foreignLength, foreignFields) {
|
|
240
|
-
const level = fromSingle(foreignLevel).toNumber();
|
|
241
|
-
const message = fromArray(foreignMessage).map((field)=>String.fromCharCode(field.toNumber())).join('');
|
|
242
|
-
const fields = fromArray(foreignFields);
|
|
243
|
-
await this.handlerAsMisc().log(level, message, fields);
|
|
244
|
-
return toForeignCallResult([]);
|
|
245
|
-
}
|
|
246
|
-
// eslint-disable-next-line camelcase
|
|
247
|
-
async aztec_utl_storageRead(foreignBlockHash, foreignContractAddress, foreignStartStorageSlot, foreignNumberOfElements) {
|
|
248
|
-
const blockHash = new BlockHash(fromSingle(foreignBlockHash));
|
|
249
|
-
const contractAddress = addressFromSingle(foreignContractAddress);
|
|
250
|
-
const startStorageSlot = fromSingle(foreignStartStorageSlot);
|
|
251
|
-
const numberOfElements = fromSingle(foreignNumberOfElements).toNumber();
|
|
252
|
-
const values = await this.handlerAsUtility().storageRead(blockHash, contractAddress, startStorageSlot, numberOfElements);
|
|
253
|
-
return toForeignCallResult([
|
|
254
|
-
toArray(values)
|
|
255
|
-
]);
|
|
256
|
-
}
|
|
257
|
-
// eslint-disable-next-line camelcase
|
|
258
|
-
async aztec_utl_getPublicDataWitness(foreignBlockHash, foreignLeafSlot) {
|
|
259
|
-
const blockHash = new BlockHash(fromSingle(foreignBlockHash));
|
|
260
|
-
const leafSlot = fromSingle(foreignLeafSlot);
|
|
261
|
-
const witness = await this.handlerAsUtility().getPublicDataWitness(blockHash, leafSlot);
|
|
262
|
-
if (!witness) {
|
|
263
|
-
throw new Error(`Public data witness not found for slot ${leafSlot} at block ${blockHash.toString()}.`);
|
|
264
|
-
}
|
|
265
|
-
return toForeignCallResult(witness.toNoirRepresentation());
|
|
266
|
-
}
|
|
267
|
-
// eslint-disable-next-line camelcase
|
|
268
|
-
async aztec_utl_getNotes(foreignOwnerIsSome, foreignOwnerValue, foreignStorageSlot, foreignNumSelects, foreignSelectByIndexes, foreignSelectByOffsets, foreignSelectByLengths, foreignSelectValues, foreignSelectComparators, foreignSortByIndexes, foreignSortByOffsets, foreignSortByLengths, foreignSortOrder, foreignLimit, foreignOffset, foreignStatus, foreignMaxNotes, foreignPackedHintedNoteLength) {
|
|
269
|
-
// Parse Option<AztecAddress>: ownerIsSome is 0 for None, 1 for Some
|
|
270
|
-
const owner = fromSingle(foreignOwnerIsSome).toBool() ? AztecAddress.fromField(fromSingle(foreignOwnerValue)) : undefined;
|
|
271
|
-
const storageSlot = fromSingle(foreignStorageSlot);
|
|
272
|
-
const numSelects = fromSingle(foreignNumSelects).toNumber();
|
|
273
|
-
const selectByIndexes = fromArray(foreignSelectByIndexes).map((fr)=>fr.toNumber());
|
|
274
|
-
const selectByOffsets = fromArray(foreignSelectByOffsets).map((fr)=>fr.toNumber());
|
|
275
|
-
const selectByLengths = fromArray(foreignSelectByLengths).map((fr)=>fr.toNumber());
|
|
276
|
-
const selectValues = fromArray(foreignSelectValues);
|
|
277
|
-
const selectComparators = fromArray(foreignSelectComparators).map((fr)=>fr.toNumber());
|
|
278
|
-
const sortByIndexes = fromArray(foreignSortByIndexes).map((fr)=>fr.toNumber());
|
|
279
|
-
const sortByOffsets = fromArray(foreignSortByOffsets).map((fr)=>fr.toNumber());
|
|
280
|
-
const sortByLengths = fromArray(foreignSortByLengths).map((fr)=>fr.toNumber());
|
|
281
|
-
const sortOrder = fromArray(foreignSortOrder).map((fr)=>fr.toNumber());
|
|
282
|
-
const limit = fromSingle(foreignLimit).toNumber();
|
|
283
|
-
const offset = fromSingle(foreignOffset).toNumber();
|
|
284
|
-
const status = fromSingle(foreignStatus).toNumber();
|
|
285
|
-
const maxNotes = fromSingle(foreignMaxNotes).toNumber();
|
|
286
|
-
const packedHintedNoteLength = fromSingle(foreignPackedHintedNoteLength).toNumber();
|
|
287
|
-
const noteDatas = await this.handlerAsUtility().getNotes(owner, storageSlot, numSelects, selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, limit, offset, status);
|
|
288
|
-
const returnDataAsArrayOfArrays = noteDatas.map((noteData)=>packAsHintedNote({
|
|
289
|
-
contractAddress: noteData.contractAddress,
|
|
290
|
-
owner: noteData.owner,
|
|
291
|
-
randomness: noteData.randomness,
|
|
292
|
-
storageSlot: noteData.storageSlot,
|
|
293
|
-
noteNonce: noteData.noteNonce,
|
|
294
|
-
isPending: noteData.isPending,
|
|
295
|
-
note: noteData.note
|
|
296
|
-
}));
|
|
297
|
-
// Now we convert each sub-array to an array of ForeignCallSingles
|
|
298
|
-
const returnDataAsArrayOfForeignCallSingleArrays = returnDataAsArrayOfArrays.map((subArray)=>subArray.map(toSingle));
|
|
299
|
-
// At last we convert the array of arrays to a bounded vec of arrays
|
|
300
|
-
return toForeignCallResult(arrayOfArraysToBoundedVecOfArrays(returnDataAsArrayOfForeignCallSingleArrays, maxNotes, packedHintedNoteLength));
|
|
301
|
-
}
|
|
302
|
-
// eslint-disable-next-line camelcase
|
|
303
|
-
aztec_prv_notifyCreatedNote(foreignOwner, foreignStorageSlot, foreignRandomness, foreignNoteTypeId, foreignNote, foreignNoteHash, foreignCounter) {
|
|
304
|
-
const owner = addressFromSingle(foreignOwner);
|
|
305
|
-
const storageSlot = fromSingle(foreignStorageSlot);
|
|
306
|
-
const randomness = fromSingle(foreignRandomness);
|
|
307
|
-
const noteTypeId = NoteSelector.fromField(fromSingle(foreignNoteTypeId));
|
|
308
|
-
const note = fromArray(foreignNote);
|
|
309
|
-
const noteHash = fromSingle(foreignNoteHash);
|
|
310
|
-
const counter = fromSingle(foreignCounter).toNumber();
|
|
311
|
-
this.handlerAsPrivate().notifyCreatedNote(owner, storageSlot, randomness, noteTypeId, note, noteHash, counter);
|
|
312
|
-
return toForeignCallResult([]);
|
|
313
|
-
}
|
|
314
|
-
// eslint-disable-next-line camelcase
|
|
315
|
-
async aztec_prv_notifyNullifiedNote(foreignInnerNullifier, foreignNoteHash, foreignCounter) {
|
|
316
|
-
const innerNullifier = fromSingle(foreignInnerNullifier);
|
|
317
|
-
const noteHash = fromSingle(foreignNoteHash);
|
|
318
|
-
const counter = fromSingle(foreignCounter).toNumber();
|
|
319
|
-
await this.handlerAsPrivate().notifyNullifiedNote(innerNullifier, noteHash, counter);
|
|
320
|
-
return toForeignCallResult([]);
|
|
321
|
-
}
|
|
322
|
-
// eslint-disable-next-line camelcase
|
|
323
|
-
async aztec_prv_notifyCreatedNullifier(foreignInnerNullifier) {
|
|
324
|
-
const innerNullifier = fromSingle(foreignInnerNullifier);
|
|
325
|
-
await this.handlerAsPrivate().notifyCreatedNullifier(innerNullifier);
|
|
326
|
-
return toForeignCallResult([]);
|
|
327
|
-
}
|
|
328
|
-
// eslint-disable-next-line camelcase
|
|
329
|
-
async aztec_prv_isNullifierPending(foreignInnerNullifier, foreignContractAddress) {
|
|
330
|
-
const innerNullifier = fromSingle(foreignInnerNullifier);
|
|
331
|
-
const contractAddress = addressFromSingle(foreignContractAddress);
|
|
332
|
-
const isPending = await this.handlerAsPrivate().isNullifierPending(innerNullifier, contractAddress);
|
|
333
|
-
return toForeignCallResult([
|
|
334
|
-
toSingle(new Fr(isPending))
|
|
335
|
-
]);
|
|
336
|
-
}
|
|
337
|
-
// eslint-disable-next-line camelcase
|
|
338
|
-
async aztec_utl_checkNullifierExists(foreignInnerNullifier) {
|
|
339
|
-
const innerNullifier = fromSingle(foreignInnerNullifier);
|
|
340
|
-
const exists = await this.handlerAsUtility().checkNullifierExists(innerNullifier);
|
|
341
|
-
return toForeignCallResult([
|
|
342
|
-
toSingle(new Fr(exists))
|
|
343
|
-
]);
|
|
344
|
-
}
|
|
345
|
-
// eslint-disable-next-line camelcase
|
|
346
|
-
async aztec_utl_getContractInstance(foreignAddress) {
|
|
347
|
-
const address = addressFromSingle(foreignAddress);
|
|
348
|
-
const instance = await this.handlerAsUtility().getContractInstance(address);
|
|
349
|
-
return toForeignCallResult([
|
|
350
|
-
instance.salt,
|
|
351
|
-
instance.deployer.toField(),
|
|
352
|
-
instance.currentContractClassId,
|
|
353
|
-
instance.initializationHash,
|
|
354
|
-
...instance.publicKeys.toFields()
|
|
355
|
-
].map(toSingle));
|
|
356
|
-
}
|
|
357
|
-
// eslint-disable-next-line camelcase
|
|
358
|
-
async aztec_utl_tryGetPublicKeysAndPartialAddress(foreignAddress) {
|
|
359
|
-
const address = addressFromSingle(foreignAddress);
|
|
360
|
-
const result = await this.handlerAsUtility().tryGetPublicKeysAndPartialAddress(address);
|
|
361
|
-
// We are going to return a Noir Option struct to represent the possibility of null values. Options are a struct
|
|
362
|
-
// with two fields: `some` (a boolean) and `value` (a field array in this case).
|
|
363
|
-
if (result === undefined) {
|
|
364
|
-
// No data was found so we set `some` to 0 and pad `value` with zeros get the correct return size.
|
|
365
|
-
return toForeignCallResult([
|
|
366
|
-
toSingle(new Fr(0)),
|
|
367
|
-
toArray(Array(13).fill(new Fr(0)))
|
|
368
|
-
]);
|
|
369
|
-
} else {
|
|
370
|
-
// Data was found so we set `some` to 1 and return it along with `value`.
|
|
371
|
-
return toForeignCallResult([
|
|
372
|
-
toSingle(new Fr(1)),
|
|
373
|
-
toArray([
|
|
374
|
-
...result.publicKeys.toFields(),
|
|
375
|
-
result.partialAddress
|
|
376
|
-
])
|
|
377
|
-
]);
|
|
378
|
-
}
|
|
205
|
+
aztec_txe_getLastCallOffchainEffects() {
|
|
206
|
+
return callTxeHandler({
|
|
207
|
+
oracle: 'aztec_txe_getLastCallOffchainEffects',
|
|
208
|
+
inputs: [],
|
|
209
|
+
handler: ()=>this.stateHandler.getLastCallOffchainEffects()
|
|
210
|
+
});
|
|
379
211
|
}
|
|
380
212
|
// eslint-disable-next-line camelcase
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
213
|
+
aztec_txe_getLastCallContext() {
|
|
214
|
+
return callTxeHandler({
|
|
215
|
+
oracle: 'aztec_txe_getLastCallContext',
|
|
216
|
+
inputs: [],
|
|
217
|
+
handler: ()=>this.stateHandler.getLastCallContext()
|
|
218
|
+
});
|
|
385
219
|
}
|
|
386
220
|
// eslint-disable-next-line camelcase
|
|
387
|
-
|
|
388
|
-
|
|
221
|
+
aztec_txe_getPrivateEvents(...inputs) {
|
|
222
|
+
return callTxeHandler({
|
|
223
|
+
oracle: 'aztec_txe_getPrivateEvents',
|
|
224
|
+
inputs,
|
|
225
|
+
handler: ([selector, contractAddress, scope])=>this.stateHandler.getPrivateEvents(selector, contractAddress, scope)
|
|
226
|
+
});
|
|
389
227
|
}
|
|
390
228
|
// eslint-disable-next-line camelcase
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
}
|
|
398
|
-
return toForeignCallResult(witness.toNoirRepresentation());
|
|
229
|
+
aztec_prv_setHashPreimage(...inputs) {
|
|
230
|
+
return callTxeHandler({
|
|
231
|
+
oracle: 'aztec_prv_setHashPreimage',
|
|
232
|
+
inputs,
|
|
233
|
+
handler: ([values, hash])=>this.handlerAsPrivate().setHashPreimage(values, hash)
|
|
234
|
+
});
|
|
399
235
|
}
|
|
400
236
|
// eslint-disable-next-line camelcase
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
}
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
237
|
+
aztec_prv_getHashPreimage(...inputs) {
|
|
238
|
+
return callTxeHandler({
|
|
239
|
+
oracle: 'aztec_prv_getHashPreimage',
|
|
240
|
+
inputs,
|
|
241
|
+
handler: ([hash])=>this.handlerAsPrivate().getHashPreimage(hash)
|
|
242
|
+
});
|
|
243
|
+
}
|
|
244
|
+
// eslint-disable-next-line camelcase
|
|
245
|
+
aztec_misc_log(...inputs) {
|
|
246
|
+
return callTxeHandler({
|
|
247
|
+
oracle: 'aztec_misc_log',
|
|
248
|
+
inputs,
|
|
249
|
+
handler: ([level, message, fieldsSize, fields])=>this.handlerAsMisc().log(level, message, fieldsSize, fields)
|
|
250
|
+
});
|
|
251
|
+
}
|
|
252
|
+
// eslint-disable-next-line camelcase
|
|
253
|
+
aztec_utl_getFromPublicStorage(...inputs) {
|
|
254
|
+
return callTxeHandler({
|
|
255
|
+
oracle: 'aztec_utl_getFromPublicStorage',
|
|
256
|
+
inputs,
|
|
257
|
+
handler: ([blockHash, contractAddress, startStorageSlot, numberOfElements])=>this.handlerAsUtility().getFromPublicStorage(blockHash, contractAddress, startStorageSlot, numberOfElements)
|
|
258
|
+
});
|
|
259
|
+
}
|
|
260
|
+
// eslint-disable-next-line camelcase
|
|
261
|
+
aztec_utl_getPublicDataWitness(...inputs) {
|
|
262
|
+
return callTxeHandler({
|
|
263
|
+
oracle: 'aztec_utl_getPublicDataWitness',
|
|
264
|
+
inputs,
|
|
265
|
+
handler: ([blockHash, leafSlot])=>this.handlerAsUtility().getPublicDataWitness(blockHash, leafSlot)
|
|
266
|
+
});
|
|
267
|
+
}
|
|
268
|
+
// eslint-disable-next-line camelcase
|
|
269
|
+
aztec_utl_getNotes(...inputs) {
|
|
270
|
+
return callTxeHandler({
|
|
271
|
+
oracle: 'aztec_utl_getNotes',
|
|
272
|
+
inputs,
|
|
273
|
+
handler: ([owner, storageSlot, numSelects, selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, limit, offset, status, maxNotes, packedHintedNoteLength])=>this.handlerAsUtility().getNotes(owner, storageSlot, numSelects, selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, limit, offset, status, maxNotes, packedHintedNoteLength)
|
|
274
|
+
});
|
|
275
|
+
}
|
|
276
|
+
// eslint-disable-next-line camelcase
|
|
277
|
+
aztec_prv_notifyCreatedNote(...inputs) {
|
|
278
|
+
return callTxeHandler({
|
|
279
|
+
oracle: 'aztec_prv_notifyCreatedNote',
|
|
280
|
+
inputs,
|
|
281
|
+
handler: ([owner, storageSlot, randomness, noteTypeId, note, noteHash, counter])=>this.handlerAsPrivate().notifyCreatedNote(owner, storageSlot, randomness, noteTypeId, note, noteHash, counter)
|
|
282
|
+
});
|
|
283
|
+
}
|
|
284
|
+
// eslint-disable-next-line camelcase
|
|
285
|
+
aztec_prv_notifyNullifiedNote(...inputs) {
|
|
286
|
+
return callTxeHandler({
|
|
287
|
+
oracle: 'aztec_prv_notifyNullifiedNote',
|
|
288
|
+
inputs,
|
|
289
|
+
handler: ([innerNullifier, noteHash, counter])=>this.handlerAsPrivate().notifyNullifiedNote(innerNullifier, noteHash, counter)
|
|
290
|
+
});
|
|
410
291
|
}
|
|
411
292
|
// eslint-disable-next-line camelcase
|
|
412
|
-
|
|
413
|
-
|
|
293
|
+
aztec_prv_notifyCreatedNullifier(...inputs) {
|
|
294
|
+
return callTxeHandler({
|
|
295
|
+
oracle: 'aztec_prv_notifyCreatedNullifier',
|
|
296
|
+
inputs,
|
|
297
|
+
handler: ([innerNullifier])=>this.handlerAsPrivate().notifyCreatedNullifier(innerNullifier)
|
|
298
|
+
});
|
|
414
299
|
}
|
|
415
300
|
// eslint-disable-next-line camelcase
|
|
416
|
-
|
|
417
|
-
|
|
301
|
+
aztec_prv_isNullifierPending(...inputs) {
|
|
302
|
+
return callTxeHandler({
|
|
303
|
+
oracle: 'aztec_prv_isNullifierPending',
|
|
304
|
+
inputs,
|
|
305
|
+
handler: ([innerNullifier, contractAddress])=>this.handlerAsPrivate().isNullifierPending(innerNullifier, contractAddress)
|
|
306
|
+
});
|
|
418
307
|
}
|
|
419
308
|
// eslint-disable-next-line camelcase
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
309
|
+
aztec_utl_doesNullifierExist(...inputs) {
|
|
310
|
+
return callTxeHandler({
|
|
311
|
+
oracle: 'aztec_utl_doesNullifierExist',
|
|
312
|
+
inputs,
|
|
313
|
+
handler: ([innerNullifier])=>this.handlerAsUtility().doesNullifierExist(innerNullifier)
|
|
314
|
+
});
|
|
315
|
+
}
|
|
316
|
+
// eslint-disable-next-line camelcase
|
|
317
|
+
aztec_utl_getContractInstance(...inputs) {
|
|
318
|
+
return callTxeHandler({
|
|
319
|
+
oracle: 'aztec_utl_getContractInstance',
|
|
320
|
+
inputs,
|
|
321
|
+
handler: ([address])=>this.handlerAsUtility().getContractInstance(address)
|
|
322
|
+
});
|
|
323
|
+
}
|
|
324
|
+
// eslint-disable-next-line camelcase
|
|
325
|
+
aztec_utl_getPublicKeysAndPartialAddress(...inputs) {
|
|
326
|
+
return callTxeHandler({
|
|
327
|
+
oracle: 'aztec_utl_getPublicKeysAndPartialAddress',
|
|
328
|
+
inputs,
|
|
329
|
+
handler: ([address])=>this.handlerAsUtility().getPublicKeysAndPartialAddress(address)
|
|
330
|
+
});
|
|
331
|
+
}
|
|
332
|
+
// eslint-disable-next-line camelcase
|
|
333
|
+
aztec_utl_getKeyValidationRequest(...inputs) {
|
|
334
|
+
return callTxeHandler({
|
|
335
|
+
oracle: 'aztec_utl_getKeyValidationRequest',
|
|
336
|
+
inputs,
|
|
337
|
+
handler: ([pkMHash])=>this.handlerAsUtility().getKeyValidationRequest(pkMHash)
|
|
338
|
+
});
|
|
339
|
+
}
|
|
340
|
+
// eslint-disable-next-line camelcase
|
|
341
|
+
aztec_prv_callPrivateFunction(...inputs) {
|
|
342
|
+
return callTxeHandler({
|
|
343
|
+
oracle: 'aztec_prv_callPrivateFunction',
|
|
344
|
+
inputs,
|
|
345
|
+
handler: ([contractAddress, functionSelector, argsHash, sideEffectCounter, isStaticCall])=>this.handlerAsPrivate().callPrivateFunction(contractAddress, functionSelector, argsHash, sideEffectCounter, isStaticCall)
|
|
346
|
+
});
|
|
347
|
+
}
|
|
348
|
+
// eslint-disable-next-line camelcase
|
|
349
|
+
aztec_utl_getNullifierMembershipWitness(...inputs) {
|
|
350
|
+
return callTxeHandler({
|
|
351
|
+
oracle: 'aztec_utl_getNullifierMembershipWitness',
|
|
352
|
+
inputs,
|
|
353
|
+
handler: ([blockHash, nullifier])=>this.handlerAsUtility().getNullifierMembershipWitness(blockHash, nullifier)
|
|
354
|
+
});
|
|
355
|
+
}
|
|
356
|
+
// eslint-disable-next-line camelcase
|
|
357
|
+
aztec_utl_getAuthWitness(...inputs) {
|
|
358
|
+
return callTxeHandler({
|
|
359
|
+
oracle: 'aztec_utl_getAuthWitness',
|
|
360
|
+
inputs,
|
|
361
|
+
handler: ([messageHash])=>this.handlerAsUtility().getAuthWitness(messageHash)
|
|
362
|
+
});
|
|
363
|
+
}
|
|
364
|
+
// eslint-disable-next-line camelcase
|
|
365
|
+
aztec_prv_assertValidPublicCalldata(...inputs) {
|
|
366
|
+
return callTxeHandler({
|
|
367
|
+
oracle: 'aztec_prv_assertValidPublicCalldata',
|
|
368
|
+
inputs,
|
|
369
|
+
handler: ([calldataHash])=>this.handlerAsPrivate().assertValidPublicCalldata(calldataHash)
|
|
370
|
+
});
|
|
371
|
+
}
|
|
372
|
+
// eslint-disable-next-line camelcase
|
|
373
|
+
aztec_prv_notifyRevertiblePhaseStart(...inputs) {
|
|
374
|
+
return callTxeHandler({
|
|
375
|
+
oracle: 'aztec_prv_notifyRevertiblePhaseStart',
|
|
376
|
+
inputs,
|
|
377
|
+
handler: ([minRevertibleSideEffectCounter])=>this.handlerAsPrivate().notifyRevertiblePhaseStart(minRevertibleSideEffectCounter)
|
|
378
|
+
});
|
|
379
|
+
}
|
|
380
|
+
// eslint-disable-next-line camelcase
|
|
381
|
+
aztec_prv_isExecutionInRevertiblePhase(...inputs) {
|
|
382
|
+
return callTxeHandler({
|
|
383
|
+
oracle: 'aztec_prv_isExecutionInRevertiblePhase',
|
|
384
|
+
inputs,
|
|
385
|
+
handler: ([sideEffectCounter])=>this.handlerAsPrivate().isExecutionInRevertiblePhase(sideEffectCounter)
|
|
386
|
+
});
|
|
426
387
|
}
|
|
427
388
|
// eslint-disable-next-line camelcase
|
|
428
389
|
aztec_utl_getUtilityContext() {
|
|
429
|
-
|
|
430
|
-
|
|
390
|
+
return callTxeHandler({
|
|
391
|
+
oracle: 'aztec_utl_getUtilityContext',
|
|
392
|
+
inputs: [],
|
|
393
|
+
handler: ()=>this.handlerAsUtility().getUtilityContext()
|
|
394
|
+
});
|
|
431
395
|
}
|
|
432
396
|
// eslint-disable-next-line camelcase
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
}
|
|
439
|
-
return toForeignCallResult(header.toFields().map(toSingle));
|
|
397
|
+
aztec_utl_getBlockHeader(...inputs) {
|
|
398
|
+
return callTxeHandler({
|
|
399
|
+
oracle: 'aztec_utl_getBlockHeader',
|
|
400
|
+
inputs,
|
|
401
|
+
handler: ([blockNumber])=>this.handlerAsUtility().getBlockHeader(blockNumber)
|
|
402
|
+
});
|
|
440
403
|
}
|
|
441
404
|
// eslint-disable-next-line camelcase
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
}
|
|
449
|
-
return toForeignCallResult(witness.toNoirRepresentation());
|
|
405
|
+
aztec_utl_getNoteHashMembershipWitness(...inputs) {
|
|
406
|
+
return callTxeHandler({
|
|
407
|
+
oracle: 'aztec_utl_getNoteHashMembershipWitness',
|
|
408
|
+
inputs,
|
|
409
|
+
handler: ([blockHash, noteHash])=>this.handlerAsUtility().getNoteHashMembershipWitness(blockHash, noteHash)
|
|
410
|
+
});
|
|
450
411
|
}
|
|
451
412
|
// eslint-disable-next-line camelcase
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
}
|
|
459
|
-
return toForeignCallResult(witness.toNoirRepresentation());
|
|
413
|
+
aztec_utl_getBlockHashMembershipWitness(...inputs) {
|
|
414
|
+
return callTxeHandler({
|
|
415
|
+
oracle: 'aztec_utl_getBlockHashMembershipWitness',
|
|
416
|
+
inputs,
|
|
417
|
+
handler: ([anchorBlockHash, blockHash])=>this.handlerAsUtility().getBlockHashMembershipWitness(anchorBlockHash, blockHash)
|
|
418
|
+
});
|
|
460
419
|
}
|
|
461
420
|
// eslint-disable-next-line camelcase
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
}
|
|
469
|
-
return toForeignCallResult(witness.toNoirRepresentation());
|
|
470
|
-
}
|
|
471
|
-
// eslint-disable-next-line camelcase
|
|
472
|
-
async aztec_utl_fetchTaggedLogs(foreignPendingTaggedLogArrayBaseSlot) {
|
|
473
|
-
const pendingTaggedLogArrayBaseSlot = fromSingle(foreignPendingTaggedLogArrayBaseSlot);
|
|
474
|
-
await this.handlerAsUtility().fetchTaggedLogs(pendingTaggedLogArrayBaseSlot);
|
|
475
|
-
return toForeignCallResult([]);
|
|
476
|
-
}
|
|
477
|
-
// eslint-disable-next-line camelcase
|
|
478
|
-
async aztec_utl_validateAndStoreEnqueuedNotesAndEvents(foreignContractAddress, foreignNoteValidationRequestsArrayBaseSlot, foreignEventValidationRequestsArrayBaseSlot, foreignMaxNotePackedLen, foreignMaxEventSerializedLen) {
|
|
479
|
-
const contractAddress = AztecAddress.fromField(fromSingle(foreignContractAddress));
|
|
480
|
-
const noteValidationRequestsArrayBaseSlot = fromSingle(foreignNoteValidationRequestsArrayBaseSlot);
|
|
481
|
-
const eventValidationRequestsArrayBaseSlot = fromSingle(foreignEventValidationRequestsArrayBaseSlot);
|
|
482
|
-
const maxNotePackedLen = fromSingle(foreignMaxNotePackedLen).toNumber();
|
|
483
|
-
const maxEventSerializedLen = fromSingle(foreignMaxEventSerializedLen).toNumber();
|
|
484
|
-
await this.handlerAsUtility().validateAndStoreEnqueuedNotesAndEvents(contractAddress, noteValidationRequestsArrayBaseSlot, eventValidationRequestsArrayBaseSlot, maxNotePackedLen, maxEventSerializedLen);
|
|
485
|
-
return toForeignCallResult([]);
|
|
486
|
-
}
|
|
487
|
-
// eslint-disable-next-line camelcase
|
|
488
|
-
async aztec_utl_bulkRetrieveLogs(foreignContractAddress, foreignLogRetrievalRequestsArrayBaseSlot, foreignLogRetrievalResponsesArrayBaseSlot) {
|
|
489
|
-
const contractAddress = AztecAddress.fromField(fromSingle(foreignContractAddress));
|
|
490
|
-
const logRetrievalRequestsArrayBaseSlot = fromSingle(foreignLogRetrievalRequestsArrayBaseSlot);
|
|
491
|
-
const logRetrievalResponsesArrayBaseSlot = fromSingle(foreignLogRetrievalResponsesArrayBaseSlot);
|
|
492
|
-
await this.handlerAsUtility().bulkRetrieveLogs(contractAddress, logRetrievalRequestsArrayBaseSlot, logRetrievalResponsesArrayBaseSlot);
|
|
493
|
-
return toForeignCallResult([]);
|
|
494
|
-
}
|
|
495
|
-
// eslint-disable-next-line camelcase
|
|
496
|
-
async aztec_utl_utilityResolveMessageContexts(foreignContractAddress, foreignMessageContextRequestsArrayBaseSlot, foreignMessageContextResponsesArrayBaseSlot) {
|
|
497
|
-
const contractAddress = AztecAddress.fromField(fromSingle(foreignContractAddress));
|
|
498
|
-
const messageContextRequestsArrayBaseSlot = fromSingle(foreignMessageContextRequestsArrayBaseSlot);
|
|
499
|
-
const messageContextResponsesArrayBaseSlot = fromSingle(foreignMessageContextResponsesArrayBaseSlot);
|
|
500
|
-
await this.handlerAsUtility().utilityResolveMessageContexts(contractAddress, messageContextRequestsArrayBaseSlot, messageContextResponsesArrayBaseSlot);
|
|
501
|
-
return toForeignCallResult([]);
|
|
502
|
-
}
|
|
503
|
-
// eslint-disable-next-line camelcase
|
|
504
|
-
async aztec_utl_storeCapsule(foreignContractAddress, foreignSlot, foreignCapsule) {
|
|
505
|
-
const contractAddress = AztecAddress.fromField(fromSingle(foreignContractAddress));
|
|
506
|
-
const slot = fromSingle(foreignSlot);
|
|
507
|
-
const capsule = fromArray(foreignCapsule);
|
|
508
|
-
await this.handlerAsUtility().storeCapsule(contractAddress, slot, capsule);
|
|
509
|
-
return toForeignCallResult([]);
|
|
510
|
-
}
|
|
511
|
-
// eslint-disable-next-line camelcase
|
|
512
|
-
async aztec_utl_loadCapsule(foreignContractAddress, foreignSlot, foreignTSize) {
|
|
513
|
-
const contractAddress = AztecAddress.fromField(fromSingle(foreignContractAddress));
|
|
514
|
-
const slot = fromSingle(foreignSlot);
|
|
515
|
-
const tSize = fromSingle(foreignTSize).toNumber();
|
|
516
|
-
const values = await this.handlerAsUtility().loadCapsule(contractAddress, slot);
|
|
517
|
-
// We are going to return a Noir Option struct to represent the possibility of null values. Options are a struct
|
|
518
|
-
// with two fields: `some` (a boolean) and `value` (a field array in this case).
|
|
519
|
-
if (values === null) {
|
|
520
|
-
// No data was found so we set `some` to 0 and pad `value` with zeros get the correct return size.
|
|
521
|
-
return toForeignCallResult([
|
|
522
|
-
toSingle(new Fr(0)),
|
|
523
|
-
toArray(Array(tSize).fill(new Fr(0)))
|
|
524
|
-
]);
|
|
525
|
-
} else {
|
|
526
|
-
// Data was found so we set `some` to 1 and return it along with `value`.
|
|
527
|
-
return toForeignCallResult([
|
|
528
|
-
toSingle(new Fr(1)),
|
|
529
|
-
toArray(values)
|
|
530
|
-
]);
|
|
531
|
-
}
|
|
421
|
+
aztec_utl_getLowNullifierMembershipWitness(...inputs) {
|
|
422
|
+
return callTxeHandler({
|
|
423
|
+
oracle: 'aztec_utl_getLowNullifierMembershipWitness',
|
|
424
|
+
inputs,
|
|
425
|
+
handler: ([blockHash, nullifier])=>this.handlerAsUtility().getLowNullifierMembershipWitness(blockHash, nullifier)
|
|
426
|
+
});
|
|
532
427
|
}
|
|
533
428
|
// eslint-disable-next-line camelcase
|
|
534
|
-
|
|
535
|
-
|
|
536
|
-
|
|
537
|
-
|
|
538
|
-
|
|
429
|
+
aztec_utl_getPendingTaggedLogs(...inputs) {
|
|
430
|
+
return callTxeHandler({
|
|
431
|
+
oracle: 'aztec_utl_getPendingTaggedLogs',
|
|
432
|
+
inputs,
|
|
433
|
+
handler: ([scope, providedSecrets])=>this.handlerAsUtility().getPendingTaggedLogs(scope, providedSecrets)
|
|
434
|
+
});
|
|
539
435
|
}
|
|
540
436
|
// eslint-disable-next-line camelcase
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
return toForeignCallResult([]);
|
|
437
|
+
aztec_utl_validateAndStoreEnqueuedNotesAndEvents(...inputs) {
|
|
438
|
+
return callTxeHandler({
|
|
439
|
+
oracle: 'aztec_utl_validateAndStoreEnqueuedNotesAndEvents',
|
|
440
|
+
inputs,
|
|
441
|
+
handler: ([noteValidationRequests, eventValidationRequests, scope])=>this.handlerAsUtility().validateAndStoreEnqueuedNotesAndEvents(noteValidationRequests, eventValidationRequests, scope)
|
|
442
|
+
});
|
|
548
443
|
}
|
|
549
|
-
// TODO: I forgot to add a corresponding function here, when I introduced an oracle method to txe_oracle.ts.
|
|
550
|
-
// The compiler didn't throw an error, so it took me a while to learn of the existence of this file, and that I need
|
|
551
|
-
// to implement this function here. Isn't there a way to programmatically identify that this is missing, given the
|
|
552
|
-
// existence of a txe_oracle method?
|
|
553
|
-
// TODO(F-452): Return Option and wrap in try/catch so BB exceptions don't crash TXE.
|
|
554
444
|
// eslint-disable-next-line camelcase
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
445
|
+
aztec_utl_getLogsByTag(...inputs) {
|
|
446
|
+
return callTxeHandler({
|
|
447
|
+
oracle: 'aztec_utl_getLogsByTag',
|
|
448
|
+
inputs,
|
|
449
|
+
handler: ([requestArrayBaseSlot])=>this.handlerAsUtility().getLogsByTag(requestArrayBaseSlot)
|
|
450
|
+
});
|
|
561
451
|
}
|
|
562
452
|
// eslint-disable-next-line camelcase
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
|
|
568
|
-
|
|
569
|
-
]);
|
|
570
|
-
const secret = await this.handlerAsUtility().getSharedSecret(address, ephPK);
|
|
571
|
-
return toForeignCallResult(secret.toFields().map(toSingle));
|
|
453
|
+
aztec_utl_getMessageContextsByTxHash(...inputs) {
|
|
454
|
+
return callTxeHandler({
|
|
455
|
+
oracle: 'aztec_utl_getMessageContextsByTxHash',
|
|
456
|
+
inputs,
|
|
457
|
+
handler: ([requestArrayBaseSlot])=>this.handlerAsUtility().getMessageContextsByTxHash(requestArrayBaseSlot)
|
|
458
|
+
});
|
|
572
459
|
}
|
|
573
460
|
// eslint-disable-next-line camelcase
|
|
574
|
-
|
|
575
|
-
|
|
461
|
+
aztec_utl_setCapsule(...inputs) {
|
|
462
|
+
return callTxeHandler({
|
|
463
|
+
oracle: 'aztec_utl_setCapsule',
|
|
464
|
+
inputs,
|
|
465
|
+
handler: ([contractAddress, slot, capsule, scope])=>this.handlerAsUtility().setCapsule(contractAddress, slot, capsule, scope)
|
|
466
|
+
});
|
|
576
467
|
}
|
|
577
|
-
// AVM opcodes
|
|
578
468
|
// eslint-disable-next-line camelcase
|
|
579
|
-
|
|
580
|
-
|
|
581
|
-
|
|
469
|
+
aztec_utl_getCapsule(...inputs) {
|
|
470
|
+
return callTxeHandler({
|
|
471
|
+
oracle: 'aztec_utl_getCapsule',
|
|
472
|
+
inputs,
|
|
473
|
+
handler: ([contractAddress, slot, tSize, scope])=>this.handlerAsUtility().getCapsule(contractAddress, slot, tSize, scope)
|
|
474
|
+
});
|
|
582
475
|
}
|
|
583
476
|
// eslint-disable-next-line camelcase
|
|
584
|
-
|
|
585
|
-
|
|
586
|
-
|
|
587
|
-
|
|
588
|
-
|
|
589
|
-
|
|
590
|
-
]);
|
|
477
|
+
aztec_utl_deleteCapsule(...inputs) {
|
|
478
|
+
return callTxeHandler({
|
|
479
|
+
oracle: 'aztec_utl_deleteCapsule',
|
|
480
|
+
inputs,
|
|
481
|
+
handler: ([contractAddress, slot, scope])=>this.handlerAsUtility().deleteCapsule(contractAddress, slot, scope)
|
|
482
|
+
});
|
|
591
483
|
}
|
|
592
484
|
// eslint-disable-next-line camelcase
|
|
593
|
-
|
|
594
|
-
|
|
595
|
-
|
|
596
|
-
|
|
597
|
-
|
|
485
|
+
aztec_utl_copyCapsule(...inputs) {
|
|
486
|
+
return callTxeHandler({
|
|
487
|
+
oracle: 'aztec_utl_copyCapsule',
|
|
488
|
+
inputs,
|
|
489
|
+
handler: ([contractAddress, srcSlot, dstSlot, numEntries, scope])=>this.handlerAsUtility().copyCapsule(contractAddress, srcSlot, dstSlot, numEntries, scope)
|
|
490
|
+
});
|
|
598
491
|
}
|
|
599
492
|
// eslint-disable-next-line camelcase
|
|
600
|
-
|
|
601
|
-
|
|
602
|
-
|
|
603
|
-
|
|
604
|
-
|
|
605
|
-
|
|
606
|
-
toSingle(new Fr(1))
|
|
607
|
-
]);
|
|
493
|
+
aztec_utl_pushEphemeral(...inputs) {
|
|
494
|
+
return callTxeHandler({
|
|
495
|
+
oracle: 'aztec_utl_pushEphemeral',
|
|
496
|
+
inputs,
|
|
497
|
+
handler: ([slot, elements])=>this.handlerAsUtility().pushEphemeral(slot, elements)
|
|
498
|
+
});
|
|
608
499
|
}
|
|
609
500
|
// eslint-disable-next-line camelcase
|
|
610
|
-
|
|
611
|
-
|
|
612
|
-
|
|
613
|
-
|
|
614
|
-
|
|
615
|
-
|
|
616
|
-
toSingle(new Fr(1))
|
|
617
|
-
]);
|
|
501
|
+
aztec_utl_popEphemeral(...inputs) {
|
|
502
|
+
return callTxeHandler({
|
|
503
|
+
oracle: 'aztec_utl_popEphemeral',
|
|
504
|
+
inputs,
|
|
505
|
+
handler: ([slot])=>this.handlerAsUtility().popEphemeral(slot)
|
|
506
|
+
});
|
|
618
507
|
}
|
|
619
508
|
// eslint-disable-next-line camelcase
|
|
620
|
-
|
|
621
|
-
|
|
622
|
-
|
|
623
|
-
|
|
624
|
-
|
|
625
|
-
|
|
626
|
-
toSingle(new Fr(1))
|
|
627
|
-
]);
|
|
509
|
+
aztec_utl_getEphemeral(...inputs) {
|
|
510
|
+
return callTxeHandler({
|
|
511
|
+
oracle: 'aztec_utl_getEphemeral',
|
|
512
|
+
inputs,
|
|
513
|
+
handler: ([slot, index])=>this.handlerAsUtility().getEphemeral(slot, index)
|
|
514
|
+
});
|
|
628
515
|
}
|
|
629
516
|
// eslint-disable-next-line camelcase
|
|
630
|
-
|
|
631
|
-
|
|
632
|
-
|
|
633
|
-
|
|
634
|
-
|
|
517
|
+
aztec_utl_setEphemeral(...inputs) {
|
|
518
|
+
return callTxeHandler({
|
|
519
|
+
oracle: 'aztec_utl_setEphemeral',
|
|
520
|
+
inputs,
|
|
521
|
+
handler: ([slot, index, elements])=>this.handlerAsUtility().setEphemeral(slot, index, elements)
|
|
522
|
+
});
|
|
635
523
|
}
|
|
636
524
|
// eslint-disable-next-line camelcase
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
640
|
-
|
|
525
|
+
aztec_utl_getEphemeralLen(...inputs) {
|
|
526
|
+
return callTxeHandler({
|
|
527
|
+
oracle: 'aztec_utl_getEphemeralLen',
|
|
528
|
+
inputs,
|
|
529
|
+
handler: ([slot])=>this.handlerAsUtility().getEphemeralLen(slot)
|
|
530
|
+
});
|
|
641
531
|
}
|
|
642
532
|
// eslint-disable-next-line camelcase
|
|
643
|
-
|
|
644
|
-
|
|
645
|
-
|
|
646
|
-
|
|
533
|
+
aztec_utl_removeEphemeral(...inputs) {
|
|
534
|
+
return callTxeHandler({
|
|
535
|
+
oracle: 'aztec_utl_removeEphemeral',
|
|
536
|
+
inputs,
|
|
537
|
+
handler: ([slot, index])=>this.handlerAsUtility().removeEphemeral(slot, index)
|
|
538
|
+
});
|
|
647
539
|
}
|
|
648
540
|
// eslint-disable-next-line camelcase
|
|
649
|
-
|
|
650
|
-
|
|
651
|
-
|
|
652
|
-
|
|
653
|
-
|
|
654
|
-
|
|
541
|
+
aztec_utl_clearEphemeral(...inputs) {
|
|
542
|
+
return callTxeHandler({
|
|
543
|
+
oracle: 'aztec_utl_clearEphemeral',
|
|
544
|
+
inputs,
|
|
545
|
+
handler: ([slot])=>this.handlerAsUtility().clearEphemeral(slot)
|
|
546
|
+
});
|
|
655
547
|
}
|
|
656
548
|
// eslint-disable-next-line camelcase
|
|
657
|
-
|
|
658
|
-
|
|
659
|
-
|
|
660
|
-
|
|
661
|
-
|
|
549
|
+
aztec_utl_pushTransient(...inputs) {
|
|
550
|
+
return callTxeHandler({
|
|
551
|
+
oracle: 'aztec_utl_pushTransient',
|
|
552
|
+
inputs,
|
|
553
|
+
handler: ([slot, elements])=>this.handlerAsUtility().pushTransient(slot, elements)
|
|
554
|
+
});
|
|
662
555
|
}
|
|
663
556
|
// eslint-disable-next-line camelcase
|
|
664
|
-
|
|
665
|
-
|
|
666
|
-
|
|
667
|
-
|
|
668
|
-
|
|
557
|
+
aztec_utl_popTransient(...inputs) {
|
|
558
|
+
return callTxeHandler({
|
|
559
|
+
oracle: 'aztec_utl_popTransient',
|
|
560
|
+
inputs,
|
|
561
|
+
handler: ([slot])=>this.handlerAsUtility().popTransient(slot)
|
|
562
|
+
});
|
|
669
563
|
}
|
|
670
564
|
// eslint-disable-next-line camelcase
|
|
671
|
-
|
|
672
|
-
|
|
673
|
-
|
|
674
|
-
|
|
675
|
-
|
|
565
|
+
aztec_utl_getTransient(...inputs) {
|
|
566
|
+
return callTxeHandler({
|
|
567
|
+
oracle: 'aztec_utl_getTransient',
|
|
568
|
+
inputs,
|
|
569
|
+
handler: ([slot, index])=>this.handlerAsUtility().getTransient(slot, index)
|
|
570
|
+
});
|
|
676
571
|
}
|
|
677
572
|
// eslint-disable-next-line camelcase
|
|
678
|
-
|
|
679
|
-
|
|
680
|
-
|
|
681
|
-
|
|
682
|
-
|
|
573
|
+
aztec_utl_setTransient(...inputs) {
|
|
574
|
+
return callTxeHandler({
|
|
575
|
+
oracle: 'aztec_utl_setTransient',
|
|
576
|
+
inputs,
|
|
577
|
+
handler: ([slot, index, elements])=>this.handlerAsUtility().setTransient(slot, index, elements)
|
|
578
|
+
});
|
|
683
579
|
}
|
|
684
580
|
// eslint-disable-next-line camelcase
|
|
685
|
-
|
|
686
|
-
|
|
687
|
-
|
|
688
|
-
|
|
689
|
-
|
|
581
|
+
aztec_utl_getTransientLen(...inputs) {
|
|
582
|
+
return callTxeHandler({
|
|
583
|
+
oracle: 'aztec_utl_getTransientLen',
|
|
584
|
+
inputs,
|
|
585
|
+
handler: ([slot])=>this.handlerAsUtility().getTransientLen(slot)
|
|
586
|
+
});
|
|
690
587
|
}
|
|
691
588
|
// eslint-disable-next-line camelcase
|
|
692
|
-
|
|
693
|
-
|
|
694
|
-
|
|
695
|
-
|
|
696
|
-
|
|
589
|
+
aztec_utl_removeTransient(...inputs) {
|
|
590
|
+
return callTxeHandler({
|
|
591
|
+
oracle: 'aztec_utl_removeTransient',
|
|
592
|
+
inputs,
|
|
593
|
+
handler: ([slot, index])=>this.handlerAsUtility().removeTransient(slot, index)
|
|
594
|
+
});
|
|
697
595
|
}
|
|
698
596
|
// eslint-disable-next-line camelcase
|
|
699
|
-
|
|
700
|
-
|
|
597
|
+
aztec_utl_clearTransient(...inputs) {
|
|
598
|
+
return callTxeHandler({
|
|
599
|
+
oracle: 'aztec_utl_clearTransient',
|
|
600
|
+
inputs,
|
|
601
|
+
handler: ([slot])=>this.handlerAsUtility().clearTransient(slot)
|
|
602
|
+
});
|
|
603
|
+
}
|
|
604
|
+
// TODO: I forgot to add a corresponding function here, when I introduced an oracle method to txe_oracle.ts.
|
|
605
|
+
// The compiler didn't throw an error, so it took me a while to learn of the existence of this file, and that I need
|
|
606
|
+
// to implement this function here. Isn't there a way to programmatically identify that this is missing, given the
|
|
607
|
+
// existence of a txe_oracle method?
|
|
608
|
+
// eslint-disable-next-line camelcase
|
|
609
|
+
aztec_utl_decryptAes128(...inputs) {
|
|
610
|
+
return callTxeHandler({
|
|
611
|
+
oracle: 'aztec_utl_decryptAes128',
|
|
612
|
+
inputs,
|
|
613
|
+
handler: ([ciphertext, iv, symKey])=>this.handlerAsUtility().decryptAes128(ciphertext, iv, symKey)
|
|
614
|
+
});
|
|
615
|
+
}
|
|
616
|
+
// eslint-disable-next-line camelcase
|
|
617
|
+
aztec_utl_getSharedSecrets(...inputs) {
|
|
618
|
+
return callTxeHandler({
|
|
619
|
+
oracle: 'aztec_utl_getSharedSecrets',
|
|
620
|
+
inputs,
|
|
621
|
+
handler: ([address, ephPksSlot, contractAddress])=>this.handlerAsUtility().getSharedSecrets(address, ephPksSlot, contractAddress)
|
|
622
|
+
});
|
|
623
|
+
}
|
|
624
|
+
// eslint-disable-next-line camelcase
|
|
625
|
+
aztec_utl_setContractSyncCacheInvalid(...inputs) {
|
|
626
|
+
return callTxeHandler({
|
|
627
|
+
oracle: 'aztec_utl_setContractSyncCacheInvalid',
|
|
628
|
+
inputs,
|
|
629
|
+
handler: ([contractAddress, scopes])=>this.handlerAsUtility().setContractSyncCacheInvalid(contractAddress, scopes)
|
|
630
|
+
});
|
|
631
|
+
}
|
|
632
|
+
// eslint-disable-next-line camelcase
|
|
633
|
+
aztec_utl_emitOffchainEffect(...inputs) {
|
|
634
|
+
return callTxeHandler({
|
|
635
|
+
oracle: 'aztec_utl_emitOffchainEffect',
|
|
636
|
+
inputs,
|
|
637
|
+
handler: ([data])=>{
|
|
638
|
+
// Record the raw payload against the currently-executing top-level call. The Noir side
|
|
639
|
+
// (via `env.offchain_messages()`) is responsible for decoding the protocol-reserved prefix
|
|
640
|
+
// (`OFFCHAIN_MESSAGE_IDENTIFIER`, recipient) and turning each payload into an `OffchainMessage` struct suitable
|
|
641
|
+
// for `offchain_receive`.
|
|
642
|
+
this.stateHandler.recordOffchainEffect(data);
|
|
643
|
+
}
|
|
644
|
+
});
|
|
701
645
|
}
|
|
646
|
+
// AVM opcodes
|
|
702
647
|
// eslint-disable-next-line camelcase
|
|
703
|
-
|
|
704
|
-
|
|
648
|
+
aztec_avm_emitPublicLog() {
|
|
649
|
+
return callTxeHandler({
|
|
650
|
+
oracle: 'aztec_avm_emitPublicLog',
|
|
651
|
+
inputs: [],
|
|
652
|
+
// TODO(#8811): Implement
|
|
653
|
+
handler: ()=>{}
|
|
654
|
+
});
|
|
705
655
|
}
|
|
706
656
|
// eslint-disable-next-line camelcase
|
|
707
|
-
|
|
708
|
-
|
|
657
|
+
aztec_avm_storageRead(...inputs) {
|
|
658
|
+
return callTxeHandler({
|
|
659
|
+
oracle: 'aztec_avm_storageRead',
|
|
660
|
+
inputs,
|
|
661
|
+
handler: ([slot, contractAddress])=>this.handlerAsAvm().storageRead(slot, contractAddress)
|
|
662
|
+
});
|
|
709
663
|
}
|
|
710
664
|
// eslint-disable-next-line camelcase
|
|
711
|
-
|
|
712
|
-
|
|
665
|
+
aztec_avm_storageWrite(...inputs) {
|
|
666
|
+
return callTxeHandler({
|
|
667
|
+
oracle: 'aztec_avm_storageWrite',
|
|
668
|
+
inputs,
|
|
669
|
+
handler: ([slot, value])=>this.handlerAsAvm().storageWrite(slot, value)
|
|
670
|
+
});
|
|
713
671
|
}
|
|
714
672
|
// eslint-disable-next-line camelcase
|
|
715
|
-
|
|
716
|
-
|
|
717
|
-
|
|
718
|
-
|
|
719
|
-
|
|
720
|
-
|
|
721
|
-
|
|
722
|
-
|
|
723
|
-
|
|
724
|
-
|
|
725
|
-
|
|
726
|
-
|
|
727
|
-
|
|
728
|
-
|
|
729
|
-
|
|
730
|
-
|
|
731
|
-
|
|
732
|
-
|
|
733
|
-
|
|
734
|
-
|
|
735
|
-
|
|
736
|
-
|
|
737
|
-
|
|
738
|
-
|
|
739
|
-
|
|
740
|
-
|
|
741
|
-
|
|
742
|
-
|
|
743
|
-
|
|
744
|
-
|
|
745
|
-
|
|
746
|
-
|
|
747
|
-
|
|
748
|
-
|
|
749
|
-
|
|
750
|
-
|
|
751
|
-
|
|
752
|
-
|
|
753
|
-
|
|
754
|
-
|
|
755
|
-
|
|
756
|
-
|
|
757
|
-
|
|
758
|
-
|
|
759
|
-
|
|
760
|
-
|
|
761
|
-
|
|
762
|
-
|
|
763
|
-
|
|
764
|
-
|
|
765
|
-
|
|
766
|
-
|
|
767
|
-
])
|
|
768
|
-
}
|
|
769
|
-
|
|
770
|
-
|
|
771
|
-
|
|
772
|
-
|
|
773
|
-
|
|
774
|
-
|
|
673
|
+
aztec_avm_getContractInstanceDeployer(...inputs) {
|
|
674
|
+
return callTxeHandler({
|
|
675
|
+
oracle: 'aztec_avm_getContractInstanceDeployer',
|
|
676
|
+
inputs,
|
|
677
|
+
handler: ([address])=>this.handlerAsAvm().getContractInstanceDeployer(address)
|
|
678
|
+
});
|
|
679
|
+
}
|
|
680
|
+
// eslint-disable-next-line camelcase
|
|
681
|
+
aztec_avm_getContractInstanceClassId(...inputs) {
|
|
682
|
+
return callTxeHandler({
|
|
683
|
+
oracle: 'aztec_avm_getContractInstanceClassId',
|
|
684
|
+
inputs,
|
|
685
|
+
handler: ([address])=>this.handlerAsAvm().getContractInstanceClassId(address)
|
|
686
|
+
});
|
|
687
|
+
}
|
|
688
|
+
// eslint-disable-next-line camelcase
|
|
689
|
+
aztec_avm_getContractInstanceInitializationHash(...inputs) {
|
|
690
|
+
return callTxeHandler({
|
|
691
|
+
oracle: 'aztec_avm_getContractInstanceInitializationHash',
|
|
692
|
+
inputs,
|
|
693
|
+
handler: ([address])=>this.handlerAsAvm().getContractInstanceInitializationHash(address)
|
|
694
|
+
});
|
|
695
|
+
}
|
|
696
|
+
// eslint-disable-next-line camelcase
|
|
697
|
+
aztec_avm_getContractInstanceImmutablesHash(...inputs) {
|
|
698
|
+
return callTxeHandler({
|
|
699
|
+
oracle: 'aztec_avm_getContractInstanceImmutablesHash',
|
|
700
|
+
inputs,
|
|
701
|
+
handler: ([address])=>this.handlerAsAvm().getContractInstanceImmutablesHash(address)
|
|
702
|
+
});
|
|
703
|
+
}
|
|
704
|
+
// eslint-disable-next-line camelcase
|
|
705
|
+
aztec_avm_sender() {
|
|
706
|
+
return callTxeHandler({
|
|
707
|
+
oracle: 'aztec_avm_sender',
|
|
708
|
+
inputs: [],
|
|
709
|
+
handler: ()=>this.handlerAsAvm().sender()
|
|
710
|
+
});
|
|
711
|
+
}
|
|
712
|
+
// eslint-disable-next-line camelcase
|
|
713
|
+
aztec_avm_emitNullifier(...inputs) {
|
|
714
|
+
return callTxeHandler({
|
|
715
|
+
oracle: 'aztec_avm_emitNullifier',
|
|
716
|
+
inputs,
|
|
717
|
+
handler: ([nullifier])=>this.handlerAsAvm().emitNullifier(nullifier)
|
|
718
|
+
});
|
|
719
|
+
}
|
|
720
|
+
// eslint-disable-next-line camelcase
|
|
721
|
+
aztec_avm_emitNoteHash(...inputs) {
|
|
722
|
+
return callTxeHandler({
|
|
723
|
+
oracle: 'aztec_avm_emitNoteHash',
|
|
724
|
+
inputs,
|
|
725
|
+
handler: ([noteHash])=>this.handlerAsAvm().emitNoteHash(noteHash)
|
|
726
|
+
});
|
|
727
|
+
}
|
|
728
|
+
// eslint-disable-next-line camelcase
|
|
729
|
+
aztec_avm_nullifierExists(...inputs) {
|
|
730
|
+
return callTxeHandler({
|
|
731
|
+
oracle: 'aztec_avm_nullifierExists',
|
|
732
|
+
inputs,
|
|
733
|
+
handler: ([siloedNullifier])=>this.handlerAsAvm().nullifierExists(siloedNullifier)
|
|
734
|
+
});
|
|
735
|
+
}
|
|
736
|
+
// eslint-disable-next-line camelcase
|
|
737
|
+
aztec_avm_address() {
|
|
738
|
+
return callTxeHandler({
|
|
739
|
+
oracle: 'aztec_avm_address',
|
|
740
|
+
inputs: [],
|
|
741
|
+
handler: ()=>this.handlerAsAvm().address()
|
|
742
|
+
});
|
|
743
|
+
}
|
|
744
|
+
// eslint-disable-next-line camelcase
|
|
745
|
+
aztec_avm_blockNumber() {
|
|
746
|
+
return callTxeHandler({
|
|
747
|
+
oracle: 'aztec_avm_blockNumber',
|
|
748
|
+
inputs: [],
|
|
749
|
+
handler: ()=>this.handlerAsAvm().blockNumber()
|
|
750
|
+
});
|
|
751
|
+
}
|
|
752
|
+
// eslint-disable-next-line camelcase
|
|
753
|
+
aztec_avm_timestamp() {
|
|
754
|
+
return callTxeHandler({
|
|
755
|
+
oracle: 'aztec_avm_timestamp',
|
|
756
|
+
inputs: [],
|
|
757
|
+
handler: ()=>this.handlerAsAvm().timestamp()
|
|
758
|
+
});
|
|
775
759
|
}
|
|
776
760
|
// eslint-disable-next-line camelcase
|
|
777
|
-
|
|
778
|
-
|
|
779
|
-
|
|
780
|
-
|
|
761
|
+
aztec_avm_isStaticCall() {
|
|
762
|
+
return callTxeHandler({
|
|
763
|
+
oracle: 'aztec_avm_isStaticCall',
|
|
764
|
+
inputs: [],
|
|
765
|
+
handler: ()=>this.handlerAsAvm().isStaticCall()
|
|
766
|
+
});
|
|
781
767
|
}
|
|
782
768
|
// eslint-disable-next-line camelcase
|
|
783
|
-
|
|
784
|
-
|
|
785
|
-
|
|
786
|
-
|
|
787
|
-
|
|
788
|
-
|
|
789
|
-
|
|
769
|
+
aztec_avm_chainId() {
|
|
770
|
+
return callTxeHandler({
|
|
771
|
+
oracle: 'aztec_avm_chainId',
|
|
772
|
+
inputs: [],
|
|
773
|
+
handler: ()=>this.handlerAsAvm().chainId()
|
|
774
|
+
});
|
|
775
|
+
}
|
|
776
|
+
// eslint-disable-next-line camelcase
|
|
777
|
+
aztec_avm_version() {
|
|
778
|
+
return callTxeHandler({
|
|
779
|
+
oracle: 'aztec_avm_version',
|
|
780
|
+
inputs: [],
|
|
781
|
+
handler: ()=>this.handlerAsAvm().version()
|
|
782
|
+
});
|
|
783
|
+
}
|
|
784
|
+
// eslint-disable-next-line camelcase
|
|
785
|
+
aztec_avm_returndataSize() {
|
|
786
|
+
return callTxeHandler({
|
|
787
|
+
oracle: 'aztec_avm_returndataSize',
|
|
788
|
+
inputs: [],
|
|
789
|
+
handler: ()=>this.handlerAsAvm().returndataSize()
|
|
790
|
+
});
|
|
791
|
+
}
|
|
792
|
+
// eslint-disable-next-line camelcase
|
|
793
|
+
aztec_avm_returndataCopy(...inputs) {
|
|
794
|
+
return callTxeHandler({
|
|
795
|
+
oracle: 'aztec_avm_returndataCopy',
|
|
796
|
+
inputs,
|
|
797
|
+
handler: ([rdOffset, copySize])=>this.handlerAsAvm().returndataCopy(rdOffset, copySize)
|
|
798
|
+
});
|
|
799
|
+
}
|
|
800
|
+
// eslint-disable-next-line camelcase
|
|
801
|
+
aztec_avm_call(...inputs) {
|
|
802
|
+
return callTxeHandler({
|
|
803
|
+
oracle: 'aztec_avm_call',
|
|
804
|
+
inputs,
|
|
805
|
+
handler: ([l2Gas, daGas, address, argsLength, args])=>this.handlerAsAvm().call(l2Gas, daGas, address, argsLength, args)
|
|
806
|
+
});
|
|
807
|
+
}
|
|
808
|
+
// eslint-disable-next-line camelcase
|
|
809
|
+
aztec_avm_staticCall(...inputs) {
|
|
810
|
+
return callTxeHandler({
|
|
811
|
+
oracle: 'aztec_avm_staticCall',
|
|
812
|
+
inputs,
|
|
813
|
+
handler: ([l2Gas, daGas, address, argsLength, args])=>this.handlerAsAvm().staticCall(l2Gas, daGas, address, argsLength, args)
|
|
814
|
+
});
|
|
815
|
+
}
|
|
816
|
+
// eslint-disable-next-line camelcase
|
|
817
|
+
aztec_avm_successCopy() {
|
|
818
|
+
return callTxeHandler({
|
|
819
|
+
oracle: 'aztec_avm_successCopy',
|
|
820
|
+
inputs: [],
|
|
821
|
+
handler: ()=>this.handlerAsAvm().successCopy()
|
|
822
|
+
});
|
|
823
|
+
}
|
|
824
|
+
// eslint-disable-next-line camelcase
|
|
825
|
+
aztec_txe_privateCallNewFlow(...inputs) {
|
|
826
|
+
return callTxeHandler({
|
|
827
|
+
oracle: 'aztec_txe_privateCallNewFlow',
|
|
828
|
+
inputs,
|
|
829
|
+
handler: ([from, targetContractAddress, functionSelector, args, argsHash, isStaticCall, additionalScopes, authorizedUtilityCallTargets, gasSettings])=>this.stateHandler.executePrivateCall(from, targetContractAddress, functionSelector, args, argsHash, isStaticCall, additionalScopes, authorizedUtilityCallTargets, gasSettings)
|
|
830
|
+
});
|
|
831
|
+
}
|
|
832
|
+
// eslint-disable-next-line camelcase
|
|
833
|
+
aztec_txe_executeUtilityFunction(...inputs) {
|
|
834
|
+
return callTxeHandler({
|
|
835
|
+
oracle: 'aztec_txe_executeUtilityFunction',
|
|
836
|
+
inputs,
|
|
837
|
+
handler: ([targetContractAddress, functionSelector, args, authorizedUtilityCallTargets])=>this.stateHandler.executeUtilityFunction(targetContractAddress, functionSelector, args, authorizedUtilityCallTargets)
|
|
838
|
+
});
|
|
839
|
+
}
|
|
840
|
+
// eslint-disable-next-line camelcase
|
|
841
|
+
aztec_txe_publicCallNewFlow(...inputs) {
|
|
842
|
+
return callTxeHandler({
|
|
843
|
+
oracle: 'aztec_txe_publicCallNewFlow',
|
|
844
|
+
inputs,
|
|
845
|
+
handler: ([from, address, calldata, isStaticCall, gasSettings])=>this.stateHandler.executePublicCall(from, address, calldata, isStaticCall, gasSettings)
|
|
846
|
+
});
|
|
847
|
+
}
|
|
848
|
+
// eslint-disable-next-line camelcase
|
|
849
|
+
aztec_prv_getSenderForTags() {
|
|
850
|
+
return callTxeHandler({
|
|
851
|
+
oracle: 'aztec_prv_getSenderForTags',
|
|
852
|
+
inputs: [],
|
|
853
|
+
handler: ()=>this.handlerAsPrivate().getSenderForTags()
|
|
854
|
+
});
|
|
855
|
+
}
|
|
856
|
+
// eslint-disable-next-line camelcase
|
|
857
|
+
aztec_prv_getAppTaggingSecret(...inputs) {
|
|
858
|
+
return callTxeHandler({
|
|
859
|
+
oracle: 'aztec_prv_getAppTaggingSecret',
|
|
860
|
+
inputs,
|
|
861
|
+
handler: ([sender, recipient])=>this.handlerAsPrivate().getAppTaggingSecret(sender, recipient)
|
|
862
|
+
});
|
|
863
|
+
}
|
|
864
|
+
// eslint-disable-next-line camelcase
|
|
865
|
+
aztec_prv_getNextTaggingIndex(...inputs) {
|
|
866
|
+
return callTxeHandler({
|
|
867
|
+
oracle: 'aztec_prv_getNextTaggingIndex',
|
|
868
|
+
inputs,
|
|
869
|
+
handler: ([secret, deliveryMode])=>this.handlerAsPrivate().getNextTaggingIndex(secret, deliveryMode)
|
|
870
|
+
});
|
|
790
871
|
}
|
|
791
872
|
}
|