change database table name organization to house

This commit is contained in:
2026-02-24 10:36:53 +07:00
parent 604fe0a80f
commit 1e6f4683ea
17 changed files with 1822 additions and 1786 deletions

View File

@@ -0,0 +1,36 @@
/*
Warnings:
- You are about to drop the `organization` table. If the table is not empty, all the data it contains will be lost.
*/
-- DropForeignKey
ALTER TABLE "invitation" DROP CONSTRAINT "invitation_organizationId_fkey";
-- DropForeignKey
ALTER TABLE "member" DROP CONSTRAINT "member_organizationId_fkey";
-- DropTable
DROP TABLE "organization";
-- CreateTable
CREATE TABLE "house" (
"id" TEXT NOT NULL,
"name" TEXT NOT NULL,
"slug" TEXT NOT NULL,
"logo" TEXT,
"createdAt" TIMESTAMPTZ NOT NULL,
"metadata" TEXT,
"color" TEXT DEFAULT '#000000',
CONSTRAINT "house_pkey" PRIMARY KEY ("id")
);
-- CreateIndex
CREATE UNIQUE INDEX "house_slug_key" ON "house"("slug");
-- AddForeignKey
ALTER TABLE "member" ADD CONSTRAINT "member_organizationId_fkey" FOREIGN KEY ("organizationId") REFERENCES "house"("id") ON DELETE CASCADE ON UPDATE CASCADE;
-- AddForeignKey
ALTER TABLE "invitation" ADD CONSTRAINT "invitation_organizationId_fkey" FOREIGN KEY ("organizationId") REFERENCES "house"("id") ON DELETE CASCADE ON UPDATE CASCADE;

View File

@@ -9,44 +9,44 @@ datasource db {
}
model User {
id String @id @default(uuid())
name String
email String
emailVerified Boolean @default(false)
image String?
createdAt DateTime @default(now()) @db.Timestamptz
updatedAt DateTime @updatedAt @db.Timestamptz
sessions Session[]
accounts Account[]
audit Audit[]
notification Notification[]
id String @id @default(uuid())
name String
email String
emailVerified Boolean @default(false)
image String?
createdAt DateTime @default(now()) @db.Timestamptz
updatedAt DateTime @updatedAt @db.Timestamptz
sessions Session[]
accounts Account[]
audit Audit[]
notification Notification[]
role String?
banned Boolean? @default(false)
banReason String?
banExpires DateTime?
role String?
banned Boolean? @default(false)
banReason String?
banExpires DateTime?
members Member[]
invitations Invitation[]
members Member[]
invitations Invitation[]
@@unique([email])
@@map("user")
}
model Session {
id String @id @default(uuid())
expiresAt DateTime @db.Timestamptz
token String
createdAt DateTime @default(now()) @db.Timestamptz
updatedAt DateTime @updatedAt @db.Timestamptz
ipAddress String?
userAgent String?
userId String
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
id String @id @default(uuid())
expiresAt DateTime @db.Timestamptz
token String
createdAt DateTime @default(now()) @db.Timestamptz
updatedAt DateTime @updatedAt @db.Timestamptz
ipAddress String?
userAgent String?
userId String
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
impersonatedBy String?
impersonatedBy String?
activeOrganizationId String?
activeOrganizationId String?
@@unique([token])
@@index([userId])
@@ -54,61 +54,60 @@ model Session {
}
model Account {
id String @id @default(uuid())
accountId String
providerId String
userId String
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
accessToken String?
refreshToken String?
idToken String?
accessTokenExpiresAt DateTime?
refreshTokenExpiresAt DateTime?
scope String?
password String?
createdAt DateTime @default(now()) @db.Timestamptz
updatedAt DateTime @updatedAt @db.Timestamptz
id String @id @default(uuid())
accountId String
providerId String
userId String
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
accessToken String?
refreshToken String?
idToken String?
accessTokenExpiresAt DateTime?
refreshTokenExpiresAt DateTime?
scope String?
password String?
createdAt DateTime @default(now()) @db.Timestamptz
updatedAt DateTime @updatedAt @db.Timestamptz
@@index([userId])
@@map("account")
}
model Verification {
id String @id @default(uuid())
identifier String
value String
expiresAt DateTime
createdAt DateTime @default(now()) @db.Timestamptz
updatedAt DateTime @updatedAt @db.Timestamptz
id String @id @default(uuid())
identifier String
value String
expiresAt DateTime
createdAt DateTime @default(now()) @db.Timestamptz
updatedAt DateTime @updatedAt @db.Timestamptz
@@index([identifier])
@@map("verification")
}
model Organization {
id String @id @default(uuid())
name String
slug String
logo String?
createdAt DateTime @db.Timestamptz
metadata String?
members Member[]
invitations Invitation[]
color String? @default("#000000")
model House {
id String @id @default(uuid())
name String
slug String
logo String?
createdAt DateTime @db.Timestamptz
metadata String?
color String? @default("#000000")
members Member[]
invitations Invitation[]
@@unique([slug])
@@map("organization")
@@map("house")
}
model Member {
id String @id @default(uuid())
organizationId String
organization Organization @relation(fields: [organizationId], references: [id], onDelete: Cascade)
userId String
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
role String @default("member")
createdAt DateTime @db.Timestamptz
id String @id @default(uuid())
organizationId String
house House @relation(fields: [organizationId], references: [id], onDelete: Cascade)
userId String
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
role String @default("member")
createdAt DateTime @db.Timestamptz
@@index([organizationId])
@@index([userId])
@@ -116,16 +115,16 @@ model Member {
}
model Invitation {
id String @id @default(uuid())
organizationId String
organization Organization @relation(fields: [organizationId], references: [id], onDelete: Cascade)
email String
role String?
status String @default("pending")
expiresAt DateTime @db.Timestamptz
createdAt DateTime @default(now()) @db.Timestamptz
inviterId String
user User @relation(fields: [inviterId], references: [id], onDelete: Cascade)
id String @id @default(uuid())
organizationId String
house House @relation(fields: [organizationId], references: [id], onDelete: Cascade)
email String
role String?
status String @default("pending")
expiresAt DateTime @db.Timestamptz
createdAt DateTime @default(now()) @db.Timestamptz
inviterId String
user User @relation(fields: [inviterId], references: [id], onDelete: Cascade)
@@index([organizationId])
@@index([email])
@@ -133,48 +132,47 @@ model Invitation {
}
model Setting {
id String @id @default(uuid())
key String @unique
value String
description String
relation String @default("admin")
id String @id @default(uuid())
key String @unique
value String
description String
relation String @default("admin")
createdAt DateTime @default(now()) @db.Timestamptz
updatedAt DateTime @updatedAt @db.Timestamptz
createdAt DateTime @default(now()) @db.Timestamptz
updatedAt DateTime @updatedAt @db.Timestamptz
@@map("setting")
}
model Audit {
id String @id @default(uuid())
userId String
action String
tableName String
recordId String
oldValue String?
newValue String?
createdAt DateTime @default(now()) @db.Timestamptz
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
id String @id @default(uuid())
userId String
action String
tableName String
recordId String
oldValue String?
newValue String?
createdAt DateTime @default(now()) @db.Timestamptz
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
@@map("audit")
}
model Notification {
id String @id @default(uuid())
userId String
id String @id @default(uuid())
userId String
title String
message String
type String @default("system")
title String
message String
type String @default("system")
link String?
metadata String?
link String?
metadata String?
createdAt DateTime @default(now()) @db.Timestamptz
readAt DateTime? @db.Timestamptz
createdAt DateTime @default(now()) @db.Timestamptz
readAt DateTime? @db.Timestamptz
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
@@index([userId, readAt])
@@index([readAt])