41 lines
1.5 KiB
SQL
41 lines
1.5 KiB
SQL
-- 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;
|