2022-07-11 09:22:41 +02:00
|
|
|
|
// This is your Prisma schema file,
|
|
|
|
|
// learn more about it in the docs: https://pris.ly/d/prisma-schema
|
|
|
|
|
|
|
|
|
|
generator client {
|
2022-07-22 18:19:44 +02:00
|
|
|
|
provider = "prisma-client-js"
|
2022-07-11 09:22:41 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
datasource db {
|
2022-07-22 18:19:44 +02:00
|
|
|
|
provider = "postgresql"
|
|
|
|
|
url = env("POSTGRES_URL")
|
2022-07-15 16:39:59 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
model User {
|
2022-07-22 18:19:44 +02:00
|
|
|
|
id Int @id @default(autoincrement())
|
|
|
|
|
chipId String @unique
|
|
|
|
|
accessCode String
|
|
|
|
|
cars Car[]
|
|
|
|
|
carOrder Int[]
|
|
|
|
|
items UserItem[]
|
|
|
|
|
tutorials Boolean[]
|
|
|
|
|
userBanned Boolean @default(false)
|
|
|
|
|
bookmarks Int[]
|
|
|
|
|
ScratchSheet ScratchSheet[]
|
|
|
|
|
currentSheet Int @default(1)
|
|
|
|
|
lastScratched Int @default(0) // Timestamp
|
2022-07-20 09:29:28 +02:00
|
|
|
|
}
|
|
|
|
|
|
2022-07-22 12:02:51 +02:00
|
|
|
|
model ScratchSheet {
|
2022-07-22 18:19:44 +02:00
|
|
|
|
id Int @id @default(autoincrement())
|
|
|
|
|
User User @relation(fields: [userId], references: [id])
|
|
|
|
|
userId Int
|
|
|
|
|
sheetNo Int // Player's sheet number (i.e. first sheet)
|
|
|
|
|
squares ScratchSquare[]
|
2022-07-22 12:02:51 +02:00
|
|
|
|
}
|
2022-07-20 09:29:28 +02:00
|
|
|
|
|
2022-07-22 12:02:51 +02:00
|
|
|
|
model ScratchSquare {
|
2022-07-22 18:19:44 +02:00
|
|
|
|
id Int @id @default(autoincrement())
|
|
|
|
|
Sheet ScratchSheet @relation(fields: [sheetId], references: [id])
|
|
|
|
|
sheetId Int
|
|
|
|
|
category Int
|
|
|
|
|
itemId Int
|
|
|
|
|
earned Boolean
|
2022-07-22 12:02:51 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
model UserItem {
|
2022-07-22 18:19:44 +02:00
|
|
|
|
userItemId Int @id @default(autoincrement())
|
|
|
|
|
category Int
|
|
|
|
|
itemId Int
|
|
|
|
|
User User @relation(fields: [userId], references: [id])
|
|
|
|
|
userId Int
|
|
|
|
|
type Int @default(0)
|
|
|
|
|
earnedAt Int @default(0)
|
2022-07-15 16:39:59 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
model Car {
|
2022-07-22 18:19:44 +02:00
|
|
|
|
user User @relation(fields: [userId], references: [id])
|
|
|
|
|
userId Int
|
|
|
|
|
|
|
|
|
|
// This is the Car object itself
|
|
|
|
|
carId Int @id @default(autoincrement())
|
|
|
|
|
name String
|
|
|
|
|
manufacturer Int
|
|
|
|
|
regionId Int @default(0)
|
|
|
|
|
model Int
|
|
|
|
|
visualModel Int
|
|
|
|
|
customColor Int @default(0)
|
|
|
|
|
defaultColor Int
|
|
|
|
|
wheel Int @default(0)
|
|
|
|
|
wheelColor Int @default(0)
|
|
|
|
|
aero Int @default(0)
|
|
|
|
|
bonnet Int @default(0)
|
|
|
|
|
wing Int @default(0)
|
|
|
|
|
mirror Int @default(0)
|
|
|
|
|
neon Int @default(0)
|
|
|
|
|
trunk Int @default(0)
|
|
|
|
|
plate Int @default(0)
|
|
|
|
|
plateColor Int @default(0)
|
|
|
|
|
plateNumber Int @default(0)
|
|
|
|
|
tunePower Int @default(0)
|
|
|
|
|
tuneHandling Int @default(0)
|
|
|
|
|
title String @default("New Car")
|
|
|
|
|
level Int @default(0)
|
|
|
|
|
windowSticker Boolean @default(false)
|
|
|
|
|
windowStickerString String @default("WANGAN")
|
|
|
|
|
windowStickerFont Int @default(0)
|
2022-07-25 10:23:12 +02:00
|
|
|
|
windowDecoration Int @default(0)
|
2022-07-22 18:19:44 +02:00
|
|
|
|
rivalMarker Int @default(0)
|
|
|
|
|
lastPlayedAt Int @default(0)
|
|
|
|
|
aura Int @default(0)
|
|
|
|
|
auraMotif Int @default(0)
|
|
|
|
|
ghostLevel Int @default(1)
|
|
|
|
|
|
|
|
|
|
// This is more data about the car
|
|
|
|
|
tuningPoints Int @default(0)
|
|
|
|
|
odometer Int @default(0)
|
|
|
|
|
playCount Int @default(0)
|
|
|
|
|
earnedCustomColor Boolean @default(false)
|
|
|
|
|
carSettingsDbId Int @unique
|
|
|
|
|
settings CarSettings @relation(fields: [carSettingsDbId], references: [dbId])
|
|
|
|
|
vsPlayCount Int @default(0)
|
|
|
|
|
vsBurstCount Int @default(0)
|
|
|
|
|
vsStarCount Int @default(0)
|
|
|
|
|
vsCoolOrWild Int @default(0)
|
|
|
|
|
vsSmoothOrRough Int @default(0)
|
|
|
|
|
vsTripleStarMedals Int @default(0)
|
|
|
|
|
vsDoubleStarMedals Int @default(0)
|
|
|
|
|
vsSingleStarMedals Int @default(0)
|
|
|
|
|
vsPlainMedals Int @default(0)
|
|
|
|
|
rgPlayCount Int @default(0)
|
|
|
|
|
rgWinCount Int @default(0)
|
|
|
|
|
rgTrophy Int @default(0)
|
|
|
|
|
rgScore Int @default(0)
|
|
|
|
|
rgStamp Int @default(0)
|
|
|
|
|
rgAcquireAllCrowns Boolean @default(false)
|
|
|
|
|
rgRegionMapScore Int[]
|
|
|
|
|
dressupLevel Int @default(0)
|
|
|
|
|
dressupPoint Int @default(0)
|
|
|
|
|
stPlayCount Int @default(0)
|
|
|
|
|
stClearBits Int @default(0)
|
|
|
|
|
stClearDivCount Int @default(0)
|
|
|
|
|
stClearCount Int @default(0)
|
|
|
|
|
stLoseBits BigInt @default(0)
|
|
|
|
|
stConsecutiveWins Int @default(0)
|
|
|
|
|
stConsecutiveWinsMax Int @default(0)
|
|
|
|
|
stCompleted100Episodes Boolean @default(false)
|
|
|
|
|
|
2022-07-25 10:23:12 +02:00
|
|
|
|
items CarItem[]
|
|
|
|
|
carGTWingDbId Int @unique
|
|
|
|
|
gtWing CarGTWing @relation(fields: [carGTWingDbId], references: [dbId])
|
2022-07-22 18:19:44 +02:00
|
|
|
|
carStateDbId Int @unique
|
|
|
|
|
state CarState @relation(fields: [carStateDbId], references: [dbId])
|
|
|
|
|
TimeAttackRecord TimeAttackRecord[]
|
2022-07-15 16:39:59 +02:00
|
|
|
|
}
|
|
|
|
|
|
2022-07-25 10:23:12 +02:00
|
|
|
|
model CarGTWing {
|
|
|
|
|
dbId Int @id @default(autoincrement())
|
|
|
|
|
car Car?
|
|
|
|
|
|
|
|
|
|
pillar Int @default(0)
|
|
|
|
|
pillarMaterial Int @default(0)
|
|
|
|
|
mainWing Int @default(0)
|
|
|
|
|
mainWingColor Int @default(0)
|
|
|
|
|
wingTip Int @default(0)
|
|
|
|
|
material Int @default(0)
|
|
|
|
|
}
|
|
|
|
|
|
2022-07-15 16:39:59 +02:00
|
|
|
|
model CarItem {
|
2022-07-22 18:19:44 +02:00
|
|
|
|
dbId Int @id @default(autoincrement())
|
|
|
|
|
Car Car @relation(fields: [carId], references: [carId])
|
|
|
|
|
carId Int
|
|
|
|
|
category Int
|
|
|
|
|
itemId Int
|
|
|
|
|
amount Int
|
2022-07-15 16:39:59 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
model CarSettings {
|
2022-07-22 18:19:44 +02:00
|
|
|
|
dbId Int @id @default(autoincrement())
|
|
|
|
|
car Car?
|
|
|
|
|
|
|
|
|
|
view Boolean @default(true)
|
|
|
|
|
transmission Boolean @default(false)
|
|
|
|
|
retire Boolean @default(false)
|
|
|
|
|
meter Int @default(0)
|
|
|
|
|
navigationMap Boolean @default(true)
|
|
|
|
|
volume Int @default(1)
|
|
|
|
|
bgm Int @default(0)
|
|
|
|
|
nameplate Int @default(0)
|
|
|
|
|
nameplateColor Int @default(0)
|
|
|
|
|
terminalBackground Int @default(0)
|
2022-07-15 16:39:59 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
model CarState {
|
2022-07-22 18:19:44 +02:00
|
|
|
|
dbId Int @id @default(autoincrement())
|
|
|
|
|
car Car?
|
2022-07-15 16:39:59 +02:00
|
|
|
|
|
2022-07-22 18:19:44 +02:00
|
|
|
|
hasOpponentGhost Boolean @default(false)
|
|
|
|
|
eventJoined Boolean @default(false)
|
|
|
|
|
transferred Boolean @default(false)
|
|
|
|
|
toBeDeleted Boolean @default(false)
|
2022-07-11 09:22:41 +02:00
|
|
|
|
}
|
2022-07-16 23:46:40 +02:00
|
|
|
|
|
|
|
|
|
model TimeAttackRecord {
|
2022-07-22 18:19:44 +02:00
|
|
|
|
dbId Int @id @default(autoincrement())
|
|
|
|
|
|
|
|
|
|
car Car @relation(fields: [carId], references: [carId])
|
|
|
|
|
carId Int
|
|
|
|
|
|
|
|
|
|
model Int // Car model, literally just the `model` field from Car
|
|
|
|
|
time Int
|
|
|
|
|
course Int
|
|
|
|
|
isMorning Boolean
|
|
|
|
|
section1Time Int @map("section1Time")
|
|
|
|
|
section2Time Int @map("section2Time")
|
|
|
|
|
section3Time Int @map("section3Time")
|
|
|
|
|
section4Time Int @map("section4Time")
|
|
|
|
|
section5Time Int? @map("section5Time")
|
|
|
|
|
section6Time Int? @map("section6Time")
|
|
|
|
|
section7Time Int? @map("section7Time")
|
|
|
|
|
tunePower Int @default(0) // Car Power
|
|
|
|
|
tuneHandling Int @default(0) // Car Handling
|
2022-07-16 23:46:40 +02:00
|
|
|
|
}
|