feat: basic screenshot manager

This commit is contained in:
Huskydog9988
2025-05-08 11:38:09 -04:00
parent f93035d984
commit 8ee485feef
5 changed files with 99 additions and 3 deletions
@@ -0,0 +1,20 @@
-- CreateTable
CREATE TABLE "Screenshot" (
"id" TEXT NOT NULL,
"gameId" TEXT NOT NULL,
"userId" TEXT NOT NULL,
"objectId" TEXT NOT NULL,
"private" BOOLEAN NOT NULL DEFAULT true,
"createdAt" TIMESTAMPTZ(0) NOT NULL DEFAULT CURRENT_TIMESTAMP,
CONSTRAINT "Screenshot_pkey" PRIMARY KEY ("id")
);
-- CreateIndex
CREATE INDEX "Screenshot_gameId_userId_idx" ON "Screenshot"("gameId", "userId");
-- AddForeignKey
ALTER TABLE "Screenshot" ADD CONSTRAINT "Screenshot_gameId_fkey" FOREIGN KEY ("gameId") REFERENCES "Game"("id") ON DELETE CASCADE ON UPDATE CASCADE;
-- AddForeignKey
ALTER TABLE "Screenshot" ADD CONSTRAINT "Screenshot_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User"("id") ON DELETE CASCADE ON UPDATE CASCADE;
+17
View File
@@ -35,6 +35,7 @@ model Game {
collections CollectionEntry[]
saves SaveSlot[]
screenshots Screenshot[]
@@unique([metadataSource, metadataId], name: "metadataKey")
}
@@ -85,6 +86,22 @@ model SaveSlot {
@@id([gameId, userId, index], name: "id")
}
model Screenshot {
id String @id @default(uuid())
gameId String
game Game @relation(fields: [gameId], references: [id], onDelete: Cascade)
userId String
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
objectId String
private Boolean @default(true)
createdAt DateTime @default(now()) @db.Timestamptz(0)
@@index([gameId, userId])
}
model Developer {
id String @id @default(uuid())
+2 -1
View File
@@ -17,7 +17,8 @@ model User {
tokens APIToken[]
sessions Session[]
saves SaveSlot[]
saves SaveSlot[]
screenshots Screenshot[]
}
model Notification {