@aztec/world-state 0.6.7 → 0.7.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/Dockerfile +18 -0
- package/package.json +5 -5
- package/src/synchroniser/server_world_state_synchroniser.test.ts +2 -2
- package/src/world-state-db/merkle_trees.ts +3 -3
- package/.tsbuildinfo +0 -1
- package/dest/index.d.ts +0 -5
- package/dest/index.d.ts.map +0 -1
- package/dest/index.js +0 -5
- package/dest/merkle-tree/merkle_tree_operations_facade.d.ts +0 -127
- package/dest/merkle-tree/merkle_tree_operations_facade.d.ts.map +0 -1
- package/dest/merkle-tree/merkle_tree_operations_facade.js +0 -147
- package/dest/synchroniser/config.d.ts +0 -19
- package/dest/synchroniser/config.d.ts.map +0 -1
- package/dest/synchroniser/config.js +0 -13
- package/dest/synchroniser/index.d.ts +0 -3
- package/dest/synchroniser/index.d.ts.map +0 -1
- package/dest/synchroniser/index.js +0 -3
- package/dest/synchroniser/server_world_state_synchroniser.d.ts +0 -55
- package/dest/synchroniser/server_world_state_synchroniser.d.ts.map +0 -1
- package/dest/synchroniser/server_world_state_synchroniser.js +0 -163
- package/dest/synchroniser/server_world_state_synchroniser.test.d.ts +0 -2
- package/dest/synchroniser/server_world_state_synchroniser.test.d.ts.map +0 -1
- package/dest/synchroniser/server_world_state_synchroniser.test.js +0 -317
- package/dest/synchroniser/world_state_synchroniser.d.ts +0 -59
- package/dest/synchroniser/world_state_synchroniser.d.ts.map +0 -1
- package/dest/synchroniser/world_state_synchroniser.js +0 -11
- package/dest/utils.d.ts +0 -18
- package/dest/utils.d.ts.map +0 -1
- package/dest/utils.js +0 -23
- package/dest/world-state-db/index.d.ts +0 -189
- package/dest/world-state-db/index.d.ts.map +0 -1
- package/dest/world-state-db/index.js +0 -31
- package/dest/world-state-db/merkle_trees.d.ts +0 -228
- package/dest/world-state-db/merkle_trees.d.ts.map +0 -1
- package/dest/world-state-db/merkle_trees.js +0 -407
|
@@ -1,317 +0,0 @@
|
|
|
1
|
-
import { AppendOnlyTreeSnapshot, CircuitsWasm, Fr, GlobalVariables, MAX_NEW_COMMITMENTS_PER_TX, MAX_NEW_CONTRACTS_PER_TX, MAX_NEW_L2_TO_L1_MSGS_PER_CALL, MAX_NEW_NULLIFIERS_PER_TX, MAX_PUBLIC_DATA_UPDATE_REQUESTS_PER_TX, NUMBER_OF_L1_L2_MESSAGES_PER_ROLLUP, } from '@aztec/circuits.js';
|
|
2
|
-
import { createDebugLogger } from '@aztec/foundation/log';
|
|
3
|
-
import { sleep } from '@aztec/foundation/sleep';
|
|
4
|
-
import { INITIAL_LEAF, Pedersen } from '@aztec/merkle-tree';
|
|
5
|
-
import { ContractData, L2Block, L2BlockL2Logs, MerkleTreeId, PublicDataWrite, SiblingPath, } from '@aztec/types';
|
|
6
|
-
import { jest } from '@jest/globals';
|
|
7
|
-
import times from 'lodash.times';
|
|
8
|
-
import { ServerWorldStateSynchroniser } from './server_world_state_synchroniser.js';
|
|
9
|
-
import { WorldStateRunningState } from './world_state_synchroniser.js';
|
|
10
|
-
const LATEST_BLOCK_NUMBER = 5;
|
|
11
|
-
const getLatestBlockNumber = () => LATEST_BLOCK_NUMBER;
|
|
12
|
-
let nextBlocks = [];
|
|
13
|
-
const consumeNextBlocks = () => {
|
|
14
|
-
const blocks = nextBlocks;
|
|
15
|
-
nextBlocks = [];
|
|
16
|
-
return Promise.resolve(blocks);
|
|
17
|
-
};
|
|
18
|
-
const getMockTreeSnapshot = () => {
|
|
19
|
-
return new AppendOnlyTreeSnapshot(Fr.random(), 16);
|
|
20
|
-
};
|
|
21
|
-
const getMockContractData = () => {
|
|
22
|
-
return ContractData.random();
|
|
23
|
-
};
|
|
24
|
-
const getMockGlobalVariables = () => {
|
|
25
|
-
return GlobalVariables.from({
|
|
26
|
-
chainId: Fr.random(),
|
|
27
|
-
version: Fr.random(),
|
|
28
|
-
blockNumber: Fr.random(),
|
|
29
|
-
timestamp: Fr.random(),
|
|
30
|
-
});
|
|
31
|
-
};
|
|
32
|
-
const getMockL1ToL2MessagesData = () => {
|
|
33
|
-
return new Array(NUMBER_OF_L1_L2_MESSAGES_PER_ROLLUP).map(() => Fr.random());
|
|
34
|
-
};
|
|
35
|
-
const getMockBlock = (blockNumber, newContractsCommitments) => {
|
|
36
|
-
const newEncryptedLogs = L2BlockL2Logs.random(1, 2, 3);
|
|
37
|
-
const block = L2Block.fromFields({
|
|
38
|
-
number: blockNumber,
|
|
39
|
-
globalVariables: getMockGlobalVariables(),
|
|
40
|
-
startPrivateDataTreeSnapshot: getMockTreeSnapshot(),
|
|
41
|
-
startNullifierTreeSnapshot: getMockTreeSnapshot(),
|
|
42
|
-
startContractTreeSnapshot: getMockTreeSnapshot(),
|
|
43
|
-
startPublicDataTreeRoot: Fr.random(),
|
|
44
|
-
startL1ToL2MessageTreeSnapshot: getMockTreeSnapshot(),
|
|
45
|
-
startHistoricBlocksTreeSnapshot: getMockTreeSnapshot(),
|
|
46
|
-
endPrivateDataTreeSnapshot: getMockTreeSnapshot(),
|
|
47
|
-
endNullifierTreeSnapshot: getMockTreeSnapshot(),
|
|
48
|
-
endContractTreeSnapshot: getMockTreeSnapshot(),
|
|
49
|
-
endPublicDataTreeRoot: Fr.random(),
|
|
50
|
-
endL1ToL2MessageTreeSnapshot: getMockTreeSnapshot(),
|
|
51
|
-
endHistoricBlocksTreeSnapshot: getMockTreeSnapshot(),
|
|
52
|
-
newCommitments: times(MAX_NEW_COMMITMENTS_PER_TX, Fr.random),
|
|
53
|
-
newNullifiers: times(MAX_NEW_NULLIFIERS_PER_TX, Fr.random),
|
|
54
|
-
newContracts: newContractsCommitments?.map(x => Fr.fromBuffer(x)) ?? [Fr.random()],
|
|
55
|
-
newContractData: times(MAX_NEW_CONTRACTS_PER_TX, getMockContractData),
|
|
56
|
-
newPublicDataWrites: times(MAX_PUBLIC_DATA_UPDATE_REQUESTS_PER_TX, PublicDataWrite.random),
|
|
57
|
-
newL1ToL2Messages: getMockL1ToL2MessagesData(),
|
|
58
|
-
newL2ToL1Msgs: times(MAX_NEW_L2_TO_L1_MSGS_PER_CALL, Fr.random),
|
|
59
|
-
newEncryptedLogs,
|
|
60
|
-
});
|
|
61
|
-
return block;
|
|
62
|
-
};
|
|
63
|
-
const createSynchroniser = (merkleTreeDb, rollupSource, blockCheckInterval = 100) => {
|
|
64
|
-
const worldStateConfig = {
|
|
65
|
-
worldStateBlockCheckIntervalMS: blockCheckInterval,
|
|
66
|
-
l2QueueSize: 1000,
|
|
67
|
-
};
|
|
68
|
-
return new ServerWorldStateSynchroniser(merkleTreeDb, rollupSource, worldStateConfig);
|
|
69
|
-
};
|
|
70
|
-
const log = createDebugLogger('aztec:server_world_state_synchroniser_test');
|
|
71
|
-
describe('server_world_state_synchroniser', () => {
|
|
72
|
-
const rollupSource = {
|
|
73
|
-
getBlockNumber: jest.fn().mockImplementation(getLatestBlockNumber),
|
|
74
|
-
getL2Blocks: jest.fn().mockImplementation(consumeNextBlocks),
|
|
75
|
-
};
|
|
76
|
-
const merkleTreeDb = {
|
|
77
|
-
getTreeInfo: jest
|
|
78
|
-
.fn()
|
|
79
|
-
.mockImplementation(() => Promise.resolve({ treeId: MerkleTreeId.CONTRACT_TREE, root: Buffer.alloc(32, 0), size: 0n })),
|
|
80
|
-
appendLeaves: jest.fn().mockImplementation(() => Promise.resolve()),
|
|
81
|
-
updateLeaf: jest.fn().mockImplementation(() => Promise.resolve()),
|
|
82
|
-
getSiblingPath: jest.fn().mockImplementation(() => {
|
|
83
|
-
return async () => {
|
|
84
|
-
const wasm = await CircuitsWasm.get();
|
|
85
|
-
const pedersen = new Pedersen(wasm);
|
|
86
|
-
SiblingPath.ZERO(32, INITIAL_LEAF, pedersen);
|
|
87
|
-
}; //Promise.resolve();
|
|
88
|
-
}),
|
|
89
|
-
updateHistoricBlocksTree: jest.fn().mockImplementation(() => Promise.resolve()),
|
|
90
|
-
commit: jest.fn().mockImplementation(() => Promise.resolve()),
|
|
91
|
-
rollback: jest.fn().mockImplementation(() => Promise.resolve()),
|
|
92
|
-
handleL2Block: jest.fn().mockImplementation(() => Promise.resolve()),
|
|
93
|
-
stop: jest.fn().mockImplementation(() => Promise.resolve()),
|
|
94
|
-
};
|
|
95
|
-
const performInitialSync = async (server) => {
|
|
96
|
-
// test initial state
|
|
97
|
-
let status = await server.status();
|
|
98
|
-
expect(status.syncedToL2Block).toEqual(0);
|
|
99
|
-
expect(status.state).toEqual(WorldStateRunningState.IDLE);
|
|
100
|
-
// create the initial blocks
|
|
101
|
-
nextBlocks = Array(LATEST_BLOCK_NUMBER)
|
|
102
|
-
.fill(0)
|
|
103
|
-
.map((_, index) => getMockBlock(index + 1));
|
|
104
|
-
// start the sync process and await it
|
|
105
|
-
await server.start().catch(err => log.error('Sync not completed: ', err));
|
|
106
|
-
status = await server.status();
|
|
107
|
-
expect(status.syncedToL2Block).toBe(LATEST_BLOCK_NUMBER);
|
|
108
|
-
};
|
|
109
|
-
it('can be constructed', () => {
|
|
110
|
-
expect(() => createSynchroniser(merkleTreeDb, rollupSource)).not.toThrow();
|
|
111
|
-
});
|
|
112
|
-
it('updates sync progress', async () => {
|
|
113
|
-
const server = createSynchroniser(merkleTreeDb, rollupSource);
|
|
114
|
-
// test initial state
|
|
115
|
-
let status = await server.status();
|
|
116
|
-
expect(status.syncedToL2Block).toEqual(0);
|
|
117
|
-
expect(status.state).toEqual(WorldStateRunningState.IDLE);
|
|
118
|
-
// create an initial block
|
|
119
|
-
let currentBlockNumber = 0;
|
|
120
|
-
nextBlocks = [getMockBlock(currentBlockNumber + 1)];
|
|
121
|
-
// start the sync process but don't await
|
|
122
|
-
server.start().catch(err => log.error('Sync not completed: ', err));
|
|
123
|
-
// now setup a loop to monitor the sync progress and push new blocks in
|
|
124
|
-
while (currentBlockNumber <= LATEST_BLOCK_NUMBER) {
|
|
125
|
-
status = await server.status();
|
|
126
|
-
expect(status.syncedToL2Block >= currentBlockNumber || status.syncedToL2Block <= currentBlockNumber + 1).toBeTruthy();
|
|
127
|
-
if (status.syncedToL2Block === LATEST_BLOCK_NUMBER) {
|
|
128
|
-
break;
|
|
129
|
-
}
|
|
130
|
-
expect(status.state >= WorldStateRunningState.IDLE || status.state <= WorldStateRunningState.SYNCHING).toBeTruthy();
|
|
131
|
-
if (status.syncedToL2Block === currentBlockNumber) {
|
|
132
|
-
await sleep(100);
|
|
133
|
-
continue;
|
|
134
|
-
}
|
|
135
|
-
currentBlockNumber++;
|
|
136
|
-
nextBlocks = [getMockBlock(currentBlockNumber + 1)];
|
|
137
|
-
}
|
|
138
|
-
// check the status agian, should be fully synced
|
|
139
|
-
status = await server.status();
|
|
140
|
-
expect(status.state).toEqual(WorldStateRunningState.RUNNING);
|
|
141
|
-
expect(status.syncedToL2Block).toEqual(LATEST_BLOCK_NUMBER);
|
|
142
|
-
// stop the synchroniser
|
|
143
|
-
await server.stop();
|
|
144
|
-
// check the final status
|
|
145
|
-
status = await server.status();
|
|
146
|
-
expect(status.state).toEqual(WorldStateRunningState.STOPPED);
|
|
147
|
-
expect(status.syncedToL2Block).toEqual(LATEST_BLOCK_NUMBER);
|
|
148
|
-
});
|
|
149
|
-
it('enables blocking until synced', async () => {
|
|
150
|
-
const server = createSynchroniser(merkleTreeDb, rollupSource);
|
|
151
|
-
let currentBlockNumber = 0;
|
|
152
|
-
const newBlocks = async () => {
|
|
153
|
-
while (currentBlockNumber <= LATEST_BLOCK_NUMBER) {
|
|
154
|
-
await sleep(100);
|
|
155
|
-
nextBlocks = [...nextBlocks, getMockBlock(++currentBlockNumber)];
|
|
156
|
-
}
|
|
157
|
-
};
|
|
158
|
-
// kick off the background queueing of blocks
|
|
159
|
-
const newBlockPromise = newBlocks();
|
|
160
|
-
// kick off the synching
|
|
161
|
-
const syncPromise = server.start();
|
|
162
|
-
// await the synching
|
|
163
|
-
await syncPromise;
|
|
164
|
-
await newBlockPromise;
|
|
165
|
-
let status = await server.status();
|
|
166
|
-
expect(status.state).toEqual(WorldStateRunningState.RUNNING);
|
|
167
|
-
expect(status.syncedToL2Block).toEqual(LATEST_BLOCK_NUMBER);
|
|
168
|
-
await server.stop();
|
|
169
|
-
status = await server.status();
|
|
170
|
-
expect(status.state).toEqual(WorldStateRunningState.STOPPED);
|
|
171
|
-
expect(status.syncedToL2Block).toEqual(LATEST_BLOCK_NUMBER);
|
|
172
|
-
});
|
|
173
|
-
it('handles multiple calls to start', async () => {
|
|
174
|
-
const server = createSynchroniser(merkleTreeDb, rollupSource);
|
|
175
|
-
let currentBlockNumber = 0;
|
|
176
|
-
const newBlocks = async () => {
|
|
177
|
-
while (currentBlockNumber < LATEST_BLOCK_NUMBER) {
|
|
178
|
-
await sleep(100);
|
|
179
|
-
const newBlock = getMockBlock(++currentBlockNumber);
|
|
180
|
-
nextBlocks = [...nextBlocks, newBlock];
|
|
181
|
-
}
|
|
182
|
-
};
|
|
183
|
-
// kick off the background queueing of blocks
|
|
184
|
-
const newBlockPromise = newBlocks();
|
|
185
|
-
// kick off the synching
|
|
186
|
-
await server.start();
|
|
187
|
-
// call start again, should get back the same promise
|
|
188
|
-
await server.start();
|
|
189
|
-
// wait until the block production has finished
|
|
190
|
-
await newBlockPromise;
|
|
191
|
-
await server.stop();
|
|
192
|
-
});
|
|
193
|
-
it('immediately syncs if no new blocks', async () => {
|
|
194
|
-
const server = createSynchroniser(merkleTreeDb, rollupSource);
|
|
195
|
-
rollupSource.getBlockNumber.mockImplementationOnce(() => {
|
|
196
|
-
return Promise.resolve(0);
|
|
197
|
-
});
|
|
198
|
-
// kick off the synching
|
|
199
|
-
const syncPromise = server.start();
|
|
200
|
-
// it should already be synced, no need to push new blocks
|
|
201
|
-
await syncPromise;
|
|
202
|
-
const status = await server.status();
|
|
203
|
-
expect(status.state).toBe(WorldStateRunningState.RUNNING);
|
|
204
|
-
expect(status.syncedToL2Block).toBe(0);
|
|
205
|
-
await server.stop();
|
|
206
|
-
});
|
|
207
|
-
it("can't be started if already stopped", async () => {
|
|
208
|
-
const server = createSynchroniser(merkleTreeDb, rollupSource);
|
|
209
|
-
rollupSource.getBlockNumber.mockImplementationOnce(() => {
|
|
210
|
-
return Promise.resolve(0);
|
|
211
|
-
});
|
|
212
|
-
// kick off the synching
|
|
213
|
-
const syncPromise = server.start();
|
|
214
|
-
await syncPromise;
|
|
215
|
-
await server.stop();
|
|
216
|
-
await expect(server.start()).rejects.toThrow();
|
|
217
|
-
});
|
|
218
|
-
it('adds the received L2 blocks', async () => {
|
|
219
|
-
merkleTreeDb.handleL2Block.mockReset();
|
|
220
|
-
const server = createSynchroniser(merkleTreeDb, rollupSource);
|
|
221
|
-
const totalBlocks = LATEST_BLOCK_NUMBER + 1;
|
|
222
|
-
nextBlocks = Array(totalBlocks)
|
|
223
|
-
.fill(0)
|
|
224
|
-
.map((_, index) => getMockBlock(index, [Buffer.alloc(32, index)]));
|
|
225
|
-
// sync the server
|
|
226
|
-
await server.start();
|
|
227
|
-
expect(merkleTreeDb.handleL2Block).toHaveBeenCalledTimes(totalBlocks);
|
|
228
|
-
await server.stop();
|
|
229
|
-
});
|
|
230
|
-
it('can immediately sync to latest', async () => {
|
|
231
|
-
const server = createSynchroniser(merkleTreeDb, rollupSource, 10000);
|
|
232
|
-
await performInitialSync(server);
|
|
233
|
-
// the server should now be asleep for a long time
|
|
234
|
-
// we will add a new block and force an immediate sync
|
|
235
|
-
nextBlocks = [getMockBlock(LATEST_BLOCK_NUMBER + 1)];
|
|
236
|
-
await server.syncImmediate();
|
|
237
|
-
let status = await server.status();
|
|
238
|
-
expect(status.syncedToL2Block).toBe(LATEST_BLOCK_NUMBER + 1);
|
|
239
|
-
nextBlocks = [getMockBlock(LATEST_BLOCK_NUMBER + 2), getMockBlock(LATEST_BLOCK_NUMBER + 3)];
|
|
240
|
-
await server.syncImmediate();
|
|
241
|
-
status = await server.status();
|
|
242
|
-
expect(status.syncedToL2Block).toBe(LATEST_BLOCK_NUMBER + 3);
|
|
243
|
-
// stop the synchroniser
|
|
244
|
-
await server.stop();
|
|
245
|
-
// check the final status
|
|
246
|
-
status = await server.status();
|
|
247
|
-
expect(status.state).toEqual(WorldStateRunningState.STOPPED);
|
|
248
|
-
expect(status.syncedToL2Block).toEqual(LATEST_BLOCK_NUMBER + 3);
|
|
249
|
-
});
|
|
250
|
-
it('can immediately sync to a minimum block number', async () => {
|
|
251
|
-
const server = createSynchroniser(merkleTreeDb, rollupSource, 10000);
|
|
252
|
-
await performInitialSync(server);
|
|
253
|
-
// the server should now be asleep for a long time
|
|
254
|
-
// we will add 20 blocks and force a sync to at least LATEST + 5
|
|
255
|
-
nextBlocks = Array(20)
|
|
256
|
-
.fill(0)
|
|
257
|
-
.map((_, index) => getMockBlock(index + 1 + LATEST_BLOCK_NUMBER));
|
|
258
|
-
await server.syncImmediate(LATEST_BLOCK_NUMBER + 5);
|
|
259
|
-
// we should have synced all of the blocks
|
|
260
|
-
let status = await server.status();
|
|
261
|
-
expect(status.syncedToL2Block).toBe(LATEST_BLOCK_NUMBER + 20);
|
|
262
|
-
// stop the synchroniser
|
|
263
|
-
await server.stop();
|
|
264
|
-
// check the final status
|
|
265
|
-
status = await server.status();
|
|
266
|
-
expect(status.state).toEqual(WorldStateRunningState.STOPPED);
|
|
267
|
-
expect(status.syncedToL2Block).toEqual(LATEST_BLOCK_NUMBER + 20);
|
|
268
|
-
});
|
|
269
|
-
it('can immediately sync to a minimum block in the past', async () => {
|
|
270
|
-
const server = createSynchroniser(merkleTreeDb, rollupSource, 10000);
|
|
271
|
-
await performInitialSync(server);
|
|
272
|
-
// syncing to a block in the past should succeed
|
|
273
|
-
await server.syncImmediate(LATEST_BLOCK_NUMBER - 1);
|
|
274
|
-
// syncing to the current block should succeed
|
|
275
|
-
await server.syncImmediate(LATEST_BLOCK_NUMBER);
|
|
276
|
-
// we should have synced all of the blocks
|
|
277
|
-
let status = await server.status();
|
|
278
|
-
expect(status.syncedToL2Block).toBe(LATEST_BLOCK_NUMBER);
|
|
279
|
-
// stop the synchroniser
|
|
280
|
-
await server.stop();
|
|
281
|
-
// check the final status
|
|
282
|
-
status = await server.status();
|
|
283
|
-
expect(status.state).toEqual(WorldStateRunningState.STOPPED);
|
|
284
|
-
expect(status.syncedToL2Block).toEqual(LATEST_BLOCK_NUMBER);
|
|
285
|
-
});
|
|
286
|
-
it('throws if you try to sync to an unavailable block', async () => {
|
|
287
|
-
const server = createSynchroniser(merkleTreeDb, rollupSource, 10000);
|
|
288
|
-
await performInitialSync(server);
|
|
289
|
-
// the server should now be asleep for a long time
|
|
290
|
-
// we will add 2 blocks and force a sync to at least LATEST + 5
|
|
291
|
-
nextBlocks = Array(2)
|
|
292
|
-
.fill(0)
|
|
293
|
-
.map((_, index) => getMockBlock(index + 1 + LATEST_BLOCK_NUMBER));
|
|
294
|
-
await expect(server.syncImmediate(LATEST_BLOCK_NUMBER + 5)).rejects.toThrow(`Unable to sync to block number ${LATEST_BLOCK_NUMBER + 5}, currently synced to block ${LATEST_BLOCK_NUMBER + 2}`);
|
|
295
|
-
let status = await server.status();
|
|
296
|
-
expect(status.syncedToL2Block).toBe(LATEST_BLOCK_NUMBER + 2);
|
|
297
|
-
// stop the synchroniser
|
|
298
|
-
await server.stop();
|
|
299
|
-
// check the final status
|
|
300
|
-
status = await server.status();
|
|
301
|
-
expect(status.state).toEqual(WorldStateRunningState.STOPPED);
|
|
302
|
-
expect(status.syncedToL2Block).toEqual(LATEST_BLOCK_NUMBER + 2);
|
|
303
|
-
});
|
|
304
|
-
it('throws if you try to immediate sync when not running', async () => {
|
|
305
|
-
const server = createSynchroniser(merkleTreeDb, rollupSource, 10000);
|
|
306
|
-
// test initial state
|
|
307
|
-
const status = await server.status();
|
|
308
|
-
expect(status.syncedToL2Block).toEqual(0);
|
|
309
|
-
expect(status.state).toEqual(WorldStateRunningState.IDLE);
|
|
310
|
-
// create an initial block
|
|
311
|
-
nextBlocks = Array(LATEST_BLOCK_NUMBER)
|
|
312
|
-
.fill(0)
|
|
313
|
-
.map((_, index) => getMockBlock(index + 1));
|
|
314
|
-
await expect(server.syncImmediate()).rejects.toThrow(`World State is not running, unable to perform sync`);
|
|
315
|
-
});
|
|
316
|
-
});
|
|
317
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"server_world_state_synchroniser.test.js","sourceRoot":"","sources":["../../src/synchroniser/server_world_state_synchroniser.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
import { MerkleTreeOperations } from '../index.js';
|
|
2
|
-
/**
|
|
3
|
-
* Defines the possible states of the world state synchroniser.
|
|
4
|
-
*/
|
|
5
|
-
export declare enum WorldStateRunningState {
|
|
6
|
-
IDLE = 0,
|
|
7
|
-
SYNCHING = 1,
|
|
8
|
-
RUNNING = 2,
|
|
9
|
-
STOPPED = 3
|
|
10
|
-
}
|
|
11
|
-
/**
|
|
12
|
-
* Defines the status of the world state synchroniser.
|
|
13
|
-
*/
|
|
14
|
-
export interface WorldStateStatus {
|
|
15
|
-
/**
|
|
16
|
-
* The current state of the world state synchroniser.
|
|
17
|
-
*/
|
|
18
|
-
state: WorldStateRunningState;
|
|
19
|
-
/**
|
|
20
|
-
* The block number that the world state synchroniser is synced to.
|
|
21
|
-
*/
|
|
22
|
-
syncedToL2Block: number;
|
|
23
|
-
}
|
|
24
|
-
/**
|
|
25
|
-
* Defines the interface for a world state synchroniser.
|
|
26
|
-
*/
|
|
27
|
-
export interface WorldStateSynchroniser {
|
|
28
|
-
/**
|
|
29
|
-
* Starts the synchroniser.
|
|
30
|
-
* @returns A promise that resolves once the initial sync is completed.
|
|
31
|
-
*/
|
|
32
|
-
start(): void;
|
|
33
|
-
/**
|
|
34
|
-
* Returns the current status of the synchroniser.
|
|
35
|
-
* @returns The current status of the synchroniser.
|
|
36
|
-
*/
|
|
37
|
-
status(): Promise<WorldStateStatus>;
|
|
38
|
-
/**
|
|
39
|
-
* Stops the synchroniser.
|
|
40
|
-
*/
|
|
41
|
-
stop(): Promise<void>;
|
|
42
|
-
/**
|
|
43
|
-
* Forces an immediate sync to an optionally provided minimum block number
|
|
44
|
-
* @param minBlockNumber - The minimum block number that we must sync to
|
|
45
|
-
* @returns A promise that resolves once the sync has completed.
|
|
46
|
-
*/
|
|
47
|
-
syncImmediate(minBlockNumber?: number): Promise<void>;
|
|
48
|
-
/**
|
|
49
|
-
* Returns an instance of MerkleTreeOperations that will include uncommitted data.
|
|
50
|
-
* @returns An instance of MerkleTreeOperations that will include uncommitted data.
|
|
51
|
-
*/
|
|
52
|
-
getLatest(): MerkleTreeOperations;
|
|
53
|
-
/**
|
|
54
|
-
* Returns an instance of MerkleTreeOperations that will not include uncommitted data.
|
|
55
|
-
* @returns An instance of MerkleTreeOperations that will not include uncommitted data.
|
|
56
|
-
*/
|
|
57
|
-
getCommitted(): MerkleTreeOperations;
|
|
58
|
-
}
|
|
59
|
-
//# sourceMappingURL=world_state_synchroniser.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"world_state_synchroniser.d.ts","sourceRoot":"","sources":["../../src/synchroniser/world_state_synchroniser.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC;AAEnD;;GAEG;AACH,oBAAY,sBAAsB;IAChC,IAAI,IAAA;IACJ,QAAQ,IAAA;IACR,OAAO,IAAA;IACP,OAAO,IAAA;CACR;AAED;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B;;OAEG;IACH,KAAK,EAAE,sBAAsB,CAAC;IAC9B;;OAEG;IACH,eAAe,EAAE,MAAM,CAAC;CACzB;AAED;;GAEG;AACH,MAAM,WAAW,sBAAsB;IACrC;;;OAGG;IACH,KAAK,IAAI,IAAI,CAAC;IAEd;;;OAGG;IACH,MAAM,IAAI,OAAO,CAAC,gBAAgB,CAAC,CAAC;IAEpC;;OAEG;IACH,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAEtB;;;;OAIG;IACH,aAAa,CAAC,cAAc,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEtD;;;OAGG;IACH,SAAS,IAAI,oBAAoB,CAAC;IAElC;;;OAGG;IACH,YAAY,IAAI,oBAAoB,CAAC;CACtC"}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Defines the possible states of the world state synchroniser.
|
|
3
|
-
*/
|
|
4
|
-
export var WorldStateRunningState;
|
|
5
|
-
(function (WorldStateRunningState) {
|
|
6
|
-
WorldStateRunningState[WorldStateRunningState["IDLE"] = 0] = "IDLE";
|
|
7
|
-
WorldStateRunningState[WorldStateRunningState["SYNCHING"] = 1] = "SYNCHING";
|
|
8
|
-
WorldStateRunningState[WorldStateRunningState["RUNNING"] = 2] = "RUNNING";
|
|
9
|
-
WorldStateRunningState[WorldStateRunningState["STOPPED"] = 3] = "STOPPED";
|
|
10
|
-
})(WorldStateRunningState || (WorldStateRunningState = {}));
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ybGRfc3RhdGVfc3luY2hyb25pc2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3N5bmNocm9uaXNlci93b3JsZF9zdGF0ZV9zeW5jaHJvbmlzZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUE7O0dBRUc7QUFDSCxNQUFNLENBQU4sSUFBWSxzQkFLWDtBQUxELFdBQVksc0JBQXNCO0lBQ2hDLG1FQUFJLENBQUE7SUFDSiwyRUFBUSxDQUFBO0lBQ1IseUVBQU8sQ0FBQTtJQUNQLHlFQUFPLENBQUE7QUFDVCxDQUFDLEVBTFcsc0JBQXNCLEtBQXRCLHNCQUFzQixRQUtqQyJ9
|
package/dest/utils.d.ts
DELETED
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { GlobalVariables } from '@aztec/circuits.js';
|
|
2
|
-
import { AztecAddress } from '@aztec/foundation/aztec-address';
|
|
3
|
-
import { Fr } from '@aztec/foundation/fields';
|
|
4
|
-
import { IWasmModule } from '@aztec/foundation/wasm';
|
|
5
|
-
/**
|
|
6
|
-
* Computes the index in the public data tree for a given contract and storage slot.
|
|
7
|
-
* @param contract - Address of the contract who owns the storage.
|
|
8
|
-
* @param slot - Slot within the contract storage.
|
|
9
|
-
* @param bbWasm - Wasm module for computing the hash.
|
|
10
|
-
* @returns The leaf index of the public data tree that maps to this storage slot.
|
|
11
|
-
*/
|
|
12
|
-
export declare function computePublicDataTreeLeafIndex(contract: AztecAddress, slot: Fr, wasm: IWasmModule): bigint;
|
|
13
|
-
/**
|
|
14
|
-
* Computes the hash of the global variables.
|
|
15
|
-
* @returns The hash of the global variables.
|
|
16
|
-
*/
|
|
17
|
-
export declare function computeGlobalVariablesHash(globalVariables?: GlobalVariables): Promise<Fr>;
|
|
18
|
-
//# sourceMappingURL=utils.d.ts.map
|
package/dest/utils.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../src/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgC,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAGnF,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AAC/D,OAAO,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAE9C,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAErD;;;;;;GAMG;AACH,wBAAgB,8BAA8B,CAAC,QAAQ,EAAE,YAAY,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,WAAW,GAAG,MAAM,CAQ1G;AAED;;;GAGG;AACH,wBAAsB,0BAA0B,CAC9C,eAAe,GAAE,eAAyC,GACzD,OAAO,CAAC,EAAE,CAAC,CAGb"}
|
package/dest/utils.js
DELETED
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import { CircuitsWasm, GeneratorIndex, GlobalVariables } from '@aztec/circuits.js';
|
|
2
|
-
import { computeGlobalsHash } from '@aztec/circuits.js/abis';
|
|
3
|
-
import { pedersenCompressWithHashIndex } from '@aztec/circuits.js/barretenberg';
|
|
4
|
-
import { toBigInt } from '@aztec/foundation/serialize';
|
|
5
|
-
/**
|
|
6
|
-
* Computes the index in the public data tree for a given contract and storage slot.
|
|
7
|
-
* @param contract - Address of the contract who owns the storage.
|
|
8
|
-
* @param slot - Slot within the contract storage.
|
|
9
|
-
* @param bbWasm - Wasm module for computing the hash.
|
|
10
|
-
* @returns The leaf index of the public data tree that maps to this storage slot.
|
|
11
|
-
*/
|
|
12
|
-
export function computePublicDataTreeLeafIndex(contract, slot, wasm) {
|
|
13
|
-
return toBigInt(pedersenCompressWithHashIndex(wasm, [contract, slot].map(f => f.toBuffer()), GeneratorIndex.PUBLIC_LEAF_INDEX));
|
|
14
|
-
}
|
|
15
|
-
/**
|
|
16
|
-
* Computes the hash of the global variables.
|
|
17
|
-
* @returns The hash of the global variables.
|
|
18
|
-
*/
|
|
19
|
-
export async function computeGlobalVariablesHash(globalVariables = GlobalVariables.empty()) {
|
|
20
|
-
const wasm = await CircuitsWasm.get();
|
|
21
|
-
return computeGlobalsHash(wasm, globalVariables);
|
|
22
|
-
}
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxjQUFjLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDbkYsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDN0QsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFHaEYsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBR3ZEOzs7Ozs7R0FNRztBQUNILE1BQU0sVUFBVSw4QkFBOEIsQ0FBQyxRQUFzQixFQUFFLElBQVEsRUFBRSxJQUFpQjtJQUNoRyxPQUFPLFFBQVEsQ0FDYiw2QkFBNkIsQ0FDM0IsSUFBSSxFQUNKLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxFQUN2QyxjQUFjLENBQUMsaUJBQWlCLENBQ2pDLENBQ0YsQ0FBQztBQUNKLENBQUM7QUFFRDs7O0dBR0c7QUFDSCxNQUFNLENBQUMsS0FBSyxVQUFVLDBCQUEwQixDQUM5QyxrQkFBbUMsZUFBZSxDQUFDLEtBQUssRUFBRTtJQUUxRCxNQUFNLElBQUksR0FBRyxNQUFNLFlBQVksQ0FBQyxHQUFHLEVBQUUsQ0FBQztJQUN0QyxPQUFPLGtCQUFrQixDQUFDLElBQUksRUFBRSxlQUFlLENBQUMsQ0FBQztBQUNuRCxDQUFDIn0=
|