-- CreateEnum CREATE TYPE "UserStatus" AS ENUM ('PENDING', 'ACTIVE', 'DISABLED'); -- CreateEnum CREATE TYPE "ListingStatus" AS ENUM ('DRAFT', 'PENDING', 'PUBLISHED', 'REJECTED'); -- AlterTable ALTER TABLE "Listing" ADD COLUMN "approvedAt" TIMESTAMP(3), ADD COLUMN "approvedById" TEXT, ADD COLUMN "status" "ListingStatus" NOT NULL DEFAULT 'PENDING'; -- AlterTable ALTER TABLE "User" ADD COLUMN "approvedAt" TIMESTAMP(3), ADD COLUMN "emailVerifiedAt" TIMESTAMP(3), ADD COLUMN "passwordHash" TEXT NOT NULL DEFAULT '', ADD COLUMN "status" "UserStatus" NOT NULL DEFAULT 'PENDING'; -- CreateTable CREATE TABLE "VerificationToken" ( "id" TEXT NOT NULL, "userId" TEXT NOT NULL, "token" TEXT NOT NULL, "type" TEXT NOT NULL, "expiresAt" TIMESTAMP(3) NOT NULL, "consumedAt" TIMESTAMP(3), "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "VerificationToken_pkey" PRIMARY KEY ("id") ); -- CreateIndex CREATE UNIQUE INDEX "VerificationToken_token_key" ON "VerificationToken"("token"); -- CreateIndex CREATE INDEX "VerificationToken_userId_idx" ON "VerificationToken"("userId"); -- AddForeignKey ALTER TABLE "Listing" ADD CONSTRAINT "Listing_approvedById_fkey" FOREIGN KEY ("approvedById") REFERENCES "User"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "VerificationToken" ADD CONSTRAINT "VerificationToken_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User"("id") ON DELETE RESTRICT ON UPDATE CASCADE;