@danielcok17/prisma-db 1.6.0 → 1.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,5 @@
1
1
  {
2
- "name": "prisma-client-5f1a6ac2ef45658117695ac2fdcb5a13aee75ba340f90242b0e73f11b4f53f53",
2
+ "name": "prisma-client-40d7e3f99271843fb75f26c2361837ec74baa15e67b90e9d8bae4eecf4210928",
3
3
  "main": "index.js",
4
4
  "types": "index.d.ts",
5
5
  "browser": "default.js",
@@ -56,11 +56,13 @@ model User {
56
56
  subscriptionTier SubscriptionTier @default(FREE) // Aktuálny subscription tier (cache)
57
57
  messageCount Int @default(10) // ✅ OPRAVENÉ z 100 na 10
58
58
  messageCountResetAt DateTime? // Kedy sa má resetovať message count
59
+ adminGrantExpiresAt DateTime? // Kedy admin grant expiruje
59
60
  // Relations
60
61
  approvalRequest UserApprovalRequest?
61
62
  stripeCustomer StripeCustomer? // ✨ B2C Stripe customer
62
63
  ownedOrganizations Organization[] @relation("OrganizationOwner")
63
64
  organizationMembers OrganizationMember[]
65
+ createdInvites OrganizationInvite[] @relation("InviteCreator")
64
66
  accounts Account[]
65
67
  answers Answer[]
66
68
  conversations Conversation[]
@@ -117,6 +119,7 @@ model Organization {
117
119
  messageCount Int @default(0) // Spoločný pool správ pre všetkých členov
118
120
  messageLimit Int @default(100) // Limit správ podľa tieru
119
121
  messageCountResetAt DateTime? // Kedy sa má resetovať pool
122
+ adminGrantExpiresAt DateTime? // Kedy admin grant expiruje
120
123
 
121
124
  // Settings
122
125
  isActive Boolean @default(true)
@@ -126,6 +129,7 @@ model Organization {
126
129
  owner User @relation("OrganizationOwner", fields: [ownerId], references: [id])
127
130
  ownerId String
128
131
  members OrganizationMember[]
132
+ invites OrganizationInvite[]
129
133
  stripeCustomer StripeCustomer?
130
134
 
131
135
  createdAt DateTime @default(now())
@@ -155,6 +159,32 @@ model OrganizationMember {
155
159
  @@index([role])
156
160
  }
157
161
 
162
+ // Organization Invite System
163
+ model OrganizationInvite {
164
+ id String @id @default(cuid())
165
+ organizationId String
166
+ token String @unique
167
+ email String? // Optional: specific email invite
168
+ role MemberRole @default(MEMBER)
169
+ createdBy String
170
+ expiresAt DateTime
171
+ maxUses Int @default(1) // For multi-use invites
172
+ currentUses Int @default(0)
173
+ isActive Boolean @default(true)
174
+ usedAt DateTime? // Last usage timestamp
175
+ usedBy String? // Last user who used it
176
+ createdAt DateTime @default(now())
177
+ updatedAt DateTime @updatedAt
178
+
179
+ organization Organization @relation(fields: [organizationId], references: [id], onDelete: Cascade)
180
+ creator User @relation("InviteCreator", fields: [createdBy], references: [id])
181
+
182
+ @@index([token])
183
+ @@index([organizationId])
184
+ @@index([isActive])
185
+ @@index([expiresAt])
186
+ }
187
+
158
188
  enum MemberRole {
159
189
  OWNER // Zakladateľ/vlastník, plný prístup k billing a settings
160
190
  ADMIN // Administrátor, môže pridávať/odoberať členov
@@ -130,7 +130,8 @@ exports.Prisma.UserScalarFieldEnum = {
130
130
  applicationText: 'applicationText',
131
131
  subscriptionTier: 'subscriptionTier',
132
132
  messageCount: 'messageCount',
133
- messageCountResetAt: 'messageCountResetAt'
133
+ messageCountResetAt: 'messageCountResetAt',
134
+ adminGrantExpiresAt: 'adminGrantExpiresAt'
134
135
  };
135
136
 
136
137
  exports.Prisma.UserApprovalRequestScalarFieldEnum = {
@@ -159,6 +160,7 @@ exports.Prisma.OrganizationScalarFieldEnum = {
159
160
  messageCount: 'messageCount',
160
161
  messageLimit: 'messageLimit',
161
162
  messageCountResetAt: 'messageCountResetAt',
163
+ adminGrantExpiresAt: 'adminGrantExpiresAt',
162
164
  isActive: 'isActive',
163
165
  maxMembers: 'maxMembers',
164
166
  ownerId: 'ownerId',
@@ -174,6 +176,23 @@ exports.Prisma.OrganizationMemberScalarFieldEnum = {
174
176
  joinedAt: 'joinedAt'
175
177
  };
176
178
 
179
+ exports.Prisma.OrganizationInviteScalarFieldEnum = {
180
+ id: 'id',
181
+ organizationId: 'organizationId',
182
+ token: 'token',
183
+ email: 'email',
184
+ role: 'role',
185
+ createdBy: 'createdBy',
186
+ expiresAt: 'expiresAt',
187
+ maxUses: 'maxUses',
188
+ currentUses: 'currentUses',
189
+ isActive: 'isActive',
190
+ usedAt: 'usedAt',
191
+ usedBy: 'usedBy',
192
+ createdAt: 'createdAt',
193
+ updatedAt: 'updatedAt'
194
+ };
195
+
177
196
  exports.Prisma.ConversationScalarFieldEnum = {
178
197
  id: 'id',
179
198
  name: 'name',
@@ -550,6 +569,7 @@ exports.Prisma.ModelName = {
550
569
  UserApprovalRequest: 'UserApprovalRequest',
551
570
  Organization: 'Organization',
552
571
  OrganizationMember: 'OrganizationMember',
572
+ OrganizationInvite: 'OrganizationInvite',
553
573
  Conversation: 'Conversation',
554
574
  Answer: 'Answer',
555
575
  MessageFile: 'MessageFile',
@@ -622,13 +642,13 @@ const config = {
622
642
  }
623
643
  }
624
644
  },
625
- "inlineSchema": "generator client {\n provider = \"prisma-client-js\"\n output = \"./generated/app\"\n binaryTargets = [\"native\", \"linux-musl-openssl-3.0.x\"]\n}\n\ndatasource db {\n provider = \"postgresql\"\n url = env(\"POSTGRES_PRISMA_URL\")\n directUrl = env(\"POSTGRES_URL_NON_POOLING\")\n}\n\nmodel Account {\n id String @id @default(cuid())\n userId String\n type String\n provider String\n providerAccountId String\n refresh_token String?\n access_token String?\n expires_at Int?\n token_type String?\n scope String?\n id_token String?\n session_state String?\n user User @relation(fields: [userId], references: [id], onDelete: Cascade)\n\n @@unique([provider, providerAccountId])\n}\n\nmodel User {\n id String @id @default(cuid())\n name String?\n email String? @unique\n emailVerified DateTime?\n image String?\n // Credentials authentication fields\n password String? // Hashed password pre credentials login\n createdAt DateTime @default(now())\n agreedToTerms Boolean @default(false)\n practiceArea String[]\n lawFirm String?\n yearsOfExperience Int?\n // Nové polia pre schvalovanie používateľov\n isApproved Boolean @default(false) // Či je používateľ schválený\n isRejected Boolean @default(false) // Či je používateľ zamietnutý\n approvedAt DateTime? // Kedy bol schválený\n rejectedAt DateTime? // Kedy bol zamietnutý\n approvedBy String? // ID admina, ktorý schválil\n rejectedBy String? // ID admina, ktorý zamietol\n rejectionReason String? // Dôvod zamietnutia\n // Nové polia pre tracking a žiadosť\n referralSource String? // Odkiaľ sa o nás dozvedel (Google, Facebook, LinkedIn, etc.)\n applicationText String? // Text žiadosti o prihlásenie\n // ✨ STRIPE FIELDS (B2C - len pre individuálnych používateľov)\n subscriptionTier SubscriptionTier @default(FREE) // Aktuálny subscription tier (cache)\n messageCount Int @default(10) // ✅ OPRAVENÉ z 100 na 10\n messageCountResetAt DateTime? // Kedy sa má resetovať message count\n // Relations\n approvalRequest UserApprovalRequest?\n stripeCustomer StripeCustomer? // ✨ B2C Stripe customer\n ownedOrganizations Organization[] @relation(\"OrganizationOwner\")\n organizationMembers OrganizationMember[]\n accounts Account[]\n answers Answer[]\n conversations Conversation[]\n feedbacks Feedback[]\n pageViews PageView[]\n sessions Session[]\n workflowLogs WorkflowLog[]\n verificationTokens VerificationToken[]\n passwordResetTokens PasswordResetToken[]\n canvasDocuments CanvasDocument[]\n canvasDocumentVersions CanvasDocumentVersion[]\n}\n\n// Nový model pre žiadosti o schválenie\nmodel UserApprovalRequest {\n id String @id @default(cuid())\n userId String @unique\n status ApprovalStatus @default(PENDING)\n submittedAt DateTime @default(now())\n reviewedAt DateTime?\n reviewedBy String? // ID admina, ktorý preskúmal žiadosť\n notes String? // Poznámky admina\n user User @relation(fields: [userId], references: [id], onDelete: Cascade)\n\n @@index([status])\n @@index([submittedAt])\n @@index([reviewedAt])\n}\n\n// ============================================\n// ORGANIZATION MODELS (B2B)\n// ============================================\n\n// Organization = Právna kancelária / Firma\nmodel Organization {\n id String @id @default(cuid())\n name String // \"Advokátska kancelária XYZ s.r.o.\"\n\n // Billing & Legal Information\n companyNumber String? // IČO (Identifikačné číslo organizácie)\n vatNumber String? // IČ DPH (VAT Number)\n taxNumber String? // DIČ (Daňové identifikačné číslo)\n legalForm String? // \"s.r.o.\", \"a.s.\", \"v.o.s.\", \"k.s.\", \"SZČO\"\n billingEmail String\n\n // Address\n street String?\n city String?\n postalCode String?\n country String @default(\"SK\")\n\n // Subscription (B2B)\n subscriptionTier SubscriptionTier @default(FREE) // Tier organizácie (cache)\n messageCount Int @default(0) // Spoločný pool správ pre všetkých členov\n messageLimit Int @default(100) // Limit správ podľa tieru\n messageCountResetAt DateTime? // Kedy sa má resetovať pool\n\n // Settings\n isActive Boolean @default(true)\n maxMembers Int @default(5) // Max počet členov podľa tieru\n\n // Relations\n owner User @relation(\"OrganizationOwner\", fields: [ownerId], references: [id])\n ownerId String\n members OrganizationMember[]\n stripeCustomer StripeCustomer?\n\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n\n @@index([ownerId])\n @@index([vatNumber])\n @@index([companyNumber])\n @@index([subscriptionTier])\n @@index([billingEmail])\n}\n\n// Many-to-Many: User ↔ Organization\nmodel OrganizationMember {\n id String @id @default(cuid())\n organizationId String\n userId String\n role MemberRole @default(MEMBER)\n joinedAt DateTime @default(now())\n\n organization Organization @relation(fields: [organizationId], references: [id], onDelete: Cascade)\n user User @relation(fields: [userId], references: [id], onDelete: Cascade)\n\n @@unique([organizationId, userId])\n @@index([organizationId])\n @@index([userId])\n @@index([role])\n}\n\nenum MemberRole {\n OWNER // Zakladateľ/vlastník, plný prístup k billing a settings\n ADMIN // Administrátor, môže pridávať/odoberať členov\n MEMBER // Bežný člen, len používa systém\n}\n\n// ZJEDNODUŠENÝ Conversation - len metadata, bez duplikátov\nmodel Conversation {\n id String @id @default(cuid())\n name String\n userId String\n isShareable Boolean @default(false)\n shareUrl String? @unique\n sharedAt DateTime?\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n summary String?\n messagesSinceLastSummary Int? @default(0)\n // Relácie\n answers Answer[]\n user User @relation(fields: [userId], references: [id])\n workflowLogs WorkflowLog[]\n canvasDocuments CanvasDocument[]\n\n @@index([userId])\n @@index([createdAt])\n}\n\n// Hlavný model - všetky správy, bez duplikátov\nmodel Answer {\n id String @id @default(cuid())\n conversationId String\n messageId String @unique\n role Role\n content String\n question String?\n answer String?\n evaluation String?\n isWelcome Boolean @default(false)\n processingTime Int?\n model String?\n userId String?\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n // Relácie\n conversation Conversation @relation(fields: [conversationId], references: [id], onDelete: Cascade)\n user User? @relation(fields: [userId], references: [id])\n feedback Feedback?\n references Reference[]\n metrics AnswerMetrics?\n WorkflowLog WorkflowLog[]\n files MessageFile[]\n canvasDocumentId String? // No FK constraint - flexible document management\n\n @@index([conversationId])\n @@index([messageId])\n @@index([role])\n @@index([userId])\n @@index([createdAt])\n}\n\nmodel MessageFile {\n id String @id @default(cuid())\n answerId String\n fileName String\n fileType String\n base64Data String\n uploadedAt DateTime @default(now())\n answer Answer @relation(fields: [answerId], references: [id], onDelete: Cascade)\n\n @@index([answerId])\n @@index([fileType])\n @@index([uploadedAt])\n}\n\n// Nová tabuľka pre metriky odpovedí\nmodel AnswerMetrics {\n id String @id @default(cuid())\n answerId String @unique\n // Náklady\n apiCost Float? // Celkové náklady (ai_cost + rag_cost)\n aiCost Float? // Náklady len na AI provider volania\n ragCost Float? // Náklady na RAG operácie\n // Volania\n apiCalls Int? // Celkový počet volaní\n aiCalls Int? // Počet AI provider volaní\n ragCalls Int? // Počet RAG operácií\n // Čas a výkon\n apiDuration Int? // Doba spracovania v ms\n // AI Provider a Model\n aiProvider String? // Hlavný AI provider\n aiModel String? // Hlavný AI model\n aiProvidersUsed String[] // Všetky použité AI providery\n aiModelsUsed String[] // Všetky použité AI modely\n // Timestamps\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n // Relations\n answer Answer @relation(fields: [answerId], references: [id], onDelete: Cascade)\n\n @@index([answerId])\n @@index([apiCost])\n @@index([apiDuration])\n @@index([aiProvider])\n @@index([createdAt])\n}\n\nmodel Feedback {\n id String @id @default(cuid())\n answerId String @unique\n rating FeedbackRating\n feedbackTypes String[]\n customFeedback String?\n userId String\n messageContent String?\n createdAt DateTime @default(now())\n answer Answer @relation(fields: [answerId], references: [id], onDelete: Cascade)\n user User @relation(fields: [userId], references: [id])\n\n @@index([rating])\n @@index([userId])\n @@index([answerId])\n}\n\n// ZJEDNODUŠENÝ Reference - len na Answer, bez duplikátov\nmodel Reference {\n id String @id @default(cuid())\n answerId String // Len answerId - konzistentné\n type ReferenceType\n title String\n reference String\n summary String?\n url String?\n uuid String?\n relevance Float?\n citationNumber Int?\n metadata Json?\n userId String?\n createdAt DateTime @default(now())\n // Relácie\n answer Answer @relation(fields: [answerId], references: [id], onDelete: Cascade)\n\n @@index([answerId])\n @@index([type])\n @@index([reference])\n @@index([userId])\n @@index([createdAt])\n}\n\nmodel PageView {\n id String @id @default(cuid())\n userId String?\n sessionId String?\n page String\n path String\n referrer String?\n userAgent String?\n ipAddress String?\n country String?\n city String?\n deviceType String?\n browser String?\n os String?\n screenSize String?\n language String?\n timeOnPage Int?\n isBounce Boolean @default(true)\n createdAt DateTime @default(now())\n session Session? @relation(fields: [sessionId], references: [sessionId], onDelete: SetNull)\n user User? @relation(fields: [userId], references: [id])\n\n @@index([userId])\n @@index([sessionId])\n @@index([page])\n @@index([createdAt])\n @@index([country])\n @@index([deviceType])\n}\n\nmodel Session {\n id String @id @default(cuid())\n sessionId String @unique\n userId String?\n startedAt DateTime @default(now())\n endedAt DateTime?\n duration Int?\n pageViews PageView[]\n user User? @relation(fields: [userId], references: [id])\n workflowLogs WorkflowLog[]\n\n @@index([userId])\n @@index([startedAt])\n}\n\n// ============================================\n// STRIPE INTEGRATION MODELS\n// ============================================\n\n// Stripe Customer - polymorphic relation (User OR Organization)\nmodel StripeCustomer {\n id String @id @default(cuid())\n\n // ✅ Polymorphic relation - buď User (B2C) alebo Organization (B2B)\n userId String? @unique // B2C: Individuálny používateľ\n organizationId String? @unique // B2B: Organizácia\n\n stripeCustomerId String @unique\n email String\n name String?\n\n // Billing details (Stripe Address & Tax IDs)\n billingAddress Json? // Stripe Address object\n taxIds Json? // Stripe Tax IDs array (VAT, etc.)\n\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n\n // Relations\n user User? @relation(fields: [userId], references: [id], onDelete: Cascade)\n organization Organization? @relation(fields: [organizationId], references: [id], onDelete: Cascade)\n subscriptions StripeSubscription[]\n payments StripePayment[]\n\n @@index([stripeCustomerId])\n @@index([userId])\n @@index([organizationId])\n @@index([email])\n}\n\n// Stripe Subscription - sledovanie predplatného (User alebo Organization)\nmodel StripeSubscription {\n id String @id @default(cuid())\n\n // ✅ FIX: customerId = FK na StripeCustomer.id (nie stripeCustomerId!)\n customerId String // FK na StripeCustomer.id\n stripeCustomerId String // Stripe ID (pre logging/redundancia)\n stripeSubscriptionId String @unique\n stripePriceId String\n stripeProductId String\n\n status SubscriptionStatus\n tier SubscriptionTier @default(FREE)\n billingInterval BillingInterval @default(MONTHLY) // Monthly or Yearly billing\n\n currentPeriodStart DateTime\n currentPeriodEnd DateTime\n cancelAtPeriodEnd Boolean @default(false)\n canceledAt DateTime?\n\n trialStart DateTime?\n trialEnd DateTime?\n\n // Additional fields\n quantity Int @default(1) // Počet seats (pre LAW_FIRM/ENTERPRISE tier)\n defaultPaymentMethodId String? // Stripe payment method ID\n\n metadata Json? // Dodatočné Stripe metadata\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n\n // ✅ FIX: Relácia na customerId (interné ID), nie stripeCustomerId (Stripe ID)\n customer StripeCustomer @relation(fields: [customerId], references: [id], onDelete: Cascade)\n\n @@index([stripeSubscriptionId])\n @@index([customerId])\n @@index([stripeCustomerId])\n @@index([status])\n @@index([tier])\n @@index([billingInterval])\n @@index([currentPeriodEnd])\n}\n\n// Stripe Event - prevencia duplicitného spracovania webhookov (idempotencia)\nmodel StripeEvent {\n id String @id @default(cuid())\n eventId String @unique // Stripe event ID\n type String // Typ eventu (napr. 'checkout.session.completed')\n data Json // Úplné event data pre debugging\n processed Boolean @default(false)\n processedAt DateTime?\n error String? // Uloženie chýb pri spracovaní\n createdAt DateTime @default(now())\n\n @@index([eventId])\n @@index([processed])\n @@index([type])\n @@index([createdAt])\n}\n\n// Stripe Payment - sledovanie jednotlivých platieb (voliteľné, pre detailnú analytiku)\nmodel StripePayment {\n id String @id @default(cuid())\n\n // ✅ FIX: Pridaná relácia na StripeCustomer\n customerId String\n stripePaymentId String @unique\n stripeCustomerId String // Redundantné, ale OK pre logging\n\n amount Int // Suma v centoch\n currency String @default(\"eur\")\n status String // succeeded, failed, pending\n paymentMethod String? // card, sepa_debit, atď.\n description String?\n\n // Invoice info\n invoiceId String? // Stripe Invoice ID\n invoiceUrl String? // URL na faktúru\n\n metadata Json?\n createdAt DateTime @default(now())\n\n // ✅ Relácia na StripeCustomer\n customer StripeCustomer @relation(fields: [customerId], references: [id], onDelete: Cascade)\n\n @@index([stripePaymentId])\n @@index([customerId])\n @@index([stripeCustomerId])\n @@index([status])\n @@index([createdAt])\n}\n\n// ============================================\n// ENUMS\n// ============================================\n\nenum Role {\n USER\n ASSISTANT\n SYSTEM\n}\n\nenum FeedbackRating {\n LIKE\n DISLIKE\n NEUTRAL\n}\n\nenum ReferenceType {\n LAW\n CASE\n REGULATION\n DOCUMENT\n OTHER\n}\n\nenum ApprovalStatus {\n PENDING\n APPROVED\n REJECTED\n}\n\n// Stripe: Status predplatného\nenum SubscriptionStatus {\n ACTIVE // Predplatné je aktívne\n CANCELED // Predplatné zrušené\n INCOMPLETE // Iniciálna platba zlyhala\n INCOMPLETE_EXPIRED // Neúplné predplatné expirované\n PAST_DUE // Platba zlyhala, retry prebieha\n TRIALING // V skúšobnom období\n UNPAID // Platba zlyhala, žiadny retry\n PAUSED // Predplatné pozastavené (Stripe feature)\n}\n\n// Stripe: Tier predplatného\nenum SubscriptionTier {\n FREE // Free tier (10 messages/month)\n LAWYER // Lawyer tier (1000 messages/month, €29/month, 1 user)\n LAWYER_PRO // Lawyer Pro tier (3000 messages/month, €49/month, 1 user) - RECOMMENDED\n LAW_FIRM // Law Firm tier (10000 messages/month, €129/month, up to 5 users)\n ENTERPRISE // Enterprise tier (unlimited messages, unlimited users, custom pricing)\n}\n\n// Stripe: Billing interval\nenum BillingInterval {\n MONTHLY // Monthly billing\n YEARLY // Yearly billing (17% discount)\n}\n\n// Canvas Document Status\nenum DocumentStatus {\n DRAFT\n SAVED\n ARCHIVED\n}\n\n// Nový model pre logovanie admin akcií\nmodel AdminActionLog {\n id String @id @default(cuid())\n action String // APPROVE_USER, REJECT_USER, etc.\n targetUserId String // ID používateľa, na ktorého sa akcia vzťahuje\n adminEmail String // E-mail admina, ktorý vykonal akciu\n details Json? // Ďalšie detaily akcie (reason, notes, etc.)\n createdAt DateTime @default(now())\n\n @@index([action])\n @@index([targetUserId])\n @@index([adminEmail])\n @@index([createdAt])\n}\n\nmodel WorkflowLog {\n id String @id @default(cuid()) // Added @default(cuid())\n conversationId String\n messageId String?\n userId String? // Made optional to preserve logs when users are deleted\n sessionId String? // Removed @unique to allow multiple workflows per session\n startedAt DateTime @default(now())\n completedAt DateTime?\n status WorkflowStatus @default(IN_PROGRESS)\n totalDuration Int? // milliseconds\n error String?\n metadata Json?\n steps WorkflowStep[] // Renamed from WorkflowStep to steps (lowerCamel, plural)\n conversation Conversation @relation(fields: [conversationId], references: [id], onDelete: Cascade)\n user User? @relation(fields: [userId], references: [id], onDelete: SetNull)\n session Session? @relation(fields: [sessionId], references: [sessionId], onDelete: SetNull)\n answer Answer? @relation(fields: [messageId], references: [messageId])\n\n @@index([conversationId])\n @@index([userId])\n @@index([sessionId])\n @@index([startedAt])\n @@index([status])\n @@index([conversationId, startedAt]) // Composite index for timeline queries\n @@index([messageId])\n}\n\nmodel WorkflowStep {\n id String @id @default(cuid()) // Added @default(cuid())\n workflowId String\n stepName String // 'classify_question', 'rag_search', 'ai_processing', 'generate_response'\n stepType StepType\n startedAt DateTime @default(now())\n completedAt DateTime?\n duration Int? // milliseconds\n status StepStatus @default(IN_PROGRESS)\n inputData Json? // Sanitized input data\n outputData Json? // Sanitized output data\n error String?\n metadata Json? // Provider used, model used, tokens, costs, etc.\n workflow WorkflowLog @relation(fields: [workflowId], references: [id], onDelete: Cascade)\n\n @@index([workflowId])\n @@index([stepName])\n @@index([stepType])\n @@index([startedAt])\n @@index([status])\n @@index([workflowId, startedAt]) // Composite index for timeline queries\n}\n\nenum WorkflowStatus {\n IN_PROGRESS\n COMPLETED\n FAILED\n CANCELLED\n}\n\nenum StepStatus {\n IN_PROGRESS\n COMPLETED\n FAILED\n SKIPPED\n}\n\nenum StepType {\n CLASSIFICATION\n RAG_RETRIEVAL\n AI_PROCESSING\n RESPONSE_GENERATION\n DATA_PERSISTENCE\n ERROR_HANDLING\n}\n\n// Email verification tokens\nmodel VerificationToken {\n id String @id @default(cuid())\n userId String\n token String @unique\n expires DateTime\n createdAt DateTime @default(now())\n user User @relation(fields: [userId], references: [id], onDelete: Cascade)\n\n @@index([token])\n @@index([userId])\n @@index([expires])\n}\n\n// Password reset tokens\nmodel PasswordResetToken {\n id String @id @default(cuid())\n userId String\n token String @unique\n expires DateTime\n createdAt DateTime @default(now())\n user User @relation(fields: [userId], references: [id], onDelete: Cascade)\n\n @@index([token])\n @@index([userId])\n @@index([expires])\n}\n\n// ============================================\n// CANVAS DOCUMENT MODELS\n// ============================================\n\nmodel CanvasDocument {\n id String @id @default(cuid())\n userId String\n title String\n status DocumentStatus @default(DRAFT)\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n originConversationId String?\n originAnswerId String? // No FK constraint - async save reference\n currentVersionId String? @unique\n\n // Relations\n user User @relation(fields: [userId], references: [id], onDelete: Restrict)\n originConversation Conversation? @relation(fields: [originConversationId], references: [id], onDelete: SetNull)\n currentVersion CanvasDocumentVersion? @relation(\"CurrentVersion\", fields: [currentVersionId], references: [id], onDelete: SetNull)\n versions CanvasDocumentVersion[] @relation(\"DocumentVersions\")\n\n @@index([userId])\n @@index([originConversationId])\n @@index([status])\n @@index([createdAt])\n}\n\nmodel CanvasDocumentVersion {\n id String @id @default(cuid())\n documentId String\n versionNumber Int\n title String\n markdownContent String\n createdAt DateTime @default(now())\n createdBy String\n regenerationPrompt String?\n parentVersionId String?\n\n // Relations\n document CanvasDocument @relation(\"DocumentVersions\", fields: [documentId], references: [id], onDelete: Cascade)\n creator User @relation(fields: [createdBy], references: [id], onDelete: Restrict)\n parentVersion CanvasDocumentVersion? @relation(\"VersionHistory\", fields: [parentVersionId], references: [id], onDelete: SetNull)\n childVersions CanvasDocumentVersion[] @relation(\"VersionHistory\")\n currentForDocument CanvasDocument? @relation(\"CurrentVersion\")\n\n @@unique([documentId, versionNumber])\n @@index([documentId])\n @@index([createdBy])\n @@index([createdAt])\n}\n",
626
- "inlineSchemaHash": "b23ab0d052f709a0b934e88ba0b91926ba958f7dfa4fc6726561de337b99cd64",
645
+ "inlineSchema": "generator client {\n provider = \"prisma-client-js\"\n output = \"./generated/app\"\n binaryTargets = [\"native\", \"linux-musl-openssl-3.0.x\"]\n}\n\ndatasource db {\n provider = \"postgresql\"\n url = env(\"POSTGRES_PRISMA_URL\")\n directUrl = env(\"POSTGRES_URL_NON_POOLING\")\n}\n\nmodel Account {\n id String @id @default(cuid())\n userId String\n type String\n provider String\n providerAccountId String\n refresh_token String?\n access_token String?\n expires_at Int?\n token_type String?\n scope String?\n id_token String?\n session_state String?\n user User @relation(fields: [userId], references: [id], onDelete: Cascade)\n\n @@unique([provider, providerAccountId])\n}\n\nmodel User {\n id String @id @default(cuid())\n name String?\n email String? @unique\n emailVerified DateTime?\n image String?\n // Credentials authentication fields\n password String? // Hashed password pre credentials login\n createdAt DateTime @default(now())\n agreedToTerms Boolean @default(false)\n practiceArea String[]\n lawFirm String?\n yearsOfExperience Int?\n // Nové polia pre schvalovanie používateľov\n isApproved Boolean @default(false) // Či je používateľ schválený\n isRejected Boolean @default(false) // Či je používateľ zamietnutý\n approvedAt DateTime? // Kedy bol schválený\n rejectedAt DateTime? // Kedy bol zamietnutý\n approvedBy String? // ID admina, ktorý schválil\n rejectedBy String? // ID admina, ktorý zamietol\n rejectionReason String? // Dôvod zamietnutia\n // Nové polia pre tracking a žiadosť\n referralSource String? // Odkiaľ sa o nás dozvedel (Google, Facebook, LinkedIn, etc.)\n applicationText String? // Text žiadosti o prihlásenie\n // ✨ STRIPE FIELDS (B2C - len pre individuálnych používateľov)\n subscriptionTier SubscriptionTier @default(FREE) // Aktuálny subscription tier (cache)\n messageCount Int @default(10) // ✅ OPRAVENÉ z 100 na 10\n messageCountResetAt DateTime? // Kedy sa má resetovať message count\n adminGrantExpiresAt DateTime? // Kedy admin grant expiruje\n // Relations\n approvalRequest UserApprovalRequest?\n stripeCustomer StripeCustomer? // ✨ B2C Stripe customer\n ownedOrganizations Organization[] @relation(\"OrganizationOwner\")\n organizationMembers OrganizationMember[]\n createdInvites OrganizationInvite[] @relation(\"InviteCreator\")\n accounts Account[]\n answers Answer[]\n conversations Conversation[]\n feedbacks Feedback[]\n pageViews PageView[]\n sessions Session[]\n workflowLogs WorkflowLog[]\n verificationTokens VerificationToken[]\n passwordResetTokens PasswordResetToken[]\n canvasDocuments CanvasDocument[]\n canvasDocumentVersions CanvasDocumentVersion[]\n}\n\n// Nový model pre žiadosti o schválenie\nmodel UserApprovalRequest {\n id String @id @default(cuid())\n userId String @unique\n status ApprovalStatus @default(PENDING)\n submittedAt DateTime @default(now())\n reviewedAt DateTime?\n reviewedBy String? // ID admina, ktorý preskúmal žiadosť\n notes String? // Poznámky admina\n user User @relation(fields: [userId], references: [id], onDelete: Cascade)\n\n @@index([status])\n @@index([submittedAt])\n @@index([reviewedAt])\n}\n\n// ============================================\n// ORGANIZATION MODELS (B2B)\n// ============================================\n\n// Organization = Právna kancelária / Firma\nmodel Organization {\n id String @id @default(cuid())\n name String // \"Advokátska kancelária XYZ s.r.o.\"\n\n // Billing & Legal Information\n companyNumber String? // IČO (Identifikačné číslo organizácie)\n vatNumber String? // IČ DPH (VAT Number)\n taxNumber String? // DIČ (Daňové identifikačné číslo)\n legalForm String? // \"s.r.o.\", \"a.s.\", \"v.o.s.\", \"k.s.\", \"SZČO\"\n billingEmail String\n\n // Address\n street String?\n city String?\n postalCode String?\n country String @default(\"SK\")\n\n // Subscription (B2B)\n subscriptionTier SubscriptionTier @default(FREE) // Tier organizácie (cache)\n messageCount Int @default(0) // Spoločný pool správ pre všetkých členov\n messageLimit Int @default(100) // Limit správ podľa tieru\n messageCountResetAt DateTime? // Kedy sa má resetovať pool\n adminGrantExpiresAt DateTime? // Kedy admin grant expiruje\n\n // Settings\n isActive Boolean @default(true)\n maxMembers Int @default(5) // Max počet členov podľa tieru\n\n // Relations\n owner User @relation(\"OrganizationOwner\", fields: [ownerId], references: [id])\n ownerId String\n members OrganizationMember[]\n invites OrganizationInvite[]\n stripeCustomer StripeCustomer?\n\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n\n @@index([ownerId])\n @@index([vatNumber])\n @@index([companyNumber])\n @@index([subscriptionTier])\n @@index([billingEmail])\n}\n\n// Many-to-Many: User ↔ Organization\nmodel OrganizationMember {\n id String @id @default(cuid())\n organizationId String\n userId String\n role MemberRole @default(MEMBER)\n joinedAt DateTime @default(now())\n\n organization Organization @relation(fields: [organizationId], references: [id], onDelete: Cascade)\n user User @relation(fields: [userId], references: [id], onDelete: Cascade)\n\n @@unique([organizationId, userId])\n @@index([organizationId])\n @@index([userId])\n @@index([role])\n}\n\n// Organization Invite System\nmodel OrganizationInvite {\n id String @id @default(cuid())\n organizationId String\n token String @unique\n email String? // Optional: specific email invite\n role MemberRole @default(MEMBER)\n createdBy String\n expiresAt DateTime\n maxUses Int @default(1) // For multi-use invites\n currentUses Int @default(0)\n isActive Boolean @default(true)\n usedAt DateTime? // Last usage timestamp\n usedBy String? // Last user who used it\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n\n organization Organization @relation(fields: [organizationId], references: [id], onDelete: Cascade)\n creator User @relation(\"InviteCreator\", fields: [createdBy], references: [id])\n\n @@index([token])\n @@index([organizationId])\n @@index([isActive])\n @@index([expiresAt])\n}\n\nenum MemberRole {\n OWNER // Zakladateľ/vlastník, plný prístup k billing a settings\n ADMIN // Administrátor, môže pridávať/odoberať členov\n MEMBER // Bežný člen, len používa systém\n}\n\n// ZJEDNODUŠENÝ Conversation - len metadata, bez duplikátov\nmodel Conversation {\n id String @id @default(cuid())\n name String\n userId String\n isShareable Boolean @default(false)\n shareUrl String? @unique\n sharedAt DateTime?\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n summary String?\n messagesSinceLastSummary Int? @default(0)\n // Relácie\n answers Answer[]\n user User @relation(fields: [userId], references: [id])\n workflowLogs WorkflowLog[]\n canvasDocuments CanvasDocument[]\n\n @@index([userId])\n @@index([createdAt])\n}\n\n// Hlavný model - všetky správy, bez duplikátov\nmodel Answer {\n id String @id @default(cuid())\n conversationId String\n messageId String @unique\n role Role\n content String\n question String?\n answer String?\n evaluation String?\n isWelcome Boolean @default(false)\n processingTime Int?\n model String?\n userId String?\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n // Relácie\n conversation Conversation @relation(fields: [conversationId], references: [id], onDelete: Cascade)\n user User? @relation(fields: [userId], references: [id])\n feedback Feedback?\n references Reference[]\n metrics AnswerMetrics?\n WorkflowLog WorkflowLog[]\n files MessageFile[]\n canvasDocumentId String? // No FK constraint - flexible document management\n\n @@index([conversationId])\n @@index([messageId])\n @@index([role])\n @@index([userId])\n @@index([createdAt])\n}\n\nmodel MessageFile {\n id String @id @default(cuid())\n answerId String\n fileName String\n fileType String\n base64Data String\n uploadedAt DateTime @default(now())\n answer Answer @relation(fields: [answerId], references: [id], onDelete: Cascade)\n\n @@index([answerId])\n @@index([fileType])\n @@index([uploadedAt])\n}\n\n// Nová tabuľka pre metriky odpovedí\nmodel AnswerMetrics {\n id String @id @default(cuid())\n answerId String @unique\n // Náklady\n apiCost Float? // Celkové náklady (ai_cost + rag_cost)\n aiCost Float? // Náklady len na AI provider volania\n ragCost Float? // Náklady na RAG operácie\n // Volania\n apiCalls Int? // Celkový počet volaní\n aiCalls Int? // Počet AI provider volaní\n ragCalls Int? // Počet RAG operácií\n // Čas a výkon\n apiDuration Int? // Doba spracovania v ms\n // AI Provider a Model\n aiProvider String? // Hlavný AI provider\n aiModel String? // Hlavný AI model\n aiProvidersUsed String[] // Všetky použité AI providery\n aiModelsUsed String[] // Všetky použité AI modely\n // Timestamps\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n // Relations\n answer Answer @relation(fields: [answerId], references: [id], onDelete: Cascade)\n\n @@index([answerId])\n @@index([apiCost])\n @@index([apiDuration])\n @@index([aiProvider])\n @@index([createdAt])\n}\n\nmodel Feedback {\n id String @id @default(cuid())\n answerId String @unique\n rating FeedbackRating\n feedbackTypes String[]\n customFeedback String?\n userId String\n messageContent String?\n createdAt DateTime @default(now())\n answer Answer @relation(fields: [answerId], references: [id], onDelete: Cascade)\n user User @relation(fields: [userId], references: [id])\n\n @@index([rating])\n @@index([userId])\n @@index([answerId])\n}\n\n// ZJEDNODUŠENÝ Reference - len na Answer, bez duplikátov\nmodel Reference {\n id String @id @default(cuid())\n answerId String // Len answerId - konzistentné\n type ReferenceType\n title String\n reference String\n summary String?\n url String?\n uuid String?\n relevance Float?\n citationNumber Int?\n metadata Json?\n userId String?\n createdAt DateTime @default(now())\n // Relácie\n answer Answer @relation(fields: [answerId], references: [id], onDelete: Cascade)\n\n @@index([answerId])\n @@index([type])\n @@index([reference])\n @@index([userId])\n @@index([createdAt])\n}\n\nmodel PageView {\n id String @id @default(cuid())\n userId String?\n sessionId String?\n page String\n path String\n referrer String?\n userAgent String?\n ipAddress String?\n country String?\n city String?\n deviceType String?\n browser String?\n os String?\n screenSize String?\n language String?\n timeOnPage Int?\n isBounce Boolean @default(true)\n createdAt DateTime @default(now())\n session Session? @relation(fields: [sessionId], references: [sessionId], onDelete: SetNull)\n user User? @relation(fields: [userId], references: [id])\n\n @@index([userId])\n @@index([sessionId])\n @@index([page])\n @@index([createdAt])\n @@index([country])\n @@index([deviceType])\n}\n\nmodel Session {\n id String @id @default(cuid())\n sessionId String @unique\n userId String?\n startedAt DateTime @default(now())\n endedAt DateTime?\n duration Int?\n pageViews PageView[]\n user User? @relation(fields: [userId], references: [id])\n workflowLogs WorkflowLog[]\n\n @@index([userId])\n @@index([startedAt])\n}\n\n// ============================================\n// STRIPE INTEGRATION MODELS\n// ============================================\n\n// Stripe Customer - polymorphic relation (User OR Organization)\nmodel StripeCustomer {\n id String @id @default(cuid())\n\n // ✅ Polymorphic relation - buď User (B2C) alebo Organization (B2B)\n userId String? @unique // B2C: Individuálny používateľ\n organizationId String? @unique // B2B: Organizácia\n\n stripeCustomerId String @unique\n email String\n name String?\n\n // Billing details (Stripe Address & Tax IDs)\n billingAddress Json? // Stripe Address object\n taxIds Json? // Stripe Tax IDs array (VAT, etc.)\n\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n\n // Relations\n user User? @relation(fields: [userId], references: [id], onDelete: Cascade)\n organization Organization? @relation(fields: [organizationId], references: [id], onDelete: Cascade)\n subscriptions StripeSubscription[]\n payments StripePayment[]\n\n @@index([stripeCustomerId])\n @@index([userId])\n @@index([organizationId])\n @@index([email])\n}\n\n// Stripe Subscription - sledovanie predplatného (User alebo Organization)\nmodel StripeSubscription {\n id String @id @default(cuid())\n\n // ✅ FIX: customerId = FK na StripeCustomer.id (nie stripeCustomerId!)\n customerId String // FK na StripeCustomer.id\n stripeCustomerId String // Stripe ID (pre logging/redundancia)\n stripeSubscriptionId String @unique\n stripePriceId String\n stripeProductId String\n\n status SubscriptionStatus\n tier SubscriptionTier @default(FREE)\n billingInterval BillingInterval @default(MONTHLY) // Monthly or Yearly billing\n\n currentPeriodStart DateTime\n currentPeriodEnd DateTime\n cancelAtPeriodEnd Boolean @default(false)\n canceledAt DateTime?\n\n trialStart DateTime?\n trialEnd DateTime?\n\n // Additional fields\n quantity Int @default(1) // Počet seats (pre LAW_FIRM/ENTERPRISE tier)\n defaultPaymentMethodId String? // Stripe payment method ID\n\n metadata Json? // Dodatočné Stripe metadata\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n\n // ✅ FIX: Relácia na customerId (interné ID), nie stripeCustomerId (Stripe ID)\n customer StripeCustomer @relation(fields: [customerId], references: [id], onDelete: Cascade)\n\n @@index([stripeSubscriptionId])\n @@index([customerId])\n @@index([stripeCustomerId])\n @@index([status])\n @@index([tier])\n @@index([billingInterval])\n @@index([currentPeriodEnd])\n}\n\n// Stripe Event - prevencia duplicitného spracovania webhookov (idempotencia)\nmodel StripeEvent {\n id String @id @default(cuid())\n eventId String @unique // Stripe event ID\n type String // Typ eventu (napr. 'checkout.session.completed')\n data Json // Úplné event data pre debugging\n processed Boolean @default(false)\n processedAt DateTime?\n error String? // Uloženie chýb pri spracovaní\n createdAt DateTime @default(now())\n\n @@index([eventId])\n @@index([processed])\n @@index([type])\n @@index([createdAt])\n}\n\n// Stripe Payment - sledovanie jednotlivých platieb (voliteľné, pre detailnú analytiku)\nmodel StripePayment {\n id String @id @default(cuid())\n\n // ✅ FIX: Pridaná relácia na StripeCustomer\n customerId String\n stripePaymentId String @unique\n stripeCustomerId String // Redundantné, ale OK pre logging\n\n amount Int // Suma v centoch\n currency String @default(\"eur\")\n status String // succeeded, failed, pending\n paymentMethod String? // card, sepa_debit, atď.\n description String?\n\n // Invoice info\n invoiceId String? // Stripe Invoice ID\n invoiceUrl String? // URL na faktúru\n\n metadata Json?\n createdAt DateTime @default(now())\n\n // ✅ Relácia na StripeCustomer\n customer StripeCustomer @relation(fields: [customerId], references: [id], onDelete: Cascade)\n\n @@index([stripePaymentId])\n @@index([customerId])\n @@index([stripeCustomerId])\n @@index([status])\n @@index([createdAt])\n}\n\n// ============================================\n// ENUMS\n// ============================================\n\nenum Role {\n USER\n ASSISTANT\n SYSTEM\n}\n\nenum FeedbackRating {\n LIKE\n DISLIKE\n NEUTRAL\n}\n\nenum ReferenceType {\n LAW\n CASE\n REGULATION\n DOCUMENT\n OTHER\n}\n\nenum ApprovalStatus {\n PENDING\n APPROVED\n REJECTED\n}\n\n// Stripe: Status predplatného\nenum SubscriptionStatus {\n ACTIVE // Predplatné je aktívne\n CANCELED // Predplatné zrušené\n INCOMPLETE // Iniciálna platba zlyhala\n INCOMPLETE_EXPIRED // Neúplné predplatné expirované\n PAST_DUE // Platba zlyhala, retry prebieha\n TRIALING // V skúšobnom období\n UNPAID // Platba zlyhala, žiadny retry\n PAUSED // Predplatné pozastavené (Stripe feature)\n}\n\n// Stripe: Tier predplatného\nenum SubscriptionTier {\n FREE // Free tier (10 messages/month)\n LAWYER // Lawyer tier (1000 messages/month, €29/month, 1 user)\n LAWYER_PRO // Lawyer Pro tier (3000 messages/month, €49/month, 1 user) - RECOMMENDED\n LAW_FIRM // Law Firm tier (10000 messages/month, €129/month, up to 5 users)\n ENTERPRISE // Enterprise tier (unlimited messages, unlimited users, custom pricing)\n}\n\n// Stripe: Billing interval\nenum BillingInterval {\n MONTHLY // Monthly billing\n YEARLY // Yearly billing (17% discount)\n}\n\n// Canvas Document Status\nenum DocumentStatus {\n DRAFT\n SAVED\n ARCHIVED\n}\n\n// Nový model pre logovanie admin akcií\nmodel AdminActionLog {\n id String @id @default(cuid())\n action String // APPROVE_USER, REJECT_USER, etc.\n targetUserId String // ID používateľa, na ktorého sa akcia vzťahuje\n adminEmail String // E-mail admina, ktorý vykonal akciu\n details Json? // Ďalšie detaily akcie (reason, notes, etc.)\n createdAt DateTime @default(now())\n\n @@index([action])\n @@index([targetUserId])\n @@index([adminEmail])\n @@index([createdAt])\n}\n\nmodel WorkflowLog {\n id String @id @default(cuid()) // Added @default(cuid())\n conversationId String\n messageId String?\n userId String? // Made optional to preserve logs when users are deleted\n sessionId String? // Removed @unique to allow multiple workflows per session\n startedAt DateTime @default(now())\n completedAt DateTime?\n status WorkflowStatus @default(IN_PROGRESS)\n totalDuration Int? // milliseconds\n error String?\n metadata Json?\n steps WorkflowStep[] // Renamed from WorkflowStep to steps (lowerCamel, plural)\n conversation Conversation @relation(fields: [conversationId], references: [id], onDelete: Cascade)\n user User? @relation(fields: [userId], references: [id], onDelete: SetNull)\n session Session? @relation(fields: [sessionId], references: [sessionId], onDelete: SetNull)\n answer Answer? @relation(fields: [messageId], references: [messageId])\n\n @@index([conversationId])\n @@index([userId])\n @@index([sessionId])\n @@index([startedAt])\n @@index([status])\n @@index([conversationId, startedAt]) // Composite index for timeline queries\n @@index([messageId])\n}\n\nmodel WorkflowStep {\n id String @id @default(cuid()) // Added @default(cuid())\n workflowId String\n stepName String // 'classify_question', 'rag_search', 'ai_processing', 'generate_response'\n stepType StepType\n startedAt DateTime @default(now())\n completedAt DateTime?\n duration Int? // milliseconds\n status StepStatus @default(IN_PROGRESS)\n inputData Json? // Sanitized input data\n outputData Json? // Sanitized output data\n error String?\n metadata Json? // Provider used, model used, tokens, costs, etc.\n workflow WorkflowLog @relation(fields: [workflowId], references: [id], onDelete: Cascade)\n\n @@index([workflowId])\n @@index([stepName])\n @@index([stepType])\n @@index([startedAt])\n @@index([status])\n @@index([workflowId, startedAt]) // Composite index for timeline queries\n}\n\nenum WorkflowStatus {\n IN_PROGRESS\n COMPLETED\n FAILED\n CANCELLED\n}\n\nenum StepStatus {\n IN_PROGRESS\n COMPLETED\n FAILED\n SKIPPED\n}\n\nenum StepType {\n CLASSIFICATION\n RAG_RETRIEVAL\n AI_PROCESSING\n RESPONSE_GENERATION\n DATA_PERSISTENCE\n ERROR_HANDLING\n}\n\n// Email verification tokens\nmodel VerificationToken {\n id String @id @default(cuid())\n userId String\n token String @unique\n expires DateTime\n createdAt DateTime @default(now())\n user User @relation(fields: [userId], references: [id], onDelete: Cascade)\n\n @@index([token])\n @@index([userId])\n @@index([expires])\n}\n\n// Password reset tokens\nmodel PasswordResetToken {\n id String @id @default(cuid())\n userId String\n token String @unique\n expires DateTime\n createdAt DateTime @default(now())\n user User @relation(fields: [userId], references: [id], onDelete: Cascade)\n\n @@index([token])\n @@index([userId])\n @@index([expires])\n}\n\n// ============================================\n// CANVAS DOCUMENT MODELS\n// ============================================\n\nmodel CanvasDocument {\n id String @id @default(cuid())\n userId String\n title String\n status DocumentStatus @default(DRAFT)\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n originConversationId String?\n originAnswerId String? // No FK constraint - async save reference\n currentVersionId String? @unique\n\n // Relations\n user User @relation(fields: [userId], references: [id], onDelete: Restrict)\n originConversation Conversation? @relation(fields: [originConversationId], references: [id], onDelete: SetNull)\n currentVersion CanvasDocumentVersion? @relation(\"CurrentVersion\", fields: [currentVersionId], references: [id], onDelete: SetNull)\n versions CanvasDocumentVersion[] @relation(\"DocumentVersions\")\n\n @@index([userId])\n @@index([originConversationId])\n @@index([status])\n @@index([createdAt])\n}\n\nmodel CanvasDocumentVersion {\n id String @id @default(cuid())\n documentId String\n versionNumber Int\n title String\n markdownContent String\n createdAt DateTime @default(now())\n createdBy String\n regenerationPrompt String?\n parentVersionId String?\n\n // Relations\n document CanvasDocument @relation(\"DocumentVersions\", fields: [documentId], references: [id], onDelete: Cascade)\n creator User @relation(fields: [createdBy], references: [id], onDelete: Restrict)\n parentVersion CanvasDocumentVersion? @relation(\"VersionHistory\", fields: [parentVersionId], references: [id], onDelete: SetNull)\n childVersions CanvasDocumentVersion[] @relation(\"VersionHistory\")\n currentForDocument CanvasDocument? @relation(\"CurrentVersion\")\n\n @@unique([documentId, versionNumber])\n @@index([documentId])\n @@index([createdBy])\n @@index([createdAt])\n}\n",
646
+ "inlineSchemaHash": "1149d3689b3e2ea690d8e04114455959af8c015c56f3185274408c2190a82a7f",
627
647
  "copyEngine": true
628
648
  }
629
649
  config.dirname = '/'
630
650
 
631
- config.runtimeDataModel = JSON.parse("{\"models\":{\"Account\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"type\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"provider\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"providerAccountId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"refresh_token\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"access_token\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"expires_at\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"token_type\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"scope\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"id_token\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"session_state\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"AccountToUser\"}],\"dbName\":null},\"User\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"name\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"email\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"emailVerified\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"image\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"password\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"agreedToTerms\",\"kind\":\"scalar\",\"type\":\"Boolean\"},{\"name\":\"practiceArea\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"lawFirm\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"yearsOfExperience\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"isApproved\",\"kind\":\"scalar\",\"type\":\"Boolean\"},{\"name\":\"isRejected\",\"kind\":\"scalar\",\"type\":\"Boolean\"},{\"name\":\"approvedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"rejectedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"approvedBy\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"rejectedBy\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"rejectionReason\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"referralSource\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"applicationText\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"subscriptionTier\",\"kind\":\"enum\",\"type\":\"SubscriptionTier\"},{\"name\":\"messageCount\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"messageCountResetAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"approvalRequest\",\"kind\":\"object\",\"type\":\"UserApprovalRequest\",\"relationName\":\"UserToUserApprovalRequest\"},{\"name\":\"stripeCustomer\",\"kind\":\"object\",\"type\":\"StripeCustomer\",\"relationName\":\"StripeCustomerToUser\"},{\"name\":\"ownedOrganizations\",\"kind\":\"object\",\"type\":\"Organization\",\"relationName\":\"OrganizationOwner\"},{\"name\":\"organizationMembers\",\"kind\":\"object\",\"type\":\"OrganizationMember\",\"relationName\":\"OrganizationMemberToUser\"},{\"name\":\"accounts\",\"kind\":\"object\",\"type\":\"Account\",\"relationName\":\"AccountToUser\"},{\"name\":\"answers\",\"kind\":\"object\",\"type\":\"Answer\",\"relationName\":\"AnswerToUser\"},{\"name\":\"conversations\",\"kind\":\"object\",\"type\":\"Conversation\",\"relationName\":\"ConversationToUser\"},{\"name\":\"feedbacks\",\"kind\":\"object\",\"type\":\"Feedback\",\"relationName\":\"FeedbackToUser\"},{\"name\":\"pageViews\",\"kind\":\"object\",\"type\":\"PageView\",\"relationName\":\"PageViewToUser\"},{\"name\":\"sessions\",\"kind\":\"object\",\"type\":\"Session\",\"relationName\":\"SessionToUser\"},{\"name\":\"workflowLogs\",\"kind\":\"object\",\"type\":\"WorkflowLog\",\"relationName\":\"UserToWorkflowLog\"},{\"name\":\"verificationTokens\",\"kind\":\"object\",\"type\":\"VerificationToken\",\"relationName\":\"UserToVerificationToken\"},{\"name\":\"passwordResetTokens\",\"kind\":\"object\",\"type\":\"PasswordResetToken\",\"relationName\":\"PasswordResetTokenToUser\"},{\"name\":\"canvasDocuments\",\"kind\":\"object\",\"type\":\"CanvasDocument\",\"relationName\":\"CanvasDocumentToUser\"},{\"name\":\"canvasDocumentVersions\",\"kind\":\"object\",\"type\":\"CanvasDocumentVersion\",\"relationName\":\"CanvasDocumentVersionToUser\"}],\"dbName\":null},\"UserApprovalRequest\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"status\",\"kind\":\"enum\",\"type\":\"ApprovalStatus\"},{\"name\":\"submittedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"reviewedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"reviewedBy\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"notes\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"UserToUserApprovalRequest\"}],\"dbName\":null},\"Organization\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"name\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"companyNumber\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"vatNumber\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"taxNumber\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"legalForm\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"billingEmail\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"street\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"city\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"postalCode\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"country\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"subscriptionTier\",\"kind\":\"enum\",\"type\":\"SubscriptionTier\"},{\"name\":\"messageCount\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"messageLimit\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"messageCountResetAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"isActive\",\"kind\":\"scalar\",\"type\":\"Boolean\"},{\"name\":\"maxMembers\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"owner\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"OrganizationOwner\"},{\"name\":\"ownerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"members\",\"kind\":\"object\",\"type\":\"OrganizationMember\",\"relationName\":\"OrganizationToOrganizationMember\"},{\"name\":\"stripeCustomer\",\"kind\":\"object\",\"type\":\"StripeCustomer\",\"relationName\":\"OrganizationToStripeCustomer\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"}],\"dbName\":null},\"OrganizationMember\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"organizationId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"role\",\"kind\":\"enum\",\"type\":\"MemberRole\"},{\"name\":\"joinedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"organization\",\"kind\":\"object\",\"type\":\"Organization\",\"relationName\":\"OrganizationToOrganizationMember\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"OrganizationMemberToUser\"}],\"dbName\":null},\"Conversation\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"name\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"isShareable\",\"kind\":\"scalar\",\"type\":\"Boolean\"},{\"name\":\"shareUrl\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"sharedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"summary\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"messagesSinceLastSummary\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"answers\",\"kind\":\"object\",\"type\":\"Answer\",\"relationName\":\"AnswerToConversation\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"ConversationToUser\"},{\"name\":\"workflowLogs\",\"kind\":\"object\",\"type\":\"WorkflowLog\",\"relationName\":\"ConversationToWorkflowLog\"},{\"name\":\"canvasDocuments\",\"kind\":\"object\",\"type\":\"CanvasDocument\",\"relationName\":\"CanvasDocumentToConversation\"}],\"dbName\":null},\"Answer\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"conversationId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"messageId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"role\",\"kind\":\"enum\",\"type\":\"Role\"},{\"name\":\"content\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"question\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"answer\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"evaluation\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"isWelcome\",\"kind\":\"scalar\",\"type\":\"Boolean\"},{\"name\":\"processingTime\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"model\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"conversation\",\"kind\":\"object\",\"type\":\"Conversation\",\"relationName\":\"AnswerToConversation\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"AnswerToUser\"},{\"name\":\"feedback\",\"kind\":\"object\",\"type\":\"Feedback\",\"relationName\":\"AnswerToFeedback\"},{\"name\":\"references\",\"kind\":\"object\",\"type\":\"Reference\",\"relationName\":\"AnswerToReference\"},{\"name\":\"metrics\",\"kind\":\"object\",\"type\":\"AnswerMetrics\",\"relationName\":\"AnswerToAnswerMetrics\"},{\"name\":\"WorkflowLog\",\"kind\":\"object\",\"type\":\"WorkflowLog\",\"relationName\":\"AnswerToWorkflowLog\"},{\"name\":\"files\",\"kind\":\"object\",\"type\":\"MessageFile\",\"relationName\":\"AnswerToMessageFile\"},{\"name\":\"canvasDocumentId\",\"kind\":\"scalar\",\"type\":\"String\"}],\"dbName\":null},\"MessageFile\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"answerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"fileName\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"fileType\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"base64Data\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"uploadedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"answer\",\"kind\":\"object\",\"type\":\"Answer\",\"relationName\":\"AnswerToMessageFile\"}],\"dbName\":null},\"AnswerMetrics\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"answerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"apiCost\",\"kind\":\"scalar\",\"type\":\"Float\"},{\"name\":\"aiCost\",\"kind\":\"scalar\",\"type\":\"Float\"},{\"name\":\"ragCost\",\"kind\":\"scalar\",\"type\":\"Float\"},{\"name\":\"apiCalls\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"aiCalls\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"ragCalls\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"apiDuration\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"aiProvider\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"aiModel\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"aiProvidersUsed\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"aiModelsUsed\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"answer\",\"kind\":\"object\",\"type\":\"Answer\",\"relationName\":\"AnswerToAnswerMetrics\"}],\"dbName\":null},\"Feedback\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"answerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"rating\",\"kind\":\"enum\",\"type\":\"FeedbackRating\"},{\"name\":\"feedbackTypes\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"customFeedback\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"messageContent\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"answer\",\"kind\":\"object\",\"type\":\"Answer\",\"relationName\":\"AnswerToFeedback\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"FeedbackToUser\"}],\"dbName\":null},\"Reference\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"answerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"type\",\"kind\":\"enum\",\"type\":\"ReferenceType\"},{\"name\":\"title\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"reference\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"summary\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"url\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"uuid\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"relevance\",\"kind\":\"scalar\",\"type\":\"Float\"},{\"name\":\"citationNumber\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"metadata\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"answer\",\"kind\":\"object\",\"type\":\"Answer\",\"relationName\":\"AnswerToReference\"}],\"dbName\":null},\"PageView\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"sessionId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"page\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"path\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"referrer\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userAgent\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"ipAddress\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"country\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"city\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"deviceType\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"browser\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"os\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"screenSize\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"language\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"timeOnPage\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"isBounce\",\"kind\":\"scalar\",\"type\":\"Boolean\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"session\",\"kind\":\"object\",\"type\":\"Session\",\"relationName\":\"PageViewToSession\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"PageViewToUser\"}],\"dbName\":null},\"Session\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"sessionId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"startedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"endedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"duration\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"pageViews\",\"kind\":\"object\",\"type\":\"PageView\",\"relationName\":\"PageViewToSession\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"SessionToUser\"},{\"name\":\"workflowLogs\",\"kind\":\"object\",\"type\":\"WorkflowLog\",\"relationName\":\"SessionToWorkflowLog\"}],\"dbName\":null},\"StripeCustomer\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"organizationId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"stripeCustomerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"email\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"name\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"billingAddress\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"taxIds\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"StripeCustomerToUser\"},{\"name\":\"organization\",\"kind\":\"object\",\"type\":\"Organization\",\"relationName\":\"OrganizationToStripeCustomer\"},{\"name\":\"subscriptions\",\"kind\":\"object\",\"type\":\"StripeSubscription\",\"relationName\":\"StripeCustomerToStripeSubscription\"},{\"name\":\"payments\",\"kind\":\"object\",\"type\":\"StripePayment\",\"relationName\":\"StripeCustomerToStripePayment\"}],\"dbName\":null},\"StripeSubscription\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"customerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"stripeCustomerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"stripeSubscriptionId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"stripePriceId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"stripeProductId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"status\",\"kind\":\"enum\",\"type\":\"SubscriptionStatus\"},{\"name\":\"tier\",\"kind\":\"enum\",\"type\":\"SubscriptionTier\"},{\"name\":\"billingInterval\",\"kind\":\"enum\",\"type\":\"BillingInterval\"},{\"name\":\"currentPeriodStart\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"currentPeriodEnd\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"cancelAtPeriodEnd\",\"kind\":\"scalar\",\"type\":\"Boolean\"},{\"name\":\"canceledAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"trialStart\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"trialEnd\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"quantity\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"defaultPaymentMethodId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"metadata\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"customer\",\"kind\":\"object\",\"type\":\"StripeCustomer\",\"relationName\":\"StripeCustomerToStripeSubscription\"}],\"dbName\":null},\"StripeEvent\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"eventId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"type\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"data\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"processed\",\"kind\":\"scalar\",\"type\":\"Boolean\"},{\"name\":\"processedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"error\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"}],\"dbName\":null},\"StripePayment\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"customerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"stripePaymentId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"stripeCustomerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"amount\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"currency\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"status\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"paymentMethod\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"description\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"invoiceId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"invoiceUrl\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"metadata\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"customer\",\"kind\":\"object\",\"type\":\"StripeCustomer\",\"relationName\":\"StripeCustomerToStripePayment\"}],\"dbName\":null},\"AdminActionLog\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"action\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"targetUserId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"adminEmail\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"details\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"}],\"dbName\":null},\"WorkflowLog\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"conversationId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"messageId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"sessionId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"startedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"completedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"status\",\"kind\":\"enum\",\"type\":\"WorkflowStatus\"},{\"name\":\"totalDuration\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"error\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"metadata\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"steps\",\"kind\":\"object\",\"type\":\"WorkflowStep\",\"relationName\":\"WorkflowLogToWorkflowStep\"},{\"name\":\"conversation\",\"kind\":\"object\",\"type\":\"Conversation\",\"relationName\":\"ConversationToWorkflowLog\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"UserToWorkflowLog\"},{\"name\":\"session\",\"kind\":\"object\",\"type\":\"Session\",\"relationName\":\"SessionToWorkflowLog\"},{\"name\":\"answer\",\"kind\":\"object\",\"type\":\"Answer\",\"relationName\":\"AnswerToWorkflowLog\"}],\"dbName\":null},\"WorkflowStep\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"workflowId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"stepName\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"stepType\",\"kind\":\"enum\",\"type\":\"StepType\"},{\"name\":\"startedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"completedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"duration\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"status\",\"kind\":\"enum\",\"type\":\"StepStatus\"},{\"name\":\"inputData\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"outputData\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"error\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"metadata\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"workflow\",\"kind\":\"object\",\"type\":\"WorkflowLog\",\"relationName\":\"WorkflowLogToWorkflowStep\"}],\"dbName\":null},\"VerificationToken\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"token\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"expires\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"UserToVerificationToken\"}],\"dbName\":null},\"PasswordResetToken\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"token\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"expires\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"PasswordResetTokenToUser\"}],\"dbName\":null},\"CanvasDocument\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"title\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"status\",\"kind\":\"enum\",\"type\":\"DocumentStatus\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"originConversationId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"originAnswerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"currentVersionId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"CanvasDocumentToUser\"},{\"name\":\"originConversation\",\"kind\":\"object\",\"type\":\"Conversation\",\"relationName\":\"CanvasDocumentToConversation\"},{\"name\":\"currentVersion\",\"kind\":\"object\",\"type\":\"CanvasDocumentVersion\",\"relationName\":\"CurrentVersion\"},{\"name\":\"versions\",\"kind\":\"object\",\"type\":\"CanvasDocumentVersion\",\"relationName\":\"DocumentVersions\"}],\"dbName\":null},\"CanvasDocumentVersion\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"documentId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"versionNumber\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"title\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"markdownContent\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"createdBy\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"regenerationPrompt\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"parentVersionId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"document\",\"kind\":\"object\",\"type\":\"CanvasDocument\",\"relationName\":\"DocumentVersions\"},{\"name\":\"creator\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"CanvasDocumentVersionToUser\"},{\"name\":\"parentVersion\",\"kind\":\"object\",\"type\":\"CanvasDocumentVersion\",\"relationName\":\"VersionHistory\"},{\"name\":\"childVersions\",\"kind\":\"object\",\"type\":\"CanvasDocumentVersion\",\"relationName\":\"VersionHistory\"},{\"name\":\"currentForDocument\",\"kind\":\"object\",\"type\":\"CanvasDocument\",\"relationName\":\"CurrentVersion\"}],\"dbName\":null}},\"enums\":{},\"types\":{}}")
651
+ config.runtimeDataModel = JSON.parse("{\"models\":{\"Account\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"type\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"provider\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"providerAccountId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"refresh_token\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"access_token\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"expires_at\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"token_type\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"scope\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"id_token\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"session_state\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"AccountToUser\"}],\"dbName\":null},\"User\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"name\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"email\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"emailVerified\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"image\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"password\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"agreedToTerms\",\"kind\":\"scalar\",\"type\":\"Boolean\"},{\"name\":\"practiceArea\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"lawFirm\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"yearsOfExperience\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"isApproved\",\"kind\":\"scalar\",\"type\":\"Boolean\"},{\"name\":\"isRejected\",\"kind\":\"scalar\",\"type\":\"Boolean\"},{\"name\":\"approvedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"rejectedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"approvedBy\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"rejectedBy\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"rejectionReason\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"referralSource\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"applicationText\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"subscriptionTier\",\"kind\":\"enum\",\"type\":\"SubscriptionTier\"},{\"name\":\"messageCount\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"messageCountResetAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"adminGrantExpiresAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"approvalRequest\",\"kind\":\"object\",\"type\":\"UserApprovalRequest\",\"relationName\":\"UserToUserApprovalRequest\"},{\"name\":\"stripeCustomer\",\"kind\":\"object\",\"type\":\"StripeCustomer\",\"relationName\":\"StripeCustomerToUser\"},{\"name\":\"ownedOrganizations\",\"kind\":\"object\",\"type\":\"Organization\",\"relationName\":\"OrganizationOwner\"},{\"name\":\"organizationMembers\",\"kind\":\"object\",\"type\":\"OrganizationMember\",\"relationName\":\"OrganizationMemberToUser\"},{\"name\":\"createdInvites\",\"kind\":\"object\",\"type\":\"OrganizationInvite\",\"relationName\":\"InviteCreator\"},{\"name\":\"accounts\",\"kind\":\"object\",\"type\":\"Account\",\"relationName\":\"AccountToUser\"},{\"name\":\"answers\",\"kind\":\"object\",\"type\":\"Answer\",\"relationName\":\"AnswerToUser\"},{\"name\":\"conversations\",\"kind\":\"object\",\"type\":\"Conversation\",\"relationName\":\"ConversationToUser\"},{\"name\":\"feedbacks\",\"kind\":\"object\",\"type\":\"Feedback\",\"relationName\":\"FeedbackToUser\"},{\"name\":\"pageViews\",\"kind\":\"object\",\"type\":\"PageView\",\"relationName\":\"PageViewToUser\"},{\"name\":\"sessions\",\"kind\":\"object\",\"type\":\"Session\",\"relationName\":\"SessionToUser\"},{\"name\":\"workflowLogs\",\"kind\":\"object\",\"type\":\"WorkflowLog\",\"relationName\":\"UserToWorkflowLog\"},{\"name\":\"verificationTokens\",\"kind\":\"object\",\"type\":\"VerificationToken\",\"relationName\":\"UserToVerificationToken\"},{\"name\":\"passwordResetTokens\",\"kind\":\"object\",\"type\":\"PasswordResetToken\",\"relationName\":\"PasswordResetTokenToUser\"},{\"name\":\"canvasDocuments\",\"kind\":\"object\",\"type\":\"CanvasDocument\",\"relationName\":\"CanvasDocumentToUser\"},{\"name\":\"canvasDocumentVersions\",\"kind\":\"object\",\"type\":\"CanvasDocumentVersion\",\"relationName\":\"CanvasDocumentVersionToUser\"}],\"dbName\":null},\"UserApprovalRequest\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"status\",\"kind\":\"enum\",\"type\":\"ApprovalStatus\"},{\"name\":\"submittedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"reviewedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"reviewedBy\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"notes\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"UserToUserApprovalRequest\"}],\"dbName\":null},\"Organization\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"name\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"companyNumber\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"vatNumber\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"taxNumber\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"legalForm\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"billingEmail\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"street\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"city\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"postalCode\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"country\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"subscriptionTier\",\"kind\":\"enum\",\"type\":\"SubscriptionTier\"},{\"name\":\"messageCount\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"messageLimit\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"messageCountResetAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"adminGrantExpiresAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"isActive\",\"kind\":\"scalar\",\"type\":\"Boolean\"},{\"name\":\"maxMembers\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"owner\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"OrganizationOwner\"},{\"name\":\"ownerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"members\",\"kind\":\"object\",\"type\":\"OrganizationMember\",\"relationName\":\"OrganizationToOrganizationMember\"},{\"name\":\"invites\",\"kind\":\"object\",\"type\":\"OrganizationInvite\",\"relationName\":\"OrganizationToOrganizationInvite\"},{\"name\":\"stripeCustomer\",\"kind\":\"object\",\"type\":\"StripeCustomer\",\"relationName\":\"OrganizationToStripeCustomer\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"}],\"dbName\":null},\"OrganizationMember\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"organizationId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"role\",\"kind\":\"enum\",\"type\":\"MemberRole\"},{\"name\":\"joinedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"organization\",\"kind\":\"object\",\"type\":\"Organization\",\"relationName\":\"OrganizationToOrganizationMember\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"OrganizationMemberToUser\"}],\"dbName\":null},\"OrganizationInvite\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"organizationId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"token\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"email\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"role\",\"kind\":\"enum\",\"type\":\"MemberRole\"},{\"name\":\"createdBy\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"expiresAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"maxUses\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"currentUses\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"isActive\",\"kind\":\"scalar\",\"type\":\"Boolean\"},{\"name\":\"usedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"usedBy\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"organization\",\"kind\":\"object\",\"type\":\"Organization\",\"relationName\":\"OrganizationToOrganizationInvite\"},{\"name\":\"creator\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"InviteCreator\"}],\"dbName\":null},\"Conversation\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"name\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"isShareable\",\"kind\":\"scalar\",\"type\":\"Boolean\"},{\"name\":\"shareUrl\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"sharedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"summary\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"messagesSinceLastSummary\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"answers\",\"kind\":\"object\",\"type\":\"Answer\",\"relationName\":\"AnswerToConversation\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"ConversationToUser\"},{\"name\":\"workflowLogs\",\"kind\":\"object\",\"type\":\"WorkflowLog\",\"relationName\":\"ConversationToWorkflowLog\"},{\"name\":\"canvasDocuments\",\"kind\":\"object\",\"type\":\"CanvasDocument\",\"relationName\":\"CanvasDocumentToConversation\"}],\"dbName\":null},\"Answer\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"conversationId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"messageId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"role\",\"kind\":\"enum\",\"type\":\"Role\"},{\"name\":\"content\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"question\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"answer\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"evaluation\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"isWelcome\",\"kind\":\"scalar\",\"type\":\"Boolean\"},{\"name\":\"processingTime\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"model\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"conversation\",\"kind\":\"object\",\"type\":\"Conversation\",\"relationName\":\"AnswerToConversation\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"AnswerToUser\"},{\"name\":\"feedback\",\"kind\":\"object\",\"type\":\"Feedback\",\"relationName\":\"AnswerToFeedback\"},{\"name\":\"references\",\"kind\":\"object\",\"type\":\"Reference\",\"relationName\":\"AnswerToReference\"},{\"name\":\"metrics\",\"kind\":\"object\",\"type\":\"AnswerMetrics\",\"relationName\":\"AnswerToAnswerMetrics\"},{\"name\":\"WorkflowLog\",\"kind\":\"object\",\"type\":\"WorkflowLog\",\"relationName\":\"AnswerToWorkflowLog\"},{\"name\":\"files\",\"kind\":\"object\",\"type\":\"MessageFile\",\"relationName\":\"AnswerToMessageFile\"},{\"name\":\"canvasDocumentId\",\"kind\":\"scalar\",\"type\":\"String\"}],\"dbName\":null},\"MessageFile\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"answerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"fileName\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"fileType\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"base64Data\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"uploadedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"answer\",\"kind\":\"object\",\"type\":\"Answer\",\"relationName\":\"AnswerToMessageFile\"}],\"dbName\":null},\"AnswerMetrics\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"answerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"apiCost\",\"kind\":\"scalar\",\"type\":\"Float\"},{\"name\":\"aiCost\",\"kind\":\"scalar\",\"type\":\"Float\"},{\"name\":\"ragCost\",\"kind\":\"scalar\",\"type\":\"Float\"},{\"name\":\"apiCalls\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"aiCalls\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"ragCalls\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"apiDuration\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"aiProvider\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"aiModel\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"aiProvidersUsed\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"aiModelsUsed\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"answer\",\"kind\":\"object\",\"type\":\"Answer\",\"relationName\":\"AnswerToAnswerMetrics\"}],\"dbName\":null},\"Feedback\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"answerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"rating\",\"kind\":\"enum\",\"type\":\"FeedbackRating\"},{\"name\":\"feedbackTypes\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"customFeedback\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"messageContent\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"answer\",\"kind\":\"object\",\"type\":\"Answer\",\"relationName\":\"AnswerToFeedback\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"FeedbackToUser\"}],\"dbName\":null},\"Reference\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"answerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"type\",\"kind\":\"enum\",\"type\":\"ReferenceType\"},{\"name\":\"title\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"reference\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"summary\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"url\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"uuid\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"relevance\",\"kind\":\"scalar\",\"type\":\"Float\"},{\"name\":\"citationNumber\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"metadata\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"answer\",\"kind\":\"object\",\"type\":\"Answer\",\"relationName\":\"AnswerToReference\"}],\"dbName\":null},\"PageView\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"sessionId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"page\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"path\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"referrer\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userAgent\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"ipAddress\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"country\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"city\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"deviceType\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"browser\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"os\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"screenSize\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"language\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"timeOnPage\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"isBounce\",\"kind\":\"scalar\",\"type\":\"Boolean\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"session\",\"kind\":\"object\",\"type\":\"Session\",\"relationName\":\"PageViewToSession\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"PageViewToUser\"}],\"dbName\":null},\"Session\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"sessionId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"startedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"endedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"duration\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"pageViews\",\"kind\":\"object\",\"type\":\"PageView\",\"relationName\":\"PageViewToSession\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"SessionToUser\"},{\"name\":\"workflowLogs\",\"kind\":\"object\",\"type\":\"WorkflowLog\",\"relationName\":\"SessionToWorkflowLog\"}],\"dbName\":null},\"StripeCustomer\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"organizationId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"stripeCustomerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"email\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"name\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"billingAddress\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"taxIds\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"StripeCustomerToUser\"},{\"name\":\"organization\",\"kind\":\"object\",\"type\":\"Organization\",\"relationName\":\"OrganizationToStripeCustomer\"},{\"name\":\"subscriptions\",\"kind\":\"object\",\"type\":\"StripeSubscription\",\"relationName\":\"StripeCustomerToStripeSubscription\"},{\"name\":\"payments\",\"kind\":\"object\",\"type\":\"StripePayment\",\"relationName\":\"StripeCustomerToStripePayment\"}],\"dbName\":null},\"StripeSubscription\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"customerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"stripeCustomerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"stripeSubscriptionId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"stripePriceId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"stripeProductId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"status\",\"kind\":\"enum\",\"type\":\"SubscriptionStatus\"},{\"name\":\"tier\",\"kind\":\"enum\",\"type\":\"SubscriptionTier\"},{\"name\":\"billingInterval\",\"kind\":\"enum\",\"type\":\"BillingInterval\"},{\"name\":\"currentPeriodStart\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"currentPeriodEnd\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"cancelAtPeriodEnd\",\"kind\":\"scalar\",\"type\":\"Boolean\"},{\"name\":\"canceledAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"trialStart\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"trialEnd\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"quantity\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"defaultPaymentMethodId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"metadata\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"customer\",\"kind\":\"object\",\"type\":\"StripeCustomer\",\"relationName\":\"StripeCustomerToStripeSubscription\"}],\"dbName\":null},\"StripeEvent\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"eventId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"type\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"data\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"processed\",\"kind\":\"scalar\",\"type\":\"Boolean\"},{\"name\":\"processedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"error\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"}],\"dbName\":null},\"StripePayment\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"customerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"stripePaymentId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"stripeCustomerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"amount\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"currency\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"status\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"paymentMethod\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"description\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"invoiceId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"invoiceUrl\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"metadata\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"customer\",\"kind\":\"object\",\"type\":\"StripeCustomer\",\"relationName\":\"StripeCustomerToStripePayment\"}],\"dbName\":null},\"AdminActionLog\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"action\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"targetUserId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"adminEmail\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"details\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"}],\"dbName\":null},\"WorkflowLog\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"conversationId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"messageId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"sessionId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"startedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"completedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"status\",\"kind\":\"enum\",\"type\":\"WorkflowStatus\"},{\"name\":\"totalDuration\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"error\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"metadata\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"steps\",\"kind\":\"object\",\"type\":\"WorkflowStep\",\"relationName\":\"WorkflowLogToWorkflowStep\"},{\"name\":\"conversation\",\"kind\":\"object\",\"type\":\"Conversation\",\"relationName\":\"ConversationToWorkflowLog\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"UserToWorkflowLog\"},{\"name\":\"session\",\"kind\":\"object\",\"type\":\"Session\",\"relationName\":\"SessionToWorkflowLog\"},{\"name\":\"answer\",\"kind\":\"object\",\"type\":\"Answer\",\"relationName\":\"AnswerToWorkflowLog\"}],\"dbName\":null},\"WorkflowStep\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"workflowId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"stepName\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"stepType\",\"kind\":\"enum\",\"type\":\"StepType\"},{\"name\":\"startedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"completedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"duration\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"status\",\"kind\":\"enum\",\"type\":\"StepStatus\"},{\"name\":\"inputData\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"outputData\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"error\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"metadata\",\"kind\":\"scalar\",\"type\":\"Json\"},{\"name\":\"workflow\",\"kind\":\"object\",\"type\":\"WorkflowLog\",\"relationName\":\"WorkflowLogToWorkflowStep\"}],\"dbName\":null},\"VerificationToken\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"token\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"expires\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"UserToVerificationToken\"}],\"dbName\":null},\"PasswordResetToken\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"token\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"expires\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"PasswordResetTokenToUser\"}],\"dbName\":null},\"CanvasDocument\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"title\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"status\",\"kind\":\"enum\",\"type\":\"DocumentStatus\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"originConversationId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"originAnswerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"currentVersionId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"CanvasDocumentToUser\"},{\"name\":\"originConversation\",\"kind\":\"object\",\"type\":\"Conversation\",\"relationName\":\"CanvasDocumentToConversation\"},{\"name\":\"currentVersion\",\"kind\":\"object\",\"type\":\"CanvasDocumentVersion\",\"relationName\":\"CurrentVersion\"},{\"name\":\"versions\",\"kind\":\"object\",\"type\":\"CanvasDocumentVersion\",\"relationName\":\"DocumentVersions\"}],\"dbName\":null},\"CanvasDocumentVersion\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"documentId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"versionNumber\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"title\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"markdownContent\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"createdBy\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"regenerationPrompt\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"parentVersionId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"document\",\"kind\":\"object\",\"type\":\"CanvasDocument\",\"relationName\":\"DocumentVersions\"},{\"name\":\"creator\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"CanvasDocumentVersionToUser\"},{\"name\":\"parentVersion\",\"kind\":\"object\",\"type\":\"CanvasDocumentVersion\",\"relationName\":\"VersionHistory\"},{\"name\":\"childVersions\",\"kind\":\"object\",\"type\":\"CanvasDocumentVersion\",\"relationName\":\"VersionHistory\"},{\"name\":\"currentForDocument\",\"kind\":\"object\",\"type\":\"CanvasDocument\",\"relationName\":\"CurrentVersion\"}],\"dbName\":null}},\"enums\":{},\"types\":{}}")
632
652
  defineDmmfProperty(exports.Prisma, config.runtimeDataModel)
633
653
  config.engineWasm = {
634
654
  getRuntime: async () => require('./query_engine_bg.js'),
@@ -0,0 +1,5 @@
1
+ -- AlterTable
2
+ ALTER TABLE "Organization" ADD COLUMN "adminGrantExpiresAt" TIMESTAMP(3);
3
+
4
+ -- AlterTable
5
+ ALTER TABLE "User" ADD COLUMN "adminGrantExpiresAt" TIMESTAMP(3);
@@ -0,0 +1,40 @@
1
+ -- CreateTable
2
+ CREATE TABLE "OrganizationInvite" (
3
+ "id" TEXT NOT NULL,
4
+ "organizationId" TEXT NOT NULL,
5
+ "token" TEXT NOT NULL,
6
+ "email" TEXT,
7
+ "role" "MemberRole" NOT NULL DEFAULT 'MEMBER',
8
+ "createdBy" TEXT NOT NULL,
9
+ "expiresAt" TIMESTAMP(3) NOT NULL,
10
+ "maxUses" INTEGER NOT NULL DEFAULT 1,
11
+ "currentUses" INTEGER NOT NULL DEFAULT 0,
12
+ "isActive" BOOLEAN NOT NULL DEFAULT true,
13
+ "usedAt" TIMESTAMP(3),
14
+ "usedBy" TEXT,
15
+ "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
16
+ "updatedAt" TIMESTAMP(3) NOT NULL,
17
+
18
+ CONSTRAINT "OrganizationInvite_pkey" PRIMARY KEY ("id")
19
+ );
20
+
21
+ -- CreateIndex
22
+ CREATE UNIQUE INDEX "OrganizationInvite_token_key" ON "OrganizationInvite"("token");
23
+
24
+ -- CreateIndex
25
+ CREATE INDEX "OrganizationInvite_token_idx" ON "OrganizationInvite"("token");
26
+
27
+ -- CreateIndex
28
+ CREATE INDEX "OrganizationInvite_organizationId_idx" ON "OrganizationInvite"("organizationId");
29
+
30
+ -- CreateIndex
31
+ CREATE INDEX "OrganizationInvite_isActive_idx" ON "OrganizationInvite"("isActive");
32
+
33
+ -- CreateIndex
34
+ CREATE INDEX "OrganizationInvite_expiresAt_idx" ON "OrganizationInvite"("expiresAt");
35
+
36
+ -- AddForeignKey
37
+ ALTER TABLE "OrganizationInvite" ADD CONSTRAINT "OrganizationInvite_organizationId_fkey" FOREIGN KEY ("organizationId") REFERENCES "Organization"("id") ON DELETE CASCADE ON UPDATE CASCADE;
38
+
39
+ -- AddForeignKey
40
+ ALTER TABLE "OrganizationInvite" ADD CONSTRAINT "OrganizationInvite_createdBy_fkey" FOREIGN KEY ("createdBy") REFERENCES "User"("id") ON DELETE RESTRICT ON UPDATE CASCADE;