feat: basic screenshot manager

This commit is contained in:
Huskydog9988
2025-05-08 11:38:09 -04:00
committed by DecDuck
parent 3a9eb82fdf
commit 836ba33fe4
5 changed files with 99 additions and 3 deletions

View File

@ -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;

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())

View File

@ -17,7 +17,8 @@ model User {
tokens APIToken[]
sessions Session[]
saves SaveSlot[]
saves SaveSlot[]
screenshots Screenshot[]
}
model Notification {