import { mysqlTable, varchar, text, timestamp, boolean, } from "drizzle-orm/mysql-core"; export const custom_user = mysqlTable("custom_user", { id: varchar("id", { length: 36 }).primaryKey(), name: text("name").notNull(), email: varchar("email", { length: 255 }).notNull().unique(), emailVerified: boolean("email_verified").default(false).notNull(), image: text("image"), createdAt: timestamp("created_at", { fsp: 3 }).defaultNow().notNull(), updatedAt: timestamp("updated_at", { fsp: 3 }) .defaultNow() .$onUpdate(() => /* @__PURE__ */ new Date()) .notNull(), twoFactorEnabled: boolean("two_factor_enabled").default(false), username: varchar("username", { length: 255 }).unique(), displayUsername: text("display_username"), }); export const custom_session = mysqlTable("custom_session", { id: varchar("id", { length: 36 }).primaryKey(), expiresAt: timestamp("expires_at", { fsp: 3 }).notNull(), token: varchar("token", { length: 255 }).notNull().unique(), createdAt: timestamp("created_at", { fsp: 3 }).defaultNow().notNull(), updatedAt: timestamp("updated_at", { fsp: 3 }) .$onUpdate(() => /* @__PURE__ */ new Date()) .notNull(), ipAddress: text("ip_address"), userAgent: text("user_agent"), userId: varchar("user_id", { length: 36 }) .notNull() .references(() => custom_user.id, { onDelete: "cascade" }), }); export const custom_account = mysqlTable("custom_account", { id: varchar("id", { length: 36 }).primaryKey(), accountId: text("account_id").notNull(), providerId: text("provider_id").notNull(), userId: varchar("user_id", { length: 36 }) .notNull() .references(() => custom_user.id, { onDelete: "cascade" }), accessToken: text("access_token"), refreshToken: text("refresh_token"), idToken: text("id_token"), accessTokenExpiresAt: timestamp("access_token_expires_at", { fsp: 3 }), refreshTokenExpiresAt: timestamp("refresh_token_expires_at", { fsp: 3 }), scope: text("scope"), password: text("password"), createdAt: timestamp("created_at", { fsp: 3 }).defaultNow().notNull(), updatedAt: timestamp("updated_at", { fsp: 3 }) .$onUpdate(() => /* @__PURE__ */ new Date()) .notNull(), }); export const custom_verification = mysqlTable("custom_verification", { id: varchar("id", { length: 36 }).primaryKey(), identifier: text("identifier").notNull(), value: text("value").notNull(), expiresAt: timestamp("expires_at", { fsp: 3 }).notNull(), createdAt: timestamp("created_at", { fsp: 3 }).defaultNow().notNull(), updatedAt: timestamp("updated_at", { fsp: 3 }) .defaultNow() .$onUpdate(() => /* @__PURE__ */ new Date()) .notNull(), }); export const twoFactor = mysqlTable("two_factor", { id: varchar("id", { length: 36 }).primaryKey(), secret: text("secret").notNull(), backupCodes: text("backup_codes").notNull(), userId: varchar("user_id", { length: 36 }) .notNull() .references(() => custom_user.id, { onDelete: "cascade" }), });