import { boolean, integer, pgSchema, text, timestamp, } from "drizzle-orm/pg-core"; export const shared = pgSchema("shared"); export const user = shared.table("user", { id: text("id").primaryKey(), name: text("name").notNull(), email: text("email").notNull().unique(), emailVerified: boolean("email_verified") .$defaultFn(() => !1) .notNull(), image: text("image"), createdAt: timestamp("created_at") .$defaultFn(() => new Date()) .notNull(), updatedAt: timestamp("updated_at") .$defaultFn(() => new Date()) .notNull(), username: text("username").unique(), displayUsername: text("display_username"), }); export const session = shared.table("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" }), }); export const account = shared.table("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 = shared.table("verification", { id: text("id").primaryKey(), identifier: text("identifier").notNull(), value: text("value").notNull(), expiresAt: timestamp("expires_at").notNull(), createdAt: timestamp("created_at").$defaultFn(() => new Date()), updatedAt: timestamp("updated_at").$defaultFn(() => new Date()), }); export const apikey = shared.table("apikey", { id: text("id").primaryKey(), name: text("name"), start: text("start"), prefix: text("prefix"), key: text("key").notNull(), userId: text("user_id") .notNull() .references(() => user.id, { onDelete: "cascade" }), refillInterval: integer("refill_interval"), refillAmount: integer("refill_amount"), lastRefillAt: timestamp("last_refill_at"), enabled: boolean("enabled").default(true), rateLimitEnabled: boolean("rate_limit_enabled").default(true), rateLimitTimeWindow: integer("rate_limit_time_window").default(86400000), rateLimitMax: integer("rate_limit_max").default(10), requestCount: integer("request_count"), remaining: integer("remaining"), lastRequest: timestamp("last_request"), expiresAt: timestamp("expires_at"), createdAt: timestamp("created_at").notNull(), updatedAt: timestamp("updated_at").notNull(), permissions: text("permissions"), metadata: text("metadata"), });