19 lines
606 B
TypeScript
19 lines
606 B
TypeScript
import { sql } from "drizzle-orm";
|
|
import { index, integer, sqliteTable, text } from "drizzle-orm/sqlite-core";
|
|
|
|
export const reminder = sqliteTable(
|
|
"reminder",
|
|
{
|
|
id: text("id").primaryKey(), // UUID
|
|
email: text("email").notNull(),
|
|
sentAt: integer("sent_at", { mode: "timestamp_ms" }),
|
|
createdAt: integer("created_at", { mode: "timestamp_ms" })
|
|
.default(sql`(cast(unixepoch('subsecond') * 1000 as integer))`)
|
|
.notNull(),
|
|
},
|
|
(t) => [index("reminder_email_idx").on(t.email)],
|
|
);
|
|
|
|
export type Reminder = typeof reminder.$inferSelect;
|
|
export type NewReminder = typeof reminder.$inferInsert;
|