stacker.news/prisma/schema.prisma

245 lines
7.2 KiB
Plaintext
Raw Normal View History

2021-03-25 14:29:24 -05:00
// 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("DATABASE_URL")
}
generator client {
provider = "prisma-client-js"
}
model User {
2021-09-08 16:51:23 -05:00
id Int @id @default(autoincrement())
createdAt DateTime @default(now()) @map(name: "created_at")
updatedAt DateTime @default(now()) @updatedAt @map(name: "updated_at")
name String? @unique @db.Citext
email String? @unique
emailVerified DateTime? @map(name: "email_verified")
2021-06-24 18:56:01 -05:00
image String?
items Item[]
2021-08-18 17:20:33 -05:00
mentions Mention[]
2021-06-24 18:56:01 -05:00
messages Message[]
2021-09-09 14:10:15 -05:00
actions ItemAct[]
2021-06-24 18:56:01 -05:00
invoices Invoice[]
withdrawls Withdrawl[]
2021-10-12 15:40:30 -05:00
invites Invite[] @relation(name: "Invites")
invite Invite? @relation(fields: [inviteId], references: [id])
inviteId String?
2021-09-23 12:42:00 -05:00
bio Item? @relation(name: "Item", fields: [bioId], references: [id])
bioId Int?
2021-09-08 16:51:23 -05:00
msats Int @default(0)
freeComments Int @default(5)
freePosts Int @default(2)
2021-06-24 18:56:01 -05:00
checkedNotesAt DateTime?
tipDefault Int @default(1)
2021-09-08 16:51:23 -05:00
pubkey String? @unique
2022-01-14 11:28:05 -06:00
trust Float @default(0)
2021-03-25 14:29:24 -05:00
2021-12-09 14:40:40 -06:00
upvotePopover Boolean @default(false)
tipPopover Boolean @default(false)
2021-10-06 07:43:32 -07:00
@@index([createdAt])
2021-03-25 14:29:24 -05:00
@@map(name: "users")
}
2021-06-26 22:09:39 -05:00
model LnAuth {
id Int @id @default(autoincrement())
createdAt DateTime @default(now()) @map(name: "created_at")
updatedAt DateTime @default(now()) @updatedAt @map(name: "updated_at")
k1 String @unique
pubkey String?
}
2021-10-28 14:59:53 -05:00
model LnWith {
id Int @id @default(autoincrement())
createdAt DateTime @default(now()) @map(name: "created_at")
updatedAt DateTime @default(now()) @updatedAt @map(name: "updated_at")
k1 String @unique
userId Int
withdrawalId Int?
}
2021-10-12 15:40:30 -05:00
model Invite {
id String @id @default(cuid())
createdAt DateTime @default(now()) @map(name: "created_at")
updatedAt DateTime @default(now()) @updatedAt @map(name: "updated_at")
user User @relation(name: "Invites", fields: [userId], references: [id])
userId Int
gift Int?
limit Int?
revoked Boolean @default(false)
invitees User[]
}
2021-03-25 14:29:24 -05:00
model Message {
id Int @id @default(autoincrement())
text String
user User @relation(fields: [userId], references: [id])
userId Int
}
model Item {
2021-04-12 13:05:09 -05:00
id Int @id @default(autoincrement())
createdAt DateTime @default(now()) @map(name: "created_at")
2022-01-07 10:32:31 -06:00
updatedAt DateTime @default(now()) @updatedAt @map(name: "updated_at")
2021-04-13 19:57:32 -05:00
title String?
2021-04-12 13:05:09 -05:00
text String?
url String?
user User @relation(fields: [userId], references: [id])
userId Int
parent Item? @relation("ParentChildren", fields: [parentId], references: [id])
parentId Int?
children Item[] @relation("ParentChildren")
2021-09-08 16:51:23 -05:00
actions ItemAct[]
2021-08-18 17:20:33 -05:00
mentions Mention[]
2021-04-12 13:05:09 -05:00
path Unsupported("LTREE")?
2022-01-07 10:32:31 -06:00
pin Pin? @relation(fields: [pinId], references: [id])
pinId Int?
2021-03-25 14:29:24 -05:00
2021-09-23 12:42:00 -05:00
User User[] @relation("Item")
2022-01-07 10:32:31 -06:00
2021-10-06 07:43:32 -07:00
@@index([createdAt])
2021-03-25 14:29:24 -05:00
@@index([userId])
@@index([parentId])
}
2022-01-07 10:32:31 -06:00
// the active pin is the latest one when it's a recurring cron
model Pin {
id Int @id @default(autoincrement())
createdAt DateTime @default(now()) @map(name: "created_at")
updatedAt DateTime @default(now()) @updatedAt @map(name: "updated_at")
cron String?
timezone String?
position Int
Item Item[]
}
2021-09-08 16:51:23 -05:00
enum ItemActType {
2021-09-08 16:15:06 -05:00
VOTE
BOOST
TIP
}
2021-09-08 16:51:23 -05:00
model ItemAct {
id Int @id @default(autoincrement())
createdAt DateTime @default(now()) @map(name: "created_at")
updatedAt DateTime @updatedAt @map(name: "updated_at")
sats Int
act ItemActType
item Item @relation(fields: [itemId], references: [id])
2021-04-22 17:14:32 -05:00
itemId Int
2021-09-08 16:51:23 -05:00
user User @relation(fields: [userId], references: [id])
2021-04-22 17:14:32 -05:00
userId Int
@@index([itemId])
@@index([userId])
2021-09-08 16:51:23 -05:00
@@index([act])
2021-10-06 07:43:32 -07:00
@@index([createdAt])
2021-04-22 17:14:32 -05:00
}
2021-08-18 17:20:33 -05:00
model Mention {
id Int @id @default(autoincrement())
createdAt DateTime @default(now()) @map(name: "created_at")
updatedAt DateTime @updatedAt @map(name: "updated_at")
item Item @relation(fields: [itemId], references: [id])
itemId Int
user User @relation(fields: [userId], references: [id])
userId Int
@@unique([itemId, userId])
2021-10-06 07:43:32 -07:00
@@index([createdAt])
2021-08-18 17:20:33 -05:00
@@index([itemId])
@@index([userId])
}
2021-05-11 10:52:50 -05:00
model Invoice {
id Int @id @default(autoincrement())
createdAt DateTime @default(now()) @map(name: "created_at")
updatedAt DateTime @updatedAt @map(name: "updated_at")
user User @relation(fields: [userId], references: [id])
userId Int
hash String @unique
bolt11 String
expiresAt DateTime
confirmedAt DateTime?
msatsRequested Int
msatsReceived Int?
cancelled Boolean @default(false)
2021-10-06 07:43:32 -07:00
@@index([createdAt])
2021-05-11 10:52:50 -05:00
@@index([userId])
}
2021-05-12 18:04:19 -05:00
enum WithdrawlStatus {
2021-05-13 16:19:51 -05:00
CONFIRMED
2021-05-12 18:04:19 -05:00
INSUFFICIENT_BALANCE
INVALID_PAYMENT
PATHFINDING_TIMEOUT
ROUTE_NOT_FOUND
2021-05-13 16:19:51 -05:00
UNKNOWN_FAILURE
2021-05-12 18:04:19 -05:00
}
model Withdrawl {
id Int @id @default(autoincrement())
createdAt DateTime @default(now()) @map(name: "created_at")
updatedAt DateTime @updatedAt @map(name: "updated_at")
user User @relation(fields: [userId], references: [id])
userId Int
hash String
2021-05-12 18:04:19 -05:00
bolt11 String
msatsPaying Int
msatsPaid Int?
msatsFeePaying Int
msatsFeePaid Int?
status WithdrawlStatus?
2021-10-06 07:43:32 -07:00
@@index([createdAt])
2021-05-12 18:04:19 -05:00
@@index([userId])
}
2021-03-25 14:29:24 -05:00
model Account {
id Int @id @default(autoincrement())
createdAt DateTime @default(now()) @map(name: "created_at")
updatedAt DateTime @updatedAt @map(name: "updated_at")
compoundId String @unique @map(name: "compound_id")
userId Int @map(name: "user_id")
providerType String @map(name: "provider_type")
providerId String @map(name: "provider_id")
providerAccountId String @map(name: "provider_account_id")
refreshToken String? @map(name: "refresh_token")
accessToken String? @map(name: "access_token")
accessTokenExpires DateTime? @map(name: "access_token_expires")
@@index([providerAccountId])
@@index([providerId])
@@index([userId])
@@map(name: "accounts")
}
model Session {
id Int @id @default(autoincrement())
createdAt DateTime @default(now()) @map(name: "created_at")
updatedAt DateTime @updatedAt @map(name: "updated_at")
userId Int @map(name: "user_id")
expires DateTime
sessionToken String @unique @map(name: "session_token")
accessToken String @unique @map(name: "access_token")
@@map(name: "sessions")
}
model VerificationRequest {
id Int @id @default(autoincrement())
createdAt DateTime @default(now()) @map(name: "created_at")
updatedAt DateTime @updatedAt @map(name: "updated_at")
identifier String
token String @unique
expires DateTime
@@map(name: "verification_requests")
}