30 lines
1.3 KiB
SQL
30 lines
1.3 KiB
SQL
-- CreateTable: log polymorphic untuk admin actions lintas entity. Append-only,
|
|
-- never update/delete. Dipakai untuk compliance & investigasi (siapa
|
|
-- approve/reject/cancel/suspend, kapan, dengan payload apa).
|
|
--
|
|
-- `adminId` nullable + `adminEmail` snapshot supaya kalau admin dihapus,
|
|
-- log entry tetap auditable (siapa via email, kapan, payload apa). FK
|
|
-- ON DELETE SET NULL menjamin adminId di-clear tanpa cascade ke baris log.
|
|
CREATE TABLE "AdminActionLog" (
|
|
"id" TEXT NOT NULL,
|
|
"adminId" TEXT,
|
|
"adminEmail" TEXT NOT NULL,
|
|
"action" TEXT NOT NULL,
|
|
"entityType" TEXT NOT NULL,
|
|
"entityId" TEXT NOT NULL,
|
|
"payload" JSONB,
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
|
|
CONSTRAINT "AdminActionLog_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- Index: filter "all actions by admin X" + "all actions on entity Y".
|
|
CREATE INDEX "AdminActionLog_adminId_createdAt_idx" ON "AdminActionLog"("adminId", "createdAt" DESC);
|
|
CREATE INDEX "AdminActionLog_entityType_entityId_idx" ON "AdminActionLog"("entityType", "entityId");
|
|
CREATE INDEX "AdminActionLog_createdAt_idx" ON "AdminActionLog"("createdAt" DESC);
|
|
|
|
-- FK: admin user — SET NULL kalau admin dihapus supaya log tidak hilang.
|
|
ALTER TABLE "AdminActionLog" ADD CONSTRAINT "AdminActionLog_adminId_fkey"
|
|
FOREIGN KEY ("adminId") REFERENCES "User"("id")
|
|
ON DELETE SET NULL ON UPDATE CASCADE;
|