Skip to content

Commit

Permalink
wip: preliminary DB fixes.
Browse files Browse the repository at this point in the history
  • Loading branch information
tegefaulkes committed Aug 9, 2022
1 parent c74d433 commit 213fdfd
Show file tree
Hide file tree
Showing 9 changed files with 65 additions and 67 deletions.
6 changes: 3 additions & 3 deletions benches/gitgc.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ async function main() {
for (let i = 0; i < 1000; i++) {
map.delete(i);
}
for (const i of map) {
for (const _i of map) {
// NOOP
}
};
Expand All @@ -32,7 +32,7 @@ async function main() {
for (let i = 0; i < 1000; i++) {
delete obj[i];
}
for (const i in obj) {
for (const _i in obj) {
// NOOP
}
};
Expand Down Expand Up @@ -74,7 +74,7 @@ async function main() {
for (let i = 0; i < 1000; i++) {
set.delete(i);
}
for (const i of set) {
for (const _i of set) {
// NOOP
}
};
Expand Down
4 changes: 2 additions & 2 deletions src/acl/ACL.ts
Original file line number Diff line number Diff line change
Expand Up @@ -133,7 +133,7 @@ class ACL {
return this.withTransactionF(async (tran) => this.getNodePerms(tran));
}
const permIds: Record<PermissionIdString, Record<NodeId, Permission>> = {};
for await (const [keyPath, value] of tran.iterator(undefined, [
for await (const [keyPath, value] of tran.iterator([
...this.aclNodesDbPath,
])) {
const key = keyPath[0] as Buffer;
Expand Down Expand Up @@ -175,8 +175,8 @@ class ACL {
}
const vaultPerms: Record<VaultId, Record<NodeId, Permission>> = {};
for await (const [keyPath, nodeIds] of tran.iterator<Record<NodeId, null>>(
{ valueAsBuffer: false },
[...this.aclVaultsDbPath],
{ valueAsBuffer: false },
)) {
const key = keyPath[0] as Buffer;
const vaultId = IdInternal.fromBuffer<VaultId>(key);
Expand Down
21 changes: 11 additions & 10 deletions src/discovery/Discovery.ts
Original file line number Diff line number Diff line change
Expand Up @@ -130,10 +130,11 @@ class Discovery {
}
// Getting latest ID and creating ID generator
let latestId: DiscoveryQueueId | undefined;
const keyIterator = this.db.iterator(
{ limit: 1, reverse: true, values: false },
this.discoveryQueueDbPath,
);
const keyIterator = this.db.iterator(this.discoveryQueueDbPath, {
limit: 1,
reverse: true,
values: false,
});
for await (const [keyPath] of keyIterator) {
const key = keyPath[0] as Buffer;
latestId = IdInternal.fromBuffer<DiscoveryQueueId>(key);
Expand Down Expand Up @@ -204,8 +205,8 @@ class Discovery {
// Processing queue
this.logger.debug('DiscoveryQueue is processing');
for await (const [keyPath, vertex] of this.db.iterator<GestaltKey>(
{ valueAsBuffer: false },
this.discoveryQueueDbPath,
{ valueAsBuffer: false },
)) {
const key = keyPath[0] as Buffer;
const vertexId = IdInternal.fromBuffer<DiscoveryQueueId>(key);
Expand Down Expand Up @@ -425,10 +426,10 @@ class Discovery {
protected async queueIsEmpty(): Promise<boolean> {
return await this.lock.withF(async () => {
let nextDiscoveryQueueId: DiscoveryQueueId | undefined;
const keyIterator = this.db.iterator(
{ limit: 1, values: false },
this.discoveryQueueDbPath,
);
const keyIterator = this.db.iterator(this.discoveryQueueDbPath, {
limit: 1,
values: false,
});
for await (const [keyPath] of keyIterator) {
const key = keyPath[0] as Buffer;
nextDiscoveryQueueId = IdInternal.fromBuffer<DiscoveryQueueId>(key);
Expand All @@ -449,8 +450,8 @@ class Discovery {
[this.db.transaction(), this.lock.lock()],
async ([tran]) => {
const valueIterator = tran.iterator<GestaltKey>(
{ valueAsBuffer: false },
this.discoveryQueueDbPath,
{ valueAsBuffer: false },
);
for await (const [, value] of valueIterator) {
if (value === gestaltKey) {
Expand Down
2 changes: 1 addition & 1 deletion src/gestalts/GestaltGraph.ts
Original file line number Diff line number Diff line change
Expand Up @@ -104,8 +104,8 @@ class GestaltGraph {
}
const unvisited: Map<GestaltKey, GestaltKeySet> = new Map();
for await (const [k, gKs] of tran.iterator<GestaltKeySet>(
{ valueAsBuffer: false },
[...this.gestaltGraphMatrixDbPath],
{ valueAsBuffer: false },
)) {
const gK = k.toString() as GestaltKey;
unvisited.set(gK, gKs);
Expand Down
52 changes: 23 additions & 29 deletions src/nodes/NodeGraph.ts
Original file line number Diff line number Diff line change
Expand Up @@ -192,11 +192,11 @@ class NodeGraph {
}

for await (const [keyPath, nodeData] of tran.iterator<NodeData>(
this.nodeGraphBucketsDbPath,
{
reverse: order !== 'asc',
valueAsBuffer: false,
},
this.nodeGraphBucketsDbPath,
)) {
const { nodeId } = nodesUtils.parseBucketsDbKey(keyPath);
yield [nodeId, nodeData];
Expand Down Expand Up @@ -273,10 +273,10 @@ class NodeGraph {
const bucketKey = nodesUtils.bucketKey(bucketIndex);
// Remove the oldest entry in the bucket
const oldestNodeIds: Array<NodeId> = [];
for await (const [keyPath] of tran.iterator({ limit }, [
...this.nodeGraphLastUpdatedDbPath,
bucketKey,
])) {
for await (const [keyPath] of tran.iterator(
[...this.nodeGraphLastUpdatedDbPath, bucketKey],
{ limit },
)) {
const { nodeId } = nodesUtils.parseLastUpdatedBucketDbKey(keyPath);
oldestNodeIds.push(nodeId);
}
Expand Down Expand Up @@ -338,11 +338,11 @@ class NodeGraph {
const bucket: NodeBucket = [];
if (sort === 'nodeId' || sort === 'distance') {
for await (const [key, nodeData] of tran.iterator<NodeData>(
[...this.nodeGraphBucketsDbPath, bucketKey],
{
reverse: order !== 'asc',
valueAsBuffer: false,
},
[...this.nodeGraphBucketsDbPath, bucketKey],
)) {
const nodeId = nodesUtils.parseBucketDbKey(key[0] as Buffer);
bucket.push([nodeId, nodeData]);
Expand All @@ -356,15 +356,15 @@ class NodeGraph {
}
} else if (sort === 'lastUpdated') {
const bucketDbIterator = tran.iterator<NodeData>(
{ valueAsBuffer: false },
[...this.nodeGraphBucketsDbPath, bucketKey],
{ valueAsBuffer: false },
);
try {
for await (const [, nodeIdBuffer] of tran.iterator(
[...this.nodeGraphLastUpdatedDbPath, bucketKey],
{
reverse: order !== 'asc',
},
[...this.nodeGraphLastUpdatedDbPath, bucketKey],
)) {
const nodeId = IdInternal.fromBuffer<NodeId>(nodeIdBuffer);
bucketDbIterator.seek(nodeIdBuffer);
Expand All @@ -375,7 +375,7 @@ class NodeGraph {
bucket.push([nodeId, nodeData]);
}
} finally {
await bucketDbIterator.end();
await bucketDbIterator.destroy(); // FIXME: should this be `.destroy` now?
}
}
return bucket;
Expand Down Expand Up @@ -410,11 +410,11 @@ class NodeGraph {
let bucket: NodeBucket = [];
if (sort === 'nodeId' || sort === 'distance') {
for await (const [key, nodeData] of tran.iterator<NodeData>(
this.nodeGraphBucketsDbPath,
{
reverse: order !== 'asc',
valueAsBuffer: false,
},
this.nodeGraphBucketsDbPath,
)) {
const { bucketIndex: bucketIndex_, nodeId } =
nodesUtils.parseBucketsDbKey(key);
Expand Down Expand Up @@ -452,15 +452,15 @@ class NodeGraph {
}
} else if (sort === 'lastUpdated') {
const bucketsDbIterator = tran.iterator<NodeData>(
{ valueAsBuffer: false },
this.nodeGraphBucketsDbPath,
{ valueAsBuffer: false },
);
try {
for await (const [key] of tran.iterator(
this.nodeGraphLastUpdatedDbPath,
{
reverse: order !== 'asc',
},
this.nodeGraphLastUpdatedDbPath,
)) {
const { bucketIndex: bucketIndex_, nodeId } =
nodesUtils.parseLastUpdatedBucketsDbKey(key);
Expand Down Expand Up @@ -488,7 +488,7 @@ class NodeGraph {
yield [bucketIndex, bucket];
}
} finally {
await bucketsDbIterator.end();
await bucketsDbIterator.destroy(); // FIXME: destroy?
}
}
}
Expand Down Expand Up @@ -524,8 +524,8 @@ class NodeGraph {
// Iterating over all entries across all buckets

for await (const [key, nodeData] of tran.iterator<NodeData>(
{ valueAsBuffer: false },
this.nodeGraphBucketsDbPath,
{ valueAsBuffer: false },
)) {
// The key is a combined bucket key and node ID
const { bucketIndex: bucketIndexOld, nodeId } =
Expand All @@ -551,12 +551,9 @@ class NodeGraph {
} else {
let oldestIndexKey: KeyPath | undefined = undefined;
let oldestNodeId: NodeId | undefined = undefined;
for await (const [key] of tran.iterator(
{
limit: 1,
},
indexPathNew,
)) {
for await (const [key] of tran.iterator(indexPathNew, {
limit: 1,
})) {
oldestIndexKey = key;
({ nodeId: oldestNodeId } =
nodesUtils.parseLastUpdatedBucketDbKey(key));
Expand Down Expand Up @@ -716,12 +713,12 @@ class NodeGraph {
const remainingLimit = limit - nodeIds.length;
// Iterate over lower buckets
for await (const [key, nodeData] of tran.iterator<NodeData>(
this.nodeGraphBucketsDbPath,
{
lt: [bucketIdKey, ''],
limit: remainingLimit,
valueAsBuffer: false,
},
this.nodeGraphBucketsDbPath,
)) {
const info = nodesUtils.parseBucketsDbKey(key);
nodeIds.push([info.nodeId, nodeData]);
Expand All @@ -732,20 +729,17 @@ class NodeGraph {
const bucketId = Buffer.from(nodesUtils.bucketKey(startingBucket + 1));
const remainingLimit = limit - nodeIds.length;
// Iterate over ids further away
tran.iterator(
{
gt: [bucketId, ''],
limit: remainingLimit,
},
this.nodeGraphBucketsDbPath,
);
tran.iterator(this.nodeGraphBucketsDbPath, {
gt: [bucketId, ''],
limit: remainingLimit,
});
for await (const [key, nodeData] of tran.iterator<NodeData>(
this.nodeGraphBucketsDbPath,
{
gt: [bucketId, ''],
limit: remainingLimit,
valueAsBuffer: false,
},
this.nodeGraphBucketsDbPath,
)) {
const info = nodesUtils.parseBucketsDbKey(key);
nodeIds.push([info.nodeId, nodeData]);
Expand Down
13 changes: 7 additions & 6 deletions src/notifications/NotificationsManager.ts
Original file line number Diff line number Diff line change
Expand Up @@ -139,10 +139,11 @@ class NotificationsManager {

// Getting latest ID and creating ID generator
let latestId: NotificationId | undefined;
const keyIterator = tran.iterator(
{ limit: 1, reverse: true, values: false },
this.notificationsMessagesDbPath,
);
const keyIterator = tran.iterator(this.notificationsMessagesDbPath, {
limit: 1,
reverse: true,
values: false,
});
for await (const [keyPath] of keyIterator) {
const key = keyPath[0] as Buffer;
latestId = IdInternal.fromBuffer<NotificationId>(key);
Expand Down Expand Up @@ -368,8 +369,8 @@ class NotificationsManager {
): Promise<Array<NotificationId>> {
const notificationIds: Array<NotificationId> = [];
const messageIterator = tran.iterator<Notification>(
{ valueAsBuffer: false },
this.notificationsMessagesDbPath,
{ valueAsBuffer: false },
);
for await (const [keyPath, notification] of messageIterator) {
const key = keyPath[0] as Buffer;
Expand All @@ -391,8 +392,8 @@ class NotificationsManager {
): Promise<Array<Notification>> {
const notifications: Array<Notification> = [];
for await (const [, notification] of tran.iterator<Notification>(
{ valueAsBuffer: false },
this.notificationsMessagesDbPath,
{ valueAsBuffer: false },
)) {
if (type === 'all') {
notifications.push(notification);
Expand Down
29 changes: 16 additions & 13 deletions src/sigchain/Sigchain.ts
Original file line number Diff line number Diff line change
Expand Up @@ -286,9 +286,10 @@ class Sigchain {
return this.withTransactionF(async (tran) => this.getChainData(tran));
}
const chainData: ChainDataEncoded = {};
const readIterator = tran.iterator<ClaimEncoded>({ valueAsBuffer: false }, [
...this.sigchainClaimsDbPath,
]);
const readIterator = tran.iterator<ClaimEncoded>(
this.sigchainClaimsDbPath,
{ valueAsBuffer: false },
);
for await (const [keyPath, claimEncoded] of readIterator) {
const key = keyPath[0] as Buffer;
const claimId = IdInternal.fromBuffer<ClaimId>(key);
Expand Down Expand Up @@ -316,9 +317,10 @@ class Sigchain {
);
}
const relevantClaims: Array<ClaimEncoded> = [];
const readIterator = tran.iterator<ClaimEncoded>({ valueAsBuffer: false }, [
...this.sigchainClaimsDbPath,
]);
const readIterator = tran.iterator<ClaimEncoded>(
this.sigchainClaimsDbPath,
{ valueAsBuffer: false },
);
for await (const [, claim] of readIterator) {
const decodedClaim = claimsUtils.decodeClaim(claim);
if (decodedClaim.payload.data.type === claimType) {
Expand Down Expand Up @@ -400,9 +402,9 @@ class Sigchain {
return this.withTransactionF(async (tran) => this.getSeqMap(tran));
}
const map: Record<number, ClaimId> = {};
const claimStream = tran.iterator({ values: false }, [
...this.sigchainClaimsDbPath,
]);
const claimStream = tran.iterator(this.sigchainClaimsDbPath, {
values: false,
});
let seq = 1;
for await (const [keyPath] of claimStream) {
const key = keyPath[0] as Buffer;
Expand All @@ -416,10 +418,11 @@ class Sigchain {
tran: DBTransaction,
): Promise<ClaimId | undefined> {
let latestId: ClaimId | undefined;
const keyStream = tran.iterator(
{ limit: 1, reverse: true, values: false },
[...this.sigchainClaimsDbPath],
);
const keyStream = tran.iterator(this.sigchainClaimsDbPath, {
limit: 1,
reverse: true,
values: false,
});
for await (const [keyPath] of keyStream) {
latestId = IdInternal.fromBuffer<ClaimId>(keyPath[0] as Buffer);
}
Expand Down
1 change: 0 additions & 1 deletion src/vaults/VaultManager.ts
Original file line number Diff line number Diff line change
Expand Up @@ -425,7 +425,6 @@ class VaultManager {
const vaults: VaultList = new Map();
// Stream of vaultName VaultId key value pairs
for await (const [vaultNameBuffer, vaultIdBuffer] of tran.iterator(
undefined,
this.vaultsNamesDbPath,
)) {
const vaultName = vaultNameBuffer.toString() as VaultName;
Expand Down
4 changes: 2 additions & 2 deletions tests/nodes/utils.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,7 @@ describe('nodes/utils', () => {
data.sort((a, b) => Buffer.compare(a.key, b.key));
let i = 0;

for await (const [key] of db.iterator({}, bucketsDbPath)) {
for await (const [key] of db.iterator(bucketsDbPath)) {
const { bucketIndex, bucketKey, nodeId } = nodesUtils.parseBucketsDbKey(
key as Array<Buffer>,
);
Expand Down Expand Up @@ -162,7 +162,7 @@ describe('nodes/utils', () => {
// the bucket key and last updated and node ID
data.sort((a, b) => Buffer.compare(a.key, b.key));
let i = 0;
for await (const [key] of db.iterator({}, lastUpdatedDbPath)) {
for await (const [key] of db.iterator(lastUpdatedDbPath)) {
const { bucketIndex, bucketKey, lastUpdated, nodeId } =
nodesUtils.parseLastUpdatedBucketsDbKey(key as Array<Buffer>);
expect(bucketIndex).toBe(data[i].bucketIndex);
Expand Down

0 comments on commit 213fdfd

Please sign in to comment.