@aztec/simulator 0.22.0

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.
Files changed (176) hide show
  1. package/README.md +47 -0
  2. package/dest/acvm/acvm.d.ts +39 -0
  3. package/dest/acvm/acvm.d.ts.map +1 -0
  4. package/dest/acvm/acvm.js +97 -0
  5. package/dest/acvm/acvm_types.d.ts +10 -0
  6. package/dest/acvm/acvm_types.d.ts.map +1 -0
  7. package/dest/acvm/acvm_types.js +2 -0
  8. package/dest/acvm/deserialize.d.ts +24 -0
  9. package/dest/acvm/deserialize.d.ts.map +1 -0
  10. package/dest/acvm/deserialize.js +31 -0
  11. package/dest/acvm/index.d.ts +6 -0
  12. package/dest/acvm/index.d.ts.map +1 -0
  13. package/dest/acvm/index.js +6 -0
  14. package/dest/acvm/oracle/debug.d.ts +19 -0
  15. package/dest/acvm/oracle/debug.d.ts.map +1 -0
  16. package/dest/acvm/oracle/debug.js +95 -0
  17. package/dest/acvm/oracle/index.d.ts +15 -0
  18. package/dest/acvm/oracle/index.d.ts.map +1 -0
  19. package/dest/acvm/oracle/index.js +4 -0
  20. package/dest/acvm/oracle/oracle.d.ts +38 -0
  21. package/dest/acvm/oracle/oracle.d.ts.map +1 -0
  22. package/dest/acvm/oracle/oracle.js +193 -0
  23. package/dest/acvm/oracle/typed_oracle.d.ts +88 -0
  24. package/dest/acvm/oracle/typed_oracle.d.ts.map +1 -0
  25. package/dest/acvm/oracle/typed_oracle.js +103 -0
  26. package/dest/acvm/serialize.d.ts +30 -0
  27. package/dest/acvm/serialize.d.ts.map +1 -0
  28. package/dest/acvm/serialize.js +67 -0
  29. package/dest/avm/avm_context.d.ts +49 -0
  30. package/dest/avm/avm_context.d.ts.map +1 -0
  31. package/dest/avm/avm_context.js +56 -0
  32. package/dest/avm/avm_execution_environment.d.ts +28 -0
  33. package/dest/avm/avm_execution_environment.d.ts.map +1 -0
  34. package/dest/avm/avm_execution_environment.js +42 -0
  35. package/dest/avm/avm_machine_state.d.ts +62 -0
  36. package/dest/avm/avm_machine_state.d.ts.map +1 -0
  37. package/dest/avm/avm_machine_state.js +69 -0
  38. package/dest/avm/avm_memory_types.d.ts +113 -0
  39. package/dest/avm/avm_memory_types.d.ts.map +1 -0
  40. package/dest/avm/avm_memory_types.js +269 -0
  41. package/dest/avm/avm_message_call_result.d.ts +16 -0
  42. package/dest/avm/avm_message_call_result.d.ts.map +1 -0
  43. package/dest/avm/avm_message_call_result.js +21 -0
  44. package/dest/avm/avm_simulator.d.ts +22 -0
  45. package/dest/avm/avm_simulator.d.ts.map +1 -0
  46. package/dest/avm/avm_simulator.js +74 -0
  47. package/dest/avm/errors.d.ts +30 -0
  48. package/dest/avm/errors.d.ts.map +1 -0
  49. package/dest/avm/errors.js +44 -0
  50. package/dest/avm/fixtures/index.d.ts +28 -0
  51. package/dest/avm/fixtures/index.d.ts.map +1 -0
  52. package/dest/avm/fixtures/index.js +44 -0
  53. package/dest/avm/journal/host_storage.d.ts +13 -0
  54. package/dest/avm/journal/host_storage.d.ts.map +1 -0
  55. package/dest/avm/journal/host_storage.js +13 -0
  56. package/dest/avm/journal/index.d.ts +3 -0
  57. package/dest/avm/journal/index.d.ts.map +1 -0
  58. package/dest/avm/journal/index.js +3 -0
  59. package/dest/avm/journal/journal.d.ts +95 -0
  60. package/dest/avm/journal/journal.d.ts.map +1 -0
  61. package/dest/avm/journal/journal.js +217 -0
  62. package/dest/avm/opcodes/accrued_substate.d.ts +42 -0
  63. package/dest/avm/opcodes/accrued_substate.d.ts.map +1 -0
  64. package/dest/avm/opcodes/accrued_substate.js +82 -0
  65. package/dest/avm/opcodes/arithmetic.d.ts +28 -0
  66. package/dest/avm/opcodes/arithmetic.d.ts.map +1 -0
  67. package/dest/avm/opcodes/arithmetic.js +59 -0
  68. package/dest/avm/opcodes/bitwise.d.ts +40 -0
  69. package/dest/avm/opcodes/bitwise.d.ts.map +1 -0
  70. package/dest/avm/opcodes/bitwise.js +92 -0
  71. package/dest/avm/opcodes/comparators.d.ts +22 -0
  72. package/dest/avm/opcodes/comparators.d.ts.map +1 -0
  73. package/dest/avm/opcodes/comparators.js +51 -0
  74. package/dest/avm/opcodes/control_flow.d.ts +57 -0
  75. package/dest/avm/opcodes/control_flow.d.ts.map +1 -0
  76. package/dest/avm/opcodes/control_flow.js +118 -0
  77. package/dest/avm/opcodes/environment_getters.d.ts +74 -0
  78. package/dest/avm/opcodes/environment_getters.d.ts.map +1 -0
  79. package/dest/avm/opcodes/environment_getters.js +151 -0
  80. package/dest/avm/opcodes/external_calls.d.ts +34 -0
  81. package/dest/avm/opcodes/external_calls.d.ts.map +1 -0
  82. package/dest/avm/opcodes/external_calls.js +103 -0
  83. package/dest/avm/opcodes/index.d.ts +11 -0
  84. package/dest/avm/opcodes/index.d.ts.map +1 -0
  85. package/dest/avm/opcodes/index.js +11 -0
  86. package/dest/avm/opcodes/instruction.d.ts +43 -0
  87. package/dest/avm/opcodes/instruction.d.ts.map +1 -0
  88. package/dest/avm/opcodes/instruction.js +44 -0
  89. package/dest/avm/opcodes/instruction_impl.d.ts +28 -0
  90. package/dest/avm/opcodes/instruction_impl.d.ts.map +1 -0
  91. package/dest/avm/opcodes/instruction_impl.js +47 -0
  92. package/dest/avm/opcodes/memory.d.ts +55 -0
  93. package/dest/avm/opcodes/memory.d.ts.map +1 -0
  94. package/dest/avm/opcodes/memory.js +125 -0
  95. package/dest/avm/opcodes/storage.d.ts +31 -0
  96. package/dest/avm/opcodes/storage.d.ts.map +1 -0
  97. package/dest/avm/opcodes/storage.js +59 -0
  98. package/dest/avm/serialization/buffer_cursor.d.ts +25 -0
  99. package/dest/avm/serialization/buffer_cursor.d.ts.map +1 -0
  100. package/dest/avm/serialization/buffer_cursor.js +94 -0
  101. package/dest/avm/serialization/bytecode_serialization.d.ts +25 -0
  102. package/dest/avm/serialization/bytecode_serialization.d.ts.map +1 -0
  103. package/dest/avm/serialization/bytecode_serialization.js +100 -0
  104. package/dest/avm/serialization/instruction_serialization.d.ts +91 -0
  105. package/dest/avm/serialization/instruction_serialization.d.ts.map +1 -0
  106. package/dest/avm/serialization/instruction_serialization.js +146 -0
  107. package/dest/client/client_execution_context.d.ts +188 -0
  108. package/dest/client/client_execution_context.d.ts.map +1 -0
  109. package/dest/client/client_execution_context.js +326 -0
  110. package/dest/client/db_oracle.d.ts +155 -0
  111. package/dest/client/db_oracle.d.ts.map +1 -0
  112. package/dest/client/db_oracle.js +17 -0
  113. package/dest/client/execution_note_cache.d.ts +54 -0
  114. package/dest/client/execution_note_cache.d.ts.map +1 -0
  115. package/dest/client/execution_note_cache.js +82 -0
  116. package/dest/client/execution_result.d.ts +67 -0
  117. package/dest/client/execution_result.d.ts.map +1 -0
  118. package/dest/client/execution_result.js +32 -0
  119. package/dest/client/index.d.ts +4 -0
  120. package/dest/client/index.d.ts.map +1 -0
  121. package/dest/client/index.js +4 -0
  122. package/dest/client/pick_notes.d.ts +80 -0
  123. package/dest/client/pick_notes.d.ts.map +1 -0
  124. package/dest/client/pick_notes.js +45 -0
  125. package/dest/client/private_execution.d.ts +10 -0
  126. package/dest/client/private_execution.d.ts.map +1 -0
  127. package/dest/client/private_execution.js +55 -0
  128. package/dest/client/simulator.d.ts +100 -0
  129. package/dest/client/simulator.d.ts.map +1 -0
  130. package/dest/client/simulator.js +171 -0
  131. package/dest/client/unconstrained_execution.d.ts +10 -0
  132. package/dest/client/unconstrained_execution.d.ts.map +1 -0
  133. package/dest/client/unconstrained_execution.js +25 -0
  134. package/dest/client/view_data_oracle.d.ts +139 -0
  135. package/dest/client/view_data_oracle.d.ts.map +1 -0
  136. package/dest/client/view_data_oracle.js +196 -0
  137. package/dest/common/errors.d.ts +36 -0
  138. package/dest/common/errors.d.ts.map +1 -0
  139. package/dest/common/errors.js +57 -0
  140. package/dest/common/index.d.ts +4 -0
  141. package/dest/common/index.d.ts.map +1 -0
  142. package/dest/common/index.js +4 -0
  143. package/dest/common/packed_args_cache.d.ts +28 -0
  144. package/dest/common/packed_args_cache.d.ts.map +1 -0
  145. package/dest/common/packed_args_cache.js +50 -0
  146. package/dest/common/side_effect_counter.d.ts +9 -0
  147. package/dest/common/side_effect_counter.d.ts.map +1 -0
  148. package/dest/common/side_effect_counter.js +14 -0
  149. package/dest/index.d.ts +4 -0
  150. package/dest/index.d.ts.map +1 -0
  151. package/dest/index.js +4 -0
  152. package/dest/public/db.d.ts +77 -0
  153. package/dest/public/db.d.ts.map +1 -0
  154. package/dest/public/db.js +2 -0
  155. package/dest/public/execution.d.ts +62 -0
  156. package/dest/public/execution.d.ts.map +1 -0
  157. package/dest/public/execution.js +61 -0
  158. package/dest/public/executor.d.ts +27 -0
  159. package/dest/public/executor.d.ts.map +1 -0
  160. package/dest/public/executor.js +83 -0
  161. package/dest/public/index.d.ts +4 -0
  162. package/dest/public/index.d.ts.map +1 -0
  163. package/dest/public/index.js +4 -0
  164. package/dest/public/public_execution_context.d.ts +103 -0
  165. package/dest/public/public_execution_context.d.ts.map +1 -0
  166. package/dest/public/public_execution_context.js +175 -0
  167. package/dest/public/state_actions.d.ts +39 -0
  168. package/dest/public/state_actions.d.ts.map +1 -0
  169. package/dest/public/state_actions.js +79 -0
  170. package/dest/test/utils.d.ts +12 -0
  171. package/dest/test/utils.d.ts.map +1 -0
  172. package/dest/test/utils.js +23 -0
  173. package/dest/utils.d.ts +27 -0
  174. package/dest/utils.d.ts.map +1 -0
  175. package/dest/utils.js +28 -0
  176. package/package.json +66 -0
@@ -0,0 +1,193 @@
1
+ import { MerkleTreeId, UnencryptedL2Log } from '@aztec/circuit-types';
2
+ import { RETURN_VALUES_LENGTH } from '@aztec/circuits.js';
3
+ import { EventSelector, FunctionSelector } from '@aztec/foundation/abi';
4
+ import { AztecAddress } from '@aztec/foundation/aztec-address';
5
+ import { padArrayEnd } from '@aztec/foundation/collection';
6
+ import { Fr, Point } from '@aztec/foundation/fields';
7
+ import { createDebugLogger } from '@aztec/foundation/log';
8
+ import { frToNumber, fromACVMField } from '../deserialize.js';
9
+ import { toACVMField, toAcvmEnqueuePublicFunctionResult } from '../serialize.js';
10
+ import { acvmFieldMessageToString, oracleDebugCallToFormattedStr } from './debug.js';
11
+ /**
12
+ * A data source that has all the apis required by Aztec.nr.
13
+ */
14
+ export class Oracle {
15
+ constructor(typedOracle, log = createDebugLogger('aztec:simulator:oracle')) {
16
+ this.typedOracle = typedOracle;
17
+ this.log = log;
18
+ }
19
+ getRandomField() {
20
+ const val = this.typedOracle.getRandomField();
21
+ return toACVMField(val);
22
+ }
23
+ async packArguments(args) {
24
+ const packed = await this.typedOracle.packArguments(args.map(fromACVMField));
25
+ return toACVMField(packed);
26
+ }
27
+ async getNullifierKeyPair([accountAddress]) {
28
+ const { publicKey, secretKey } = await this.typedOracle.getNullifierKeyPair(fromACVMField(accountAddress));
29
+ return [
30
+ toACVMField(publicKey.x),
31
+ toACVMField(publicKey.y),
32
+ toACVMField(secretKey.high),
33
+ toACVMField(secretKey.low),
34
+ ];
35
+ }
36
+ async getPublicKeyAndPartialAddress([address]) {
37
+ const { publicKey, partialAddress } = await this.typedOracle.getCompleteAddress(AztecAddress.fromField(fromACVMField(address)));
38
+ return [publicKey.x, publicKey.y, partialAddress].map(toACVMField);
39
+ }
40
+ async getMembershipWitness([blockNumber], [treeId], [leafValue]) {
41
+ const parsedBlockNumber = frToNumber(fromACVMField(blockNumber));
42
+ const parsedTreeId = frToNumber(fromACVMField(treeId));
43
+ const parsedLeafValue = fromACVMField(leafValue);
44
+ const witness = await this.typedOracle.getMembershipWitness(parsedBlockNumber, parsedTreeId, parsedLeafValue);
45
+ if (!witness) {
46
+ throw new Error(`Leaf ${leafValue} not found in the tree ${MerkleTreeId[parsedTreeId]} at block ${parsedBlockNumber}.`);
47
+ }
48
+ return witness.map(toACVMField);
49
+ }
50
+ async getSiblingPath([blockNumber], [treeId], [leafIndex]) {
51
+ const parsedBlockNumber = frToNumber(fromACVMField(blockNumber));
52
+ const parsedTreeId = frToNumber(fromACVMField(treeId));
53
+ const parsedLeafIndex = fromACVMField(leafIndex);
54
+ const path = await this.typedOracle.getSiblingPath(parsedBlockNumber, parsedTreeId, parsedLeafIndex);
55
+ return path.map(toACVMField);
56
+ }
57
+ async getNullifierMembershipWitness([blockNumber], [nullifier]) {
58
+ const parsedBlockNumber = frToNumber(fromACVMField(blockNumber));
59
+ const parsedNullifier = fromACVMField(nullifier);
60
+ const witness = await this.typedOracle.getNullifierMembershipWitness(parsedBlockNumber, parsedNullifier);
61
+ if (!witness) {
62
+ throw new Error(`Low nullifier witness not found for nullifier ${parsedNullifier} at block ${parsedBlockNumber}.`);
63
+ }
64
+ return witness.toFields().map(toACVMField);
65
+ }
66
+ async getLowNullifierMembershipWitness([blockNumber], [nullifier]) {
67
+ const parsedBlockNumber = frToNumber(fromACVMField(blockNumber));
68
+ const parsedNullifier = fromACVMField(nullifier);
69
+ const witness = await this.typedOracle.getLowNullifierMembershipWitness(parsedBlockNumber, parsedNullifier);
70
+ if (!witness) {
71
+ throw new Error(`Low nullifier witness not found for nullifier ${parsedNullifier} at block ${parsedBlockNumber}.`);
72
+ }
73
+ return witness.toFields().map(toACVMField);
74
+ }
75
+ async getPublicDataTreeWitness([blockNumber], [leafSlot]) {
76
+ const parsedBlockNumber = frToNumber(fromACVMField(blockNumber));
77
+ const parsedLeafSlot = fromACVMField(leafSlot);
78
+ const witness = await this.typedOracle.getPublicDataTreeWitness(parsedBlockNumber, parsedLeafSlot);
79
+ if (!witness) {
80
+ throw new Error(`Public data witness not found for slot ${parsedLeafSlot} at block ${parsedBlockNumber}.`);
81
+ }
82
+ return witness.toFields().map(toACVMField);
83
+ }
84
+ async getHeader([blockNumber]) {
85
+ const parsedBlockNumber = frToNumber(fromACVMField(blockNumber));
86
+ const header = await this.typedOracle.getHeader(parsedBlockNumber);
87
+ if (!header) {
88
+ throw new Error(`Block header not found for block ${parsedBlockNumber}.`);
89
+ }
90
+ return header.toFields().map(toACVMField);
91
+ }
92
+ async getAuthWitness([messageHash]) {
93
+ const messageHashField = fromACVMField(messageHash);
94
+ const witness = await this.typedOracle.getAuthWitness(messageHashField);
95
+ if (!witness) {
96
+ throw new Error(`Authorization not found for message hash ${messageHashField}`);
97
+ }
98
+ return witness.map(toACVMField);
99
+ }
100
+ async popCapsule() {
101
+ const capsule = await this.typedOracle.popCapsule();
102
+ if (!capsule) {
103
+ throw new Error(`No capsules available`);
104
+ }
105
+ return capsule.map(toACVMField);
106
+ }
107
+ async getNotes([storageSlot], [numSelects], selectBy, selectValues, selectComparators, sortBy, sortOrder, [limit], [offset], [status], [returnSize]) {
108
+ const noteDatas = await this.typedOracle.getNotes(fromACVMField(storageSlot), +numSelects, selectBy.map(s => +s), selectValues.map(fromACVMField), selectComparators.map(s => +s), sortBy.map(s => +s), sortOrder.map(s => +s), +limit, +offset, +status);
109
+ const noteLength = noteDatas?.[0]?.note.items.length ?? 0;
110
+ if (!noteDatas.every(({ note }) => noteLength === note.items.length)) {
111
+ throw new Error('Notes should all be the same length.');
112
+ }
113
+ const contractAddress = noteDatas[0]?.contractAddress ?? Fr.ZERO;
114
+ // Values indicates whether the note is settled or transient.
115
+ const noteTypes = {
116
+ isSettled: new Fr(0),
117
+ isTransient: new Fr(1),
118
+ };
119
+ const flattenData = noteDatas.flatMap(({ nonce, note, index }) => [
120
+ nonce,
121
+ index === undefined ? noteTypes.isTransient : noteTypes.isSettled,
122
+ ...note.items,
123
+ ]);
124
+ const returnFieldSize = +returnSize;
125
+ const returnData = [noteDatas.length, contractAddress, ...flattenData].map(v => toACVMField(v));
126
+ if (returnData.length > returnFieldSize) {
127
+ throw new Error(`Return data size too big. Maximum ${returnFieldSize} fields. Got ${flattenData.length}.`);
128
+ }
129
+ const paddedZeros = Array(returnFieldSize - returnData.length).fill(toACVMField(0));
130
+ return returnData.concat(paddedZeros);
131
+ }
132
+ notifyCreatedNote([storageSlot], note, [innerNoteHash]) {
133
+ this.typedOracle.notifyCreatedNote(fromACVMField(storageSlot), note.map(fromACVMField), fromACVMField(innerNoteHash));
134
+ return toACVMField(0);
135
+ }
136
+ async notifyNullifiedNote([innerNullifier], [innerNoteHash]) {
137
+ await this.typedOracle.notifyNullifiedNote(fromACVMField(innerNullifier), fromACVMField(innerNoteHash));
138
+ return toACVMField(0);
139
+ }
140
+ async checkNullifierExists([innerNullifier]) {
141
+ const exists = await this.typedOracle.checkNullifierExists(fromACVMField(innerNullifier));
142
+ return toACVMField(exists);
143
+ }
144
+ async getL1ToL2Message([msgKey]) {
145
+ const message = await this.typedOracle.getL1ToL2Message(fromACVMField(msgKey));
146
+ return message.toFields().map(toACVMField);
147
+ }
148
+ async getPortalContractAddress([aztecAddress]) {
149
+ const contractAddress = AztecAddress.fromString(aztecAddress);
150
+ const portalContactAddress = await this.typedOracle.getPortalContractAddress(contractAddress);
151
+ return toACVMField(portalContactAddress);
152
+ }
153
+ async storageRead([startStorageSlot], [numberOfElements]) {
154
+ const values = await this.typedOracle.storageRead(fromACVMField(startStorageSlot), +numberOfElements);
155
+ return values.map(toACVMField);
156
+ }
157
+ async storageWrite([startStorageSlot], values) {
158
+ const newValues = await this.typedOracle.storageWrite(fromACVMField(startStorageSlot), values.map(fromACVMField));
159
+ return newValues.map(toACVMField);
160
+ }
161
+ emitEncryptedLog([contractAddress], [storageSlot], [publicKeyX], [publicKeyY], log) {
162
+ const publicKey = new Point(fromACVMField(publicKeyX), fromACVMField(publicKeyY));
163
+ this.typedOracle.emitEncryptedLog(AztecAddress.fromString(contractAddress), Fr.fromString(storageSlot), publicKey, log.map(fromACVMField));
164
+ return toACVMField(0);
165
+ }
166
+ emitUnencryptedLog([contractAddress], [eventSelector], message) {
167
+ const logPayload = Buffer.concat(message.map(fromACVMField).map(f => f.toBuffer()));
168
+ const log = new UnencryptedL2Log(AztecAddress.fromString(contractAddress), EventSelector.fromField(fromACVMField(eventSelector)), logPayload);
169
+ this.typedOracle.emitUnencryptedLog(log);
170
+ return toACVMField(0);
171
+ }
172
+ debugLog(...args) {
173
+ this.log(oracleDebugCallToFormattedStr(args));
174
+ return toACVMField(0);
175
+ }
176
+ debugLogWithPrefix(arg0, ...args) {
177
+ this.log(`${acvmFieldMessageToString(arg0)}: ${oracleDebugCallToFormattedStr(args)}`);
178
+ return toACVMField(0);
179
+ }
180
+ async callPrivateFunction([contractAddress], [functionSelector], [argsHash], [sideffectCounter]) {
181
+ const callStackItem = await this.typedOracle.callPrivateFunction(AztecAddress.fromField(fromACVMField(contractAddress)), FunctionSelector.fromField(fromACVMField(functionSelector)), fromACVMField(argsHash), frToNumber(fromACVMField(sideffectCounter)));
182
+ return callStackItem.toFields().map(toACVMField);
183
+ }
184
+ async callPublicFunction([contractAddress], [functionSelector], [argsHash]) {
185
+ const returnValues = await this.typedOracle.callPublicFunction(AztecAddress.fromField(fromACVMField(contractAddress)), FunctionSelector.fromField(fromACVMField(functionSelector)), fromACVMField(argsHash));
186
+ return padArrayEnd(returnValues, Fr.ZERO, RETURN_VALUES_LENGTH).map(toACVMField);
187
+ }
188
+ async enqueuePublicFunctionCall([contractAddress], [functionSelector], [argsHash], [sideffectCounter]) {
189
+ const enqueuedRequest = await this.typedOracle.enqueuePublicFunctionCall(AztecAddress.fromString(contractAddress), FunctionSelector.fromField(fromACVMField(functionSelector)), fromACVMField(argsHash), frToNumber(fromACVMField(sideffectCounter)));
190
+ return toAcvmEnqueuePublicFunctionResult(enqueuedRequest);
191
+ }
192
+ }
193
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"oracle.js","sourceRoot":"","sources":["../../../src/acvm/oracle/oracle.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,88 @@
1
+ import { CompleteAddress, L1ToL2Message, MerkleTreeId, Note, NoteStatus, NullifierMembershipWitness, PublicDataWitness, PublicKey, SiblingPath, UnencryptedL2Log } from '@aztec/circuit-types';
2
+ import { GrumpkinPrivateKey, Header, L1_TO_L2_MSG_TREE_HEIGHT, PrivateCallStackItem, PublicCallRequest } from '@aztec/circuits.js';
3
+ import { FunctionSelector } from '@aztec/foundation/abi';
4
+ import { AztecAddress } from '@aztec/foundation/aztec-address';
5
+ import { EthAddress } from '@aztec/foundation/eth-address';
6
+ import { Fr } from '@aztec/foundation/fields';
7
+ /**
8
+ * A pair of public key and secret key.
9
+ */
10
+ export interface KeyPair {
11
+ /**
12
+ * Public key.
13
+ */
14
+ publicKey: PublicKey;
15
+ /**
16
+ * Secret Key.
17
+ */
18
+ secretKey: GrumpkinPrivateKey;
19
+ }
20
+ /**
21
+ * Information about a note needed during execution.
22
+ */
23
+ export interface NoteData {
24
+ /** The note. */
25
+ note: Note;
26
+ /** The contract address of the note. */
27
+ contractAddress: AztecAddress;
28
+ /** The storage slot of the note. */
29
+ storageSlot: Fr;
30
+ /** The nonce of the note. */
31
+ nonce: Fr;
32
+ /** The inner note hash of the note. */
33
+ innerNoteHash: Fr;
34
+ /** The corresponding nullifier of the note. Undefined for pending notes. */
35
+ siloedNullifier?: Fr;
36
+ /** The note's leaf index in the note hash tree. Undefined for pending notes. */
37
+ index?: bigint;
38
+ }
39
+ export declare class MessageLoadOracleInputs<N extends number> {
40
+ /** The message. */
41
+ message: L1ToL2Message;
42
+ /** The index of the message commitment in the merkle tree. */
43
+ index: bigint;
44
+ /** The path in the merkle tree to the message. */
45
+ siblingPath: SiblingPath<N>;
46
+ constructor(
47
+ /** The message. */
48
+ message: L1ToL2Message,
49
+ /** The index of the message commitment in the merkle tree. */
50
+ index: bigint,
51
+ /** The path in the merkle tree to the message. */
52
+ siblingPath: SiblingPath<N>);
53
+ toFields(): Fr[];
54
+ }
55
+ /**
56
+ * Oracle with typed parameters and typed return values.
57
+ * Methods that require read and/or write will have to be implemented based on the context (public, private, or view)
58
+ * and are unavailable by default.
59
+ */
60
+ export declare abstract class TypedOracle {
61
+ getRandomField(): Fr;
62
+ packArguments(_args: Fr[]): Promise<Fr>;
63
+ getNullifierKeyPair(_accountAddress: AztecAddress): Promise<KeyPair>;
64
+ getPublicKeyAndPartialAddress(_address: AztecAddress): Promise<Fr[] | undefined>;
65
+ getMembershipWitness(_blockNumber: number, _treeId: MerkleTreeId, _leafValue: Fr): Promise<Fr[] | undefined>;
66
+ getSiblingPath(_blockNumber: number, _treeId: MerkleTreeId, _leafIndex: Fr): Promise<Fr[]>;
67
+ getNullifierMembershipWitness(_blockNumber: number, _nullifier: Fr): Promise<NullifierMembershipWitness | undefined>;
68
+ getPublicDataTreeWitness(_blockNumber: number, _leafSlot: Fr): Promise<PublicDataWitness | undefined>;
69
+ getLowNullifierMembershipWitness(_blockNumber: number, _nullifier: Fr): Promise<NullifierMembershipWitness | undefined>;
70
+ getHeader(_blockNumber: number): Promise<Header | undefined>;
71
+ getCompleteAddress(_address: AztecAddress): Promise<CompleteAddress>;
72
+ getAuthWitness(_messageHash: Fr): Promise<Fr[] | undefined>;
73
+ popCapsule(): Promise<Fr[]>;
74
+ getNotes(_storageSlot: Fr, _numSelects: number, _selectBy: number[], _selectValues: Fr[], _selectComparators: number[], _sortBy: number[], _sortOrder: number[], _limit: number, _offset: number, _status: NoteStatus): Promise<NoteData[]>;
75
+ notifyCreatedNote(_storageSlot: Fr, _note: Fr[], _innerNoteHash: Fr): void;
76
+ notifyNullifiedNote(_innerNullifier: Fr, _innerNoteHash: Fr): Promise<void>;
77
+ checkNullifierExists(_innerNullifier: Fr): Promise<boolean>;
78
+ getL1ToL2Message(_msgKey: Fr): Promise<MessageLoadOracleInputs<typeof L1_TO_L2_MSG_TREE_HEIGHT>>;
79
+ getPortalContractAddress(_contractAddress: AztecAddress): Promise<EthAddress>;
80
+ storageRead(_startStorageSlot: Fr, _numberOfElements: number): Promise<Fr[]>;
81
+ storageWrite(_startStorageSlot: Fr, _values: Fr[]): Promise<Fr[]>;
82
+ emitEncryptedLog(_contractAddress: AztecAddress, _storageSlot: Fr, _publicKey: PublicKey, _log: Fr[]): void;
83
+ emitUnencryptedLog(_log: UnencryptedL2Log): void;
84
+ callPrivateFunction(_targetContractAddress: AztecAddress, _functionSelector: FunctionSelector, _argsHash: Fr, _sideffectCounter: number): Promise<PrivateCallStackItem>;
85
+ callPublicFunction(_targetContractAddress: AztecAddress, _functionSelector: FunctionSelector, _argsHash: Fr): Promise<Fr[]>;
86
+ enqueuePublicFunctionCall(_targetContractAddress: AztecAddress, _functionSelector: FunctionSelector, _argsHash: Fr, _sideffectCounter: number): Promise<PublicCallRequest>;
87
+ }
88
+ //# sourceMappingURL=typed_oracle.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"typed_oracle.d.ts","sourceRoot":"","sources":["../../../src/acvm/oracle/typed_oracle.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,103 @@
1
+ import { Fr } from '@aztec/foundation/fields';
2
+ export class MessageLoadOracleInputs {
3
+ constructor(
4
+ /** The message. */
5
+ message,
6
+ /** The index of the message commitment in the merkle tree. */
7
+ index,
8
+ /** The path in the merkle tree to the message. */
9
+ siblingPath) {
10
+ this.message = message;
11
+ this.index = index;
12
+ this.siblingPath = siblingPath;
13
+ }
14
+ toFields() {
15
+ return [...this.message.toFields(), new Fr(this.index), ...this.siblingPath.toFields()];
16
+ }
17
+ }
18
+ /**
19
+ * Oracle with typed parameters and typed return values.
20
+ * Methods that require read and/or write will have to be implemented based on the context (public, private, or view)
21
+ * and are unavailable by default.
22
+ */
23
+ export class TypedOracle {
24
+ getRandomField() {
25
+ return Fr.random();
26
+ }
27
+ packArguments(_args) {
28
+ throw new Error('Not available.');
29
+ }
30
+ getNullifierKeyPair(_accountAddress) {
31
+ throw new Error('Not available.');
32
+ }
33
+ getPublicKeyAndPartialAddress(_address) {
34
+ throw new Error('Not available.');
35
+ }
36
+ getMembershipWitness(_blockNumber, _treeId, _leafValue) {
37
+ throw new Error('Not available.');
38
+ }
39
+ getSiblingPath(_blockNumber, _treeId, _leafIndex) {
40
+ throw new Error('Not available.');
41
+ }
42
+ getNullifierMembershipWitness(_blockNumber, _nullifier) {
43
+ throw new Error('Not available.');
44
+ }
45
+ getPublicDataTreeWitness(_blockNumber, _leafSlot) {
46
+ throw new Error('Not available.');
47
+ }
48
+ getLowNullifierMembershipWitness(_blockNumber, _nullifier) {
49
+ throw new Error('Not available.');
50
+ }
51
+ getHeader(_blockNumber) {
52
+ throw new Error('Not available.');
53
+ }
54
+ getCompleteAddress(_address) {
55
+ throw new Error('Not available.');
56
+ }
57
+ getAuthWitness(_messageHash) {
58
+ throw new Error('Not available.');
59
+ }
60
+ popCapsule() {
61
+ throw new Error('Not available.');
62
+ }
63
+ getNotes(_storageSlot, _numSelects, _selectBy, _selectValues, _selectComparators, _sortBy, _sortOrder, _limit, _offset, _status) {
64
+ throw new Error('Not available.');
65
+ }
66
+ notifyCreatedNote(_storageSlot, _note, _innerNoteHash) {
67
+ throw new Error('Not available.');
68
+ }
69
+ notifyNullifiedNote(_innerNullifier, _innerNoteHash) {
70
+ throw new Error('Not available.');
71
+ }
72
+ checkNullifierExists(_innerNullifier) {
73
+ throw new Error('Not available.');
74
+ }
75
+ getL1ToL2Message(_msgKey) {
76
+ throw new Error('Not available.');
77
+ }
78
+ getPortalContractAddress(_contractAddress) {
79
+ throw new Error('Not available.');
80
+ }
81
+ storageRead(_startStorageSlot, _numberOfElements) {
82
+ throw new Error('Not available.');
83
+ }
84
+ storageWrite(_startStorageSlot, _values) {
85
+ throw new Error('Not available.');
86
+ }
87
+ emitEncryptedLog(_contractAddress, _storageSlot, _publicKey, _log) {
88
+ throw new Error('Not available.');
89
+ }
90
+ emitUnencryptedLog(_log) {
91
+ throw new Error('Not available.');
92
+ }
93
+ callPrivateFunction(_targetContractAddress, _functionSelector, _argsHash, _sideffectCounter) {
94
+ throw new Error('Not available.');
95
+ }
96
+ callPublicFunction(_targetContractAddress, _functionSelector, _argsHash) {
97
+ throw new Error('Not available.');
98
+ }
99
+ enqueuePublicFunctionCall(_targetContractAddress, _functionSelector, _argsHash, _sideffectCounter) {
100
+ throw new Error('Not available.');
101
+ }
102
+ }
103
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZWRfb3JhY2xlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2Fjdm0vb3JhY2xlL3R5cGVkX29yYWNsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQkEsT0FBTyxFQUFFLEVBQUUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBb0M5QyxNQUFNLE9BQU8sdUJBQXVCO0lBQ2xDO0lBQ0UsbUJBQW1CO0lBQ1osT0FBc0I7SUFDN0IsOERBQThEO0lBQ3ZELEtBQWE7SUFDcEIsa0RBQWtEO0lBQzNDLFdBQTJCO1FBSjNCLFlBQU8sR0FBUCxPQUFPLENBQWU7UUFFdEIsVUFBSyxHQUFMLEtBQUssQ0FBUTtRQUViLGdCQUFXLEdBQVgsV0FBVyxDQUFnQjtJQUNqQyxDQUFDO0lBRUosUUFBUTtRQUNOLE9BQU8sQ0FBQyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFLEVBQUUsSUFBSSxFQUFFLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUFFLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO0lBQzFGLENBQUM7Q0FDRjtBQUVEOzs7O0dBSUc7QUFDSCxNQUFNLE9BQWdCLFdBQVc7SUFDL0IsY0FBYztRQUNaLE9BQU8sRUFBRSxDQUFDLE1BQU0sRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFFRCxhQUFhLENBQUMsS0FBVztRQUN2QixNQUFNLElBQUksS0FBSyxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFDcEMsQ0FBQztJQUVELG1CQUFtQixDQUFDLGVBQTZCO1FBQy9DLE1BQU0sSUFBSSxLQUFLLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBRUQsNkJBQTZCLENBQUMsUUFBc0I7UUFDbEQsTUFBTSxJQUFJLEtBQUssQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFFRCxvQkFBb0IsQ0FBQyxZQUFvQixFQUFFLE9BQXFCLEVBQUUsVUFBYztRQUM5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
@@ -0,0 +1,30 @@
1
+ /// <reference types="node" resolution-mode="require"/>
2
+ import { PublicCallRequest } from '@aztec/circuits.js';
3
+ import { AztecAddress } from '@aztec/foundation/aztec-address';
4
+ import { EthAddress } from '@aztec/foundation/eth-address';
5
+ import { Fr } from '@aztec/foundation/fields';
6
+ import { ACVMField } from './acvm_types.js';
7
+ /**
8
+ * Converts a value to an ACVM field.
9
+ * @param value - The value to convert.
10
+ * @returns The ACVM field.
11
+ */
12
+ export declare function toACVMField(value: AztecAddress | EthAddress | Fr | Buffer | boolean | number | bigint | ACVMField): ACVMField;
13
+ /**
14
+ * Converts a public call stack item with the request for executing a public function to
15
+ * a set of ACVM fields accepted by the enqueue_public_function_call_oracle Aztec.nr function.
16
+ * Note that only the fields related to the request are serialized: those related to the result
17
+ * are empty since this is just an execution request, so we don't send them to the circuit.
18
+ * @param item - The public call stack item to serialize to be passed onto Noir.
19
+ * @returns The fields expected by the enqueue_public_function_call_oracle Aztec.nr function.
20
+ * TODO(#4380): Nuke this and replace it with PublicCallRequest.toFields()
21
+ */
22
+ export declare function toAcvmEnqueuePublicFunctionResult(item: PublicCallRequest): ACVMField[];
23
+ /**
24
+ * Inserts a list of ACVM fields to a witness.
25
+ * @param witnessStartIndex - The index where to start inserting the fields.
26
+ * @param fields - The fields to insert.
27
+ * @returns The witness.
28
+ */
29
+ export declare function toACVMWitness(witnessStartIndex: number, fields: Parameters<typeof toACVMField>[0][]): Map<number, string>;
30
+ //# sourceMappingURL=serialize.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"serialize.d.ts","sourceRoot":"","sources":["../../src/acvm/serialize.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAC3D,OAAO,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAE9C,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAgB5C;;;;GAIG;AACH,wBAAgB,WAAW,CACzB,KAAK,EAAE,YAAY,GAAG,UAAU,GAAG,EAAE,GAAG,MAAM,GAAG,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,SAAS,GACrF,SAAS,CAYX;AAKD;;;;;;;;GAQG;AACH,wBAAgB,iCAAiC,CAAC,IAAI,EAAE,iBAAiB,GAAG,SAAS,EAAE,CAOtF;AAED;;;;;GAKG;AACH,wBAAgB,aAAa,CAAC,iBAAiB,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,CAAC,OAAO,WAAW,CAAC,CAAC,CAAC,CAAC,EAAE,uBAKnG"}
@@ -0,0 +1,67 @@
1
+ import { Fr } from '@aztec/foundation/fields';
2
+ /**
3
+ * Adapts the buffer to the field size.
4
+ * @param originalBuf - The buffer to adapt.
5
+ * @returns The adapted buffer.
6
+ */
7
+ function adaptBufferSize(originalBuf) {
8
+ const buffer = Buffer.alloc(Fr.SIZE_IN_BYTES);
9
+ if (originalBuf.length > buffer.length) {
10
+ throw new Error('Buffer does not fit in field');
11
+ }
12
+ originalBuf.copy(buffer, buffer.length - originalBuf.length);
13
+ return buffer;
14
+ }
15
+ /**
16
+ * Converts a value to an ACVM field.
17
+ * @param value - The value to convert.
18
+ * @returns The ACVM field.
19
+ */
20
+ export function toACVMField(value) {
21
+ let buffer;
22
+ if (Buffer.isBuffer(value)) {
23
+ buffer = value;
24
+ }
25
+ else if (typeof value === 'boolean' || typeof value === 'number' || typeof value === 'bigint') {
26
+ buffer = new Fr(value).toBuffer();
27
+ }
28
+ else if (typeof value === 'string') {
29
+ buffer = Fr.fromString(value).toBuffer();
30
+ }
31
+ else {
32
+ buffer = value.toBuffer();
33
+ }
34
+ return `0x${adaptBufferSize(buffer).toString('hex')}`;
35
+ }
36
+ // Utilities to write TS classes to ACVM Field arrays
37
+ // In the order that the ACVM expects them
38
+ /**
39
+ * Converts a public call stack item with the request for executing a public function to
40
+ * a set of ACVM fields accepted by the enqueue_public_function_call_oracle Aztec.nr function.
41
+ * Note that only the fields related to the request are serialized: those related to the result
42
+ * are empty since this is just an execution request, so we don't send them to the circuit.
43
+ * @param item - The public call stack item to serialize to be passed onto Noir.
44
+ * @returns The fields expected by the enqueue_public_function_call_oracle Aztec.nr function.
45
+ * TODO(#4380): Nuke this and replace it with PublicCallRequest.toFields()
46
+ */
47
+ export function toAcvmEnqueuePublicFunctionResult(item) {
48
+ return [
49
+ item.contractAddress.toField(),
50
+ ...item.functionData.toFields(),
51
+ ...item.callContext.toFields(),
52
+ item.getArgsHash(),
53
+ ].map(toACVMField);
54
+ }
55
+ /**
56
+ * Inserts a list of ACVM fields to a witness.
57
+ * @param witnessStartIndex - The index where to start inserting the fields.
58
+ * @param fields - The fields to insert.
59
+ * @returns The witness.
60
+ */
61
+ export function toACVMWitness(witnessStartIndex, fields) {
62
+ return fields.reduce((witness, field, index) => {
63
+ witness.set(index + witnessStartIndex, toACVMField(field));
64
+ return witness;
65
+ }, new Map());
66
+ }
67
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VyaWFsaXplLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2Fjdm0vc2VyaWFsaXplLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUk5Qzs7OztHQUlHO0FBQ0gsU0FBUyxlQUFlLENBQUMsV0FBbUI7SUFDMUMsTUFBTSxNQUFNLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDOUMsSUFBSSxXQUFXLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUN2QyxNQUFNLElBQUksS0FBSyxDQUFDLDhCQUE4QixDQUFDLENBQUM7SUFDbEQsQ0FBQztJQUNELFdBQVcsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLE1BQU0sQ0FBQyxNQUFNLEdBQUcsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzdELE9BQU8sTUFBTSxDQUFDO0FBQ2hCLENBQUM7QUFFRDs7OztHQUlHO0FBQ0gsTUFBTSxVQUFVLFdBQVcsQ0FDekIsS0FBc0Y7SUFFdEYsSUFBSSxNQUFNLENBQUM7SUFDWCxJQUFJLE1BQU0sQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztRQUMzQixNQUFNLEdBQUcsS0FBSyxDQUFDO0lBQ2pCLENBQUM7U0FBTSxJQUFJLE9BQU8sS0FBSyxLQUFLLFNBQVMsSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLElBQUksT0FBTyxLQUFLLEtBQUssUUFBUSxFQUFFLENBQUM7UUFDaEcsTUFBTSxHQUFHLElBQUksRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ3BDLENBQUM7U0FBTSxJQUFJLE9BQU8sS0FBSyxLQUFLLFFBQVEsRUFBRSxDQUFDO1FBQ3JDLE1BQU0sR0FBRyxFQUFFLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQzNDLENBQUM7U0FBTSxDQUFDO1FBQ04sTUFBTSxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUM1QixDQUFDO0lBQ0QsT0FBTyxLQUFLLGVBQWUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztBQUN4RCxDQUFDO0FBRUQscURBQXFEO0FBQ3JELDBDQUEwQztBQUUxQzs7Ozs7Ozs7R0FRRztBQUNILE1BQU0sVUFBVSxpQ0FBaUMsQ0FBQyxJQUF1QjtJQUN2RSxPQUFPO1FBQ0wsSUFBSSxDQUFDLGVBQWUsQ0FBQyxPQUFPLEVBQUU7UUFDOUIsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsRUFBRTtRQUMvQixHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsUUFBUSxFQUFFO1FBQzlCLElBQUksQ0FBQyxXQUFXLEVBQUU7S0FDbkIsQ0FBQyxHQUFHLENBQUMsV0FBVyxDQUFDLENBQUM7QUFDckIsQ0FBQztBQUVEOzs7OztHQUtHO0FBQ0gsTUFBTSxVQUFVLGFBQWEsQ0FBQyxpQkFBeUIsRUFBRSxNQUEyQztJQUNsRyxPQUFPLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxPQUFPLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFO1FBQzdDLE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxHQUFHLGlCQUFpQixFQUFFLFdBQVcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1FBQzNELE9BQU8sT0FBTyxDQUFDO0lBQ2pCLENBQUMsRUFBRSxJQUFJLEdBQUcsRUFBcUIsQ0FBQyxDQUFDO0FBQ25DLENBQUMifQ==
@@ -0,0 +1,49 @@
1
+ import { AztecAddress } from '@aztec/circuits.js';
2
+ import { Fr } from '@aztec/foundation/fields';
3
+ import { AvmExecutionEnvironment } from './avm_execution_environment.js';
4
+ import { AvmMachineState } from './avm_machine_state.js';
5
+ import { AvmWorldStateJournal } from './journal/journal.js';
6
+ /**
7
+ * An execution context includes the information necessary to initiate AVM
8
+ * execution along with all state maintained by the AVM throughout execution.
9
+ */
10
+ export declare class AvmContext {
11
+ worldState: AvmWorldStateJournal;
12
+ environment: AvmExecutionEnvironment;
13
+ machineState: AvmMachineState;
14
+ /**
15
+ * Create a new AVM context
16
+ * @param worldState - Manages mutable state during execution - (caching, fetching)
17
+ * @param environment - Contains constant variables provided by the kernel
18
+ * @param machineState - VM state that is modified on an instruction-by-instruction basis
19
+ * @returns new AvmContext instance
20
+ */
21
+ constructor(worldState: AvmWorldStateJournal, environment: AvmExecutionEnvironment, machineState: AvmMachineState);
22
+ /**
23
+ * Prepare a new AVM context that will be ready for an external/nested call
24
+ * - Fork the world state journal
25
+ * - Derive a machine state from the current state
26
+ * - E.g., gas metering is preserved but pc is reset
27
+ * - Derive an execution environment from the caller/parent
28
+ * - Alter both address and storageAddress
29
+ *
30
+ * @param address - The contract instance to initialize a context for
31
+ * @param calldata - Data/arguments for nested call
32
+ * @returns new AvmContext instance
33
+ */
34
+ createNestedContractCallContext(address: AztecAddress, calldata: Fr[]): AvmContext;
35
+ /**
36
+ * Prepare a new AVM context that will be ready for an external/nested static call
37
+ * - Fork the world state journal
38
+ * - Derive a machine state from the current state
39
+ * - E.g., gas metering is preserved but pc is reset
40
+ * - Derive an execution environment from the caller/parent
41
+ * - Alter both address and storageAddress
42
+ *
43
+ * @param address - The contract instance to initialize a context for
44
+ * @param calldata - Data/arguments for nested call
45
+ * @returns new AvmContext instance
46
+ */
47
+ createNestedContractStaticCallContext(address: AztecAddress, calldata: Fr[]): AvmContext;
48
+ }
49
+ //# sourceMappingURL=avm_context.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"avm_context.d.ts","sourceRoot":"","sources":["../../src/avm/avm_context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAE9C,OAAO,EAAE,uBAAuB,EAAE,MAAM,gCAAgC,CAAC;AACzE,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAE5D;;;GAGG;AACH,qBAAa,UAAU;IASZ,UAAU,EAAE,oBAAoB;IAChC,WAAW,EAAE,uBAAuB;IACpC,YAAY,EAAE,eAAe;IAVtC;;;;;;OAMG;gBAEM,UAAU,EAAE,oBAAoB,EAChC,WAAW,EAAE,uBAAuB,EACpC,YAAY,EAAE,eAAe;IAGtC;;;;;;;;;;;OAWG;IACI,+BAA+B,CAAC,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,EAAE,EAAE,GAAG,UAAU;IAOzF;;;;;;;;;;;OAWG;IACI,qCAAqC,CAAC,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,EAAE,EAAE,GAAG,UAAU;CAMhG"}
@@ -0,0 +1,56 @@
1
+ import { AvmMachineState } from './avm_machine_state.js';
2
+ /**
3
+ * An execution context includes the information necessary to initiate AVM
4
+ * execution along with all state maintained by the AVM throughout execution.
5
+ */
6
+ export class AvmContext {
7
+ /**
8
+ * Create a new AVM context
9
+ * @param worldState - Manages mutable state during execution - (caching, fetching)
10
+ * @param environment - Contains constant variables provided by the kernel
11
+ * @param machineState - VM state that is modified on an instruction-by-instruction basis
12
+ * @returns new AvmContext instance
13
+ */
14
+ constructor(worldState, environment, machineState) {
15
+ this.worldState = worldState;
16
+ this.environment = environment;
17
+ this.machineState = machineState;
18
+ }
19
+ /**
20
+ * Prepare a new AVM context that will be ready for an external/nested call
21
+ * - Fork the world state journal
22
+ * - Derive a machine state from the current state
23
+ * - E.g., gas metering is preserved but pc is reset
24
+ * - Derive an execution environment from the caller/parent
25
+ * - Alter both address and storageAddress
26
+ *
27
+ * @param address - The contract instance to initialize a context for
28
+ * @param calldata - Data/arguments for nested call
29
+ * @returns new AvmContext instance
30
+ */
31
+ createNestedContractCallContext(address, calldata) {
32
+ const newExecutionEnvironment = this.environment.deriveEnvironmentForNestedCall(address, calldata);
33
+ const forkedWorldState = this.worldState.fork();
34
+ const machineState = AvmMachineState.fromState(this.machineState);
35
+ return new AvmContext(forkedWorldState, newExecutionEnvironment, machineState);
36
+ }
37
+ /**
38
+ * Prepare a new AVM context that will be ready for an external/nested static call
39
+ * - Fork the world state journal
40
+ * - Derive a machine state from the current state
41
+ * - E.g., gas metering is preserved but pc is reset
42
+ * - Derive an execution environment from the caller/parent
43
+ * - Alter both address and storageAddress
44
+ *
45
+ * @param address - The contract instance to initialize a context for
46
+ * @param calldata - Data/arguments for nested call
47
+ * @returns new AvmContext instance
48
+ */
49
+ createNestedContractStaticCallContext(address, calldata) {
50
+ const newExecutionEnvironment = this.environment.deriveEnvironmentForNestedStaticCall(address, calldata);
51
+ const forkedWorldState = this.worldState.fork();
52
+ const machineState = AvmMachineState.fromState(this.machineState);
53
+ return new AvmContext(forkedWorldState, newExecutionEnvironment, machineState);
54
+ }
55
+ }
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXZtX2NvbnRleHQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYXZtL2F2bV9jb250ZXh0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUd6RDs7O0dBR0c7QUFDSCxNQUFNLE9BQU8sVUFBVTtJQUNyQjs7Ozs7O09BTUc7SUFDSCxZQUNTLFVBQWdDLEVBQ2hDLFdBQW9DLEVBQ3BDLFlBQTZCO1FBRjdCLGVBQVUsR0FBVixVQUFVLENBQXNCO1FBQ2hDLGdCQUFXLEdBQVgsV0FBVyxDQUF5QjtRQUNwQyxpQkFBWSxHQUFaLFlBQVksQ0FBaUI7SUFDbkMsQ0FBQztJQUVKOzs7Ozs7Ozs7OztPQVdHO0lBQ0ksK0JBQStCLENBQUMsT0FBcUIsRUFBRSxRQUFjO1FBQzFFLE1BQU0sdUJBQXVCLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyw4QkFBOEIsQ0FBQyxPQUFPLEVBQUUsUUFBUSxDQUFDLENBQUM7UUFDbkcsTUFBTSxnQkFBZ0IsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ2hELE1BQU0sWUFBWSxHQUFHLGVBQWUsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ2xFLE9BQU8sSUFBSSxVQUFVLENBQUMsZ0JBQWdCLEVBQUUsdUJBQXVCLEVBQUUsWUFBWSxDQUFDLENBQUM7SUFDakYsQ0FBQztJQUVEOzs7Ozs7Ozs7OztPQVdHO0lBQ0kscUNBQXFDLENBQUMsT0FBcUIsRUFBRSxRQUFjO1FBQ2hGLE1BQU0sdUJBQXVCLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxvQ0FBb0MsQ0FBQyxPQUFPLEVBQUUsUUFBUSxDQUFDLENBQUM7UUFDekcsTUFBTSxnQkFBZ0IsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ2hELE1BQU0sWUFBWSxHQUFHLGVBQWUsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ2xFLE9BQU8sSUFBSSxVQUFVLENBQUMsZ0JBQWdCLEVBQUUsdUJBQXVCLEVBQUUsWUFBWSxDQUFDLENBQUM7SUFDakYsQ0FBQztDQUNGIn0=