29 lines
1.0 KiB
SQL
29 lines
1.0 KiB
SQL
-- CreateEnum
|
|
CREATE TYPE "PenaltyType" AS ENUM ('KICK', 'TIME_BAN', 'BAN');
|
|
|
|
-- AlterTable
|
|
ALTER TABLE "Report" ADD COLUMN "penaltyId" INTEGER;
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "Penalty" (
|
|
"id" SERIAL NOT NULL,
|
|
"userId" TEXT NOT NULL,
|
|
"createdUserId" TEXT NOT NULL,
|
|
"type" "PenaltyType" NOT NULL,
|
|
"reason" TEXT NOT NULL,
|
|
"until" TIMESTAMP(3),
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "Penalty_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "Penalty" ADD CONSTRAINT "Penalty_userId_fkey" FOREIGN KEY ("userId") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "Penalty" ADD CONSTRAINT "Penalty_createdUserId_fkey" FOREIGN KEY ("createdUserId") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "Report" ADD CONSTRAINT "Report_penaltyId_fkey" FOREIGN KEY ("penaltyId") REFERENCES "Penalty"("id") ON DELETE SET NULL ON UPDATE CASCADE;
|