Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: persistent archiver store #3410

Merged
merged 31 commits into from
Nov 28, 2023
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
Show all changes
31 commits
Select commit Hold shift + click to select a range
5ba9aff
feat: add jest helpers to @aztec/types
alexghr Nov 23, 2023
f3869b6
refactor: split MemoryArchiverStore to own file
alexghr Nov 23, 2023
de93bfc
refactor: addLogs per block
alexghr Nov 23, 2023
051549d
test: add comprehensive archiver_store test suite
alexghr Nov 23, 2023
0b378e4
feat: add archiver store backed by LMDB
alexghr Nov 23, 2023
bdf9c5c
fix: await contracts added to the archiver store
alexghr Nov 23, 2023
1b82206
feat: use persistent archiver store
alexghr Nov 23, 2023
d21cb49
Merge branch 'master' into alexg/feat/persistent-archiver-store
alexghr Nov 23, 2023
02f924b
fix: L1ToL2Message.random takes optional entryKey
alexghr Nov 23, 2023
d84ab77
fix: typing error in ts-jest
alexghr Nov 23, 2023
fd95142
fix: parse aztec address from string
alexghr Nov 23, 2023
b33ce02
refactor: add loop labels for more elegant breaks
alexghr Nov 23, 2023
ca43db3
refactor: use of transactions
alexghr Nov 23, 2023
8fc557e
Merge branch 'master' into alexg/feat/persistent-archiver-store
alexghr Nov 24, 2023
8653839
fix: merkle trees store last globalVariablesHash
alexghr Nov 27, 2023
a4235f9
fix: store/restore indexed tree's leaves to db
alexghr Nov 27, 2023
20c5acd
fix: pass global vars hash
alexghr Nov 27, 2023
5e202ef
refactor: inject archiver store into archiver
alexghr Nov 27, 2023
b0955a4
refactor: archiver gets L1 block number from store
alexghr Nov 27, 2023
600002b
refactor: use private property for l1BlockNumber
alexghr Nov 27, 2023
f724acd
Merge branch 'master' into alexg/feat/persistent-archiver-store
alexghr Nov 27, 2023
8a8a60b
refactor: segregate tx and contract indexed data
alexghr Nov 27, 2023
beb0102
refactor: add debug logging to lmdb archiver store
alexghr Nov 27, 2023
ad2093a
fix: use uint32 for block keys
alexghr Nov 27, 2023
4010d8a
fix: process L1->L2 messages just once
alexghr Nov 27, 2023
9b46e88
refactor: store entry keys as buffers in dup table
alexghr Nov 28, 2023
04e7e73
Merge remote-tracking branch 'origin/master' into alexg/feat/persiste…
alexghr Nov 28, 2023
4a85244
fix: memory l1tol2 message store is idempotent
alexghr Nov 28, 2023
aa07751
test: verify archiver store is idempotent
alexghr Nov 28, 2023
1cb5e12
docs: update archiver sync doc
alexghr Nov 28, 2023
801fb6f
fix: slow tree test more lenient
alexghr Nov 28, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,12 @@ import { TreeBase } from '../tree_base.js';
const log = createDebugLogger('aztec:standard-indexed-tree');

const indexToKeyLeaf = (name: string, index: bigint) => {
return `${name}:leaf:${index}`;
return `${name}:leaf:${toBufferBE(index, 32).toString('hex')}`;
};

const keyLeafToIndex = (key: string): bigint => {
const index = key.split(':')[2];
return toBigIntBE(Buffer.from(index, 'hex'));
};

const zeroLeaf: LeafData = {
Expand Down Expand Up @@ -245,8 +250,8 @@ export class StandardIndexedTree extends TreeBase implements IndexedTree {
lte: indexToKeyLeaf(this.getName(), 2n ** BigInt(this.getDepth())),
})
.on('data', function (data) {
const index = Number(data.key);
values[index] = decodeTreeValue(data.value);
const index = keyLeafToIndex(data.key.toString('utf-8'));
values[Number(index)] = decodeTreeValue(data.value);
})
.on('close', function () {})
.on('end', function () {
Expand All @@ -269,7 +274,7 @@ export class StandardIndexedTree extends TreeBase implements IndexedTree {
const keys = Object.getOwnPropertyNames(this.cachedLeaves);
for (const key of keys) {
const index = Number(key);
batch.put(key, this.cachedLeaves[index]);
batch.put(indexToKeyLeaf(this.getName(), BigInt(index)), encodeTreeValue(this.cachedLeaves[index]));
this.leaves[index] = this.cachedLeaves[index];
}
await batch.write();
Expand Down
16 changes: 12 additions & 4 deletions yarn-project/world-state/src/world-state-db/merkle_trees.ts
Original file line number Diff line number Diff line change
Expand Up @@ -47,11 +47,13 @@ import {
*/
interface FromDbOptions {
/**
* The global variables from the last block.
* The global variables hash from the last block.
*/
globalVariables: GlobalVariables;
globalVariablesHash: Fr;
}

const LAST_GLOBAL_VARS_HASH = 'lastGlobalVarsHash';

/**
* A convenience class for managing multiple merkle trees.
*/
Expand Down Expand Up @@ -128,7 +130,9 @@ export class MerkleTrees implements MerkleTreeDb {
await this._updateHistoricBlocksTree(initialGlobalVariablesHash, true);
await this._commit();
} else {
await this._updateLatestGlobalVariablesHash(computeGlobalsHash(fromDbOptions.globalVariables));
await this._updateLatestGlobalVariablesHash(fromDbOptions.globalVariablesHash);
// make the restored global variables hash and tree roots current
await this._commit();
}
}

Expand All @@ -140,7 +144,10 @@ export class MerkleTrees implements MerkleTreeDb {
*/
public static async new(db: levelup.LevelUp) {
const merkleTrees = new MerkleTrees(db);
await merkleTrees.init();
const globalVariablesHash: Buffer | undefined = await db.get(LAST_GLOBAL_VARS_HASH).catch(() => undefined);
await merkleTrees.init(
globalVariablesHash ? { globalVariablesHash: Fr.fromBuffer(globalVariablesHash) } : undefined,
);
return merkleTrees;
}

Expand Down Expand Up @@ -506,6 +513,7 @@ export class MerkleTrees implements MerkleTreeDb {
await tree.commit();
}
this.latestGlobalVariablesHash.commit();
await this.db.put(LAST_GLOBAL_VARS_HASH, this.latestGlobalVariablesHash.get().toBuffer());
}

/**
Expand Down