@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.
- package/README.md +47 -0
- package/dest/acvm/acvm.d.ts +39 -0
- package/dest/acvm/acvm.d.ts.map +1 -0
- package/dest/acvm/acvm.js +97 -0
- package/dest/acvm/acvm_types.d.ts +10 -0
- package/dest/acvm/acvm_types.d.ts.map +1 -0
- package/dest/acvm/acvm_types.js +2 -0
- package/dest/acvm/deserialize.d.ts +24 -0
- package/dest/acvm/deserialize.d.ts.map +1 -0
- package/dest/acvm/deserialize.js +31 -0
- package/dest/acvm/index.d.ts +6 -0
- package/dest/acvm/index.d.ts.map +1 -0
- package/dest/acvm/index.js +6 -0
- package/dest/acvm/oracle/debug.d.ts +19 -0
- package/dest/acvm/oracle/debug.d.ts.map +1 -0
- package/dest/acvm/oracle/debug.js +95 -0
- package/dest/acvm/oracle/index.d.ts +15 -0
- package/dest/acvm/oracle/index.d.ts.map +1 -0
- package/dest/acvm/oracle/index.js +4 -0
- package/dest/acvm/oracle/oracle.d.ts +38 -0
- package/dest/acvm/oracle/oracle.d.ts.map +1 -0
- package/dest/acvm/oracle/oracle.js +193 -0
- package/dest/acvm/oracle/typed_oracle.d.ts +88 -0
- package/dest/acvm/oracle/typed_oracle.d.ts.map +1 -0
- package/dest/acvm/oracle/typed_oracle.js +103 -0
- package/dest/acvm/serialize.d.ts +30 -0
- package/dest/acvm/serialize.d.ts.map +1 -0
- package/dest/acvm/serialize.js +67 -0
- package/dest/avm/avm_context.d.ts +49 -0
- package/dest/avm/avm_context.d.ts.map +1 -0
- package/dest/avm/avm_context.js +56 -0
- package/dest/avm/avm_execution_environment.d.ts +28 -0
- package/dest/avm/avm_execution_environment.d.ts.map +1 -0
- package/dest/avm/avm_execution_environment.js +42 -0
- package/dest/avm/avm_machine_state.d.ts +62 -0
- package/dest/avm/avm_machine_state.d.ts.map +1 -0
- package/dest/avm/avm_machine_state.js +69 -0
- package/dest/avm/avm_memory_types.d.ts +113 -0
- package/dest/avm/avm_memory_types.d.ts.map +1 -0
- package/dest/avm/avm_memory_types.js +269 -0
- package/dest/avm/avm_message_call_result.d.ts +16 -0
- package/dest/avm/avm_message_call_result.d.ts.map +1 -0
- package/dest/avm/avm_message_call_result.js +21 -0
- package/dest/avm/avm_simulator.d.ts +22 -0
- package/dest/avm/avm_simulator.d.ts.map +1 -0
- package/dest/avm/avm_simulator.js +74 -0
- package/dest/avm/errors.d.ts +30 -0
- package/dest/avm/errors.d.ts.map +1 -0
- package/dest/avm/errors.js +44 -0
- package/dest/avm/fixtures/index.d.ts +28 -0
- package/dest/avm/fixtures/index.d.ts.map +1 -0
- package/dest/avm/fixtures/index.js +44 -0
- package/dest/avm/journal/host_storage.d.ts +13 -0
- package/dest/avm/journal/host_storage.d.ts.map +1 -0
- package/dest/avm/journal/host_storage.js +13 -0
- package/dest/avm/journal/index.d.ts +3 -0
- package/dest/avm/journal/index.d.ts.map +1 -0
- package/dest/avm/journal/index.js +3 -0
- package/dest/avm/journal/journal.d.ts +95 -0
- package/dest/avm/journal/journal.d.ts.map +1 -0
- package/dest/avm/journal/journal.js +217 -0
- package/dest/avm/opcodes/accrued_substate.d.ts +42 -0
- package/dest/avm/opcodes/accrued_substate.d.ts.map +1 -0
- package/dest/avm/opcodes/accrued_substate.js +82 -0
- package/dest/avm/opcodes/arithmetic.d.ts +28 -0
- package/dest/avm/opcodes/arithmetic.d.ts.map +1 -0
- package/dest/avm/opcodes/arithmetic.js +59 -0
- package/dest/avm/opcodes/bitwise.d.ts +40 -0
- package/dest/avm/opcodes/bitwise.d.ts.map +1 -0
- package/dest/avm/opcodes/bitwise.js +92 -0
- package/dest/avm/opcodes/comparators.d.ts +22 -0
- package/dest/avm/opcodes/comparators.d.ts.map +1 -0
- package/dest/avm/opcodes/comparators.js +51 -0
- package/dest/avm/opcodes/control_flow.d.ts +57 -0
- package/dest/avm/opcodes/control_flow.d.ts.map +1 -0
- package/dest/avm/opcodes/control_flow.js +118 -0
- package/dest/avm/opcodes/environment_getters.d.ts +74 -0
- package/dest/avm/opcodes/environment_getters.d.ts.map +1 -0
- package/dest/avm/opcodes/environment_getters.js +151 -0
- package/dest/avm/opcodes/external_calls.d.ts +34 -0
- package/dest/avm/opcodes/external_calls.d.ts.map +1 -0
- package/dest/avm/opcodes/external_calls.js +103 -0
- package/dest/avm/opcodes/index.d.ts +11 -0
- package/dest/avm/opcodes/index.d.ts.map +1 -0
- package/dest/avm/opcodes/index.js +11 -0
- package/dest/avm/opcodes/instruction.d.ts +43 -0
- package/dest/avm/opcodes/instruction.d.ts.map +1 -0
- package/dest/avm/opcodes/instruction.js +44 -0
- package/dest/avm/opcodes/instruction_impl.d.ts +28 -0
- package/dest/avm/opcodes/instruction_impl.d.ts.map +1 -0
- package/dest/avm/opcodes/instruction_impl.js +47 -0
- package/dest/avm/opcodes/memory.d.ts +55 -0
- package/dest/avm/opcodes/memory.d.ts.map +1 -0
- package/dest/avm/opcodes/memory.js +125 -0
- package/dest/avm/opcodes/storage.d.ts +31 -0
- package/dest/avm/opcodes/storage.d.ts.map +1 -0
- package/dest/avm/opcodes/storage.js +59 -0
- package/dest/avm/serialization/buffer_cursor.d.ts +25 -0
- package/dest/avm/serialization/buffer_cursor.d.ts.map +1 -0
- package/dest/avm/serialization/buffer_cursor.js +94 -0
- package/dest/avm/serialization/bytecode_serialization.d.ts +25 -0
- package/dest/avm/serialization/bytecode_serialization.d.ts.map +1 -0
- package/dest/avm/serialization/bytecode_serialization.js +100 -0
- package/dest/avm/serialization/instruction_serialization.d.ts +91 -0
- package/dest/avm/serialization/instruction_serialization.d.ts.map +1 -0
- package/dest/avm/serialization/instruction_serialization.js +146 -0
- package/dest/client/client_execution_context.d.ts +188 -0
- package/dest/client/client_execution_context.d.ts.map +1 -0
- package/dest/client/client_execution_context.js +326 -0
- package/dest/client/db_oracle.d.ts +155 -0
- package/dest/client/db_oracle.d.ts.map +1 -0
- package/dest/client/db_oracle.js +17 -0
- package/dest/client/execution_note_cache.d.ts +54 -0
- package/dest/client/execution_note_cache.d.ts.map +1 -0
- package/dest/client/execution_note_cache.js +82 -0
- package/dest/client/execution_result.d.ts +67 -0
- package/dest/client/execution_result.d.ts.map +1 -0
- package/dest/client/execution_result.js +32 -0
- package/dest/client/index.d.ts +4 -0
- package/dest/client/index.d.ts.map +1 -0
- package/dest/client/index.js +4 -0
- package/dest/client/pick_notes.d.ts +80 -0
- package/dest/client/pick_notes.d.ts.map +1 -0
- package/dest/client/pick_notes.js +45 -0
- package/dest/client/private_execution.d.ts +10 -0
- package/dest/client/private_execution.d.ts.map +1 -0
- package/dest/client/private_execution.js +55 -0
- package/dest/client/simulator.d.ts +100 -0
- package/dest/client/simulator.d.ts.map +1 -0
- package/dest/client/simulator.js +171 -0
- package/dest/client/unconstrained_execution.d.ts +10 -0
- package/dest/client/unconstrained_execution.d.ts.map +1 -0
- package/dest/client/unconstrained_execution.js +25 -0
- package/dest/client/view_data_oracle.d.ts +139 -0
- package/dest/client/view_data_oracle.d.ts.map +1 -0
- package/dest/client/view_data_oracle.js +196 -0
- package/dest/common/errors.d.ts +36 -0
- package/dest/common/errors.d.ts.map +1 -0
- package/dest/common/errors.js +57 -0
- package/dest/common/index.d.ts +4 -0
- package/dest/common/index.d.ts.map +1 -0
- package/dest/common/index.js +4 -0
- package/dest/common/packed_args_cache.d.ts +28 -0
- package/dest/common/packed_args_cache.d.ts.map +1 -0
- package/dest/common/packed_args_cache.js +50 -0
- package/dest/common/side_effect_counter.d.ts +9 -0
- package/dest/common/side_effect_counter.d.ts.map +1 -0
- package/dest/common/side_effect_counter.js +14 -0
- package/dest/index.d.ts +4 -0
- package/dest/index.d.ts.map +1 -0
- package/dest/index.js +4 -0
- package/dest/public/db.d.ts +77 -0
- package/dest/public/db.d.ts.map +1 -0
- package/dest/public/db.js +2 -0
- package/dest/public/execution.d.ts +62 -0
- package/dest/public/execution.d.ts.map +1 -0
- package/dest/public/execution.js +61 -0
- package/dest/public/executor.d.ts +27 -0
- package/dest/public/executor.d.ts.map +1 -0
- package/dest/public/executor.js +83 -0
- package/dest/public/index.d.ts +4 -0
- package/dest/public/index.d.ts.map +1 -0
- package/dest/public/index.js +4 -0
- package/dest/public/public_execution_context.d.ts +103 -0
- package/dest/public/public_execution_context.d.ts.map +1 -0
- package/dest/public/public_execution_context.js +175 -0
- package/dest/public/state_actions.d.ts +39 -0
- package/dest/public/state_actions.d.ts.map +1 -0
- package/dest/public/state_actions.js +79 -0
- package/dest/test/utils.d.ts +12 -0
- package/dest/test/utils.d.ts.map +1 -0
- package/dest/test/utils.js +23 -0
- package/dest/utils.d.ts +27 -0
- package/dest/utils.d.ts.map +1 -0
- package/dest/utils.js +28 -0
- 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=
|