257 lines
10 KiB
SQL
257 lines
10 KiB
SQL
-- CreateTable
|
|
CREATE TABLE "User" (
|
|
"id" TEXT NOT NULL,
|
|
"name" TEXT,
|
|
"email" TEXT NOT NULL,
|
|
"emailVerified" TIMESTAMP(3),
|
|
"password" TEXT,
|
|
"role" TEXT NOT NULL DEFAULT 'USER',
|
|
"image" TEXT,
|
|
"theme" TEXT NOT NULL DEFAULT 'light',
|
|
"resetToken" TEXT,
|
|
"resetTokenExpiry" TIMESTAMP(3),
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "User_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "Account" (
|
|
"userId" TEXT NOT NULL,
|
|
"type" TEXT NOT NULL,
|
|
"provider" TEXT NOT NULL,
|
|
"providerAccountId" TEXT NOT NULL,
|
|
"refresh_token" TEXT,
|
|
"access_token" TEXT,
|
|
"expires_at" INTEGER,
|
|
"token_type" TEXT,
|
|
"scope" TEXT,
|
|
"id_token" TEXT,
|
|
"session_state" TEXT,
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "Account_pkey" PRIMARY KEY ("provider","providerAccountId")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "Session" (
|
|
"sessionToken" TEXT NOT NULL,
|
|
"userId" TEXT NOT NULL,
|
|
"expires" TIMESTAMP(3) NOT NULL,
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "Session_pkey" PRIMARY KEY ("sessionToken")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "VerificationToken" (
|
|
"identifier" TEXT NOT NULL,
|
|
"token" TEXT NOT NULL,
|
|
"expires" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "VerificationToken_pkey" PRIMARY KEY ("identifier","token")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "Notebook" (
|
|
"id" TEXT NOT NULL,
|
|
"name" TEXT NOT NULL,
|
|
"icon" TEXT,
|
|
"color" TEXT,
|
|
"order" INTEGER NOT NULL,
|
|
"userId" TEXT NOT NULL,
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "Notebook_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "Label" (
|
|
"id" TEXT NOT NULL,
|
|
"name" TEXT NOT NULL,
|
|
"color" TEXT NOT NULL DEFAULT 'gray',
|
|
"notebookId" TEXT,
|
|
"userId" TEXT,
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "Label_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "Note" (
|
|
"id" TEXT NOT NULL,
|
|
"title" TEXT,
|
|
"content" TEXT NOT NULL,
|
|
"color" TEXT NOT NULL DEFAULT 'default',
|
|
"isPinned" BOOLEAN NOT NULL DEFAULT false,
|
|
"isArchived" BOOLEAN NOT NULL DEFAULT false,
|
|
"type" TEXT NOT NULL DEFAULT 'text',
|
|
"dismissedFromRecent" BOOLEAN NOT NULL DEFAULT false,
|
|
"checkItems" JSONB,
|
|
"labels" JSONB,
|
|
"images" JSONB,
|
|
"links" JSONB,
|
|
"reminder" TIMESTAMP(3),
|
|
"isReminderDone" BOOLEAN NOT NULL DEFAULT false,
|
|
"reminderRecurrence" TEXT,
|
|
"reminderLocation" TEXT,
|
|
"isMarkdown" BOOLEAN NOT NULL DEFAULT false,
|
|
"size" TEXT NOT NULL DEFAULT 'small',
|
|
"embedding" JSONB,
|
|
"sharedWith" JSONB,
|
|
"userId" TEXT,
|
|
"order" INTEGER NOT NULL DEFAULT 0,
|
|
"notebookId" TEXT,
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
"contentUpdatedAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"autoGenerated" BOOLEAN,
|
|
"aiProvider" TEXT,
|
|
"aiConfidence" INTEGER,
|
|
"language" TEXT,
|
|
"languageConfidence" DOUBLE PRECISION,
|
|
"lastAiAnalysis" TIMESTAMP(3),
|
|
|
|
CONSTRAINT "Note_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "NoteShare" (
|
|
"id" TEXT NOT NULL,
|
|
"noteId" TEXT NOT NULL,
|
|
"userId" TEXT NOT NULL,
|
|
"sharedBy" TEXT NOT NULL,
|
|
"status" TEXT NOT NULL DEFAULT 'pending',
|
|
"permission" TEXT NOT NULL DEFAULT 'view',
|
|
"notifiedAt" TIMESTAMP(3),
|
|
"respondedAt" TIMESTAMP(3),
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "NoteShare_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "SystemConfig" (
|
|
"key" TEXT NOT NULL,
|
|
"value" TEXT NOT NULL,
|
|
|
|
CONSTRAINT "SystemConfig_pkey" PRIMARY KEY ("key")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "AiFeedback" (
|
|
"id" TEXT NOT NULL,
|
|
"noteId" TEXT NOT NULL,
|
|
"userId" TEXT,
|
|
"feedbackType" TEXT NOT NULL,
|
|
"feature" TEXT NOT NULL,
|
|
"originalContent" TEXT NOT NULL,
|
|
"correctedContent" TEXT,
|
|
"metadata" JSONB,
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
|
|
CONSTRAINT "AiFeedback_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "MemoryEchoInsight" (
|
|
"id" TEXT NOT NULL,
|
|
"userId" TEXT,
|
|
"note1Id" TEXT NOT NULL,
|
|
"note2Id" TEXT NOT NULL,
|
|
"similarityScore" DOUBLE PRECISION NOT NULL,
|
|
"insight" TEXT NOT NULL,
|
|
"insightDate" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"viewed" BOOLEAN NOT NULL DEFAULT false,
|
|
"feedback" TEXT,
|
|
"dismissed" BOOLEAN NOT NULL DEFAULT false,
|
|
|
|
CONSTRAINT "MemoryEchoInsight_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "UserAISettings" (
|
|
"userId" TEXT NOT NULL,
|
|
"titleSuggestions" BOOLEAN NOT NULL DEFAULT true,
|
|
"semanticSearch" BOOLEAN NOT NULL DEFAULT true,
|
|
"paragraphRefactor" BOOLEAN NOT NULL DEFAULT true,
|
|
"memoryEcho" BOOLEAN NOT NULL DEFAULT true,
|
|
"memoryEchoFrequency" TEXT NOT NULL DEFAULT 'daily',
|
|
"aiProvider" TEXT NOT NULL DEFAULT 'auto',
|
|
"preferredLanguage" TEXT NOT NULL DEFAULT 'auto',
|
|
"fontSize" TEXT NOT NULL DEFAULT 'medium',
|
|
"demoMode" BOOLEAN NOT NULL DEFAULT false,
|
|
"showRecentNotes" BOOLEAN NOT NULL DEFAULT true,
|
|
"notesViewMode" TEXT NOT NULL DEFAULT 'masonry',
|
|
"emailNotifications" BOOLEAN NOT NULL DEFAULT false,
|
|
"desktopNotifications" BOOLEAN NOT NULL DEFAULT false,
|
|
"anonymousAnalytics" BOOLEAN NOT NULL DEFAULT false,
|
|
|
|
CONSTRAINT "UserAISettings_pkey" PRIMARY KEY ("userId")
|
|
);
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "User_email_key" ON "User"("email");
|
|
CREATE UNIQUE INDEX "User_resetToken_key" ON "User"("resetToken");
|
|
CREATE UNIQUE INDEX "Label_notebookId_name_key" ON "Label"("notebookId", "name");
|
|
CREATE UNIQUE INDEX "NoteShare_noteId_userId_key" ON "NoteShare"("noteId", "userId");
|
|
CREATE UNIQUE INDEX "MemoryEchoInsight_userId_insightDate_key" ON "MemoryEchoInsight"("userId", "insightDate");
|
|
|
|
-- CreateIndex (performance)
|
|
CREATE INDEX "Notebook_userId_order_idx" ON "Notebook"("userId", "order");
|
|
CREATE INDEX "Notebook_userId_idx" ON "Notebook"("userId");
|
|
CREATE INDEX "Label_notebookId_idx" ON "Label"("notebookId");
|
|
CREATE INDEX "Label_userId_idx" ON "Label"("userId");
|
|
CREATE INDEX "Note_isPinned_idx" ON "Note"("isPinned");
|
|
CREATE INDEX "Note_isArchived_idx" ON "Note"("isArchived");
|
|
CREATE INDEX "Note_order_idx" ON "Note"("order");
|
|
CREATE INDEX "Note_reminder_idx" ON "Note"("reminder");
|
|
CREATE INDEX "Note_userId_idx" ON "Note"("userId");
|
|
CREATE INDEX "Note_userId_notebookId_idx" ON "Note"("userId", "notebookId");
|
|
CREATE INDEX "NoteShare_userId_idx" ON "NoteShare"("userId");
|
|
CREATE INDEX "NoteShare_status_idx" ON "NoteShare"("status");
|
|
CREATE INDEX "NoteShare_sharedBy_idx" ON "NoteShare"("sharedBy");
|
|
CREATE INDEX "AiFeedback_noteId_idx" ON "AiFeedback"("noteId");
|
|
CREATE INDEX "AiFeedback_userId_idx" ON "AiFeedback"("userId");
|
|
CREATE INDEX "AiFeedback_feature_idx" ON "AiFeedback"("feature");
|
|
CREATE INDEX "MemoryEchoInsight_userId_insightDate_idx" ON "MemoryEchoInsight"("userId", "insightDate");
|
|
CREATE INDEX "MemoryEchoInsight_userId_dismissed_idx" ON "MemoryEchoInsight"("userId", "dismissed");
|
|
CREATE INDEX "UserAISettings_memoryEcho_idx" ON "UserAISettings"("memoryEcho");
|
|
CREATE INDEX "UserAISettings_aiProvider_idx" ON "UserAISettings"("aiProvider");
|
|
CREATE INDEX "UserAISettings_memoryEchoFrequency_idx" ON "UserAISettings"("memoryEchoFrequency");
|
|
CREATE INDEX "UserAISettings_preferredLanguage_idx" ON "UserAISettings"("preferredLanguage");
|
|
|
|
-- _LabelToNote (many-to-many between Note and Label)
|
|
CREATE TABLE "_LabelToNote" (
|
|
"A" TEXT NOT NULL,
|
|
"B" TEXT NOT NULL,
|
|
CONSTRAINT "_LabelToNote_A_fkey" FOREIGN KEY ("A") REFERENCES "Label"("id") ON DELETE CASCADE ON UPDATE CASCADE,
|
|
CONSTRAINT "_LabelToNote_B_fkey" FOREIGN KEY ("B") REFERENCES "Note"("id") ON DELETE CASCADE ON UPDATE CASCADE
|
|
);
|
|
CREATE UNIQUE INDEX "_LabelToNote_AB_unique" ON "_LabelToNote"("A", "B");
|
|
CREATE INDEX "_LabelToNote_B_index" ON "_LabelToNote"("B");
|
|
|
|
-- Foreign Keys
|
|
ALTER TABLE "Account" ADD CONSTRAINT "Account_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
ALTER TABLE "Session" ADD CONSTRAINT "Session_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
ALTER TABLE "Notebook" ADD CONSTRAINT "Notebook_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
ALTER TABLE "Label" ADD CONSTRAINT "Label_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
ALTER TABLE "Label" ADD CONSTRAINT "Label_notebookId_fkey" FOREIGN KEY ("notebookId") REFERENCES "Notebook"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
ALTER TABLE "Note" ADD CONSTRAINT "Note_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
ALTER TABLE "Note" ADD CONSTRAINT "Note_notebookId_fkey" FOREIGN KEY ("notebookId") REFERENCES "Notebook"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
ALTER TABLE "NoteShare" ADD CONSTRAINT "NoteShare_noteId_fkey" FOREIGN KEY ("noteId") REFERENCES "Note"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
ALTER TABLE "NoteShare" ADD CONSTRAINT "NoteShare_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
ALTER TABLE "NoteShare" ADD CONSTRAINT "NoteShare_sharedBy_fkey" FOREIGN KEY ("sharedBy") REFERENCES "User"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
ALTER TABLE "AiFeedback" ADD CONSTRAINT "AiFeedback_noteId_fkey" FOREIGN KEY ("noteId") REFERENCES "Note"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
ALTER TABLE "AiFeedback" ADD CONSTRAINT "AiFeedback_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
ALTER TABLE "MemoryEchoInsight" ADD CONSTRAINT "MemoryEchoInsight_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
ALTER TABLE "MemoryEchoInsight" ADD CONSTRAINT "MemoryEchoInsight_note1Id_fkey" FOREIGN KEY ("note1Id") REFERENCES "Note"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
ALTER TABLE "MemoryEchoInsight" ADD CONSTRAINT "MemoryEchoInsight_note2Id_fkey" FOREIGN KEY ("note2Id") REFERENCES "Note"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
ALTER TABLE "UserAISettings" ADD CONSTRAINT "UserAISettings_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|