@aztec/txe 2.1.0-rc.9 → 3.0.0-devnet.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dest/bin/index.js +1 -1
- package/dest/index.d.ts.map +1 -1
- package/dest/index.js +5 -2
- package/dest/oracle/interfaces.d.ts +54 -0
- package/dest/oracle/interfaces.d.ts.map +1 -0
- package/dest/oracle/interfaces.js +3 -0
- package/dest/oracle/txe_oracle_public_context.d.ts +7 -7
- package/dest/oracle/txe_oracle_public_context.d.ts.map +1 -1
- package/dest/oracle/txe_oracle_public_context.js +29 -31
- package/dest/oracle/txe_oracle_top_level_context.d.ts +56 -0
- package/dest/oracle/txe_oracle_top_level_context.d.ts.map +1 -0
- package/dest/oracle/txe_oracle_top_level_context.js +423 -0
- package/dest/{txe_service/txe_service.d.ts → rpc_translator.d.ts} +34 -28
- package/dest/rpc_translator.d.ts.map +1 -0
- package/dest/{txe_service/txe_service.js → rpc_translator.js} +143 -115
- package/dest/state_machine/archiver.d.ts +5 -1
- package/dest/state_machine/archiver.d.ts.map +1 -1
- package/dest/state_machine/archiver.js +8 -1
- package/dest/state_machine/dummy_p2p_client.d.ts +1 -0
- package/dest/state_machine/dummy_p2p_client.d.ts.map +1 -1
- package/dest/state_machine/dummy_p2p_client.js +3 -0
- package/dest/state_machine/global_variable_builder.d.ts +1 -14
- package/dest/state_machine/global_variable_builder.d.ts.map +1 -1
- package/dest/state_machine/global_variable_builder.js +3 -22
- package/dest/state_machine/index.d.ts.map +1 -1
- package/dest/state_machine/index.js +4 -3
- package/dest/txe_session.d.ts +34 -44
- package/dest/txe_session.d.ts.map +1 -1
- package/dest/txe_session.js +197 -82
- package/dest/util/encoding.d.ts +1 -1
- package/dest/util/txe_contract_data_provider.d.ts +2 -1
- package/dest/util/txe_contract_data_provider.d.ts.map +1 -1
- package/dest/util/txe_contract_data_provider.js +1 -1
- package/dest/util/txe_public_contract_data_source.d.ts +4 -3
- package/dest/util/txe_public_contract_data_source.d.ts.map +1 -1
- package/dest/util/txe_public_contract_data_source.js +13 -11
- package/dest/utils/block_creation.d.ts +13 -0
- package/dest/utils/block_creation.d.ts.map +1 -0
- package/dest/utils/block_creation.js +24 -0
- package/dest/utils/tx_effect_creation.d.ts +5 -0
- package/dest/utils/tx_effect_creation.d.ts.map +1 -0
- package/dest/utils/tx_effect_creation.js +16 -0
- package/package.json +15 -15
- package/src/bin/index.ts +1 -1
- package/src/index.ts +5 -8
- package/src/oracle/interfaces.ts +83 -0
- package/src/oracle/txe_oracle_public_context.ts +36 -69
- package/src/oracle/txe_oracle_top_level_context.ts +658 -0
- package/src/{txe_service/txe_service.ts → rpc_translator.ts} +181 -115
- package/src/state_machine/archiver.ts +8 -2
- package/src/state_machine/dummy_p2p_client.ts +4 -0
- package/src/state_machine/global_variable_builder.ts +6 -41
- package/src/state_machine/index.ts +6 -4
- package/src/txe_session.ts +301 -90
- package/src/util/txe_contract_data_provider.ts +2 -1
- package/src/util/txe_public_contract_data_source.ts +13 -11
- package/src/utils/block_creation.ts +62 -0
- package/src/utils/tx_effect_creation.ts +37 -0
- package/dest/oracle/txe_oracle.d.ts +0 -124
- package/dest/oracle/txe_oracle.d.ts.map +0 -1
- package/dest/oracle/txe_oracle.js +0 -770
- package/dest/oracle/txe_typed_oracle.d.ts +0 -42
- package/dest/oracle/txe_typed_oracle.d.ts.map +0 -1
- package/dest/oracle/txe_typed_oracle.js +0 -83
- package/dest/txe_constants.d.ts +0 -2
- package/dest/txe_constants.d.ts.map +0 -1
- package/dest/txe_constants.js +0 -7
- package/dest/txe_service/txe_service.d.ts.map +0 -1
- package/src/oracle/txe_oracle.ts +0 -1287
- package/src/oracle/txe_typed_oracle.ts +0 -142
- package/src/txe_constants.ts +0 -9
package/dest/bin/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
#!/usr/bin/env -S node --no-warnings
|
|
2
|
-
import { createLogger } from '@aztec/aztec.js';
|
|
2
|
+
import { createLogger } from '@aztec/aztec.js/log';
|
|
3
3
|
import { startHttpRpcServer } from '@aztec/foundation/json-rpc/server';
|
|
4
4
|
import { createTXERpcServer } from '../index.js';
|
|
5
5
|
/**
|
package/dest/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAUA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AA6NpD;;;;GAIG;AACH,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,MAAM,iEAIhD"}
|
package/dest/index.js
CHANGED
|
@@ -1,5 +1,9 @@
|
|
|
1
1
|
import { SchnorrAccountContractArtifact } from '@aztec/accounts/schnorr';
|
|
2
|
-
import {
|
|
2
|
+
import { loadContractArtifact } from '@aztec/aztec.js/abi';
|
|
3
|
+
import { AztecAddress } from '@aztec/aztec.js/addresses';
|
|
4
|
+
import { getContractInstanceFromInstantiationParams } from '@aztec/aztec.js/contracts';
|
|
5
|
+
import { Fr } from '@aztec/aztec.js/fields';
|
|
6
|
+
import { PublicKeys, deriveKeys } from '@aztec/aztec.js/keys';
|
|
3
7
|
import { createSafeJsonRpcServer } from '@aztec/foundation/json-rpc/server';
|
|
4
8
|
import { protocolContractNames } from '@aztec/protocol-contracts';
|
|
5
9
|
import { BundledProtocolContractsProvider } from '@aztec/protocol-contracts/providers/bundle';
|
|
@@ -16,7 +20,6 @@ const sessions = new Map();
|
|
|
16
20
|
* TXE typically has to load the same contract artifacts over and over again for multiple tests,
|
|
17
21
|
* so we cache them here to avoid both loading them from disk repeatedly and computing their artifact hashes
|
|
18
22
|
*/ const TXEArtifactsCache = new Map();
|
|
19
|
-
// TODO: why does the zod validation in the txe dispatcher not reject invalid function names?
|
|
20
23
|
const TXEForeignCallInputSchema = z.object({
|
|
21
24
|
// eslint-disable-next-line camelcase
|
|
22
25
|
session_id: z.number().int().nonnegative(),
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import type { ContractArtifact } from '@aztec/aztec.js/abi';
|
|
2
|
+
import { CompleteAddress } from '@aztec/aztec.js/addresses';
|
|
3
|
+
import type { ContractInstanceWithAddress } from '@aztec/aztec.js/contracts';
|
|
4
|
+
import { TxHash } from '@aztec/aztec.js/tx';
|
|
5
|
+
import type { Fr } from '@aztec/foundation/fields';
|
|
6
|
+
import type { FunctionSelector } from '@aztec/stdlib/abi';
|
|
7
|
+
import type { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
8
|
+
import type { UInt32, UInt64 } from '@aztec/stdlib/types';
|
|
9
|
+
/**
|
|
10
|
+
* Oracle methods associated with the execution of an Aztec #[external("public")] function.
|
|
11
|
+
*
|
|
12
|
+
* Note that real contracts have their Brillig calls to these be transpiled into opcodes, the oracles are only executed
|
|
13
|
+
* as such when running the original Brillig code, e.g. when invoking functions that interact with a PublicContext
|
|
14
|
+
* directly in a Noir test.
|
|
15
|
+
*/
|
|
16
|
+
export interface IAvmExecutionOracle {
|
|
17
|
+
isAvm: true;
|
|
18
|
+
avmOpcodeAddress(): Promise<AztecAddress>;
|
|
19
|
+
avmOpcodeSender(): Promise<AztecAddress>;
|
|
20
|
+
avmOpcodeBlockNumber(): Promise<UInt32>;
|
|
21
|
+
avmOpcodeTimestamp(): Promise<bigint>;
|
|
22
|
+
avmOpcodeIsStaticCall(): Promise<boolean>;
|
|
23
|
+
avmOpcodeChainId(): Promise<Fr>;
|
|
24
|
+
avmOpcodeVersion(): Promise<Fr>;
|
|
25
|
+
avmOpcodeEmitNullifier(nullifier: Fr): Promise<void>;
|
|
26
|
+
avmOpcodeEmitNoteHash(noteHash: Fr): Promise<void>;
|
|
27
|
+
avmOpcodeNullifierExists(innerNullifier: Fr, targetAddress: AztecAddress): Promise<boolean>;
|
|
28
|
+
avmOpcodeStorageWrite(slot: Fr, value: Fr): Promise<void>;
|
|
29
|
+
avmOpcodeStorageRead(slot: Fr): Promise<Fr>;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Oracle methods associated with the execution of an Aztec Noir test.
|
|
33
|
+
*/
|
|
34
|
+
export interface ITxeExecutionOracle {
|
|
35
|
+
isTxe: true;
|
|
36
|
+
txeGetNextBlockNumber(): Promise<number>;
|
|
37
|
+
txeGetNextBlockTimestamp(): Promise<UInt64>;
|
|
38
|
+
txeAdvanceBlocksBy(blocks: number): Promise<void>;
|
|
39
|
+
txeAdvanceTimestampBy(duration: UInt64): void;
|
|
40
|
+
txeDeploy(artifact: ContractArtifact, instance: ContractInstanceWithAddress, foreignSecret: Fr): Promise<void>;
|
|
41
|
+
txeCreateAccount(secret: Fr): Promise<CompleteAddress>;
|
|
42
|
+
txeAddAccount(artifact: ContractArtifact, instance: ContractInstanceWithAddress, secret: Fr): Promise<CompleteAddress>;
|
|
43
|
+
txeAddAuthWitness(address: AztecAddress, messageHash: Fr): Promise<void>;
|
|
44
|
+
txeGetLastBlockTimestamp(): Promise<bigint>;
|
|
45
|
+
txeGetLastTxEffects(): Promise<{
|
|
46
|
+
txHash: TxHash;
|
|
47
|
+
noteHashes: Fr[];
|
|
48
|
+
nullifiers: Fr[];
|
|
49
|
+
}>;
|
|
50
|
+
txePrivateCallNewFlow(from: AztecAddress, targetContractAddress: AztecAddress, functionSelector: FunctionSelector, args: Fr[], argsHash: Fr, isStaticCall: boolean): Promise<Fr[]>;
|
|
51
|
+
txeSimulateUtilityFunction(targetContractAddress: AztecAddress, functionSelector: FunctionSelector, args: Fr[]): Promise<Fr[]>;
|
|
52
|
+
txePublicCallNewFlow(from: AztecAddress, targetContractAddress: AztecAddress, calldata: Fr[], isStaticCall: boolean): Promise<Fr[]>;
|
|
53
|
+
}
|
|
54
|
+
//# sourceMappingURL=interfaces.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"interfaces.d.ts","sourceRoot":"","sources":["../../src/oracle/interfaces.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,21 +1,23 @@
|
|
|
1
1
|
import { Fr } from '@aztec/foundation/fields';
|
|
2
|
-
import
|
|
2
|
+
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
3
3
|
import { L2Block } from '@aztec/stdlib/block';
|
|
4
4
|
import { type MerkleTreeWriteOperations } from '@aztec/stdlib/trees';
|
|
5
5
|
import { GlobalVariables } from '@aztec/stdlib/tx';
|
|
6
6
|
import type { UInt32 } from '@aztec/stdlib/types';
|
|
7
|
-
import {
|
|
8
|
-
export declare class TXEOraclePublicContext
|
|
7
|
+
import type { IAvmExecutionOracle } from './interfaces.js';
|
|
8
|
+
export declare class TXEOraclePublicContext implements IAvmExecutionOracle {
|
|
9
9
|
private contractAddress;
|
|
10
|
-
private
|
|
10
|
+
private forkedWorldTrees;
|
|
11
11
|
private txRequestHash;
|
|
12
12
|
private globalVariables;
|
|
13
|
+
isAvm: true;
|
|
13
14
|
private logger;
|
|
14
15
|
private transientUniqueNoteHashes;
|
|
15
16
|
private transientSiloedNullifiers;
|
|
16
17
|
private publicDataWrites;
|
|
17
|
-
constructor(contractAddress: AztecAddress,
|
|
18
|
+
constructor(contractAddress: AztecAddress, forkedWorldTrees: MerkleTreeWriteOperations, txRequestHash: Fr, globalVariables: GlobalVariables);
|
|
18
19
|
avmOpcodeAddress(): Promise<AztecAddress>;
|
|
20
|
+
avmOpcodeSender(): Promise<AztecAddress>;
|
|
19
21
|
avmOpcodeBlockNumber(): Promise<UInt32>;
|
|
20
22
|
avmOpcodeTimestamp(): Promise<bigint>;
|
|
21
23
|
avmOpcodeIsStaticCall(): Promise<boolean>;
|
|
@@ -28,7 +30,5 @@ export declare class TXEOraclePublicContext extends TXETypedOracle {
|
|
|
28
30
|
avmOpcodeStorageRead(slot: Fr): Promise<Fr>;
|
|
29
31
|
close(): Promise<L2Block>;
|
|
30
32
|
private makeTxEffect;
|
|
31
|
-
private insertSideEffectIntoWorldTrees;
|
|
32
|
-
private makeBlockHeader;
|
|
33
33
|
}
|
|
34
34
|
//# sourceMappingURL=txe_oracle_public_context.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"txe_oracle_public_context.d.ts","sourceRoot":"","sources":["../../src/oracle/txe_oracle_public_context.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"txe_oracle_public_context.d.ts","sourceRoot":"","sources":["../../src/oracle/txe_oracle_public_context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAG9C,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAC3D,OAAO,EAAQ,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAGpD,OAAO,EAEL,KAAK,yBAAyB,EAG/B,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,eAAe,EAAoB,MAAM,kBAAkB,CAAC;AACrE,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAGlD,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AAE3D,qBAAa,sBAAuB,YAAW,mBAAmB;IAS9D,OAAO,CAAC,eAAe;IACvB,OAAO,CAAC,gBAAgB;IACxB,OAAO,CAAC,aAAa;IACrB,OAAO,CAAC,eAAe;IAXzB,KAAK,EAAG,IAAI,CAAU;IAEtB,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,yBAAyB,CAAY;IAC7C,OAAO,CAAC,yBAAyB,CAAY;IAC7C,OAAO,CAAC,gBAAgB,CAAyB;gBAGvC,eAAe,EAAE,YAAY,EAC7B,gBAAgB,EAAE,yBAAyB,EAC3C,aAAa,EAAE,EAAE,EACjB,eAAe,EAAE,eAAe;IAW1C,gBAAgB,IAAI,OAAO,CAAC,YAAY,CAAC;IAIzC,eAAe,IAAI,OAAO,CAAC,YAAY,CAAC;IAIxC,oBAAoB,IAAI,OAAO,CAAC,MAAM,CAAC;IAIvC,kBAAkB,IAAI,OAAO,CAAC,MAAM,CAAC;IAIrC,qBAAqB,IAAI,OAAO,CAAC,OAAO,CAAC;IAIzC,gBAAgB,IAAI,OAAO,CAAC,EAAE,CAAC;IAI/B,gBAAgB,IAAI,OAAO,CAAC,EAAE,CAAC;IAIzB,sBAAsB,CAAC,SAAS,EAAE,EAAE;IAKpC,qBAAqB,CAAC,QAAQ,EAAE,EAAE;IAMlC,wBAAwB,CAAC,cAAc,EAAE,EAAE,EAAE,aAAa,EAAE,YAAY,GAAG,OAAO,CAAC,OAAO,CAAC;IAW3F,qBAAqB,CAAC,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE;IAYzC,oBAAoB,CAAC,IAAI,EAAE,EAAE,GAAG,OAAO,CAAC,EAAE,CAAC;IAuB3C,KAAK,IAAI,OAAO,CAAC,OAAO,CAAC;IAwB/B,OAAO,CAAC,YAAY;CAarB"}
|
|
@@ -1,27 +1,34 @@
|
|
|
1
|
-
import { MAX_NOTE_HASHES_PER_TX, MAX_NULLIFIERS_PER_TX, NULLIFIER_SUBTREE_HEIGHT, NUMBER_OF_L1_L2_MESSAGES_PER_ROLLUP } from '@aztec/constants';
|
|
2
|
-
import { padArrayEnd } from '@aztec/foundation/collection';
|
|
3
1
|
import { Fr } from '@aztec/foundation/fields';
|
|
4
2
|
import { createLogger } from '@aztec/foundation/log';
|
|
5
3
|
import { PublicDataWrite } from '@aztec/stdlib/avm';
|
|
4
|
+
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
6
5
|
import { Body, L2Block } from '@aztec/stdlib/block';
|
|
7
6
|
import { computePublicDataTreeLeafSlot, siloNoteHash, siloNullifier } from '@aztec/stdlib/hash';
|
|
8
|
-
import { makeAppendOnlyTreeSnapshot
|
|
9
|
-
import {
|
|
10
|
-
import {
|
|
11
|
-
import {
|
|
12
|
-
export class TXEOraclePublicContext
|
|
7
|
+
import { makeAppendOnlyTreeSnapshot } from '@aztec/stdlib/testing';
|
|
8
|
+
import { MerkleTreeId, PublicDataTreeLeaf } from '@aztec/stdlib/trees';
|
|
9
|
+
import { TxEffect, TxHash } from '@aztec/stdlib/tx';
|
|
10
|
+
import { insertTxEffectIntoWorldTrees, makeTXEBlockHeader } from '../utils/block_creation.js';
|
|
11
|
+
export class TXEOraclePublicContext {
|
|
13
12
|
contractAddress;
|
|
14
|
-
|
|
13
|
+
forkedWorldTrees;
|
|
15
14
|
txRequestHash;
|
|
16
15
|
globalVariables;
|
|
16
|
+
isAvm;
|
|
17
17
|
logger;
|
|
18
18
|
transientUniqueNoteHashes;
|
|
19
19
|
transientSiloedNullifiers;
|
|
20
20
|
publicDataWrites;
|
|
21
|
-
constructor(contractAddress,
|
|
22
|
-
|
|
21
|
+
constructor(contractAddress, forkedWorldTrees, txRequestHash, globalVariables){
|
|
22
|
+
this.contractAddress = contractAddress;
|
|
23
|
+
this.forkedWorldTrees = forkedWorldTrees;
|
|
24
|
+
this.txRequestHash = txRequestHash;
|
|
25
|
+
this.globalVariables = globalVariables;
|
|
26
|
+
this.isAvm = true;
|
|
27
|
+
this.transientUniqueNoteHashes = [];
|
|
28
|
+
this.transientSiloedNullifiers = [];
|
|
29
|
+
this.publicDataWrites = [];
|
|
23
30
|
this.logger = createLogger('txe:public_context');
|
|
24
|
-
this.logger.debug('Entering
|
|
31
|
+
this.logger.debug('Entering Public Context', {
|
|
25
32
|
contractAddress,
|
|
26
33
|
blockNumber: globalVariables.blockNumber,
|
|
27
34
|
timestamp: globalVariables.timestamp
|
|
@@ -30,6 +37,9 @@ export class TXEOraclePublicContext extends TXETypedOracle {
|
|
|
30
37
|
avmOpcodeAddress() {
|
|
31
38
|
return Promise.resolve(this.contractAddress);
|
|
32
39
|
}
|
|
40
|
+
avmOpcodeSender() {
|
|
41
|
+
return Promise.resolve(AztecAddress.ZERO); // todo: change?
|
|
42
|
+
}
|
|
33
43
|
avmOpcodeBlockNumber() {
|
|
34
44
|
return Promise.resolve(this.globalVariables.blockNumber);
|
|
35
45
|
}
|
|
@@ -56,7 +66,7 @@ export class TXEOraclePublicContext extends TXETypedOracle {
|
|
|
56
66
|
}
|
|
57
67
|
async avmOpcodeNullifierExists(innerNullifier, targetAddress) {
|
|
58
68
|
const nullifier = await siloNullifier(targetAddress, innerNullifier);
|
|
59
|
-
const treeIndex = (await this.
|
|
69
|
+
const treeIndex = (await this.forkedWorldTrees.findLeafIndices(MerkleTreeId.NULLIFIER_TREE, [
|
|
60
70
|
nullifier.toBuffer()
|
|
61
71
|
]))[0];
|
|
62
72
|
const transientIndex = this.transientSiloedNullifiers.find((n)=>n.equals(nullifier));
|
|
@@ -69,14 +79,14 @@ export class TXEOraclePublicContext extends TXETypedOracle {
|
|
|
69
79
|
});
|
|
70
80
|
const dataWrite = new PublicDataWrite(await computePublicDataTreeLeafSlot(this.contractAddress, slot), value);
|
|
71
81
|
this.publicDataWrites.push(dataWrite);
|
|
72
|
-
await this.
|
|
82
|
+
await this.forkedWorldTrees.sequentialInsert(MerkleTreeId.PUBLIC_DATA_TREE, [
|
|
73
83
|
new PublicDataTreeLeaf(dataWrite.leafSlot, dataWrite.value).toBuffer()
|
|
74
84
|
]);
|
|
75
85
|
}
|
|
76
86
|
async avmOpcodeStorageRead(slot) {
|
|
77
87
|
const leafSlot = await computePublicDataTreeLeafSlot(this.contractAddress, slot);
|
|
78
|
-
const lowLeafResult = await this.
|
|
79
|
-
const value = !lowLeafResult || !lowLeafResult.alreadyPresent ? Fr.ZERO : (await this.
|
|
88
|
+
const lowLeafResult = await this.forkedWorldTrees.getPreviousValueIndex(MerkleTreeId.PUBLIC_DATA_TREE, leafSlot.toBigInt());
|
|
89
|
+
const value = !lowLeafResult || !lowLeafResult.alreadyPresent ? Fr.ZERO : (await this.forkedWorldTrees.getLeafPreimage(MerkleTreeId.PUBLIC_DATA_TREE, lowLeafResult.index)).leaf.value;
|
|
80
90
|
this.logger.debug('AVM storage read', {
|
|
81
91
|
slot,
|
|
82
92
|
value
|
|
@@ -84,15 +94,15 @@ export class TXEOraclePublicContext extends TXETypedOracle {
|
|
|
84
94
|
return value;
|
|
85
95
|
}
|
|
86
96
|
async close() {
|
|
87
|
-
this.logger.debug('Exiting
|
|
97
|
+
this.logger.debug('Exiting Public Context, building block with collected side effects', {
|
|
88
98
|
blockNumber: this.globalVariables.blockNumber
|
|
89
99
|
});
|
|
90
100
|
const txEffect = this.makeTxEffect();
|
|
91
|
-
await this.
|
|
92
|
-
const block = new L2Block(makeAppendOnlyTreeSnapshot(
|
|
101
|
+
await insertTxEffectIntoWorldTrees(txEffect, this.forkedWorldTrees);
|
|
102
|
+
const block = new L2Block(makeAppendOnlyTreeSnapshot(), await makeTXEBlockHeader(this.forkedWorldTrees, this.globalVariables), new Body([
|
|
93
103
|
txEffect
|
|
94
104
|
]));
|
|
95
|
-
await this.
|
|
105
|
+
await this.forkedWorldTrees.close();
|
|
96
106
|
this.logger.debug('Exited PublicContext with built block', {
|
|
97
107
|
blockNumber: block.number,
|
|
98
108
|
txEffects: block.body.txEffects
|
|
@@ -111,16 +121,4 @@ export class TXEOraclePublicContext extends TXETypedOracle {
|
|
|
111
121
|
txEffect.txHash = new TxHash(new Fr(this.globalVariables.blockNumber));
|
|
112
122
|
return txEffect;
|
|
113
123
|
}
|
|
114
|
-
async insertSideEffectIntoWorldTrees(txEffect) {
|
|
115
|
-
const l1ToL2Messages = Array(NUMBER_OF_L1_L2_MESSAGES_PER_ROLLUP).fill(0).map(Fr.zero);
|
|
116
|
-
await this.worldTrees.appendLeaves(MerkleTreeId.NOTE_HASH_TREE, padArrayEnd(txEffect.noteHashes, Fr.ZERO, MAX_NOTE_HASHES_PER_TX));
|
|
117
|
-
await this.worldTrees.appendLeaves(MerkleTreeId.L1_TO_L2_MESSAGE_TREE, l1ToL2Messages);
|
|
118
|
-
// We do not need to add public data writes because we apply them as we go.
|
|
119
|
-
await this.worldTrees.batchInsert(MerkleTreeId.NULLIFIER_TREE, padArrayEnd(txEffect.nullifiers, Fr.ZERO, MAX_NULLIFIERS_PER_TX).map((nullifier)=>nullifier.toBuffer()), NULLIFIER_SUBTREE_HEIGHT);
|
|
120
|
-
}
|
|
121
|
-
async makeBlockHeader() {
|
|
122
|
-
const stateReference = await this.worldTrees.getStateReference();
|
|
123
|
-
const archiveInfo = await this.worldTrees.getTreeInfo(MerkleTreeId.ARCHIVE);
|
|
124
|
-
return new BlockHeader(new AppendOnlyTreeSnapshot(new Fr(archiveInfo.root), Number(archiveInfo.size)), makeContentCommitment(), stateReference, this.globalVariables, Fr.ZERO, Fr.ZERO);
|
|
125
|
-
}
|
|
126
124
|
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { Fr } from '@aztec/foundation/fields';
|
|
2
|
+
import type { KeyStore } from '@aztec/key-store';
|
|
3
|
+
import { AddressDataProvider, PXEOracleInterface } from '@aztec/pxe/server';
|
|
4
|
+
import { type IMiscOracle } from '@aztec/pxe/simulator';
|
|
5
|
+
import { type ContractArtifact, FunctionSelector } from '@aztec/stdlib/abi';
|
|
6
|
+
import { AuthWitness } from '@aztec/stdlib/auth-witness';
|
|
7
|
+
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
8
|
+
import { type ContractInstanceWithAddress } from '@aztec/stdlib/contract';
|
|
9
|
+
import { TxHash } from '@aztec/stdlib/tx';
|
|
10
|
+
import type { UInt64 } from '@aztec/stdlib/types';
|
|
11
|
+
import type { TXEStateMachine } from '../state_machine/index.js';
|
|
12
|
+
import type { TXEAccountDataProvider } from '../util/txe_account_data_provider.js';
|
|
13
|
+
import type { TXEContractDataProvider } from '../util/txe_contract_data_provider.js';
|
|
14
|
+
import type { ITxeExecutionOracle } from './interfaces.js';
|
|
15
|
+
export declare class TXEOracleTopLevelContext implements IMiscOracle, ITxeExecutionOracle {
|
|
16
|
+
private stateMachine;
|
|
17
|
+
private contractDataProvider;
|
|
18
|
+
private keyStore;
|
|
19
|
+
private addressDataProvider;
|
|
20
|
+
private accountDataProvider;
|
|
21
|
+
private pxeOracleInterface;
|
|
22
|
+
private nextBlockTimestamp;
|
|
23
|
+
private version;
|
|
24
|
+
private chainId;
|
|
25
|
+
private authwits;
|
|
26
|
+
isMisc: true;
|
|
27
|
+
isTxe: true;
|
|
28
|
+
private logger;
|
|
29
|
+
constructor(stateMachine: TXEStateMachine, contractDataProvider: TXEContractDataProvider, keyStore: KeyStore, addressDataProvider: AddressDataProvider, accountDataProvider: TXEAccountDataProvider, pxeOracleInterface: PXEOracleInterface, nextBlockTimestamp: bigint, version: Fr, chainId: Fr, authwits: Map<string, AuthWitness>);
|
|
30
|
+
utilityAssertCompatibleOracleVersion(version: number): void;
|
|
31
|
+
utilityGetRandomField(): Fr;
|
|
32
|
+
utilityDebugLog(level: number, message: string, fields: Fr[]): void;
|
|
33
|
+
txeGetNextBlockNumber(): Promise<number>;
|
|
34
|
+
txeGetNextBlockTimestamp(): Promise<bigint>;
|
|
35
|
+
txeGetLastBlockTimestamp(): Promise<bigint>;
|
|
36
|
+
txeGetLastTxEffects(): Promise<{
|
|
37
|
+
txHash: TxHash;
|
|
38
|
+
noteHashes: Fr[];
|
|
39
|
+
nullifiers: Fr[];
|
|
40
|
+
}>;
|
|
41
|
+
txeAdvanceBlocksBy(blocks: number): Promise<void>;
|
|
42
|
+
txeAdvanceTimestampBy(duration: UInt64): void;
|
|
43
|
+
txeDeploy(artifact: ContractArtifact, instance: ContractInstanceWithAddress, secret: Fr): Promise<void>;
|
|
44
|
+
txeAddAccount(artifact: ContractArtifact, instance: ContractInstanceWithAddress, secret: Fr): Promise<import("@aztec/stdlib/contract").CompleteAddress>;
|
|
45
|
+
txeCreateAccount(secret: Fr): Promise<import("@aztec/stdlib/contract").CompleteAddress>;
|
|
46
|
+
txeAddAuthWitness(address: AztecAddress, messageHash: Fr): Promise<void>;
|
|
47
|
+
mineBlock(options?: {
|
|
48
|
+
nullifiers?: Fr[];
|
|
49
|
+
}): Promise<void>;
|
|
50
|
+
txePrivateCallNewFlow(from: AztecAddress, targetContractAddress: AztecAddress | undefined, functionSelector: FunctionSelector | undefined, args: Fr[], argsHash?: Fr, isStaticCall?: boolean): Promise<Fr[]>;
|
|
51
|
+
txePublicCallNewFlow(from: AztecAddress, targetContractAddress: AztecAddress, calldata: Fr[], isStaticCall: boolean): Promise<Fr[]>;
|
|
52
|
+
txeSimulateUtilityFunction(targetContractAddress: AztecAddress, functionSelector: FunctionSelector, args: Fr[]): Promise<Fr[]>;
|
|
53
|
+
close(): [bigint, Map<string, AuthWitness>];
|
|
54
|
+
private getLastBlockNumber;
|
|
55
|
+
}
|
|
56
|
+
//# sourceMappingURL=txe_oracle_top_level_context.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"txe_oracle_top_level_context.d.ts","sourceRoot":"","sources":["../../src/oracle/txe_oracle_top_level_context.ts"],"names":[],"mappings":"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"}
|