import { boolean, pgEnum, pgTable, text, timestamp } from 'drizzle-orm/pg-core'; export const userRoleEnum = pgEnum('user_role', ['admin', 'user']); export const userTable = pgTable('user_table', { id: text('id').primaryKey(), name: text('name').notNull(), email: text('email').notNull().unique(), emailVerified: boolean('email_verified') .$defaultFn(() => false) .notNull(), role: userRoleEnum('role').default('user'), isActive: boolean('is_active').default(true), image: text('image'), createdAt: timestamp('created_at') .$defaultFn(() => /* @__PURE__ */ new Date()) .notNull(), updatedAt: timestamp('updated_at') .$defaultFn(() => /* @__PURE__ */ new Date()) .notNull(), }); export const sessionTable = pgTable('session_table', { 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(() => userTable.id, { onDelete: 'cascade' }), }); export const accountTable = pgTable('account_table', { id: text('id').primaryKey(), accountId: text('account_id').notNull(), providerId: text('provider_id').notNull(), userId: text('user_id') .notNull() .references(() => userTable.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( () => /* @__PURE__ */ new Date() ), updatedAt: timestamp('updated_at').$defaultFn( () => /* @__PURE__ */ new Date() ), });