Drizzle ORM
use Drizzle ORM to store data
Setup
Add schemas:
import {
pgTable,
varchar,
boolean,
integer,
serial,
json,
timestamp,
primaryKey,
index,
} from "drizzle-orm/pg-core";
export const roles = pgTable("roles", {
userId: varchar("userId", { length: 256 }).primaryKey(),
name: varchar("name", { length: 256 }).notNull(),
canDelete: boolean("canDelete").notNull(),
});
export const comments = pgTable("comments", {
id: serial("id").primaryKey().notNull(),
page: varchar("page", { length: 256 }).notNull(),
thread: integer("thread"),
author: varchar("author", { length: 256 }).notNull(),
content: json("content").notNull(),
timestamp: timestamp("timestamp", { withTimezone: true })
.defaultNow()
.notNull(),
});
export const rates = pgTable(
"rates",
{
userId: varchar("userId", { length: 256 }).notNull(),
commentId: integer("commentId").notNull(),
like: boolean("like").notNull(),
},
(table) => [
primaryKey({ columns: [table.userId, table.commentId] }),
index("comment_idx").on(table.commentId),
],
);
Add to your Fuma Comment config:
import { createDrizzleAdapter } from "@fuma-comment/server/adapters/drizzle";
import { db } from "@/lib/database";
import { comments, rates, roles, user } from "@/lib/schema";
const storage = createDrizzleAdapter({
db,
auth: "next-auth" | "better-auth",
schemas: {
comments,
rates,
roles,
user,
},
});