diff --git a/.gitignore b/.gitignore index fe49650..ea161cd 100644 --- a/.gitignore +++ b/.gitignore @@ -8,5 +8,4 @@ cert.pfx key.pem config.json package-lock.json -ecosystem.config.js -prisma/public.sql \ No newline at end of file +ecosystem.config.js \ No newline at end of file diff --git a/LICENSE b/LICENSE index 32acc6e..f64b446 100644 --- a/LICENSE +++ b/LICENSE @@ -2,6 +2,8 @@ Copyright 2022 Project Asakura Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: +TeknoGods, the TeknoParrot team, and anyone affiliated with the TeknoParrot project ("TeknoParrot") is not authorised to use any part of the Software. + The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. \ No newline at end of file diff --git a/README.md b/README.md index e69d60c..3c34d78 100644 --- a/README.md +++ b/README.md @@ -14,4 +14,7 @@ Special thanks: ## Donations Donations are not required, however I'm only one person, and I'm still a student, so if you want to thank me for my work, [please buy me a coffee or two](https://ko-fi.com/lostkagamine). -This won't get you anything other than my gratitude, the entire project is and will always remain available to everyone for free. \ No newline at end of file +This won't get you anything other than my gratitude, the entire project is and will always remain available to everyone for free. + +## On TeknoParrot +The TeknoParrot team (TeknoGods) are not authorised to use **any part** of this project. **Do not integrate any portion of Bayshore into TeknoParrot.** \ No newline at end of file diff --git a/prisma/migrations/20220720155206_terminalmode/migration.sql b/prisma/migrations/20220720155206_terminalmode/migration.sql new file mode 100644 index 0000000..89fe842 --- /dev/null +++ b/prisma/migrations/20220720155206_terminalmode/migration.sql @@ -0,0 +1,12 @@ +-- AlterTable +ALTER TABLE "Car" ALTER COLUMN "stLoseBits" SET DEFAULT 0; + +-- AlterTable +ALTER TABLE "TimeAttackRecord" ADD COLUMN "tuneHandling" INTEGER NOT NULL DEFAULT 0, +ADD COLUMN "tunePower" INTEGER NOT NULL DEFAULT 0; + +-- AlterTable +ALTER TABLE "User" ADD COLUMN "bookmarks" INTEGER[], +ADD COLUMN "carOrder" INTEGER[], +ADD COLUMN "currentSheet" INTEGER NOT NULL DEFAULT 0, +ADD COLUMN "lastSheet" INTEGER NOT NULL DEFAULT 0; diff --git a/prisma/migrations/20220721011310_rg_region_map_score/migration.sql b/prisma/migrations/20220721011310_rg_region_map_score/migration.sql new file mode 100644 index 0000000..48d3cda --- /dev/null +++ b/prisma/migrations/20220721011310_rg_region_map_score/migration.sql @@ -0,0 +1,3 @@ +-- AlterTable +ALTER TABLE "Car" ADD COLUMN "rgRegionMapScore" INTEGER[], +ALTER COLUMN "stLoseBits" SET DEFAULT 0; diff --git a/prisma/migrations/20220721084743_ghostbattle/migration.sql b/prisma/migrations/20220721084743_ghostbattle/migration.sql new file mode 100644 index 0000000..811ffe0 --- /dev/null +++ b/prisma/migrations/20220721084743_ghostbattle/migration.sql @@ -0,0 +1,2 @@ +-- AlterTable +ALTER TABLE "Car" ALTER COLUMN "stLoseBits" SET DEFAULT 0; diff --git a/prisma/schema.prisma b/prisma/schema.prisma index 7f34d28..bac7abb 100644 --- a/prisma/schema.prisma +++ b/prisma/schema.prisma @@ -2,186 +2,186 @@ // learn more about it in the docs: https://pris.ly/d/prisma-schema generator client { - provider = "prisma-client-js" + provider = "prisma-client-js" } datasource db { - provider = "postgresql" - url = env("POSTGRES_URL") + provider = "postgresql" + url = env("POSTGRES_URL") } model User { - 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) - lastSheet Int @default(1) - lastScratched Int @default(0) // Timestamp + 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) + lastSheet Int @default(1) + lastScratched Int @default(0) // Timestamp } model ScratchSheet { - 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[] + 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[] } model ScratchSquare { - id Int @id @default(autoincrement()) - Sheet ScratchSheet @relation(fields: [sheetId], references: [id]) - sheetId Int - category Int - itemId Int - earned Boolean + id Int @id @default(autoincrement()) + Sheet ScratchSheet @relation(fields: [sheetId], references: [id]) + sheetId Int + category Int + itemId Int + earned Boolean } model UserItem { - 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) + 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) } model Car { - user User @relation(fields: [userId], references: [id]) - userId Int + 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) - rivalMarker Int @default(0) - lastPlayedAt Int @default(0) - aura Int @default(0) - auraMotif Int @default(0) - ghostLevel Int @default(1) + // 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) + 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) - 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) + // 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) + 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) - items CarItem[] + items CarItem[] - carStateDbId Int @unique - state CarState @relation(fields: [carStateDbId], references: [dbId]) - TimeAttackRecord TimeAttackRecord[] + carStateDbId Int @unique + state CarState @relation(fields: [carStateDbId], references: [dbId]) + TimeAttackRecord TimeAttackRecord[] } model CarItem { - dbId Int @id @default(autoincrement()) - Car Car @relation(fields: [carId], references: [carId]) - carId Int - category Int - itemId Int - amount Int + dbId Int @id @default(autoincrement()) + Car Car @relation(fields: [carId], references: [carId]) + carId Int + category Int + itemId Int + amount Int } model CarSettings { - dbId Int @id @default(autoincrement()) - car Car? + 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) + 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) } model CarState { - dbId Int @id @default(autoincrement()) - car Car? + dbId Int @id @default(autoincrement()) + car Car? - hasOpponentGhost Boolean @default(false) - eventJoined Boolean @default(false) - transferred Boolean @default(false) - toBeDeleted Boolean @default(false) + hasOpponentGhost Boolean @default(false) + eventJoined Boolean @default(false) + transferred Boolean @default(false) + toBeDeleted Boolean @default(false) } model TimeAttackRecord { - dbId Int @id @default(autoincrement()) + dbId Int @id @default(autoincrement()) - car Car @relation(fields: [carId], references: [carId]) - carId Int + 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 + 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 } diff --git a/src/modules/game.ts b/src/modules/game.ts index 5cf3e28..0b158c8 100644 --- a/src/modules/game.ts +++ b/src/modules/game.ts @@ -20,6 +20,7 @@ export default class GameModule extends Module { carId: body.carId } }); + console.log(body); let storyLose: boolean = false; switch (body.gameMode) { case wm.wm.protobuf.GameMode.MODE_STORY: @@ -91,15 +92,18 @@ export default class GameModule extends Module { console.log('-------'); console.log(c); - for(let i=0; i