(#2) Members can now be in multiple guilds

Signed-off-by: Louis Hollingworth <louis@hollingworth.ch>
This commit is contained in:
Louis Hollingworth 2023-06-18 14:05:21 +01:00
parent e8f797d1e0
commit 530e99a7d0
Signed by: lucxjo
GPG key ID: A11415CB3DC7809B
4 changed files with 27 additions and 22 deletions

View file

@ -9,9 +9,12 @@ CREATE TABLE "guild" (
-- CreateTable
CREATE TABLE "member" (
"id" TEXT NOT NULL,
"id" UUID NOT NULL DEFAULT gen_random_uuid(),
"name" TEXT NOT NULL,
"booster_role_id" TEXT NOT NULL,
"booster_role_id" TEXT,
"created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
"dgid" TEXT NOT NULL,
"duid" TEXT NOT NULL,
CONSTRAINT "member_pkey" PRIMARY KEY ("id")
);
@ -20,7 +23,4 @@ CREATE TABLE "member" (
CREATE UNIQUE INDEX "guild_id_key" ON "guild"("id");
-- CreateIndex
CREATE UNIQUE INDEX "member_id_key" ON "member"("id");
-- CreateIndex
CREATE UNIQUE INDEX "member_booster_role_id_key" ON "member"("booster_role_id");
CREATE UNIQUE INDEX "member_dgid_duid_key" ON "member"("dgid", "duid");

View file

@ -1,5 +1,6 @@
generator client {
provider = "prisma-client-js"
provider = "prisma-client-js"
previewFeatures = ["postgresqlExtensions"]
}
datasource db {
@ -14,7 +15,14 @@ model guild {
}
model member {
id String @id @unique
id String @id @default(dbgenerated("gen_random_uuid()")) @db.Uuid
name String
booster_role_id String @unique
booster_role_id String?
created_at DateTime @default(now())
/// Discord Guild ID
dgid String
/// Discord User ID
duid String
@@unique([dgid, duid])
}