-- CreateTable CREATE TABLE "RefreshToken" ( "id" TEXT NOT NULL, "userId" INTEGER NOT NULL, "tokenHash" TEXT NOT NULL, "familyId" TEXT NOT NULL, "jti" TEXT NOT NULL, "expiresAt" TIMESTAMP(3) NOT NULL, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "revokedAt" TIMESTAMP(3), "replacedById" TEXT, "createdByIp" TEXT, "userAgent" TEXT, CONSTRAINT "RefreshToken_pkey" PRIMARY KEY ("id") ); -- CreateIndex CREATE UNIQUE INDEX "RefreshToken_tokenHash_key" ON "RefreshToken"("tokenHash"); -- CreateIndex CREATE UNIQUE INDEX "RefreshToken_replacedById_key" ON "RefreshToken"("replacedById"); -- CreateIndex CREATE INDEX "RefreshToken_userId_idx" ON "RefreshToken"("userId"); -- CreateIndex CREATE INDEX "RefreshToken_familyId_idx" ON "RefreshToken"("familyId"); -- CreateIndex CREATE INDEX "RefreshToken_expiresAt_idx" ON "RefreshToken"("expiresAt"); -- AddForeignKey ALTER TABLE "RefreshToken" ADD CONSTRAINT "RefreshToken_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "RefreshToken" ADD CONSTRAINT "RefreshToken_replacedById_fkey" FOREIGN KEY ("replacedById") REFERENCES "RefreshToken"("id") ON DELETE SET NULL ON UPDATE CASCADE;