79 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| // 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"
 | |
|     previewFeatures = ["jsonProtocol"]
 | |
|     binaryTargets   = ["native", "linux-musl-openssl-3.0.x"]
 | |
| }
 | |
| 
 | |
| datasource db {
 | |
|     provider = "postgresql"
 | |
|     // NOTE: When using mysql or sqlserver, uncomment the @db.Text annotations in model Account below
 | |
|     // Further reading:
 | |
|     // https://next-auth.js.org/adapters/prisma#create-the-prisma-schema
 | |
|     // https://www.prisma.io/docs/reference/api-reference/prisma-schema-reference#string
 | |
|     url      = env("DATABASE_URL")
 | |
| }
 | |
| 
 | |
| model Training {
 | |
|     id             String  @id @default(cuid())
 | |
|     name           String
 | |
|     slug           String  @unique
 | |
|     days           Int
 | |
|     weight         Int
 | |
|     draft          Boolean @default(true)
 | |
|     logoURL        String?
 | |
|     svgIconURL     String?
 | |
|     repositoryURL  String?
 | |
|     priceOpen      Int
 | |
|     priceCorporate Int
 | |
|     content        String?
 | |
| 
 | |
|     @@index([slug])
 | |
| }
 | |
| 
 | |
| // Necessary for Next auth
 | |
| model Account {
 | |
|     id                String  @id @default(cuid())
 | |
|     userId            String
 | |
|     type              String
 | |
|     provider          String
 | |
|     providerAccountId String
 | |
|     refresh_token     String? // @db.Text
 | |
|     access_token      String? // @db.Text
 | |
|     expires_at        Int?
 | |
|     token_type        String?
 | |
|     scope             String?
 | |
|     id_token          String? // @db.Text
 | |
|     session_state     String?
 | |
|     user              User    @relation(fields: [userId], references: [id], onDelete: Cascade)
 | |
| 
 | |
|     @@unique([provider, providerAccountId])
 | |
| }
 | |
| 
 | |
| model Session {
 | |
|     id           String   @id @default(cuid())
 | |
|     sessionToken String   @unique
 | |
|     userId       String
 | |
|     expires      DateTime
 | |
|     user         User     @relation(fields: [userId], references: [id], onDelete: Cascade)
 | |
| }
 | |
| 
 | |
| model User {
 | |
|     id            String    @id @default(cuid())
 | |
|     name          String?
 | |
|     email         String?   @unique
 | |
|     emailVerified DateTime?
 | |
|     image         String?
 | |
|     accounts      Account[]
 | |
|     sessions      Session[]
 | |
| }
 | |
| 
 | |
| model VerificationToken {
 | |
|     identifier String
 | |
|     token      String   @unique
 | |
|     expires    DateTime
 | |
| 
 | |
|     @@unique([identifier, token])
 | |
| }
 |