Files
FrenoCorp/scripts/export-waitlist.mjs
Michael Freno 6183557e95 Add waitlist export scripts for Mailchimp import (FRE-650)
Created export scripts that query the Turso database and produce CSV/JSON
exports compatible with Mailchimp contact import. CMO can run these once
they have database credentials.

Co-Authored-By: Paperclip <noreply@paperclip.ing>
2026-04-26 08:00:01 -04:00

59 lines
1.8 KiB
JavaScript

import { createClient } from "@libsql/client";
import { drizzle } from "drizzle-orm/libsql";
import { waitlistSignups } from "../src/db/schema/waitlist.js";
import * as schema from "../src/db/schema/index.js";
import { writeFile } from "fs/promises";
const DB_URL = process.env.TURSO_DATABASE_URL;
const AUTH_TOKEN = process.env.TURSO_AUTH_TOKEN;
if (!DB_URL) {
console.error("TURSO_DATABASE_URL is required");
process.exit(1);
}
async function exportWaitlist() {
const client = createClient({ url: DB_URL, authToken: AUTH_TOKEN });
const db = drizzle(client, { schema });
const signups = await db.select().from(waitlistSignups).orderBy(waitlistSignups.createdAt);
if (signups.length === 0) {
console.log("No waitlist signups found.");
await client.close();
return;
}
const jsonData = signups.map(s => ({
id: s.id,
email: s.email,
name: s.name,
source: s.source,
status: s.status,
metadata: s.metadata ? JSON.parse(s.metadata) : null,
createdAt: s.createdAt,
updatedAt: s.updatedAt,
}));
const csvHeader = "id,email,name,source,status,metadata,createdAt,updatedAt";
const csvRows = signups.map(s => {
const meta = s.metadata ? `"${s.metadata.replace(/"/g, '""')}"` : "";
return `${s.id},"${s.email}","${s.name || ""}","${s.source}","${s.status}",${meta},"${s.createdAt}","${s.updatedAt}"`;
});
const csv = [csvHeader, ...csvRows].join("\n");
await writeFile("waitlist-export.json", JSON.stringify(jsonData, null, 2));
await writeFile("waitlist-export.csv", csv);
console.log(`Exported ${signups.length} signups`);
console.log(" waitlist-export.json");
console.log(" waitlist-export.csv");
await client.close();
}
exportWaitlist().catch(err => {
console.error("Export failed:", err.message);
process.exit(1);
});