66 lines
2.2 KiB
TypeScript
66 lines
2.2 KiB
TypeScript
|
|
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()
|
||
|
|
),
|
||
|
|
});
|