From 8704ef04e438f6bfc994b1b23d00f6dc8b6e9480 Mon Sep 17 00:00:00 2001 From: Juan P Lopez Date: Thu, 7 Nov 2024 10:07:44 -0500 Subject: [PATCH 1/2] chore: add debug script to fix journals consistency --- .../debug/populate-journal-transactions.ts | 88 +++++++++++++++++++ 1 file changed, 88 insertions(+) create mode 100644 core/api/src/debug/populate-journal-transactions.ts diff --git a/core/api/src/debug/populate-journal-transactions.ts b/core/api/src/debug/populate-journal-transactions.ts new file mode 100644 index 0000000000..7872ec1e29 --- /dev/null +++ b/core/api/src/debug/populate-journal-transactions.ts @@ -0,0 +1,88 @@ +/** + * how to run: + * pnpm tsx src/debug/populate-journal-transactions.ts + */ + +import { setupMongoConnection } from "@/services/mongodb" +import { Transaction } from "@/services/ledger/schema" +import mongoose from "mongoose" + +const Journal = mongoose.connection.models["Medici_Journal"] + +const populateJournalTransactions = async (startingJournalId: string) => { + console.log("Starting from journal ID:", startingJournalId) + + const journals = Journal.find({ + _id: { $gte: new mongoose.Types.ObjectId(startingJournalId) }, + $or: [{ _transactions: { $size: 0 } }, { _transactions: { $exists: false } }], + }).cursor() + + let processedCount = 0 + let updatedCount = 0 + let startTime = Date.now() + + for await (const journal of journals) { + processedCount++ + + // Find transactions for this journal + const transactions = await Transaction.find({ _journal: journal._id }, { _id: 1 }) + + if (transactions.length <= 0) { + console.error(`No transactions found for journal ${journal._id}`) + continue + } + + // Update journal + const transactionIds = transactions.map((tx) => tx._id) + await Journal.updateOne( + { _id: journal._id }, + { $set: { _transactions: transactionIds } }, + ) + updatedCount++ + + // Log progress every 100 journals + if (processedCount % 100 === 0) { + const timeElapsed = (Date.now() - startTime) / 1000 + console.log(` + Processed: ${processedCount} journals + Updated: ${updatedCount} journals + Time elapsed: ${timeElapsed.toFixed(2)}s + Current journal ID: ${journal._id} + `) + } + } + + const totalTimeElapsed = (Date.now() - startTime) / 1000 + console.log(` + Finished! + Total processed: ${processedCount} + Total updated: ${updatedCount} + Total time: ${totalTimeElapsed.toFixed(2)}s + `) + + return { processedCount, updatedCount } +} + +const main = async () => { + const args = process.argv.slice(-1) + const startingJournalId = args[0] + + if (!startingJournalId) { + console.error("Please provide a starting journal ID") + process.exit(1) + } + + try { + const result = await populateJournalTransactions(startingJournalId) + console.log("Result:", result) + } catch (err) { + console.error("Error:", err) + } +} + +setupMongoConnection() + .then(async (mongoose) => { + await main() + if (mongoose) await mongoose.connection.close() + }) + .catch((err) => console.log(err)) From bdeaf821a4c3b812e63a0341d5d2c0a13ba89b0d Mon Sep 17 00:00:00 2001 From: Juan P Lopez Date: Thu, 7 Nov 2024 14:07:26 -0500 Subject: [PATCH 2/2] fix: lint issues --- core/api/src/debug/populate-journal-transactions.ts | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/core/api/src/debug/populate-journal-transactions.ts b/core/api/src/debug/populate-journal-transactions.ts index 7872ec1e29..d86d3f7b3f 100644 --- a/core/api/src/debug/populate-journal-transactions.ts +++ b/core/api/src/debug/populate-journal-transactions.ts @@ -3,9 +3,10 @@ * pnpm tsx src/debug/populate-journal-transactions.ts */ +import mongoose from "mongoose" + import { setupMongoConnection } from "@/services/mongodb" import { Transaction } from "@/services/ledger/schema" -import mongoose from "mongoose" const Journal = mongoose.connection.models["Medici_Journal"] @@ -19,7 +20,7 @@ const populateJournalTransactions = async (startingJournalId: string) => { let processedCount = 0 let updatedCount = 0 - let startTime = Date.now() + const startTime = Date.now() for await (const journal of journals) { processedCount++