generator client { provider = "prisma-client-js" } datasource db { provider = "sqlite" url = "file:../data/pingvin-share.db" } model User { id String @id @default(uuid()) createdAt DateTime @default(now()) updatedAt DateTime @updatedAt username String @unique email String @unique password String isAdmin Boolean @default(false) shares Share[] refreshTokens RefreshToken[] loginTokens LoginToken[] reverseShares ReverseShare[] totpEnabled Boolean @default(false) totpVerified Boolean @default(false) totpSecret String? } model RefreshToken { id String @id @default(uuid()) token String @unique @default(uuid()) createdAt DateTime @default(now()) expiresAt DateTime userId String user User @relation(fields: [userId], references: [id], onDelete: Cascade) } model LoginToken { token String @id @default(uuid()) createdAt DateTime @default(now()) expiresAt DateTime userId String user User @relation(fields: [userId], references: [id], onDelete: Cascade) used Boolean @default(false) } model Share { id String @id @default(uuid()) createdAt DateTime @default(now()) uploadLocked Boolean @default(false) isZipReady Boolean @default(false) views Int @default(0) expiration DateTime description String? removedReason String? creatorId String? creator User? @relation(fields: [creatorId], references: [id], onDelete: Cascade) reverseShare ReverseShare? security ShareSecurity? recipients ShareRecipient[] files File[] } model ReverseShare { id String @id @default(uuid()) createdAt DateTime @default(now()) token String @unique @default(uuid()) shareExpiration DateTime maxShareSize String sendEmailNotification Boolean used Boolean @default(false) creatorId String creator User @relation(fields: [creatorId], references: [id], onDelete: Cascade) shareId String? @unique share Share? @relation(fields: [shareId], references: [id], onDelete: Cascade) } model ShareRecipient { id String @id @default(uuid()) email String shareId String share Share @relation(fields: [shareId], references: [id], onDelete: Cascade) } model File { id String @id @default(uuid()) createdAt DateTime @default(now()) name String size String shareId String share Share @relation(fields: [shareId], references: [id], onDelete: Cascade) } model ShareSecurity { id String @id @default(uuid()) createdAt DateTime @default(now()) password String? maxViews Int? shareId String? @unique share Share? @relation(fields: [shareId], references: [id], onDelete: Cascade) } model Config { id Int @id updatedAt DateTime @updatedAt key String @unique type String value String description String category String obscured Boolean @default(false) secret Boolean @default(true) locked Boolean @default(false) }