2022-12-06 07:48:02 +00:00
datasource db {
provider = "postgresql"
url = env("DATABASE_URL")
}
generator client {
provider = "prisma-client-js"
2023-08-23 18:31:28 +00:00
binaryTargets = ["native", "debian-openssl-1.1.x", "debian-openssl-3.0.x"]
2022-12-06 07:48:02 +00:00
}
model Team {
id String @id @default(cuid())
name String
members TeamMember[]
TeamInvitation TeamInvitation[]
TeamCollection TeamCollection[]
TeamRequest TeamRequest[]
TeamEnvironment TeamEnvironment[]
}
model TeamMember {
id String @id @default(uuid()) // Membership ID
2025-05-07 12:26:10 +00:00
role TeamAccessRole
2022-12-06 07:48:02 +00:00
userUid String
teamID String
team Team @relation(fields: [teamID], references: [id], onDelete: Cascade)
@@unique([teamID, userUid])
}
model TeamInvitation {
id String @id @default(cuid())
teamID String
team Team @relation(fields: [teamID], references: [id], onDelete: Cascade)
creatorUid String
inviteeEmail String
2025-05-07 12:26:10 +00:00
inviteeRole TeamAccessRole
2022-12-06 07:48:02 +00:00
@@unique([teamID, inviteeEmail])
@@index([teamID])
}
model TeamCollection {
2024-05-27 16:19:42 +00:00
id String @id @default(cuid())
2023-03-09 14:07:40 +00:00
parentID String?
2023-12-05 14:42:37 +00:00
data Json?
2024-05-27 16:19:42 +00:00
parent TeamCollection? @relation("TeamCollectionChildParent", fields: [parentID], references: [id])
children TeamCollection[] @relation("TeamCollectionChildParent")
2023-03-09 14:07:40 +00:00
requests TeamRequest[]
teamID String
2024-05-27 16:19:42 +00:00
team Team @relation(fields: [teamID], references: [id], onDelete: Cascade)
2023-03-09 14:07:40 +00:00
title String
orderIndex Int
2024-05-27 16:19:42 +00:00
createdOn DateTime @default(now()) @db.Timestamp(3)
updatedOn DateTime @updatedAt @db.Timestamp(3)
2022-12-06 07:48:02 +00:00
}
model TeamRequest {
2024-05-27 16:19:42 +00:00
id String @id @default(cuid())
2022-12-06 07:48:02 +00:00
collectionID String
2024-05-27 16:19:42 +00:00
collection TeamCollection @relation(fields: [collectionID], references: [id], onDelete: Cascade)
2022-12-06 07:48:02 +00:00
teamID String
2024-05-27 16:19:42 +00:00
team Team @relation(fields: [teamID], references: [id], onDelete: Cascade)
2022-12-06 07:48:02 +00:00
title String
request Json
2023-03-09 14:07:40 +00:00
orderIndex Int
2024-05-27 16:19:42 +00:00
createdOn DateTime @default(now()) @db.Timestamp(3)
updatedOn DateTime @updatedAt @db.Timestamp(3)
2022-12-06 07:48:02 +00:00
}
model Shortcode {
2023-11-07 12:27:51 +00:00
id String @id @unique
request Json
embedProperties Json?
creatorUid String?
User User? @relation(fields: [creatorUid], references: [uid])
createdOn DateTime @default(now())
2023-12-05 14:42:37 +00:00
updatedOn DateTime @default(now()) @updatedAt
2022-12-06 07:48:02 +00:00
@@unique(fields: [id, creatorUid], name: "creator_uid_shortcode_unique")
}
model TeamEnvironment {
id String @id @default(cuid())
teamID String
team Team @relation(fields: [teamID], references: [id], onDelete: Cascade)
name String
variables Json
}
2022-12-08 14:56:22 +00:00
model User {
2024-05-28 11:09:50 +00:00
uid String @id @default(cuid())
displayName String?
email String? @unique
photoURL String?
isAdmin Boolean @default(false)
refreshToken String?
providerAccounts Account[]
VerificationToken VerificationToken[]
settings UserSettings?
UserHistory UserHistory[]
UserEnvironments UserEnvironment[]
userCollections UserCollection[]
userRequests UserRequest[]
currentRESTSession Json?
currentGQLSession Json?
2024-06-21 07:10:21 +00:00
lastLoggedOn DateTime? @db.Timestamp(3)
lastActiveOn DateTime? @db.Timestamp(3)
2024-05-28 11:09:50 +00:00
createdOn DateTime @default(now()) @db.Timestamp(3)
invitedUsers InvitedUsers[]
shortcodes Shortcode[]
personalAccessTokens PersonalAccessToken[]
2023-01-09 06:45:21 +00:00
}
model Account {
id String @id @default(cuid())
userId String
2023-01-30 01:01:10 +00:00
user User @relation(fields: [userId], references: [uid], onDelete: Cascade)
2023-01-09 06:45:21 +00:00
provider String
providerAccountId String
providerRefreshToken String?
providerAccessToken String?
providerScope String?
2023-01-18 23:43:21 +00:00
loggedIn DateTime @default(now()) @db.Timestamp(3)
2023-01-09 06:45:21 +00:00
@@unique(fields: [provider, providerAccountId], name: "verifyProviderAccount")
}
2023-01-30 13:25:53 +00:00
model VerificationToken {
2023-01-09 06:45:21 +00:00
deviceIdentifier String
2023-01-19 09:43:55 +00:00
token String @unique @default(cuid())
userUid String
user User @relation(fields: [userUid], references: [uid], onDelete: Cascade)
expiresOn DateTime @db.Timestamp(3)
2023-01-09 06:45:21 +00:00
@@unique(fields: [deviceIdentifier, token], name: "passwordless_deviceIdentifier_tokens")
2022-12-08 14:56:22 +00:00
}
2023-01-24 09:24:11 +00:00
model UserSettings {
id String @id @default(cuid())
userUid String @unique
user User @relation(fields: [userUid], references: [uid], onDelete: Cascade)
properties Json
updatedOn DateTime @updatedAt @db.Timestamp(3)
}
model UserHistory {
id String @id @default(cuid())
userUid String
user User @relation(fields: [userUid], references: [uid], onDelete: Cascade)
reqType ReqType
request Json
responseMetadata Json
isStarred Boolean
executedOn DateTime @default(now()) @db.Timestamp(3)
}
enum ReqType {
REST
GQL
}
2022-12-13 07:44:13 +00:00
model UserEnvironment {
id String @id @default(cuid())
userUid String
user User @relation(fields: [userUid], references: [uid], onDelete: Cascade)
name String?
variables Json
isGlobal Boolean
2022-12-08 14:56:22 +00:00
}
2023-03-21 11:12:30 +00:00
model InvitedUsers {
adminUid String
user User @relation(fields: [adminUid], references: [uid], onDelete: Cascade)
adminEmail String
inviteeEmail String @unique
invitedOn DateTime @default(now()) @db.Timestamp(3)
}
2023-03-03 10:51:49 +00:00
model UserRequest {
id String @id @default(cuid())
userCollection UserCollection @relation(fields: [collectionID], references: [id])
collectionID String
userUid String
user User @relation(fields: [userUid], references: [uid], onDelete: Cascade)
title String
request Json
type ReqType
orderIndex Int
createdOn DateTime @default(now()) @db.Timestamp(3)
updatedOn DateTime @updatedAt @db.Timestamp(3)
}
2023-03-03 09:33:05 +00:00
model UserCollection {
id String @id @default(cuid())
parentID String?
parent UserCollection? @relation("ParentUserCollection", fields: [parentID], references: [id], onDelete: Cascade)
children UserCollection[] @relation("ParentUserCollection")
requests UserRequest[]
userUid String
user User @relation(fields: [userUid], references: [uid], onDelete: Cascade)
title String
2023-12-05 14:42:37 +00:00
data Json?
2023-03-03 09:33:05 +00:00
orderIndex Int
type ReqType
createdOn DateTime @default(now()) @db.Timestamp(3)
updatedOn DateTime @updatedAt @db.Timestamp(3)
}
2025-05-07 12:26:10 +00:00
enum TeamAccessRole {
2022-12-06 07:48:02 +00:00
OWNER
VIEWER
EDITOR
}
2023-12-12 10:42:58 +00:00
model InfraConfig {
2024-11-26 14:22:51 +00:00
id String @id @default(cuid())
name String @unique
value String?
lastSyncedEnvFileValue String?
isEncrypted Boolean @default(false) // Use case: Let's say, Admin wants to store a Secret Key, but doesn't want to store it in plain text in `value` column
createdOn DateTime @default(now()) @db.Timestamp(3)
updatedOn DateTime @updatedAt @db.Timestamp(3)
2023-12-12 10:42:58 +00:00
}
2024-05-28 11:09:50 +00:00
model PersonalAccessToken {
id String @id @default(cuid())
userUid String
user User @relation(fields: [userUid], references: [uid], onDelete: Cascade)
label String
token String @unique @default(uuid())
expiresOn DateTime? @db.Timestamp(3)
createdOn DateTime @default(now()) @db.Timestamp(3)
updatedOn DateTime @updatedAt @db.Timestamp(3)
}
2024-07-29 07:06:18 +00:00
model InfraToken {
id String @id @default(cuid())
creatorUid String
label String
token String @unique @default(uuid())
expiresOn DateTime? @db.Timestamp(3)
createdOn DateTime @default(now()) @db.Timestamp(3)
updatedOn DateTime @default(now()) @db.Timestamp(3)
}