48 lines
1.7 KiB
TypeScript
48 lines
1.7 KiB
TypeScript
import { pgTable, text, timestamp, boolean } from 'drizzle-orm/pg-core';
|
|
|
|
export const user = pgTable('user', {
|
|
id: text('id').primaryKey(),
|
|
name: text('name'),
|
|
email: text('email').notNull().unique(),
|
|
emailVerified: boolean('emailVerified').default(false),
|
|
image: text('image'),
|
|
createdAt: timestamp('createdAt').defaultNow(),
|
|
updatedAt: timestamp('updatedAt').defaultNow(),
|
|
});
|
|
|
|
export const session = pgTable('session', {
|
|
id: text('id').primaryKey(),
|
|
expiresAt: timestamp('expiresAt').notNull(),
|
|
token: text('token').notNull().unique(),
|
|
createdAt: timestamp('createdAt').defaultNow(),
|
|
updatedAt: timestamp('updatedAt').defaultNow(),
|
|
ipAddress: text('ipAddress'),
|
|
userAgent: text('userAgent'),
|
|
userId: text('userId').notNull().references(() => user.id, { onDelete: 'cascade' }),
|
|
});
|
|
|
|
export const account = pgTable('account', {
|
|
id: text('id').primaryKey(),
|
|
accountId: text('accountId').notNull(),
|
|
providerId: text('providerId').notNull(),
|
|
userId: text('userId').notNull().references(() => user.id, { onDelete: 'cascade' }),
|
|
accessToken: text('accessToken'),
|
|
refreshToken: text('refreshToken'),
|
|
accessTokenExpiresAt: timestamp('accessTokenExpiresAt'),
|
|
refreshTokenExpiresAt: timestamp('refreshTokenExpiresAt'),
|
|
scope: text('scope'),
|
|
idToken: text('idToken'),
|
|
password: text('password'),
|
|
createdAt: timestamp('createdAt').defaultNow(),
|
|
updatedAt: timestamp('updatedAt').defaultNow(),
|
|
});
|
|
|
|
export const verification = pgTable('verification', {
|
|
id: text('id').primaryKey(),
|
|
identifier: text('identifier').notNull(),
|
|
value: text('value').notNull(),
|
|
expiresAt: timestamp('expiresAt').notNull(),
|
|
createdAt: timestamp('createdAt').defaultNow(),
|
|
updatedAt: timestamp('updatedAt').defaultNow(),
|
|
});
|