2023-12-23 17:21:42 -06:00
|
|
|
datasource db {
|
|
|
|
provider = "postgresql"
|
|
|
|
url = env("DATABASE_URL")
|
|
|
|
}
|
|
|
|
|
2024-02-11 00:00:27 -06:00
|
|
|
generator client {
|
|
|
|
provider = "prisma-client-js"
|
|
|
|
}
|
|
|
|
|
2023-12-23 17:21:42 -06:00
|
|
|
model User {
|
2024-03-20 19:42:28 -05:00
|
|
|
id String @id @default(uuid())
|
2024-03-20 12:59:24 -05:00
|
|
|
pubkey String @unique
|
|
|
|
username String? @unique
|
|
|
|
avatar String?
|
|
|
|
purchased Purchase[]
|
|
|
|
courses Course[] // Relation field added for courses created by the user
|
|
|
|
resources Resource[] // Relation field added for resources created by the user
|
2024-03-25 13:39:32 -05:00
|
|
|
drafts Draft[] // Relation field added for drafts created by the user
|
2024-03-20 12:59:24 -05:00
|
|
|
role Role? @relation(fields: [roleId], references: [id])
|
2024-03-20 19:42:28 -05:00
|
|
|
roleId String?
|
2024-03-20 12:59:24 -05:00
|
|
|
createdAt DateTime @default(now())
|
|
|
|
updatedAt DateTime @updatedAt
|
2023-12-23 17:21:42 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
model Role {
|
2024-03-20 19:42:28 -05:00
|
|
|
id String @id @default(uuid())
|
|
|
|
subscribed Boolean @default(false)
|
|
|
|
users User[]
|
2023-12-23 17:21:42 -06:00
|
|
|
}
|
|
|
|
|
2024-02-10 21:42:19 -06:00
|
|
|
model Purchase {
|
2024-03-20 19:42:28 -05:00
|
|
|
id String @id @default(uuid())
|
2024-02-10 21:42:19 -06:00
|
|
|
user User @relation(fields: [userId], references: [id])
|
2024-03-20 19:42:28 -05:00
|
|
|
userId String
|
2024-02-10 21:42:19 -06:00
|
|
|
course Course? @relation(fields: [courseId], references: [id])
|
2024-03-20 19:42:28 -05:00
|
|
|
courseId String?
|
2024-02-10 21:42:19 -06:00
|
|
|
resource Resource? @relation(fields: [resourceId], references: [id])
|
2024-03-20 19:42:28 -05:00
|
|
|
resourceId String?
|
2024-02-10 21:42:19 -06:00
|
|
|
amountPaid Int // in satoshis
|
|
|
|
createdAt DateTime @default(now())
|
|
|
|
updatedAt DateTime @updatedAt
|
|
|
|
}
|
|
|
|
|
2023-12-23 17:21:42 -06:00
|
|
|
model Course {
|
2024-03-20 19:42:28 -05:00
|
|
|
id String @id // Client generates UUID
|
|
|
|
userId String
|
|
|
|
user User @relation(fields: [userId], references: [id])
|
|
|
|
price Int @default(0)
|
2023-12-23 17:21:42 -06:00
|
|
|
resources Resource[]
|
|
|
|
purchases Purchase[]
|
2024-03-20 19:42:28 -05:00
|
|
|
noteId String? @unique
|
|
|
|
createdAt DateTime @default(now())
|
|
|
|
updatedAt DateTime @updatedAt
|
2023-12-23 17:21:42 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
model Resource {
|
2024-03-20 19:42:28 -05:00
|
|
|
id String @id // Client generates UUID
|
|
|
|
userId String
|
|
|
|
user User @relation(fields: [userId], references: [id])
|
|
|
|
course Course? @relation(fields: [courseId], references: [id])
|
|
|
|
courseId String?
|
|
|
|
price Int @default(0)
|
2024-02-10 21:42:19 -06:00
|
|
|
purchases Purchase[]
|
2024-03-20 19:42:28 -05:00
|
|
|
noteId String? @unique
|
|
|
|
createdAt DateTime @default(now())
|
|
|
|
updatedAt DateTime @updatedAt
|
2023-12-23 17:21:42 -06:00
|
|
|
}
|
2024-03-25 13:39:32 -05:00
|
|
|
|
|
|
|
model Draft {
|
|
|
|
id String @id @default(uuid())
|
|
|
|
userId String
|
|
|
|
user User @relation(fields: [userId], references: [id])
|
|
|
|
type String
|
|
|
|
title String
|
|
|
|
summary String
|
|
|
|
content String
|
|
|
|
image String?
|
|
|
|
price Int? @default(0)
|
|
|
|
topics String[]
|
|
|
|
createdAt DateTime @default(now())
|
|
|
|
updatedAt DateTime @updatedAt
|
|
|
|
}
|
|
|
|
|