-- CreateTable CREATE TABLE "User" ( "id" SERIAL NOT NULL, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updatedAt" TIMESTAMP(3) NOT NULL, "name" TEXT, "email" TEXT NOT NULL, "hashedPassword" TEXT, "role" TEXT NOT NULL DEFAULT 'USER', CONSTRAINT "User_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "Session" ( "id" SERIAL NOT NULL, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updatedAt" TIMESTAMP(3) NOT NULL, "expiresAt" TIMESTAMP(3), "handle" TEXT NOT NULL, "hashedSessionToken" TEXT, "antiCSRFToken" TEXT, "publicData" TEXT, "privateData" TEXT, "userId" INTEGER, CONSTRAINT "Session_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "Token" ( "id" SERIAL NOT NULL, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updatedAt" TIMESTAMP(3) NOT NULL, "hashedToken" TEXT NOT NULL, "type" TEXT NOT NULL, "expiresAt" TIMESTAMP(3) NOT NULL, "sentTo" TEXT NOT NULL, "userId" INTEGER NOT NULL, CONSTRAINT "Token_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "SearchRequest" ( "id" SERIAL NOT NULL, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updatedAt" TIMESTAMP(3) NOT NULL, "text" TEXT NOT NULL, "count" INTEGER NOT NULL DEFAULT 0, CONSTRAINT "SearchRequest_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "Webpage" ( "id" SERIAL NOT NULL, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updatedAt" TIMESTAMP(3) NOT NULL, "path" TEXT NOT NULL, CONSTRAINT "Webpage_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "Domain" ( "id" SERIAL NOT NULL, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updatedAt" TIMESTAMP(3) NOT NULL, "address" TEXT NOT NULL, "lastParse" TIMESTAMP(3) NOT NULL, CONSTRAINT "Domain_pkey" PRIMARY KEY ("id") ); -- CreateIndex CREATE UNIQUE INDEX "User_email_key" ON "User"("email"); -- CreateIndex CREATE UNIQUE INDEX "Session_handle_key" ON "Session"("handle"); -- CreateIndex CREATE UNIQUE INDEX "Token_hashedToken_type_key" ON "Token"("hashedToken", "type"); -- CreateIndex CREATE UNIQUE INDEX "SearchRequest_text_key" ON "SearchRequest"("text"); -- CreateIndex CREATE UNIQUE INDEX "Webpage_path_key" ON "Webpage"("path"); -- CreateIndex CREATE UNIQUE INDEX "Domain_address_key" ON "Domain"("address"); -- AddForeignKey ALTER TABLE "Session" ADD CONSTRAINT "Session_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "Token" ADD CONSTRAINT "Token_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User"("id") ON DELETE RESTRICT ON UPDATE CASCADE;