mirror of
https://github.com/ChatGPTNextWeb/ChatGPT-Next-Web.git
synced 2025-11-17 06:23:44 +08:00
init
This commit is contained in:
134
prisma/schema.prisma
Normal file
134
prisma/schema.prisma
Normal file
@@ -0,0 +1,134 @@
|
||||
// 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
|
||||
// directUrl = env("POSTGRES_URL_NON_POOLING") // uses a direct connection
|
||||
}
|
||||
|
||||
generator client {
|
||||
provider = "prisma-client-js"
|
||||
binaryTargets = ["native", "linux-musl-openssl-3.0.x"]
|
||||
}
|
||||
|
||||
model User {
|
||||
id String @id @default(cuid())
|
||||
name String? @unique
|
||||
// if you are using Github OAuth, you can get rid of the username attribute (that is for Twitter OAuth)
|
||||
username String?
|
||||
gh_username String?
|
||||
email String? @unique
|
||||
emailVerified DateTime?
|
||||
image String?
|
||||
createdAt DateTime @default(now())
|
||||
updatedAt DateTime @updatedAt
|
||||
accounts Account[]
|
||||
sessions Session[]
|
||||
// sites Site[]
|
||||
// posts Post[]
|
||||
logs LogEntry[]
|
||||
}
|
||||
|
||||
model Account {
|
||||
id String @id @default(cuid())
|
||||
userId String
|
||||
type String
|
||||
provider String
|
||||
providerAccountId String
|
||||
refresh_token String?
|
||||
refresh_token_expires_in Int?
|
||||
access_token String?
|
||||
expires_at Int?
|
||||
token_type String?
|
||||
scope String?
|
||||
id_token String?
|
||||
session_state String?
|
||||
oauth_token_secret String?
|
||||
oauth_token String?
|
||||
|
||||
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
|
||||
|
||||
@@unique([provider, providerAccountId])
|
||||
@@index([userId])
|
||||
}
|
||||
|
||||
model Session {
|
||||
id String @id @default(cuid())
|
||||
sessionToken String @unique
|
||||
userId String
|
||||
expires DateTime
|
||||
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
|
||||
|
||||
@@index([userId])
|
||||
}
|
||||
|
||||
model LogEntry {
|
||||
id Int @id @default(autoincrement())
|
||||
ip String? @db.Char(25)
|
||||
path String? @db.Text
|
||||
model String? @db.Char(25)
|
||||
userName String? @db.Char(50)
|
||||
createdAt DateTime @default(now())
|
||||
logEntry String? @db.Text
|
||||
user User? @relation(fields: [userName], references: [name], onDelete: NoAction)
|
||||
}
|
||||
|
||||
model VerificationToken {
|
||||
identifier String
|
||||
token String @unique
|
||||
expires DateTime
|
||||
|
||||
@@unique([identifier, token])
|
||||
}
|
||||
|
||||
// model Post {
|
||||
// id String @id @default(cuid())
|
||||
// title String? @db.Text
|
||||
// description String? @db.Text
|
||||
// content String? @db.Text
|
||||
// slug String @default(cuid())
|
||||
// image String? @default("https://public.blob.vercel-storage.com/eEZHAoPTOBSYGBE3/hxfcV5V-eInX3jbVUhjAt1suB7zB88uGd1j20b.png") @db.Text
|
||||
// imageBlurhash String? @default("") @db.Text
|
||||
// createdAt DateTime @default(now())
|
||||
// updatedAt DateTime @updatedAt
|
||||
// published Boolean @default(false)
|
||||
// site Site? @relation(fields: [siteId], references: [id], onDelete: Cascade, onUpdate: Cascade)
|
||||
// siteId String?
|
||||
// user User? @relation(fields: [userId], references: [id], onDelete: Cascade, onUpdate: Cascade)
|
||||
// userId String?
|
||||
//
|
||||
// @@unique([slug, siteId])
|
||||
// @@index([siteId])
|
||||
// @@index([userId])
|
||||
// }
|
||||
|
||||
// model Site {
|
||||
// id String @id @default(cuid())
|
||||
// name String?
|
||||
// description String? @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("https://public.blob.vercel-storage.com/eEZHAoPTOBSYGBE3/hxfcV5V-eInX3jbVUhjAt1suB7zB88uGd1j20b.png") @db.Text
|
||||
// imageBlurhash String? @default("") @db.Text
|
||||
// subdomain String? @unique
|
||||
// customDomain String? @unique
|
||||
// message404 String? @default("Blimey! You've found a page that doesn't exist.") @db.Text
|
||||
// createdAt DateTime @default(now())
|
||||
// updatedAt DateTime @updatedAt
|
||||
// user User? @relation(fields: [userId], references: [id], onDelete: Cascade, onUpdate: Cascade)
|
||||
// userId String?
|
||||
// posts Post[]
|
||||
//
|
||||
// @@index([userId])
|
||||
// }
|
||||
|
||||
// model Example {
|
||||
// id Int @id @default(autoincrement())
|
||||
// name String?
|
||||
// description String? @db.Text
|
||||
// domainCount Int?
|
||||
// url String?
|
||||
// image String? @db.Text
|
||||
// imageBlurhash String? @db.Text
|
||||
// }
|
||||
Reference in New Issue
Block a user