95 lines
3.6 KiB
TypeScript
95 lines
3.6 KiB
TypeScript
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').notNull(),
|
|
image: text('image'),
|
|
createdAt: timestamp('created_at').notNull(),
|
|
updatedAt: timestamp('updated_at').notNull(),
|
|
role: text('role'),
|
|
banned: boolean('banned'),
|
|
banReason: text('ban_reason'),
|
|
banExpires: timestamp('ban_expires'),
|
|
customerId: text('customer_id'),
|
|
});
|
|
|
|
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' }),
|
|
impersonatedBy: text('impersonated_by')
|
|
});
|
|
|
|
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'),
|
|
updatedAt: timestamp('updated_at')
|
|
});
|
|
|
|
export const payment = pgTable("payment", {
|
|
id: text("id").primaryKey(),
|
|
priceId: text('price_id').notNull(),
|
|
type: text('type').notNull(),
|
|
interval: text('interval'),
|
|
userId: text('user_id').notNull().references(() => user.id, { onDelete: 'cascade' }),
|
|
customerId: text('customer_id').notNull(),
|
|
subscriptionId: text('subscription_id'),
|
|
status: text('status').notNull(),
|
|
periodStart: timestamp('period_start'),
|
|
periodEnd: timestamp('period_end'),
|
|
cancelAtPeriodEnd: boolean('cancel_at_period_end'),
|
|
trialStart: timestamp('trial_start'),
|
|
trialEnd: timestamp('trial_end'),
|
|
createdAt: timestamp('created_at').notNull().defaultNow(),
|
|
updatedAt: timestamp('updated_at').notNull().defaultNow(),
|
|
});
|
|
|
|
export const userCredit = pgTable("user_credit", {
|
|
id: text("id").primaryKey(),
|
|
userId: text("user_id").notNull().references(() => user.id, { onDelete: 'cascade' }),
|
|
currentCredits: integer("current_credits").notNull().default(0),
|
|
lastRefreshAt: timestamp("last_refresh_at"),
|
|
createdAt: timestamp("created_at").notNull().defaultNow(),
|
|
updatedAt: timestamp("updated_at").notNull().defaultNow(),
|
|
});
|
|
|
|
export const creditTransaction = pgTable("credit_transaction", {
|
|
id: text("id").primaryKey(),
|
|
userId: text("user_id").notNull().references(() => user.id, { onDelete: 'cascade' }),
|
|
type: text("type").notNull(),
|
|
description: text("description"),
|
|
amount: integer("amount").notNull(),
|
|
remainingAmount: integer("remaining_amount"),
|
|
paymentId: text("payment_id"),
|
|
expirationDate: timestamp("expiration_date"),
|
|
expirationDateProcessedAt: timestamp("expiration_date_processed_at"),
|
|
createdAt: timestamp("created_at").notNull().defaultNow(),
|
|
updatedAt: timestamp("updated_at").notNull().defaultNow(),
|
|
});
|