tractatus/scripts/fix-category-mismatches.js
TheFlow ac2db33732 fix(submissions): restructure Economist package and fix article display
- Create Economist SubmissionTracking package correctly:
  * mainArticle = full blog post content
  * coverLetter = 216-word SIR— letter
  * Links to blog post via blogPostId
- Archive 'Letter to The Economist' from blog posts (it's the cover letter)
- Fix date display on article cards (use published_at)
- Target publication already displaying via blue badge

Database changes:
- Make blogPostId optional in SubmissionTracking model
- Economist package ID: 68fa85ae49d4900e7f2ecd83
- Le Monde package ID: 68fa2abd2e6acd5691932150

Next: Enhanced modal with tabs, validation, export

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-24 08:47:42 +13:00

79 lines
2.2 KiB
JavaScript

#!/usr/bin/env node
/**
* Fix Category Mismatches Between Dev and Prod
*
* Harmonizes document categories to canonical values based on document content and purpose
*/
require('dotenv').config();
const { getDb } = require('../src/utils/db.util');
// Canonical category assignments (based on content analysis)
const categoryFixes = {
'architectural-overview-and-research-status': 'research-theory',
'comparison-matrix-claude-code-claudemd-and-tractatus-framework': 'technical-reference',
'executive-brief-tractatus-based-llm-architecture-for-ai-safety': 'research-theory',
'pluralistic-values-research-foundations': 'advanced-topics'
};
async function fixCategoryMismatches() {
console.log('🔧 Fixing category mismatches...\n');
const db = await getDb();
const collection = db.collection('documents');
let fixedCount = 0;
let notFoundCount = 0;
for (const [slug, correctCategory] of Object.entries(categoryFixes)) {
try {
const doc = await collection.findOne({ slug });
if (!doc) {
console.log(`⚠️ Not found: ${slug}`);
notFoundCount++;
continue;
}
if (doc.category === correctCategory) {
console.log(`✓ Already correct: ${slug} (${correctCategory})`);
continue;
}
// Update category
await collection.updateOne(
{ slug },
{
$set: {
category: correctCategory,
'metadata.date_updated': new Date()
}
}
);
console.log(`✅ Fixed: ${slug}`);
console.log(` ${doc.category || 'none'}${correctCategory}\n`);
fixedCount++;
} catch (error) {
console.error(`❌ Error fixing ${slug}:`, error.message);
}
}
console.log('='.repeat(60));
console.log('📊 Summary:');
console.log('='.repeat(60));
console.log(`Total documents to fix: ${Object.keys(categoryFixes).length}`);
console.log(`✅ Fixed: ${fixedCount}`);
console.log(`⚠️ Not found: ${notFoundCount}`);
console.log(`✓ Already correct: ${Object.keys(categoryFixes).length - fixedCount - notFoundCount}`);
console.log('='.repeat(60));
process.exit(0);
}
// Run fix
fixCategoryMismatches().catch(error => {
console.error('❌ Fix failed:', error);
process.exit(1);
});