@aztec/world-state 0.1.0-alpha43 → 0.1.0-alpha45
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/.tsbuildinfo +1 -1
- package/dest/merkle-tree/merkle_tree_operations_facade.d.ts +14 -5
- package/dest/merkle-tree/merkle_tree_operations_facade.d.ts.map +1 -1
- package/dest/merkle-tree/merkle_tree_operations_facade.js +20 -6
- package/dest/synchroniser/server_world_state_synchroniser.d.ts +14 -5
- package/dest/synchroniser/server_world_state_synchroniser.d.ts.map +1 -1
- package/dest/synchroniser/server_world_state_synchroniser.js +55 -14
- package/dest/synchroniser/server_world_state_synchroniser.test.js +112 -5
- package/dest/synchroniser/world_state_synchroniser.d.ts +6 -5
- package/dest/synchroniser/world_state_synchroniser.d.ts.map +1 -1
- package/dest/synchroniser/world_state_synchroniser.js +1 -1
- package/dest/world-state-db/index.d.ts +14 -5
- package/dest/world-state-db/index.d.ts.map +1 -1
- package/dest/world-state-db/index.js +1 -1
- package/dest/world-state-db/merkle_trees.d.ts +20 -6
- package/dest/world-state-db/merkle_trees.d.ts.map +1 -1
- package/dest/world-state-db/merkle_trees.js +51 -16
- package/package.json +5 -5
- package/src/merkle-tree/merkle_tree_operations_facade.ts +23 -7
- package/src/synchroniser/server_world_state_synchroniser.test.ts +148 -7
- package/src/synchroniser/server_world_state_synchroniser.ts +61 -14
- package/src/synchroniser/world_state_synchroniser.ts +7 -7
- package/src/world-state-db/index.ts +17 -5
- package/src/world-state-db/merkle_trees.ts +60 -16
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/// <reference types="node" resolution-mode="require"/>
|
|
2
|
-
import { Fr
|
|
2
|
+
import { Fr } from '@aztec/circuits.js';
|
|
3
3
|
import { IWasmModule } from '@aztec/foundation/wasm';
|
|
4
4
|
import { LeafData, LowLeafWitnessData } from '@aztec/merkle-tree';
|
|
5
5
|
import { L2Block, MerkleTreeId, SiblingPath } from '@aztec/types';
|
|
@@ -12,6 +12,7 @@ export declare class MerkleTrees implements MerkleTreeDb {
|
|
|
12
12
|
private db;
|
|
13
13
|
private log;
|
|
14
14
|
private trees;
|
|
15
|
+
private latestGlobalVariablesHash;
|
|
15
16
|
private jobQueue;
|
|
16
17
|
constructor(db: levelup.LevelUp, log?: import("@aztec/foundation/log").DebugLogger);
|
|
17
18
|
/**
|
|
@@ -43,10 +44,20 @@ export declare class MerkleTrees implements MerkleTreeDb {
|
|
|
43
44
|
/**
|
|
44
45
|
* Inserts into the roots trees (CONTRACT_TREE_ROOTS_TREE, PRIVATE_DATA_TREE_ROOTS_TREE, L1_TO_L2_MESSAGES_TREE_ROOTS_TREE)
|
|
45
46
|
* the current roots of the corresponding trees (CONTRACT_TREE, PRIVATE_DATA_TREE, L1_TO_L2_MESSAGES_TREE).
|
|
46
|
-
* @param
|
|
47
|
+
* @param globalsHash - The current global variables hash.
|
|
47
48
|
* @param includeUncommitted - Indicates whether to include uncommitted data.
|
|
48
49
|
*/
|
|
49
|
-
updateHistoricBlocksTree(
|
|
50
|
+
updateHistoricBlocksTree(globalsHash: Fr, includeUncommitted: boolean): Promise<void>;
|
|
51
|
+
/**
|
|
52
|
+
* Updates the latest global variables hash
|
|
53
|
+
* @param globalVariablesHash - The latest global variables hash
|
|
54
|
+
*/
|
|
55
|
+
updateLatestGlobalVariablesHash(globalVariablesHash: Fr): Promise<void>;
|
|
56
|
+
/**
|
|
57
|
+
* Gets the global variables hash from the previous block
|
|
58
|
+
* @param includeUncommitted - Indicates whether to include uncommitted data.
|
|
59
|
+
*/
|
|
60
|
+
getLatestGlobalVariablesHash(includeUncommitted: boolean): Promise<Fr>;
|
|
50
61
|
/**
|
|
51
62
|
* Gets the tree info for the specified tree.
|
|
52
63
|
* @param treeId - Id of the tree to get information from.
|
|
@@ -59,9 +70,9 @@ export declare class MerkleTrees implements MerkleTreeDb {
|
|
|
59
70
|
* @param includeUncommitted - Indicates whether to include uncommitted data.
|
|
60
71
|
* @returns The current roots of the trees.
|
|
61
72
|
*/
|
|
62
|
-
getTreeRoots(includeUncommitted: boolean): CurrentTreeRoots
|
|
63
|
-
|
|
64
|
-
|
|
73
|
+
getTreeRoots(includeUncommitted: boolean): Promise<CurrentTreeRoots>;
|
|
74
|
+
private _getCurrentBlockHash;
|
|
75
|
+
private _getAllTreeRoots;
|
|
65
76
|
/**
|
|
66
77
|
* Gets the value at the given index.
|
|
67
78
|
* @param treeId - The ID of the tree to get the leaf value from.
|
|
@@ -155,6 +166,9 @@ export declare class MerkleTrees implements MerkleTreeDb {
|
|
|
155
166
|
* @returns Promise containing the result of the function.
|
|
156
167
|
*/
|
|
157
168
|
private synchronise;
|
|
169
|
+
private _updateLatestGlobalVariablesHash;
|
|
170
|
+
private _getGlobalVariablesHash;
|
|
171
|
+
private _updateHistoricBlocksTree;
|
|
158
172
|
/**
|
|
159
173
|
* Returns the tree info for the specified tree id.
|
|
160
174
|
* @param treeId - Id of the tree to get information from.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"merkle_trees.d.ts","sourceRoot":"","sources":["../../src/world-state-db/merkle_trees.ts"],"names":[],"mappings":";AAAA,OAAO,EAIL,EAAE,
|
|
1
|
+
{"version":3,"file":"merkle_trees.d.ts","sourceRoot":"","sources":["../../src/world-state-db/merkle_trees.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
import { BaseRollupInputs, CONTRACT_TREE_HEIGHT, CircuitsWasm, Fr, GlobalVariables, HISTORIC_BLOCKS_TREE_HEIGHT, L1_TO_L2_MSG_TREE_HEIGHT, NULLIFIER_TREE_HEIGHT, PRIVATE_DATA_TREE_HEIGHT, PUBLIC_DATA_TREE_HEIGHT, } from '@aztec/circuits.js';
|
|
2
|
-
import {
|
|
2
|
+
import { computeBlockHash } from '@aztec/circuits.js/abis';
|
|
3
|
+
import { Committable } from '@aztec/foundation/committable';
|
|
3
4
|
import { SerialQueue } from '@aztec/foundation/fifo';
|
|
4
5
|
import { createDebugLogger } from '@aztec/foundation/log';
|
|
5
6
|
import { Pedersen, SparseTree, StandardIndexedTree, StandardTree, newTree, } from '@aztec/merkle-tree';
|
|
6
7
|
import { MerkleTreeId, merkleTreeIds } from '@aztec/types';
|
|
7
8
|
import { MerkleTreeOperationsFacade } from '../merkle-tree/merkle_tree_operations_facade.js';
|
|
9
|
+
import { computeGlobalVariablesHash } from '../utils.js';
|
|
8
10
|
import { INITIAL_NULLIFIER_TREE_SIZE, } from './index.js';
|
|
9
11
|
/**
|
|
10
12
|
* A convenience class for managing multiple merkle trees.
|
|
@@ -15,6 +17,7 @@ export class MerkleTrees {
|
|
|
15
17
|
this.log = log;
|
|
16
18
|
this.trees = [];
|
|
17
19
|
this.jobQueue = new SerialQueue();
|
|
20
|
+
this.latestGlobalVariablesHash = new Committable(Fr.zero());
|
|
18
21
|
}
|
|
19
22
|
/**
|
|
20
23
|
* Initialises the collection of Merkle Trees.
|
|
@@ -32,8 +35,10 @@ export class MerkleTrees {
|
|
|
32
35
|
this.trees = [contractTree, nullifierTree, privateDataTree, publicDataTree, l1Tol2MessagesTree, historicBlocksTree];
|
|
33
36
|
this.jobQueue.start();
|
|
34
37
|
// The first leaf in the blocks tree contains the empty roots of the other trees and empty global variables.
|
|
35
|
-
await
|
|
36
|
-
await
|
|
38
|
+
const initialGlobalVariablesHash = await computeGlobalVariablesHash(GlobalVariables.empty());
|
|
39
|
+
await this._updateLatestGlobalVariablesHash(initialGlobalVariablesHash);
|
|
40
|
+
await this._updateHistoricBlocksTree(initialGlobalVariablesHash, true);
|
|
41
|
+
await this._commit();
|
|
37
42
|
}
|
|
38
43
|
/**
|
|
39
44
|
* Method to asynchronously create and initialise a MerkleTrees instance.
|
|
@@ -69,12 +74,25 @@ export class MerkleTrees {
|
|
|
69
74
|
/**
|
|
70
75
|
* Inserts into the roots trees (CONTRACT_TREE_ROOTS_TREE, PRIVATE_DATA_TREE_ROOTS_TREE, L1_TO_L2_MESSAGES_TREE_ROOTS_TREE)
|
|
71
76
|
* the current roots of the corresponding trees (CONTRACT_TREE, PRIVATE_DATA_TREE, L1_TO_L2_MESSAGES_TREE).
|
|
72
|
-
* @param
|
|
77
|
+
* @param globalsHash - The current global variables hash.
|
|
73
78
|
* @param includeUncommitted - Indicates whether to include uncommitted data.
|
|
74
79
|
*/
|
|
75
|
-
async updateHistoricBlocksTree(
|
|
76
|
-
|
|
77
|
-
|
|
80
|
+
async updateHistoricBlocksTree(globalsHash, includeUncommitted) {
|
|
81
|
+
await this.synchronise(() => this._updateHistoricBlocksTree(globalsHash, includeUncommitted));
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Updates the latest global variables hash
|
|
85
|
+
* @param globalVariablesHash - The latest global variables hash
|
|
86
|
+
*/
|
|
87
|
+
async updateLatestGlobalVariablesHash(globalVariablesHash) {
|
|
88
|
+
return await this.synchronise(() => this._updateLatestGlobalVariablesHash(globalVariablesHash));
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Gets the global variables hash from the previous block
|
|
92
|
+
* @param includeUncommitted - Indicates whether to include uncommitted data.
|
|
93
|
+
*/
|
|
94
|
+
async getLatestGlobalVariablesHash(includeUncommitted) {
|
|
95
|
+
return await this.synchronise(() => this._getGlobalVariablesHash(includeUncommitted));
|
|
78
96
|
}
|
|
79
97
|
/**
|
|
80
98
|
* Gets the tree info for the specified tree.
|
|
@@ -90,8 +108,8 @@ export class MerkleTrees {
|
|
|
90
108
|
* @param includeUncommitted - Indicates whether to include uncommitted data.
|
|
91
109
|
* @returns The current roots of the trees.
|
|
92
110
|
*/
|
|
93
|
-
getTreeRoots(includeUncommitted) {
|
|
94
|
-
const roots = this.
|
|
111
|
+
async getTreeRoots(includeUncommitted) {
|
|
112
|
+
const roots = await this.synchronise(() => Promise.resolve(this._getAllTreeRoots(includeUncommitted)));
|
|
95
113
|
return {
|
|
96
114
|
privateDataTreeRoot: roots[0],
|
|
97
115
|
nullifierTreeRoot: roots[1],
|
|
@@ -101,13 +119,13 @@ export class MerkleTrees {
|
|
|
101
119
|
blocksTreeRoot: roots[5],
|
|
102
120
|
};
|
|
103
121
|
}
|
|
104
|
-
async
|
|
105
|
-
const roots = this.
|
|
122
|
+
async _getCurrentBlockHash(globalsHash, includeUncommitted) {
|
|
123
|
+
const roots = (await this._getAllTreeRoots(includeUncommitted)).map(root => Fr.fromBuffer(root));
|
|
106
124
|
const wasm = await CircuitsWasm.get();
|
|
107
|
-
return
|
|
125
|
+
return computeBlockHash(wasm, globalsHash, roots[0], roots[1], roots[2], roots[3], roots[4]);
|
|
108
126
|
}
|
|
109
|
-
|
|
110
|
-
|
|
127
|
+
_getAllTreeRoots(includeUncommitted) {
|
|
128
|
+
const roots = [
|
|
111
129
|
MerkleTreeId.PRIVATE_DATA_TREE,
|
|
112
130
|
MerkleTreeId.NULLIFIER_TREE,
|
|
113
131
|
MerkleTreeId.CONTRACT_TREE,
|
|
@@ -115,6 +133,7 @@ export class MerkleTrees {
|
|
|
115
133
|
MerkleTreeId.PUBLIC_DATA_TREE,
|
|
116
134
|
MerkleTreeId.BLOCKS_TREE,
|
|
117
135
|
].map(tree => this.trees[tree].getRoot(includeUncommitted));
|
|
136
|
+
return Promise.resolve(roots);
|
|
118
137
|
}
|
|
119
138
|
/**
|
|
120
139
|
* Gets the value at the given index.
|
|
@@ -237,6 +256,17 @@ export class MerkleTrees {
|
|
|
237
256
|
async synchronise(fn) {
|
|
238
257
|
return await this.jobQueue.put(fn);
|
|
239
258
|
}
|
|
259
|
+
_updateLatestGlobalVariablesHash(globalVariablesHash) {
|
|
260
|
+
this.latestGlobalVariablesHash.set(globalVariablesHash);
|
|
261
|
+
return Promise.resolve();
|
|
262
|
+
}
|
|
263
|
+
_getGlobalVariablesHash(includeUncommitted) {
|
|
264
|
+
return Promise.resolve(this.latestGlobalVariablesHash.get(includeUncommitted));
|
|
265
|
+
}
|
|
266
|
+
async _updateHistoricBlocksTree(globalsHash, includeUncommitted) {
|
|
267
|
+
const blockHash = await this._getCurrentBlockHash(globalsHash, includeUncommitted);
|
|
268
|
+
await this._appendLeaves(MerkleTreeId.BLOCKS_TREE, [blockHash.toBuffer()]);
|
|
269
|
+
}
|
|
240
270
|
/**
|
|
241
271
|
* Returns the tree info for the specified tree id.
|
|
242
272
|
* @param treeId - Id of the tree to get information from.
|
|
@@ -298,6 +328,7 @@ export class MerkleTrees {
|
|
|
298
328
|
for (const tree of this.trees) {
|
|
299
329
|
await tree.commit();
|
|
300
330
|
}
|
|
331
|
+
this.latestGlobalVariablesHash.commit();
|
|
301
332
|
}
|
|
302
333
|
/**
|
|
303
334
|
* Rolls back all pending updates.
|
|
@@ -307,6 +338,7 @@ export class MerkleTrees {
|
|
|
307
338
|
for (const tree of this.trees) {
|
|
308
339
|
await tree.rollback();
|
|
309
340
|
}
|
|
341
|
+
this.latestGlobalVariablesHash.rollback();
|
|
310
342
|
}
|
|
311
343
|
/**
|
|
312
344
|
* Handles a single L2 block (i.e. Inserts the new commitments into the merkle tree).
|
|
@@ -351,7 +383,10 @@ export class MerkleTrees {
|
|
|
351
383
|
await this._updateLeaf(MerkleTreeId.PUBLIC_DATA_TREE, newValue.toBuffer(), leafIndex.value);
|
|
352
384
|
}
|
|
353
385
|
// Sync and add the block to the historic blocks tree
|
|
354
|
-
const
|
|
386
|
+
const globalVariablesHash = await computeGlobalVariablesHash(l2Block.globalVariables);
|
|
387
|
+
await this._updateLatestGlobalVariablesHash(globalVariablesHash);
|
|
388
|
+
this.log(`Synced global variables with hash ${this.latestGlobalVariablesHash.toString()}`);
|
|
389
|
+
const blockHash = await this._getCurrentBlockHash(globalVariablesHash, true);
|
|
355
390
|
await this._appendLeaves(MerkleTreeId.BLOCKS_TREE, [blockHash.toBuffer()]);
|
|
356
391
|
await this._commit();
|
|
357
392
|
}
|
|
@@ -361,4 +396,4 @@ export class MerkleTrees {
|
|
|
361
396
|
}
|
|
362
397
|
}
|
|
363
398
|
}
|
|
364
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"merkle_trees.js","sourceRoot":"","sources":["../../src/world-state-db/merkle_trees.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,gBAAgB,EAChB,oBAAoB,EACpB,YAAY,EACZ,EAAE,EACF,eAAe,EACf,2BAA2B,EAC3B,wBAAwB,EACxB,qBAAqB,EACrB,wBAAwB,EACxB,uBAAuB,GACxB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,2BAA2B,EAAE,MAAM,yBAAyB,CAAC;AACtE,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AACrD,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAE1D,OAAO,EAKL,QAAQ,EACR,UAAU,EACV,mBAAmB,EACnB,YAAY,EAEZ,OAAO,GACR,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAW,YAAY,EAAe,aAAa,EAAE,MAAM,cAAc,CAAC;AAIjF,OAAO,EAAE,0BAA0B,EAAE,MAAM,iDAAiD,CAAC;AAC7F,OAAO,EAEL,2BAA2B,GAM5B,MAAM,YAAY,CAAC;AAEpB;;GAEG;AACH,MAAM,OAAO,WAAW;IAItB,YAAoB,EAAmB,EAAU,MAAM,iBAAiB,CAAC,oBAAoB,CAAC;QAA1E,OAAE,GAAF,EAAE,CAAiB;QAAU,QAAG,GAAH,GAAG,CAA0C;QAHtF,UAAK,GAAwC,EAAE,CAAC;QAChD,aAAQ,GAAG,IAAI,WAAW,EAAE,CAAC;IAE4D,CAAC;IAElG;;;OAGG;IACI,KAAK,CAAC,IAAI,CAAC,YAA0B;QAC1C,MAAM,IAAI,GAAG,YAAY,IAAI,CAAC,MAAM,YAAY,CAAC,GAAG,EAAE,CAAC,CAAC;QACxD,MAAM,MAAM,GAAG,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAC;QAClC,MAAM,YAAY,GAAmB,MAAM,OAAO,CAChD,YAAY,EACZ,IAAI,CAAC,EAAE,EACP,MAAM,EACN,GAAG,YAAY,CAAC,YAAY,CAAC,aAAa,CAAC,EAAE,EAC7C,oBAAoB,CACrB,CAAC;QACF,MAAM,aAAa,GAAG,MAAM,OAAO,CACjC,mBAAmB,EACnB,IAAI,CAAC,EAAE,EACP,MAAM,EACN,GAAG,YAAY,CAAC,YAAY,CAAC,cAAc,CAAC,EAAE,EAC9C,qBAAqB,EACrB,2BAA2B,CAC5B,CAAC;QACF,MAAM,eAAe,GAAmB,MAAM,OAAO,CACnD,YAAY,EACZ,IAAI,CAAC,EAAE,EACP,MAAM,EACN,GAAG,YAAY,CAAC,YAAY,CAAC,iBAAiB,CAAC,EAAE,EACjD,wBAAwB,CACzB,CAAC;QACF,MAAM,cAAc,GAAmB,MAAM,OAAO,CAClD,UAAU,EACV,IAAI,CAAC,EAAE,EACP,MAAM,EACN,GAAG,YAAY,CAAC,YAAY,CAAC,gBAAgB,CAAC,EAAE,EAChD,uBAAuB,CACxB,CAAC;QACF,MAAM,kBAAkB,GAAmB,MAAM,OAAO,CACtD,YAAY,EACZ,IAAI,CAAC,EAAE,EACP,MAAM,EACN,GAAG,YAAY,CAAC,YAAY,CAAC,sBAAsB,CAAC,EAAE,EACtD,wBAAwB,CACzB,CAAC;QACF,MAAM,kBAAkB,GAAmB,MAAM,OAAO,CACtD,YAAY,EACZ,IAAI,CAAC,EAAE,EACP,MAAM,EACN,GAAG,YAAY,CAAC,YAAY,CAAC,WAAW,CAAC,EAAE,EAC3C,2BAA2B,CAC5B,CAAC;QACF,IAAI,CAAC,KAAK,GAAG,CAAC,YAAY,EAAE,aAAa,EAAE,eAAe,EAAE,cAAc,EAAE,kBAAkB,EAAE,kBAAkB,CAAC,CAAC;QAEpH,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;QAEtB,4GAA4G;QAC5G,MAAM,IAAI,CAAC,wBAAwB,CAAC,eAAe,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,CAAC;QACnE,MAAM,kBAAkB,CAAC,MAAM,EAAE,CAAC;IACpC,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,EAAmB,EAAE,IAAkB;QAC7D,MAAM,WAAW,GAAG,IAAI,WAAW,CAAC,EAAE,CAAC,CAAC;QACxC,MAAM,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC7B,OAAO,WAAW,CAAC;IACrB,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,IAAI;QACf,MAAM,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC;IAC5B,CAAC;IAED;;;OAGG;IACI,QAAQ;QACb,OAAO,IAAI,0BAA0B,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACpD,CAAC;IAED;;;OAGG;IACI,WAAW;QAChB,OAAO,IAAI,0BAA0B,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IACrD,CAAC;IAED;;;;;OAKG;IACI,KAAK,CAAC,wBAAwB,CAAC,OAAwB,EAAE,kBAA2B;QACzF,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,mBAAmB,CAAC,OAAO,EAAE,kBAAkB,CAAC,CAAC;QAC9E,MAAM,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;IAC5E,CAAC;IAED;;;;;OAKG;IACI,KAAK,CAAC,WAAW,CAAC,MAAoB,EAAE,kBAA2B;QACxE,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,kBAAkB,CAAC,CAAC,CAAC;IACrF,CAAC;IAED;;;;OAIG;IACI,YAAY,CAAC,kBAA2B;QAC7C,MAAM,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC;QAEvD,OAAO;YACL,mBAAmB,EAAE,KAAK,CAAC,CAAC,CAAC;YAC7B,iBAAiB,EAAE,KAAK,CAAC,CAAC,CAAC;YAC3B,oBAAoB,EAAE,KAAK,CAAC,CAAC,CAAC;YAC9B,sBAAsB,EAAE,KAAK,CAAC,CAAC,CAAC;YAChC,kBAAkB,EAAE,KAAK,CAAC,CAAC,CAAC;YAC5B,cAAc,EAAE,KAAK,CAAC,CAAC,CAAC;SACzB,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,mBAAmB,CAAC,OAAwB,EAAE,kBAA2B;QAC7E,MAAM,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC;QACxF,MAAM,IAAI,GAAG,MAAM,YAAY,CAAC,GAAG,EAAE,CAAC;QACtC,OAAO,2BAA2B,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IACtG,CAAC;IAED,eAAe,CAAC,kBAA2B;QACzC,OAAO;YACL,YAAY,CAAC,iBAAiB;YAC9B,YAAY,CAAC,cAAc;YAC3B,YAAY,CAAC,aAAa;YAC1B,YAAY,CAAC,sBAAsB;YACnC,YAAY,CAAC,gBAAgB;YAC7B,YAAY,CAAC,WAAW;SACzB,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC,CAAC;IAC9D,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,YAAY,CACvB,MAAoB,EACpB,KAAa,EACb,kBAA2B;QAE3B,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC,KAAK,EAAE,kBAAkB,CAAC,CAAC,CAAC;IAClG,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,cAAc,CACzB,MAAoB,EACpB,KAAa,EACb,kBAA2B;QAE3B,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,KAAK,EAAE,kBAAkB,CAAC,CAAC,CAAC;IAC/F,CAAC;IAED;;;;;OAKG;IACI,KAAK,CAAC,YAAY,CAAC,MAAoB,EAAE,MAAgB;QAC9D,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC;IAC1E,CAAC;IAED;;;OAGG;IACI,KAAK,CAAC,MAAM;QACjB,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;IACtD,CAAC;IAED;;;OAGG;IACI,KAAK,CAAC,QAAQ;QACnB,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;IACxD,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,qBAAqB,CAChC,MAAqB,EACrB,KAAa,EACb,kBAA2B;QAW3B,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CACjC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,wBAAwB,CAAC,KAAK,EAAE,kBAAkB,CAAC,CAAC,CAClG,CAAC;IACJ,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,WAAW,CACtB,MAAqB,EACrB,KAAa,EACb,kBAA2B;QAE3B,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CACjC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,qBAAqB,CAAC,KAAK,EAAE,kBAAkB,CAAC,CAAC,CAC/F,CAAC;IACJ,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,aAAa,CACxB,MAAoB,EACpB,KAAa,EACb,kBAA2B;QAE3B,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,KAAK,IAAI,EAAE;YACvC,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YAChC,KAAK,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,kBAAkB,CAAC,EAAE,CAAC,EAAE,EAAE;gBAC/D,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,CAAC,EAAE,kBAAkB,CAAC,CAAC;gBACpE,IAAI,YAAY,IAAI,YAAY,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;oBAC9C,OAAO,CAAC,CAAC;iBACV;aACF;YACD,OAAO,SAAS,CAAC;QACnB,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,UAAU,CAAC,MAAoC,EAAE,IAAuB,EAAE,KAAa;QAClG,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC;IAC7E,CAAC;IAED;;;OAGG;IACI,KAAK,CAAC,aAAa,CAAC,KAAc;QACvC,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC;IAC3D,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,WAAW,CAKtB,MAAoB,EACpB,MAAgB,EAChB,aAA4B;QAK5B,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAwB,CAAC;QACvD,IAAI,CAAC,CAAC,aAAa,IAAI,IAAI,CAAC,EAAE;YAC5B,MAAM,IAAI,KAAK,CAAC,4CAA4C,CAAC,CAAC;SAC/D;QACD,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC,CAAC;IAC/E,CAAC;IAED;;;;OAIG;IACK,KAAK,CAAC,WAAW,CAAI,EAAoB;QAC/C,OAAO,MAAM,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IACrC,CAAC;IAED;;;;;OAKG;IACK,YAAY,CAAC,MAAoB,EAAE,kBAA2B;QACpE,MAAM,QAAQ,GAAG;YACf,MAAM;YACN,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,kBAAkB,CAAC;YACpD,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC,kBAAkB,CAAC;YACzD,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE;SACzB,CAAC;QACd,OAAO,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IACnC,CAAC;IAED;;;;OAIG;IACK,eAAe,CAAC,MAAqB;QAC3C,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAgB,CAAC;IAC3C,CAAC;IAED;;;;;;OAMG;IACK,eAAe,CACrB,MAAoB,EACpB,KAAa,EACb,kBAA2B;QAE3B,OAAO,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,cAAc,CAAI,KAAK,EAAE,kBAAkB,CAAC,CAAC,CAAC;IAC1F,CAAC;IAED;;;;;OAKG;IACK,KAAK,CAAC,aAAa,CAAC,MAAoB,EAAE,MAAgB;QAChE,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAChC,IAAI,CAAC,CAAC,cAAc,IAAI,IAAI,CAAC,EAAE;YAC7B,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAC;SAChE;QACD,OAAO,MAAM,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;IACzC,CAAC;IAEO,KAAK,CAAC,WAAW,CACvB,MAAoC,EACpC,IAAuB,EACvB,KAAa;QAEb,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAChC,IAAI,CAAC,CAAC,YAAY,IAAI,IAAI,CAAC,EAAE;YAC3B,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;SAC9D;QACD,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IAC5C,CAAC;IAED;;;OAGG;IACK,KAAK,CAAC,OAAO;QACnB,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE;YAC7B,MAAM,IAAI,CAAC,MAAM,EAAE,CAAC;SACrB;IACH,CAAC;IAED;;;OAGG;IACK,KAAK,CAAC,SAAS;QACrB,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE;YAC7B,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC;SACvB;IACH,CAAC;IAED;;;OAGG;IACK,KAAK,CAAC,cAAc,CAAC,OAAgB;QAC3C,MAAM,WAAW,GAAG,CAAC,IAAQ,EAAE,MAAoB,EAAE,EAAE;YACrD,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YAClD,OAAO,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC1C,CAAC,CAAC;QACF,MAAM,UAAU,GAAG;YACjB,WAAW,CAAC,OAAO,CAAC,uBAAuB,CAAC,IAAI,EAAE,YAAY,CAAC,aAAa,CAAC;YAC7E,WAAW,CAAC,OAAO,CAAC,wBAAwB,CAAC,IAAI,EAAE,YAAY,CAAC,cAAc,CAAC;YAC/E,WAAW,CAAC,OAAO,CAAC,0BAA0B,CAAC,IAAI,EAAE,YAAY,CAAC,iBAAiB,CAAC;YACpF,WAAW,CAAC,OAAO,CAAC,qBAAqB,EAAE,YAAY,CAAC,gBAAgB,CAAC;YACzE,WAAW,CAAC,OAAO,CAAC,4BAA4B,CAAC,IAAI,EAAE,YAAY,CAAC,sBAAsB,CAAC;YAC3F,WAAW,CAAC,OAAO,CAAC,6BAA6B,CAAC,IAAI,EAAE,YAAY,CAAC,WAAW,CAAC;SAClF,CAAC;QACF,MAAM,QAAQ,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1C,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,GAAG,CAAC,SAAS,OAAO,CAAC,MAAM,oCAAoC,CAAC,CAAC;YACtE,MAAM,IAAI,CAAC,OAAO,EAAE,CAAC;SACtB;aAAM;YACL,IAAI,CAAC,GAAG,CAAC,SAAS,OAAO,CAAC,MAAM,0EAA0E,CAAC,CAAC;YAC5G,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC;YAEvB,6BAA6B;YAC7B,KAAK,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI;gBAC3B,CAAC,YAAY,CAAC,aAAa,EAAE,OAAO,CAAC,YAAY,CAAC;gBAClD,CAAC,YAAY,CAAC,iBAAiB,EAAE,OAAO,CAAC,cAAc,CAAC;gBACxD,CAAC,YAAY,CAAC,sBAAsB,EAAE,OAAO,CAAC,iBAAiB,CAAC;aACxD,EAAE;gBACV,MAAM,IAAI,CAAC,aAAa,CACtB,IAAI,EACJ,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,CAChC,CAAC;aACH;YAED,yBAAyB;YACzB,MAAO,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,cAAc,CAAyB,CAAC,WAAW,CAChF,OAAO,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,EAC9C,gBAAgB,CAAC,wBAAwB,CAC1C,CAAC;YAEF,4BAA4B;YAC5B,KAAK,MAAM,SAAS,IAAI,OAAO,CAAC,mBAAmB,EAAE;gBACnD,IAAI,SAAS,CAAC,OAAO,EAAE;oBAAE,SAAS;gBAClC,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,SAAS,CAAC;gBAC1C,MAAM,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,gBAAgB,EAAE,QAAQ,CAAC,QAAQ,EAAE,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC;aAC7F;YAED,qDAAqD;YACrD,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;YAChF,MAAM,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;YAE3E,MAAM,IAAI,CAAC,OAAO,EAAE,CAAC;SACtB;QACD,KAAK,MAAM,MAAM,IAAI,aAAa,EAAE,EAAE;YACpC,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;YACpD,IAAI,CAAC,GAAG,CAAC,QAAQ,YAAY,CAAC,MAAM,CAAC,sBAAsB,IAAI,CAAC,IAAI,SAAS,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;SAC3G;IACH,CAAC;CACF"}
|
|
399
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"merkle_trees.js","sourceRoot":"","sources":["../../src/world-state-db/merkle_trees.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,gBAAgB,EAChB,oBAAoB,EACpB,YAAY,EACZ,EAAE,EACF,eAAe,EACf,2BAA2B,EAC3B,wBAAwB,EACxB,qBAAqB,EACrB,wBAAwB,EACxB,uBAAuB,GACxB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAC3D,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5D,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AACrD,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAE1D,OAAO,EAKL,QAAQ,EACR,UAAU,EACV,mBAAmB,EACnB,YAAY,EAEZ,OAAO,GACR,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAW,YAAY,EAAe,aAAa,EAAE,MAAM,cAAc,CAAC;AAIjF,OAAO,EAAE,0BAA0B,EAAE,MAAM,iDAAiD,CAAC;AAC7F,OAAO,EAAE,0BAA0B,EAAE,MAAM,aAAa,CAAC;AACzD,OAAO,EAEL,2BAA2B,GAM5B,MAAM,YAAY,CAAC;AAEpB;;GAEG;AACH,MAAM,OAAO,WAAW;IAKtB,YAAoB,EAAmB,EAAU,MAAM,iBAAiB,CAAC,oBAAoB,CAAC;QAA1E,OAAE,GAAF,EAAE,CAAiB;QAAU,QAAG,GAAH,GAAG,CAA0C;QAJtF,UAAK,GAAwC,EAAE,CAAC;QAEhD,aAAQ,GAAG,IAAI,WAAW,EAAE,CAAC;QAGnC,IAAI,CAAC,yBAAyB,GAAG,IAAI,WAAW,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;IAC9D,CAAC;IAED;;;OAGG;IACI,KAAK,CAAC,IAAI,CAAC,YAA0B;QAC1C,MAAM,IAAI,GAAG,YAAY,IAAI,CAAC,MAAM,YAAY,CAAC,GAAG,EAAE,CAAC,CAAC;QACxD,MAAM,MAAM,GAAG,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAC;QAClC,MAAM,YAAY,GAAmB,MAAM,OAAO,CAChD,YAAY,EACZ,IAAI,CAAC,EAAE,EACP,MAAM,EACN,GAAG,YAAY,CAAC,YAAY,CAAC,aAAa,CAAC,EAAE,EAC7C,oBAAoB,CACrB,CAAC;QACF,MAAM,aAAa,GAAG,MAAM,OAAO,CACjC,mBAAmB,EACnB,IAAI,CAAC,EAAE,EACP,MAAM,EACN,GAAG,YAAY,CAAC,YAAY,CAAC,cAAc,CAAC,EAAE,EAC9C,qBAAqB,EACrB,2BAA2B,CAC5B,CAAC;QACF,MAAM,eAAe,GAAmB,MAAM,OAAO,CACnD,YAAY,EACZ,IAAI,CAAC,EAAE,EACP,MAAM,EACN,GAAG,YAAY,CAAC,YAAY,CAAC,iBAAiB,CAAC,EAAE,EACjD,wBAAwB,CACzB,CAAC;QACF,MAAM,cAAc,GAAmB,MAAM,OAAO,CAClD,UAAU,EACV,IAAI,CAAC,EAAE,EACP,MAAM,EACN,GAAG,YAAY,CAAC,YAAY,CAAC,gBAAgB,CAAC,EAAE,EAChD,uBAAuB,CACxB,CAAC;QACF,MAAM,kBAAkB,GAAmB,MAAM,OAAO,CACtD,YAAY,EACZ,IAAI,CAAC,EAAE,EACP,MAAM,EACN,GAAG,YAAY,CAAC,YAAY,CAAC,sBAAsB,CAAC,EAAE,EACtD,wBAAwB,CACzB,CAAC;QACF,MAAM,kBAAkB,GAAmB,MAAM,OAAO,CACtD,YAAY,EACZ,IAAI,CAAC,EAAE,EACP,MAAM,EACN,GAAG,YAAY,CAAC,YAAY,CAAC,WAAW,CAAC,EAAE,EAC3C,2BAA2B,CAC5B,CAAC;QACF,IAAI,CAAC,KAAK,GAAG,CAAC,YAAY,EAAE,aAAa,EAAE,eAAe,EAAE,cAAc,EAAE,kBAAkB,EAAE,kBAAkB,CAAC,CAAC;QAEpH,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;QAEtB,4GAA4G;QAC5G,MAAM,0BAA0B,GAAG,MAAM,0BAA0B,CAAC,eAAe,CAAC,KAAK,EAAE,CAAC,CAAC;QAC7F,MAAM,IAAI,CAAC,gCAAgC,CAAC,0BAA0B,CAAC,CAAC;QACxE,MAAM,IAAI,CAAC,yBAAyB,CAAC,0BAA0B,EAAE,IAAI,CAAC,CAAC;QACvE,MAAM,IAAI,CAAC,OAAO,EAAE,CAAC;IACvB,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,EAAmB,EAAE,IAAkB;QAC7D,MAAM,WAAW,GAAG,IAAI,WAAW,CAAC,EAAE,CAAC,CAAC;QACxC,MAAM,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC7B,OAAO,WAAW,CAAC;IACrB,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,IAAI;QACf,MAAM,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC;IAC5B,CAAC;IAED;;;OAGG;IACI,QAAQ;QACb,OAAO,IAAI,0BAA0B,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACpD,CAAC;IAED;;;OAGG;IACI,WAAW;QAChB,OAAO,IAAI,0BAA0B,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IACrD,CAAC;IAED;;;;;OAKG;IACI,KAAK,CAAC,wBAAwB,CAAC,WAAe,EAAE,kBAA2B;QAChF,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,yBAAyB,CAAC,WAAW,EAAE,kBAAkB,CAAC,CAAC,CAAC;IAChG,CAAC;IAED;;;OAGG;IACI,KAAK,CAAC,+BAA+B,CAAC,mBAAuB;QAClE,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,gCAAgC,CAAC,mBAAmB,CAAC,CAAC,CAAC;IAClG,CAAC;IAED;;;OAGG;IACI,KAAK,CAAC,4BAA4B,CAAC,kBAA2B;QACnE,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,uBAAuB,CAAC,kBAAkB,CAAC,CAAC,CAAC;IACxF,CAAC;IAED;;;;;OAKG;IACI,KAAK,CAAC,WAAW,CAAC,MAAoB,EAAE,kBAA2B;QACxE,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,kBAAkB,CAAC,CAAC,CAAC;IACrF,CAAC;IAED;;;;OAIG;IACI,KAAK,CAAC,YAAY,CAAC,kBAA2B;QACnD,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC;QAEvG,OAAO;YACL,mBAAmB,EAAE,KAAK,CAAC,CAAC,CAAC;YAC7B,iBAAiB,EAAE,KAAK,CAAC,CAAC,CAAC;YAC3B,oBAAoB,EAAE,KAAK,CAAC,CAAC,CAAC;YAC9B,sBAAsB,EAAE,KAAK,CAAC,CAAC,CAAC;YAChC,kBAAkB,EAAE,KAAK,CAAC,CAAC,CAAC;YAC5B,cAAc,EAAE,KAAK,CAAC,CAAC,CAAC;SACzB,CAAC;IACJ,CAAC;IAEO,KAAK,CAAC,oBAAoB,CAAC,WAAe,EAAE,kBAA2B;QAC7E,MAAM,KAAK,GAAG,CAAC,MAAM,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC;QACjG,MAAM,IAAI,GAAG,MAAM,YAAY,CAAC,GAAG,EAAE,CAAC;QACtC,OAAO,gBAAgB,CAAC,IAAI,EAAE,WAAW,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/F,CAAC;IAEO,gBAAgB,CAAC,kBAA2B;QAClD,MAAM,KAAK,GAAG;YACZ,YAAY,CAAC,iBAAiB;YAC9B,YAAY,CAAC,cAAc;YAC3B,YAAY,CAAC,aAAa;YAC1B,YAAY,CAAC,sBAAsB;YACnC,YAAY,CAAC,gBAAgB;YAC7B,YAAY,CAAC,WAAW;SACzB,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC,CAAC;QAE5D,OAAO,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,YAAY,CACvB,MAAoB,EACpB,KAAa,EACb,kBAA2B;QAE3B,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC,KAAK,EAAE,kBAAkB,CAAC,CAAC,CAAC;IAClG,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,cAAc,CACzB,MAAoB,EACpB,KAAa,EACb,kBAA2B;QAE3B,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,KAAK,EAAE,kBAAkB,CAAC,CAAC,CAAC;IAC/F,CAAC;IAED;;;;;OAKG;IACI,KAAK,CAAC,YAAY,CAAC,MAAoB,EAAE,MAAgB;QAC9D,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC;IAC1E,CAAC;IAED;;;OAGG;IACI,KAAK,CAAC,MAAM;QACjB,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;IACtD,CAAC;IAED;;;OAGG;IACI,KAAK,CAAC,QAAQ;QACnB,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;IACxD,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,qBAAqB,CAChC,MAAqB,EACrB,KAAa,EACb,kBAA2B;QAW3B,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CACjC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,wBAAwB,CAAC,KAAK,EAAE,kBAAkB,CAAC,CAAC,CAClG,CAAC;IACJ,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,WAAW,CACtB,MAAqB,EACrB,KAAa,EACb,kBAA2B;QAE3B,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CACjC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,qBAAqB,CAAC,KAAK,EAAE,kBAAkB,CAAC,CAAC,CAC/F,CAAC;IACJ,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,aAAa,CACxB,MAAoB,EACpB,KAAa,EACb,kBAA2B;QAE3B,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,KAAK,IAAI,EAAE;YACvC,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YAChC,KAAK,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,kBAAkB,CAAC,EAAE,CAAC,EAAE,EAAE;gBAC/D,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,CAAC,EAAE,kBAAkB,CAAC,CAAC;gBACpE,IAAI,YAAY,IAAI,YAAY,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;oBAC9C,OAAO,CAAC,CAAC;iBACV;aACF;YACD,OAAO,SAAS,CAAC;QACnB,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,UAAU,CAAC,MAAoC,EAAE,IAAuB,EAAE,KAAa;QAClG,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC;IAC7E,CAAC;IAED;;;OAGG;IACI,KAAK,CAAC,aAAa,CAAC,KAAc;QACvC,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC;IAC3D,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,WAAW,CAKtB,MAAoB,EACpB,MAAgB,EAChB,aAA4B;QAK5B,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAwB,CAAC;QACvD,IAAI,CAAC,CAAC,aAAa,IAAI,IAAI,CAAC,EAAE;YAC5B,MAAM,IAAI,KAAK,CAAC,4CAA4C,CAAC,CAAC;SAC/D;QACD,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC,CAAC;IAC/E,CAAC;IAED;;;;OAIG;IACK,KAAK,CAAC,WAAW,CAAI,EAAoB;QAC/C,OAAO,MAAM,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IACrC,CAAC;IAEO,gCAAgC,CAAC,mBAAuB;QAC9D,IAAI,CAAC,yBAAyB,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;QACxD,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;IAC3B,CAAC;IAEO,uBAAuB,CAAC,kBAA2B;QACzD,OAAO,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,yBAAyB,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC,CAAC;IACjF,CAAC;IAEO,KAAK,CAAC,yBAAyB,CAAC,WAAe,EAAE,kBAA2B;QAClF,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,WAAW,EAAE,kBAAkB,CAAC,CAAC;QACnF,MAAM,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;IAC7E,CAAC;IAED;;;;;OAKG;IACK,YAAY,CAAC,MAAoB,EAAE,kBAA2B;QACpE,MAAM,QAAQ,GAAG;YACf,MAAM;YACN,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,kBAAkB,CAAC;YACpD,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC,kBAAkB,CAAC;YACzD,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE;SACzB,CAAC;QACd,OAAO,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IACnC,CAAC;IAED;;;;OAIG;IACK,eAAe,CAAC,MAAqB;QAC3C,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAgB,CAAC;IAC3C,CAAC;IAED;;;;;;OAMG;IACK,eAAe,CACrB,MAAoB,EACpB,KAAa,EACb,kBAA2B;QAE3B,OAAO,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,cAAc,CAAI,KAAK,EAAE,kBAAkB,CAAC,CAAC,CAAC;IAC1F,CAAC;IAED;;;;;OAKG;IACK,KAAK,CAAC,aAAa,CAAC,MAAoB,EAAE,MAAgB;QAChE,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAChC,IAAI,CAAC,CAAC,cAAc,IAAI,IAAI,CAAC,EAAE;YAC7B,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAC;SAChE;QACD,OAAO,MAAM,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;IACzC,CAAC;IAEO,KAAK,CAAC,WAAW,CACvB,MAAoC,EACpC,IAAuB,EACvB,KAAa;QAEb,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAChC,IAAI,CAAC,CAAC,YAAY,IAAI,IAAI,CAAC,EAAE;YAC3B,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;SAC9D;QACD,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IAC5C,CAAC;IAED;;;OAGG;IACK,KAAK,CAAC,OAAO;QACnB,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE;YAC7B,MAAM,IAAI,CAAC,MAAM,EAAE,CAAC;SACrB;QACD,IAAI,CAAC,yBAAyB,CAAC,MAAM,EAAE,CAAC;IAC1C,CAAC;IAED;;;OAGG;IACK,KAAK,CAAC,SAAS;QACrB,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE;YAC7B,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC;SACvB;QACD,IAAI,CAAC,yBAAyB,CAAC,QAAQ,EAAE,CAAC;IAC5C,CAAC;IAED;;;OAGG;IACK,KAAK,CAAC,cAAc,CAAC,OAAgB;QAC3C,MAAM,WAAW,GAAG,CAAC,IAAQ,EAAE,MAAoB,EAAE,EAAE;YACrD,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YAClD,OAAO,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC1C,CAAC,CAAC;QACF,MAAM,UAAU,GAAG;YACjB,WAAW,CAAC,OAAO,CAAC,uBAAuB,CAAC,IAAI,EAAE,YAAY,CAAC,aAAa,CAAC;YAC7E,WAAW,CAAC,OAAO,CAAC,wBAAwB,CAAC,IAAI,EAAE,YAAY,CAAC,cAAc,CAAC;YAC/E,WAAW,CAAC,OAAO,CAAC,0BAA0B,CAAC,IAAI,EAAE,YAAY,CAAC,iBAAiB,CAAC;YACpF,WAAW,CAAC,OAAO,CAAC,qBAAqB,EAAE,YAAY,CAAC,gBAAgB,CAAC;YACzE,WAAW,CAAC,OAAO,CAAC,4BAA4B,CAAC,IAAI,EAAE,YAAY,CAAC,sBAAsB,CAAC;YAC3F,WAAW,CAAC,OAAO,CAAC,6BAA6B,CAAC,IAAI,EAAE,YAAY,CAAC,WAAW,CAAC;SAClF,CAAC;QACF,MAAM,QAAQ,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1C,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,GAAG,CAAC,SAAS,OAAO,CAAC,MAAM,oCAAoC,CAAC,CAAC;YACtE,MAAM,IAAI,CAAC,OAAO,EAAE,CAAC;SACtB;aAAM;YACL,IAAI,CAAC,GAAG,CAAC,SAAS,OAAO,CAAC,MAAM,0EAA0E,CAAC,CAAC;YAC5G,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC;YAEvB,6BAA6B;YAC7B,KAAK,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI;gBAC3B,CAAC,YAAY,CAAC,aAAa,EAAE,OAAO,CAAC,YAAY,CAAC;gBAClD,CAAC,YAAY,CAAC,iBAAiB,EAAE,OAAO,CAAC,cAAc,CAAC;gBACxD,CAAC,YAAY,CAAC,sBAAsB,EAAE,OAAO,CAAC,iBAAiB,CAAC;aACxD,EAAE;gBACV,MAAM,IAAI,CAAC,aAAa,CACtB,IAAI,EACJ,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,CAChC,CAAC;aACH;YAED,yBAAyB;YACzB,MAAO,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,cAAc,CAAyB,CAAC,WAAW,CAChF,OAAO,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,EAC9C,gBAAgB,CAAC,wBAAwB,CAC1C,CAAC;YAEF,4BAA4B;YAC5B,KAAK,MAAM,SAAS,IAAI,OAAO,CAAC,mBAAmB,EAAE;gBACnD,IAAI,SAAS,CAAC,OAAO,EAAE;oBAAE,SAAS;gBAClC,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,SAAS,CAAC;gBAC1C,MAAM,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,gBAAgB,EAAE,QAAQ,CAAC,QAAQ,EAAE,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC;aAC7F;YAED,qDAAqD;YACrD,MAAM,mBAAmB,GAAG,MAAM,0BAA0B,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;YACtF,MAAM,IAAI,CAAC,gCAAgC,CAAC,mBAAmB,CAAC,CAAC;YACjE,IAAI,CAAC,GAAG,CAAC,qCAAqC,IAAI,CAAC,yBAAyB,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;YAE3F,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,mBAAmB,EAAE,IAAI,CAAC,CAAC;YAC7E,MAAM,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;YAE3E,MAAM,IAAI,CAAC,OAAO,EAAE,CAAC;SACtB;QACD,KAAK,MAAM,MAAM,IAAI,aAAa,EAAE,EAAE;YACpC,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;YACpD,IAAI,CAAC,GAAG,CAAC,QAAQ,YAAY,CAAC,MAAM,CAAC,sBAAsB,IAAI,CAAC,IAAI,SAAS,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;SAC3G;IACH,CAAC;CACF"}
|
package/package.json
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@aztec/world-state",
|
|
3
|
-
"version": "0.1.0-
|
|
3
|
+
"version": "0.1.0-alpha45",
|
|
4
4
|
"exports": "./dest/index.js",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"dependencies": {
|
|
7
|
-
"@aztec/circuits.js": "0.1.0-
|
|
8
|
-
"@aztec/foundation": "0.1.0-
|
|
9
|
-
"@aztec/merkle-tree": "0.1.0-
|
|
10
|
-
"@aztec/types": "0.1.0-
|
|
7
|
+
"@aztec/circuits.js": "0.1.0-alpha45",
|
|
8
|
+
"@aztec/foundation": "0.1.0-alpha45",
|
|
9
|
+
"@aztec/merkle-tree": "0.1.0-alpha45",
|
|
10
|
+
"@aztec/types": "0.1.0-alpha45",
|
|
11
11
|
"levelup": "^5.1.1",
|
|
12
12
|
"lodash.times": "^4.3.2",
|
|
13
13
|
"memdown": "^6.1.1",
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Fr } from '@aztec/foundation/fields';
|
|
2
2
|
import { LowLeafWitnessData } from '@aztec/merkle-tree';
|
|
3
3
|
import { L2Block, MerkleTreeId, SiblingPath } from '@aztec/types';
|
|
4
4
|
|
|
@@ -24,7 +24,7 @@ export class MerkleTreeOperationsFacade implements MerkleTreeOperations {
|
|
|
24
24
|
* Get the current roots of the commitment trees.
|
|
25
25
|
* @returns The current roots of the trees.
|
|
26
26
|
*/
|
|
27
|
-
getTreeRoots(): CurrentTreeRoots {
|
|
27
|
+
getTreeRoots(): Promise<CurrentTreeRoots> {
|
|
28
28
|
return this.trees.getTreeRoots(this.includeUncommitted);
|
|
29
29
|
}
|
|
30
30
|
|
|
@@ -44,8 +44,9 @@ export class MerkleTreeOperationsFacade implements MerkleTreeOperations {
|
|
|
44
44
|
* @param index - The index of the leaf for which a sibling path is required.
|
|
45
45
|
* @returns A promise with the sibling path of the specified leaf index.
|
|
46
46
|
*/
|
|
47
|
-
getSiblingPath(treeId: MerkleTreeId, index: bigint): Promise<SiblingPath<
|
|
48
|
-
|
|
47
|
+
async getSiblingPath<N extends number>(treeId: MerkleTreeId, index: bigint): Promise<SiblingPath<N>> {
|
|
48
|
+
const path = await this.trees.getSiblingPath(treeId, index, this.includeUncommitted);
|
|
49
|
+
return path as unknown as SiblingPath<N>;
|
|
49
50
|
}
|
|
50
51
|
|
|
51
52
|
/**
|
|
@@ -116,11 +117,26 @@ export class MerkleTreeOperationsFacade implements MerkleTreeOperations {
|
|
|
116
117
|
/**
|
|
117
118
|
* Inserts into the roots trees (CONTRACT_TREE_ROOTS_TREE, PRIVATE_DATA_TREE_ROOTS_TREE)
|
|
118
119
|
* the current roots of the corresponding trees (CONTRACT_TREE, PRIVATE_DATA_TREE).
|
|
119
|
-
* @param
|
|
120
|
+
* @param globalVariablesHash - The hash of the current global variables to include in the block hash.
|
|
120
121
|
* @returns Empty promise.
|
|
121
122
|
*/
|
|
122
|
-
public updateHistoricBlocksTree(
|
|
123
|
-
return this.trees.updateHistoricBlocksTree(
|
|
123
|
+
public updateHistoricBlocksTree(globalVariablesHash: Fr): Promise<void> {
|
|
124
|
+
return this.trees.updateHistoricBlocksTree(globalVariablesHash, this.includeUncommitted);
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
/**
|
|
128
|
+
* Updates the latest global variables hash
|
|
129
|
+
* @param globalVariablesHash - The latest global variables hash
|
|
130
|
+
*/
|
|
131
|
+
public updateLatestGlobalVariablesHash(globalVariablesHash: Fr): Promise<void> {
|
|
132
|
+
return this.trees.updateLatestGlobalVariablesHash(globalVariablesHash, this.includeUncommitted);
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
/**
|
|
136
|
+
* Gets the global variables hash from the previous block
|
|
137
|
+
*/
|
|
138
|
+
public getLatestGlobalVariablesHash(): Promise<Fr> {
|
|
139
|
+
return this.trees.getLatestGlobalVariablesHash(this.includeUncommitted);
|
|
124
140
|
}
|
|
125
141
|
|
|
126
142
|
/**
|
|
@@ -26,7 +26,7 @@ import {
|
|
|
26
26
|
import { jest } from '@jest/globals';
|
|
27
27
|
import times from 'lodash.times';
|
|
28
28
|
|
|
29
|
-
import { MerkleTreeDb } from '../index.js';
|
|
29
|
+
import { MerkleTreeDb, MerkleTrees, WorldStateConfig } from '../index.js';
|
|
30
30
|
import { ServerWorldStateSynchroniser } from './server_world_state_synchroniser.js';
|
|
31
31
|
import { WorldStateRunningState } from './world_state_synchroniser.js';
|
|
32
32
|
|
|
@@ -96,14 +96,19 @@ const getMockBlock = (blockNumber: number, newContractsCommitments?: Buffer[]) =
|
|
|
96
96
|
return block;
|
|
97
97
|
};
|
|
98
98
|
|
|
99
|
-
const createSynchroniser = (merkleTreeDb: any, rollupSource: any) =>
|
|
100
|
-
|
|
99
|
+
const createSynchroniser = (merkleTreeDb: any, rollupSource: any, blockCheckInterval = 100) => {
|
|
100
|
+
const worldStateConfig: WorldStateConfig = {
|
|
101
|
+
worldStateBlockCheckIntervalMS: blockCheckInterval,
|
|
102
|
+
l2QueueSize: 1000,
|
|
103
|
+
};
|
|
104
|
+
return new ServerWorldStateSynchroniser(merkleTreeDb as MerkleTrees, rollupSource as L2BlockSource, worldStateConfig);
|
|
105
|
+
};
|
|
101
106
|
|
|
102
107
|
const log = createDebugLogger('aztec:server_world_state_synchroniser_test');
|
|
103
108
|
|
|
104
109
|
describe('server_world_state_synchroniser', () => {
|
|
105
|
-
const rollupSource: Mockify<Pick<L2BlockSource, '
|
|
106
|
-
|
|
110
|
+
const rollupSource: Mockify<Pick<L2BlockSource, 'getBlockNumber' | 'getL2Blocks'>> = {
|
|
111
|
+
getBlockNumber: jest.fn().mockImplementation(getLatestBlockNumber),
|
|
107
112
|
getL2Blocks: jest.fn().mockImplementation(consumeNextBlocks),
|
|
108
113
|
};
|
|
109
114
|
|
|
@@ -126,8 +131,27 @@ describe('server_world_state_synchroniser', () => {
|
|
|
126
131
|
commit: jest.fn().mockImplementation(() => Promise.resolve()),
|
|
127
132
|
rollback: jest.fn().mockImplementation(() => Promise.resolve()),
|
|
128
133
|
handleL2Block: jest.fn().mockImplementation(() => Promise.resolve()),
|
|
134
|
+
stop: jest.fn().mockImplementation(() => Promise.resolve()),
|
|
129
135
|
} as any;
|
|
130
136
|
|
|
137
|
+
const performInitialSync = async (server: ServerWorldStateSynchroniser) => {
|
|
138
|
+
// test initial state
|
|
139
|
+
let status = await server.status();
|
|
140
|
+
expect(status.syncedToL2Block).toEqual(0);
|
|
141
|
+
expect(status.state).toEqual(WorldStateRunningState.IDLE);
|
|
142
|
+
|
|
143
|
+
// create the initial blocks
|
|
144
|
+
nextBlocks = Array(LATEST_BLOCK_NUMBER)
|
|
145
|
+
.fill(0)
|
|
146
|
+
.map((_, index: number) => getMockBlock(index + 1));
|
|
147
|
+
|
|
148
|
+
// start the sync process and await it
|
|
149
|
+
await server.start().catch(err => log.error('Sync not completed: ', err));
|
|
150
|
+
|
|
151
|
+
status = await server.status();
|
|
152
|
+
expect(status.syncedToL2Block).toBe(LATEST_BLOCK_NUMBER);
|
|
153
|
+
};
|
|
154
|
+
|
|
131
155
|
it('can be constructed', () => {
|
|
132
156
|
expect(() => createSynchroniser(merkleTreeDb, rollupSource)).not.toThrow();
|
|
133
157
|
});
|
|
@@ -241,7 +265,7 @@ describe('server_world_state_synchroniser', () => {
|
|
|
241
265
|
|
|
242
266
|
it('immediately syncs if no new blocks', async () => {
|
|
243
267
|
const server = createSynchroniser(merkleTreeDb, rollupSource);
|
|
244
|
-
rollupSource.
|
|
268
|
+
rollupSource.getBlockNumber.mockImplementationOnce(() => {
|
|
245
269
|
return Promise.resolve(0);
|
|
246
270
|
});
|
|
247
271
|
|
|
@@ -259,7 +283,7 @@ describe('server_world_state_synchroniser', () => {
|
|
|
259
283
|
|
|
260
284
|
it("can't be started if already stopped", async () => {
|
|
261
285
|
const server = createSynchroniser(merkleTreeDb, rollupSource);
|
|
262
|
-
rollupSource.
|
|
286
|
+
rollupSource.getBlockNumber.mockImplementationOnce(() => {
|
|
263
287
|
return Promise.resolve(0);
|
|
264
288
|
});
|
|
265
289
|
|
|
@@ -284,4 +308,121 @@ describe('server_world_state_synchroniser', () => {
|
|
|
284
308
|
expect(merkleTreeDb.handleL2Block).toHaveBeenCalledTimes(totalBlocks);
|
|
285
309
|
await server.stop();
|
|
286
310
|
});
|
|
311
|
+
|
|
312
|
+
it('can immediately sync to latest', async () => {
|
|
313
|
+
const server = createSynchroniser(merkleTreeDb, rollupSource, 10000);
|
|
314
|
+
|
|
315
|
+
await performInitialSync(server);
|
|
316
|
+
|
|
317
|
+
// the server should now be asleep for a long time
|
|
318
|
+
// we will add a new block and force an immediate sync
|
|
319
|
+
nextBlocks = [getMockBlock(LATEST_BLOCK_NUMBER + 1)];
|
|
320
|
+
await server.syncImmediate();
|
|
321
|
+
|
|
322
|
+
let status = await server.status();
|
|
323
|
+
expect(status.syncedToL2Block).toBe(LATEST_BLOCK_NUMBER + 1);
|
|
324
|
+
|
|
325
|
+
nextBlocks = [getMockBlock(LATEST_BLOCK_NUMBER + 2), getMockBlock(LATEST_BLOCK_NUMBER + 3)];
|
|
326
|
+
await server.syncImmediate();
|
|
327
|
+
|
|
328
|
+
status = await server.status();
|
|
329
|
+
expect(status.syncedToL2Block).toBe(LATEST_BLOCK_NUMBER + 3);
|
|
330
|
+
|
|
331
|
+
// stop the synchroniser
|
|
332
|
+
await server.stop();
|
|
333
|
+
|
|
334
|
+
// check the final status
|
|
335
|
+
status = await server.status();
|
|
336
|
+
expect(status.state).toEqual(WorldStateRunningState.STOPPED);
|
|
337
|
+
expect(status.syncedToL2Block).toEqual(LATEST_BLOCK_NUMBER + 3);
|
|
338
|
+
});
|
|
339
|
+
|
|
340
|
+
it('can immediately sync to a minimum block number', async () => {
|
|
341
|
+
const server = createSynchroniser(merkleTreeDb, rollupSource, 10000);
|
|
342
|
+
|
|
343
|
+
await performInitialSync(server);
|
|
344
|
+
|
|
345
|
+
// the server should now be asleep for a long time
|
|
346
|
+
// we will add 20 blocks and force a sync to at least LATEST + 5
|
|
347
|
+
nextBlocks = Array(20)
|
|
348
|
+
.fill(0)
|
|
349
|
+
.map((_, index: number) => getMockBlock(index + 1 + LATEST_BLOCK_NUMBER));
|
|
350
|
+
await server.syncImmediate(LATEST_BLOCK_NUMBER + 5);
|
|
351
|
+
|
|
352
|
+
// we should have synced all of the blocks
|
|
353
|
+
let status = await server.status();
|
|
354
|
+
expect(status.syncedToL2Block).toBe(LATEST_BLOCK_NUMBER + 20);
|
|
355
|
+
|
|
356
|
+
// stop the synchroniser
|
|
357
|
+
await server.stop();
|
|
358
|
+
|
|
359
|
+
// check the final status
|
|
360
|
+
status = await server.status();
|
|
361
|
+
expect(status.state).toEqual(WorldStateRunningState.STOPPED);
|
|
362
|
+
expect(status.syncedToL2Block).toEqual(LATEST_BLOCK_NUMBER + 20);
|
|
363
|
+
});
|
|
364
|
+
|
|
365
|
+
it('can immediately sync to a minimum block in the past', async () => {
|
|
366
|
+
const server = createSynchroniser(merkleTreeDb, rollupSource, 10000);
|
|
367
|
+
|
|
368
|
+
await performInitialSync(server);
|
|
369
|
+
// syncing to a block in the past should succeed
|
|
370
|
+
await server.syncImmediate(LATEST_BLOCK_NUMBER - 1);
|
|
371
|
+
// syncing to the current block should succeed
|
|
372
|
+
await server.syncImmediate(LATEST_BLOCK_NUMBER);
|
|
373
|
+
|
|
374
|
+
// we should have synced all of the blocks
|
|
375
|
+
let status = await server.status();
|
|
376
|
+
expect(status.syncedToL2Block).toBe(LATEST_BLOCK_NUMBER);
|
|
377
|
+
|
|
378
|
+
// stop the synchroniser
|
|
379
|
+
await server.stop();
|
|
380
|
+
|
|
381
|
+
// check the final status
|
|
382
|
+
status = await server.status();
|
|
383
|
+
expect(status.state).toEqual(WorldStateRunningState.STOPPED);
|
|
384
|
+
expect(status.syncedToL2Block).toEqual(LATEST_BLOCK_NUMBER);
|
|
385
|
+
});
|
|
386
|
+
|
|
387
|
+
it('throws if you try to sync to an unavailable block', async () => {
|
|
388
|
+
const server = createSynchroniser(merkleTreeDb, rollupSource, 10000);
|
|
389
|
+
|
|
390
|
+
await performInitialSync(server);
|
|
391
|
+
|
|
392
|
+
// the server should now be asleep for a long time
|
|
393
|
+
// we will add 2 blocks and force a sync to at least LATEST + 5
|
|
394
|
+
nextBlocks = Array(2)
|
|
395
|
+
.fill(0)
|
|
396
|
+
.map((_, index: number) => getMockBlock(index + 1 + LATEST_BLOCK_NUMBER));
|
|
397
|
+
await expect(server.syncImmediate(LATEST_BLOCK_NUMBER + 5)).rejects.toThrow(
|
|
398
|
+
`Unable to sync to block number ${LATEST_BLOCK_NUMBER + 5}, currently synced to block ${LATEST_BLOCK_NUMBER + 2}`,
|
|
399
|
+
);
|
|
400
|
+
|
|
401
|
+
let status = await server.status();
|
|
402
|
+
expect(status.syncedToL2Block).toBe(LATEST_BLOCK_NUMBER + 2);
|
|
403
|
+
|
|
404
|
+
// stop the synchroniser
|
|
405
|
+
await server.stop();
|
|
406
|
+
|
|
407
|
+
// check the final status
|
|
408
|
+
status = await server.status();
|
|
409
|
+
expect(status.state).toEqual(WorldStateRunningState.STOPPED);
|
|
410
|
+
expect(status.syncedToL2Block).toEqual(LATEST_BLOCK_NUMBER + 2);
|
|
411
|
+
});
|
|
412
|
+
|
|
413
|
+
it('throws if you try to immediate sync when not running', async () => {
|
|
414
|
+
const server = createSynchroniser(merkleTreeDb, rollupSource, 10000);
|
|
415
|
+
|
|
416
|
+
// test initial state
|
|
417
|
+
const status = await server.status();
|
|
418
|
+
expect(status.syncedToL2Block).toEqual(0);
|
|
419
|
+
expect(status.state).toEqual(WorldStateRunningState.IDLE);
|
|
420
|
+
|
|
421
|
+
// create an initial block
|
|
422
|
+
nextBlocks = Array(LATEST_BLOCK_NUMBER)
|
|
423
|
+
.fill(0)
|
|
424
|
+
.map((_, index: number) => getMockBlock(index + 1));
|
|
425
|
+
|
|
426
|
+
await expect(server.syncImmediate()).rejects.toThrow(`World State is not running, unable to perform sync`);
|
|
427
|
+
});
|
|
287
428
|
});
|