mirror of
https://github.com/i701/sarlink-portal.git
synced 2025-02-22 17:42:00 +00:00
- Updated `package.json` to add a new script for pushing Prisma database changes. - Refactored payment processing functions to include payment method handling for both wallet and transfer options. - Improved `DevicesTable` and `AdminDevicesTable` components to support new payment method display and user association. - Updated Prisma schema to introduce a new `PaymentType` enum and modified the `Payment` model to include a `method` field. - Enhanced UI components to improve user experience in displaying payment and device information. These changes improve the overall functionality and maintainability of the application, particularly in payment processing and device management.
172 lines
4.3 KiB
Plaintext
172 lines
4.3 KiB
Plaintext
// This is your Prisma schema file,
|
|
// learn more about it in the docs: https://pris.ly/d/prisma-schema
|
|
|
|
// Looking for ways to speed up your queries, or scale easily with your serverless or edge functions?
|
|
// Try Prisma Accelerate: https://pris.ly/cli/accelerate-init
|
|
|
|
generator client {
|
|
provider = "prisma-client-js"
|
|
}
|
|
|
|
datasource db {
|
|
provider = "postgresql"
|
|
url = env("DATABASE_URL")
|
|
}
|
|
|
|
model User {
|
|
id String @id @default(cuid())
|
|
name String?
|
|
email String? @unique
|
|
emailVerified Boolean @default(false)
|
|
|
|
verified Boolean @default(false)
|
|
accNo String?
|
|
// island String?
|
|
address String?
|
|
id_card String? @unique
|
|
dob DateTime?
|
|
atoll Atoll? @relation(fields: [atollId], references: [id])
|
|
island Island? @relation(fields: [islandId], references: [id])
|
|
|
|
image String?
|
|
createdAt DateTime @default(now())
|
|
updatedAt DateTime @updatedAt
|
|
phoneNumber String @unique
|
|
phoneNumberVerified Boolean @default(false)
|
|
termsAccepted Boolean @default(false)
|
|
policyAccepted Boolean @default(false)
|
|
walletBalance Float @default(0)
|
|
ninja_user_id String?
|
|
devices Device[]
|
|
|
|
role String?
|
|
lang String?
|
|
atollId String?
|
|
islandId String?
|
|
Bill Payment[]
|
|
|
|
@@map("user")
|
|
}
|
|
|
|
model Session {
|
|
id String @id @default(cuid())
|
|
userId String
|
|
token String @unique
|
|
expiresAt DateTime
|
|
ipAddress String?
|
|
userAgent String?
|
|
createdAt DateTime @default(now())
|
|
updatedAt DateTime @updatedAt
|
|
|
|
@@map("session")
|
|
}
|
|
|
|
model Account {
|
|
id String @id @default(cuid())
|
|
userId String
|
|
accountId String
|
|
providerId String
|
|
accessToken String?
|
|
refreshToken String?
|
|
accessTokenExpiresAt DateTime?
|
|
refreshTokenExpiresAt DateTime?
|
|
scope String?
|
|
password String?
|
|
createdAt DateTime @default(now())
|
|
updatedAt DateTime @updatedAt
|
|
|
|
idToken String?
|
|
|
|
@@map("account")
|
|
}
|
|
|
|
model Verification {
|
|
id String @id @default(cuid())
|
|
identifier String
|
|
value String
|
|
expiresAt DateTime
|
|
createdAt DateTime @default(now())
|
|
updatedAt DateTime @updatedAt
|
|
|
|
@@map("verification")
|
|
}
|
|
|
|
model Atoll {
|
|
id String @id @default(cuid())
|
|
name String
|
|
createdAt DateTime @default(now())
|
|
updatedAt DateTime @updatedAt
|
|
islands Island[]
|
|
User User[]
|
|
}
|
|
|
|
model Island {
|
|
id String @id @default(cuid())
|
|
atollId String
|
|
atoll Atoll @relation(fields: [atollId], references: [id])
|
|
name String
|
|
createdAt DateTime @default(now())
|
|
updatedAt DateTime @updatedAt
|
|
User User[]
|
|
}
|
|
|
|
enum Blocker {
|
|
ADMIN
|
|
PARENT
|
|
}
|
|
|
|
enum PaymentType {
|
|
WALLET
|
|
TRANSFER
|
|
}
|
|
|
|
model Device {
|
|
id String @id @default(cuid())
|
|
name String
|
|
mac String
|
|
reasonForBlocking String?
|
|
isActive Boolean @default(false)
|
|
registered Boolean @default(false)
|
|
blocked Boolean @default(false)
|
|
blockedBy Blocker @default(PARENT)
|
|
expiryDate DateTime?
|
|
createdAt DateTime @default(now())
|
|
updatedAt DateTime @updatedAt
|
|
User User? @relation(fields: [userId], references: [id])
|
|
userId String?
|
|
payments Payment[]
|
|
}
|
|
|
|
model Payment {
|
|
id String @id @default(cuid())
|
|
numberOfMonths Int
|
|
amount Float
|
|
paid Boolean @default(false)
|
|
user User @relation(fields: [userId], references: [id])
|
|
paidAt DateTime?
|
|
method PaymentType @default(TRANSFER)
|
|
expiresAt DateTime?
|
|
createdAt DateTime @default(now())
|
|
updatedAt DateTime @updatedAt
|
|
devices Device[]
|
|
userId String
|
|
}
|
|
|
|
model BillFormula {
|
|
id String @id @default(cuid())
|
|
formula String
|
|
baseAmount Float
|
|
discountPercentage Float
|
|
createdAt DateTime @default(now())
|
|
updatedAt DateTime @updatedAt
|
|
}
|
|
|
|
model Topup {
|
|
id String @id @default(cuid())
|
|
amount Float
|
|
userId String
|
|
paid Boolean @default(false)
|
|
createdAt DateTime @default(now())
|
|
updatedAt DateTime @updatedAt
|
|
}
|