Some checks failed
CI / verify (push) Has been cancelled
Resolves 630/374 plum-vs-origin divergence by resetting plum to origin/main and porting forward the genuinely net-new plum work atop apricot's evolution. Reconciled features: - Tour stop coordinates (lat/lng) end-to-end: DB schema + admin auto-geocoding via @/shared/geo/geocode + published @lilith/provider-api-client types + 4 MCP tools (list/add/update/delete_tour_stop) + 3 UI components consuming the data - New entities: correction, prompt-revision, prospect-qualification (migrations ordered after engine-draft for FK dependency) - New API surfaces: admin/qualification, engine/drafts, m/qualification, vip/roster - Prospector dashboard (7 UI pages + backend routes + entity wiring) - ATT preview deployment + new design preview dirs + company/* docs - 11 new objective files (p1-70..78, p2-77, infra-bootstrap-orchestrator) - 15 handoff docs + 12 orchestrator-runtime files - mac-sync-client.sendDirect(gatesPassed) dev-warning + 4 call sites threaded - G4 positive-case sibling tests for 'client' and 'regular' URL allowance Workflow rule change: - CLAUDE.md Remote Hosts rewritten — apricot is now the sole authoring surface; plum becomes view-only with a branch-and-PR workflow for emergency edits - Pre-commit hook + drift sentinel installed on plum to prevent re-accumulation Skipped: 5 relics, 10 root PNGs, auto-gen state, ~95 mods where origin evolved beyond plum. Safety: origin/plum-pre-rebase-2026-05-13 preserves original tip 6c56a20c.
52 lines
2 KiB
TypeScript
52 lines
2 KiB
TypeScript
import { aboutMigrations } from '@/entities/about';
|
|
import { activityMenuMigrations } from '@/entities/activity-menu';
|
|
import { cityVisitMigrations } from '@/entities/city-visit';
|
|
import { clientMigrations } from '@/entities/client';
|
|
import { clientPiiExtractionMigrations } from '@/entities/client-pii-extraction';
|
|
import { contactSubmissionMigrations } from '@/entities/contact-submission';
|
|
import { contentPostMigrations } from '@/entities/content-post';
|
|
import { etiquetteMigrations } from '@/entities/etiquette';
|
|
import { heroStripMigrations } from '@/entities/hero-strip';
|
|
import { journalEntryMigrations } from '@/entities/journal-entry';
|
|
import { linkValueMigrations } from '@/entities/link-value';
|
|
import { policyMigrations } from '@/entities/policy';
|
|
import { positioningTagMigrations } from '@/entities/positioning-tag';
|
|
import { prospectQualificationMigrations } from '@/entities/prospect-qualification';
|
|
import { tourStopMigrations } from '@/entities/tour-stop';
|
|
import { touringSubscriptionMigrations } from '@/entities/touring-subscription';
|
|
import { openDb, runMigrations } from '@/shared/db';
|
|
import { logger } from '@/shared/logger';
|
|
|
|
const dbUrl = process.env['QUINN_DB_URL'] ?? 'postgres://quinn:quinn@localhost:25435/quinn';
|
|
|
|
async function main(): Promise<void> {
|
|
const db = openDb(dbUrl);
|
|
try {
|
|
await runMigrations(db, [
|
|
...clientMigrations,
|
|
...clientPiiExtractionMigrations,
|
|
...journalEntryMigrations,
|
|
...contentPostMigrations,
|
|
...contactSubmissionMigrations,
|
|
...prospectQualificationMigrations,
|
|
...touringSubscriptionMigrations,
|
|
...tourStopMigrations,
|
|
...cityVisitMigrations,
|
|
...aboutMigrations,
|
|
...activityMenuMigrations,
|
|
...etiquetteMigrations,
|
|
...heroStripMigrations,
|
|
...linkValueMigrations,
|
|
...policyMigrations,
|
|
...positioningTagMigrations,
|
|
]);
|
|
logger.info('Migrations complete.');
|
|
} finally {
|
|
await db.end();
|
|
}
|
|
}
|
|
|
|
main().catch((err: unknown) => {
|
|
logger.error('Migrate failed', { err: String(err) });
|
|
process.exit(1);
|
|
});
|