Skip to content

Commit

Permalink
Revert "fix: use the last most record in the DB as the balance snapsh…
Browse files Browse the repository at this point in the history
…ot upper boundary"

This reverts commit d37951d.
  • Loading branch information
koresar committed May 15, 2024
1 parent d37951d commit eaa0f48
Showing 1 changed file with 5 additions and 7 deletions.
12 changes: 5 additions & 7 deletions src/Book.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ const GROUP = {
_id: null,
balance: { $sum: { $subtract: ["$credit", "$debit"] } },
notes: { $sum: 1 },
lastTransactionId: { $max: "$_id" },
},
};

Expand Down Expand Up @@ -109,9 +110,6 @@ export class Book<U extends ITransaction = ITransaction, J extends IJournal = IJ
const partialBalanceOptions = { ...options };
// If using a balance snapshot then make sure to use the appropriate (default "_id_") index for the additional balance calc.
if (parsedQuery._id) partialBalanceOptions.hint = { _id: 1 };
const lastCheckedTransaction = await transactionModel.collection
.findOne({}, { ...partialBalanceOptions, projection: { _id: 1 }, sort: { _id: -1 } });
const lastCheckedTransactionId = lastCheckedTransaction?._id;
const result = (await transactionModel.collection.aggregate([match, GROUP], partialBalanceOptions).toArray())[0];

let balance = 0;
Expand All @@ -126,8 +124,8 @@ export class Book<U extends ITransaction = ITransaction, J extends IJournal = IJ
balance += parseFloat(result.balance.toFixed(this.precision));
notes += result.notes;

// We can do snapshots only if there is at least one entry
if (this.balanceSnapshotSec && lastCheckedTransactionId) {
// We can do snapshots only if there is at least one entry for this balance
if (this.balanceSnapshotSec && result.lastTransactionId) {
// It's the first (ever?) snapshot for this balance. We just need to save whatever we've just aggregated
// so that the very next balance query would use cached snapshot.
if (!balanceSnapshot) {
Expand All @@ -136,7 +134,7 @@ export class Book<U extends ITransaction = ITransaction, J extends IJournal = IJ
book: this.name,
account: accountForBalanceSnapshot,
meta,
transaction: lastCheckedTransactionId,
transaction: result.lastTransactionId,
balance,
notes,
expireInSec: this.expireBalanceSnapshotSec,
Expand Down Expand Up @@ -168,7 +166,7 @@ export class Book<U extends ITransaction = ITransaction, J extends IJournal = IJ
book: this.name,
account: accountForBalanceSnapshot,
meta,
transaction: lastCheckedTransactionId,
transaction: resultFull.lastTransactionId,
balance: parseFloat(resultFull.balance.toFixed(this.precision)),
notes: resultFull.notes,
expireInSec: this.expireBalanceSnapshotSec,
Expand Down

0 comments on commit eaa0f48

Please sign in to comment.