59 lines
1.3 KiB
Plaintext
59 lines
1.3 KiB
Plaintext
generator client {
|
|
provider = "prisma-client-js"
|
|
previewFeatures = ["referentialIntegrity"]
|
|
}
|
|
|
|
datasource db {
|
|
provider = "mysql"
|
|
url = env("DB_URL")
|
|
referentialIntegrity = "prisma"
|
|
}
|
|
|
|
model User {
|
|
id Int @id @default(autoincrement())
|
|
firstName String
|
|
lastName String
|
|
email String @unique
|
|
password String
|
|
posts Post[]
|
|
role Role @default(USER)
|
|
likes Like[]
|
|
tokens Token[]
|
|
}
|
|
|
|
enum Role {
|
|
USER
|
|
ADMIN
|
|
CREATOR
|
|
}
|
|
|
|
model Post {
|
|
id Int @id @default(autoincrement())
|
|
content String?
|
|
image String?
|
|
authorId Int
|
|
author User @relation(fields: [authorId], references: [id])
|
|
createdAt DateTime @default(now())
|
|
updatedAt DateTime @updatedAt
|
|
likes Int @default(0)
|
|
likedBy Like[]
|
|
edited Boolean @default(false)
|
|
}
|
|
|
|
model Like {
|
|
id Int @id @default(autoincrement())
|
|
userId Int
|
|
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
|
|
postId Int
|
|
post Post @relation(fields: [postId], references: [id], onDelete: Cascade)
|
|
}
|
|
|
|
model Token {
|
|
id Int @id @default(autoincrement())
|
|
token String @unique
|
|
userId Int
|
|
user User @relation(fields: [userId], references: [id])
|
|
createdAt DateTime @default(now())
|
|
expiresAt DateTime @default(now())
|
|
}
|