mirror of
https://github.com/ajnart/homarr.git
synced 2026-02-28 09:21:00 +01:00
85 lines
2.5 KiB
TypeScript
85 lines
2.5 KiB
TypeScript
import type { AdapterAccount } from "@auth/core/adapters";
|
|
import { relations, sql } from "drizzle-orm";
|
|
import {
|
|
index,
|
|
int,
|
|
primaryKey,
|
|
text,
|
|
timestamp,
|
|
varchar,
|
|
} from "drizzle-orm/mysql-core";
|
|
|
|
import { mySqlTable } from "./_table";
|
|
|
|
export const users = mySqlTable("user", {
|
|
id: varchar("id", { length: 255 }).notNull().primaryKey(),
|
|
name: varchar("name", { length: 255 }),
|
|
email: varchar("email", { length: 255 }).notNull(),
|
|
emailVerified: timestamp("emailVerified", {
|
|
mode: "date",
|
|
fsp: 3,
|
|
}).default(sql`CURRENT_TIMESTAMP(3)`),
|
|
image: varchar("image", { length: 255 }),
|
|
});
|
|
|
|
export const usersRelations = relations(users, ({ many }) => ({
|
|
accounts: many(accounts),
|
|
}));
|
|
|
|
export const accounts = mySqlTable(
|
|
"account",
|
|
{
|
|
userId: varchar("userId", { length: 255 }).notNull(),
|
|
type: varchar("type", { length: 255 })
|
|
.$type<AdapterAccount["type"]>()
|
|
.notNull(),
|
|
provider: varchar("provider", { length: 255 }).notNull(),
|
|
providerAccountId: varchar("providerAccountId", { length: 255 }).notNull(),
|
|
refresh_token: varchar("refresh_token", { length: 255 }),
|
|
access_token: varchar("access_token", { length: 255 }),
|
|
expires_at: int("expires_at"),
|
|
token_type: varchar("token_type", { length: 255 }),
|
|
scope: varchar("scope", { length: 255 }),
|
|
id_token: text("id_token"),
|
|
session_state: varchar("session_state", { length: 255 }),
|
|
},
|
|
(account) => ({
|
|
compoundKey: primaryKey(account.provider, account.providerAccountId),
|
|
userIdIdx: index("userId_idx").on(account.userId),
|
|
}),
|
|
);
|
|
|
|
export const accountsRelations = relations(accounts, ({ one }) => ({
|
|
user: one(users, { fields: [accounts.userId], references: [users.id] }),
|
|
}));
|
|
|
|
export const sessions = mySqlTable(
|
|
"session",
|
|
{
|
|
sessionToken: varchar("sessionToken", { length: 255 })
|
|
.notNull()
|
|
.primaryKey(),
|
|
userId: varchar("userId", { length: 255 }).notNull(),
|
|
expires: timestamp("expires", { mode: "date" }).notNull(),
|
|
},
|
|
(session) => ({
|
|
userIdIdx: index("userId_idx").on(session.userId),
|
|
}),
|
|
);
|
|
|
|
export const sessionsRelations = relations(sessions, ({ one }) => ({
|
|
user: one(users, { fields: [sessions.userId], references: [users.id] }),
|
|
}));
|
|
|
|
export const verificationTokens = mySqlTable(
|
|
"verificationToken",
|
|
{
|
|
identifier: varchar("identifier", { length: 255 }).notNull(),
|
|
token: varchar("token", { length: 255 }).notNull(),
|
|
expires: timestamp("expires", { mode: "date" }).notNull(),
|
|
},
|
|
(vt) => ({
|
|
compoundKey: primaryKey(vt.identifier, vt.token),
|
|
}),
|
|
);
|