Files
penx/prisma/schema.prisma
2024-08-10 10:31:03 +08:00

256 lines
9.7 KiB
Plaintext

// This is your Prisma schema file,
// learn more about it in the docs: https://pris.ly/d/prisma-schema
datasource db {
provider = "postgresql"
url = env("POSTGRES_PRISMA_URL") // uses connection pooling
}
generator client {
provider = "prisma-client-js"
}
model User {
id String @id @default(uuid())
address String @unique
name String?
ensName String?
email String? @unique
emailVerified DateTime?
image String?
bio String?
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
spaces Space[]
posts Post[]
members Member[]
trades Trade[]
holders Holder[]
sponsors Sponsor[]
sentMessages Message[] @relation("SentMessages")
comments Comment[]
lists List[]
@@index([id])
@@index([address])
}
model Space {
id String @id @default(uuid())
name String
description String @default("") @db.Text
logo String? @default("https://public.blob.vercel-storage.com/eEZHAoPTOBSYGBE3/JRajRyC-PhBHEinQkupt02jqfKacBVHLWJq7Iy.png") @db.Text
font String @default("font-cal")
image String? @default("") @db.Text
imageBlurhash String? @default("") @db.Text
subdomain String? @unique
customDomain String? @unique
memberCount Int @default(0)
sponsorCount Int @default(0)
postCount Int @default(0)
message404 String? @default("Blimey! You've found a page that doesn't exist.") @db.Text
creationId String? @unique // creationId on chain
sponsorCreationId String? @unique // sponsor creationId on chain
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
user User @relation(fields: [userId], references: [id], onDelete: Cascade, onUpdate: Cascade)
userId String
posts Post[]
channels Channel[]
members Member[]
trades Trade[]
holders Holder[]
sponsors Sponsor[]
@@index([userId])
@@index([name])
}
model Post {
id String @id @default(uuid())
title String @default("") @db.Text
description String @default("") @db.Text
content String @default("") @db.Text
slug String @default(uuid())
type String @default("")
gateType String @default("")
image String? @default("") @db.Text
imageBlurhash String? @default("") @db.Text
published Boolean @default(false)
creationId String? @unique // creationId on chain
holderCount Int @default(0)
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
space Space @relation(fields: [spaceId], references: [id], onDelete: Cascade, onUpdate: Cascade)
spaceId String
user User @relation(fields: [userId], references: [id], onDelete: Cascade, onUpdate: Cascade)
userId String
holders Holder[]
trades Trade[]
comments Comment[]
list List? @relation(fields: [listId], references: [id])
listId String?
listPost ListPost[]
@@unique([slug, spaceId])
@@index([spaceId])
@@index([userId])
}
model Member {
id String @id @default(uuid())
amount String @default("0")
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
space Space @relation(fields: [spaceId], references: [id], onDelete: Cascade, onUpdate: Cascade)
spaceId String
user User @relation(fields: [userId], references: [id], onDelete: Cascade, onUpdate: Cascade)
userId String
@@unique([userId, spaceId])
@@index([spaceId])
@@index([userId])
}
model Comment {
id String @id @default(uuid())
content String @default("")
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
post Post @relation(fields: [postId], references: [id], onDelete: Cascade, onUpdate: Cascade)
postId String
user User @relation(fields: [userId], references: [id], onDelete: Cascade, onUpdate: Cascade)
userId String
@@unique([userId, postId])
@@index([postId])
@@index([userId])
}
// Post key holder
model Holder {
id String @id @default(uuid())
amount String @default("0")
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
post Post @relation(fields: [postId], references: [id], onDelete: Cascade, onUpdate: Cascade)
postId String
user User @relation(fields: [userId], references: [id], onDelete: Cascade, onUpdate: Cascade)
userId String
space Space? @relation(fields: [spaceId], references: [id])
spaceId String?
@@unique([userId, postId])
@@index([postId])
@@index([userId])
}
model Sponsor {
id String @id @default(uuid())
amount String @default("0")
name String @default("")
description String @default("")
logo String @default("")
cover String @default("")
homeUrl String @default("")
status String @default("PENDING") // PENDING|AGREED|REJECTED
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
space Space @relation(fields: [spaceId], references: [id], onDelete: Cascade, onUpdate: Cascade)
spaceId String
user User @relation(fields: [userId], references: [id], onDelete: Cascade, onUpdate: Cascade)
userId String
@@unique([userId, spaceId])
@@index([spaceId])
@@index([userId])
}
model Trade {
id String @id @default(uuid())
amount String @default("0")
price String @default("0")
source String @default("")
type String @default("")
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
post Post? @relation(fields: [postId], references: [id], onDelete: Cascade, onUpdate: Cascade)
postId String?
Space Space? @relation(fields: [spaceId], references: [id])
spaceId String?
user User @relation(fields: [userId], references: [id], onDelete: Cascade, onUpdate: Cascade)
userId String
@@index([spaceId])
@@index([postId])
}
model Channel {
id String @id @default(uuid())
name String
description String @default("") @db.Text
type String @default("")
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
space Space @relation(fields: [spaceId], references: [id], onDelete: Cascade, onUpdate: Cascade)
spaceId String
messages Message[]
@@index([spaceId])
}
model Message {
id String @id @default(uuid())
// Sended = 1 Others sent successfully;SendFail = 2;Sending = 3;Undo = 4;AtAll = 5@All people;
// SelfSend = 6 Send successfully; PeerRead = 7 The other party has read;
// Reject = 8 // Backstage rejection (such as sensitive words, etc.)
status Int
chat_send_or_receive Int // send 0; receive 1;
fromId String // Send userId
toId String // Receive userId
contentType Int // TEXT = 1, IMAGE = 2
content String @default("") @db.Text
spaceId String
channelId String
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
channal Channel? @relation(fields: [channelId], references: [id], onDelete: Cascade, onUpdate: Cascade)
fromUser User @relation("SentMessages", fields: [fromId], references: [id])
@@index([channelId])
@@index([fromId])
}
model List {
id String @id @default(uuid())
name String
description String @default("") @db.Text
logo String @default("") @db.Text
postCount Int @default(0)
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
user User @relation(fields: [userId], references: [id], onDelete: Cascade, onUpdate: Cascade)
userId String
posts Post[]
listPosts ListPost[]
@@index([userId])
@@index([name])
}
model ListPost {
id String @id @default(uuid())
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
list List @relation(fields: [listId], references: [id], onDelete: Cascade, onUpdate: Cascade)
listId String
post Post @relation(fields: [postId], references: [id], onDelete: Cascade, onUpdate: Cascade)
postId String
@@index([listId])
@@index([postId])
}