First version

This commit is contained in:
Sebastien Castiel
2023-12-05 17:39:05 -05:00
parent 1fd6e48807
commit ed55c696cd
41 changed files with 8305 additions and 468 deletions

48
prisma/schema.prisma Normal file
View File

@@ -0,0 +1,48 @@
// This is your Prisma schema file,
// learn more about it in the docs: https://pris.ly/d/prisma-schema
generator client {
provider = "prisma-client-js"
}
datasource db {
provider = "postgresql"
url = env("POSTGRES_PRISMA_URL") // uses connection pooling
directUrl = env("POSTGRES_URL_NON_POOLING") // uses a direct connection
}
model Group {
id String @id
name String
participants Participant[]
expenses Expense[]
}
model Participant {
id String @id
name String
group Group @relation(fields: [groupId], references: [id])
groupId String
expensesPaidBy Expense[]
expensesPaidFor ExpensePaidFor[]
}
model Expense {
id String @id
group Group @relation(fields: [groupId], references: [id])
title String
amount Int
paidBy Participant @relation(fields: [paidById], references: [id])
paidById String
paidFor ExpensePaidFor[]
groupId String
}
model ExpensePaidFor {
expense Expense @relation(fields: [expenseId], references: [id])
participant Participant @relation(fields: [participantId], references: [id])
expenseId String
participantId String
@@id([expenseId, participantId])
}