import { pgTable, text, timestamp, boolean, integer, } 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") .$defaultFn(() => false) .notNull(), image: text("image"), createdAt: timestamp("created_at") .$defaultFn(() => /* @__PURE__ */ new Date()) .notNull(), updatedAt: timestamp("updated_at") .$defaultFn(() => /* @__PURE__ */ new Date()) .notNull(), username: text("username").unique(), displayUsername: text("display_username"), role: text("role"), banned: boolean("banned"), banReason: text("ban_reason"), banExpires: timestamp("ban_expires"), }); 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"), activeOrganizationId: text("active_organization_id"), }); 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").$defaultFn( () => /* @__PURE__ */ new Date(), ), updatedAt: timestamp("updated_at").$defaultFn( () => /* @__PURE__ */ new Date(), ), }); export const passkey = pgTable("passkey", { id: text("id").primaryKey(), name: text("name"), publicKey: text("public_key").notNull(), userId: text("user_id") .notNull() .references(() => user.id, { onDelete: "cascade" }), credentialID: text("credential_i_d").notNull(), counter: integer("counter").notNull(), deviceType: text("device_type").notNull(), backedUp: boolean("backed_up").notNull(), transports: text("transports"), createdAt: timestamp("created_at"), aaguid: text("aaguid"), }); export const organization = pgTable("organization", { id: text("id").primaryKey(), name: text("name").notNull(), slug: text("slug").unique(), logo: text("logo"), createdAt: timestamp("created_at").notNull(), metadata: text("metadata"), }); export const member = pgTable("member", { id: text("id").primaryKey(), organizationId: text("organization_id") .notNull() .references(() => organization.id, { onDelete: "cascade" }), userId: text("user_id") .notNull() .references(() => user.id, { onDelete: "cascade" }), role: text("role").default("member").notNull(), createdAt: timestamp("created_at").notNull(), }); export const invitation = pgTable("invitation", { id: text("id").primaryKey(), organizationId: text("organization_id") .notNull() .references(() => organization.id, { onDelete: "cascade" }), email: text("email").notNull(), role: text("role"), status: text("status").default("pending").notNull(), expiresAt: timestamp("expires_at").notNull(), inviterId: text("inviter_id") .notNull() .references(() => user.id, { onDelete: "cascade" }), }); export const oauthApplication = pgTable("oauth_application", { id: text("id").primaryKey(), name: text("name"), icon: text("icon"), metadata: text("metadata"), clientId: text("client_id").unique(), clientSecret: text("client_secret"), redirectURLs: text("redirect_u_r_ls"), type: text("type"), disabled: boolean("disabled"), userId: text("user_id"), createdAt: timestamp("created_at"), updatedAt: timestamp("updated_at"), }); export const oauthAccessToken = pgTable("oauth_access_token", { id: text("id").primaryKey(), accessToken: text("access_token").unique(), refreshToken: text("refresh_token").unique(), accessTokenExpiresAt: timestamp("access_token_expires_at"), refreshTokenExpiresAt: timestamp("refresh_token_expires_at"), clientId: text("client_id"), userId: text("user_id"), scopes: text("scopes"), createdAt: timestamp("created_at"), updatedAt: timestamp("updated_at"), }); export const oauthConsent = pgTable("oauth_consent", { id: text("id").primaryKey(), clientId: text("client_id"), userId: text("user_id"), scopes: text("scopes"), createdAt: timestamp("created_at"), updatedAt: timestamp("updated_at"), consentGiven: boolean("consent_given"), });