import { relations } from "drizzle-orm" import { boolean, integer, pgTable, text, timestamp } from "drizzle-orm/pg-core" export const user = pgTable("user", { id: text("id").primaryKey(), name: text("name").notNull(), email: text("email").notNull().unique(), emailVerified: boolean("email_verified").$defaultFn(() => false).notNull(), image: text("image"), createdAt: timestamp("created_at").$defaultFn(() => new Date()).notNull(), updatedAt: timestamp("updated_at").$defaultFn(() => new Date()).notNull() }) export const session = pgTable("session", { id: text("id").primaryKey(), expiresAt: timestamp("expires_at").notNull(), token: text("token").notNull().unique(), createdAt: timestamp("created_at").notNull(), updatedAt: timestamp("updated_at").notNull(), ipAddress: text("ip_address"), userAgent: text("user_agent"), userId: text("user_id").notNull().references(() => user.id, { onDelete: "cascade" }) }) export const account = pgTable("account", { id: text("id").primaryKey(), accountId: text("account_id").notNull(), providerId: text("provider_id").notNull(), userId: text("user_id").notNull().references(() => user.id, { onDelete: "cascade" }), accessToken: text("access_token"), refreshToken: text("refresh_token"), idToken: text("id_token"), accessTokenExpiresAt: timestamp("access_token_expires_at"), refreshTokenExpiresAt: timestamp("refresh_token_expires_at"), scope: text("scope"), password: text("password"), createdAt: timestamp("created_at").notNull(), updatedAt: timestamp("updated_at").notNull() }) export const verification = pgTable("verification", { id: text("id").primaryKey(), identifier: text("identifier").notNull(), value: text("value").notNull(), expiresAt: timestamp("expires_at").notNull(), createdAt: timestamp("created_at").$defaultFn(() => new Date()), updatedAt: timestamp("updated_at").$defaultFn(() => new Date()) }) export const passkey = pgTable("passkey", { id: text("id").primaryKey(), name: text("name"), publicKey: text("public_key").notNull(), userId: text("user_id").notNull().references(() => user.id, { onDelete: "cascade" }), credentialID: text("credential_i_d").notNull(), counter: integer("counter").notNull(), deviceType: text("device_type").notNull(), backedUp: boolean("backed_up").notNull(), transports: text("transports"), createdAt: timestamp("created_at"), aaguid: text("aaguid") }) export const userRelations = relations(user, ({ many }) => ({ accounts: many(account), passkeys: many(passkey), sessions: many(session) })) export const accountRelations = relations(account, ({ one }) => ({ user: one(user, { fields: [account.userId], references: [user.id] }) })) export const passkeyRelations = relations(passkey, ({ one }) => ({ user: one(user, { fields: [passkey.userId], references: [user.id] }) })) export const sessionRelations = relations(session, ({ one }) => ({ user: one(user, { fields: [session.userId], references: [user.id] }) }))