67 lines
2.3 KiB
SQL
67 lines
2.3 KiB
SQL
-- CreateEnum
|
|
CREATE TYPE "WebhookStatus" AS ENUM ('ACTIVE', 'PAUSED', 'AUTO_DISABLED');
|
|
|
|
-- CreateEnum
|
|
CREATE TYPE "WebhookCallStatus" AS ENUM ('PENDING', 'IN_PROGRESS', 'DELIVERED', 'FAILED', 'DISCARDED');
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "Webhook" (
|
|
"id" TEXT NOT NULL,
|
|
"teamId" INTEGER NOT NULL,
|
|
"url" TEXT NOT NULL,
|
|
"description" TEXT,
|
|
"secret" TEXT NOT NULL,
|
|
"status" "WebhookStatus" NOT NULL DEFAULT 'ACTIVE',
|
|
"eventTypes" TEXT[],
|
|
"apiVersion" TEXT,
|
|
"consecutiveFailures" INTEGER NOT NULL DEFAULT 0,
|
|
"lastFailureAt" TIMESTAMP(3),
|
|
"lastSuccessAt" TIMESTAMP(3),
|
|
"createdByUserId" INTEGER,
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "Webhook_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "WebhookCall" (
|
|
"id" TEXT NOT NULL,
|
|
"webhookId" TEXT NOT NULL,
|
|
"teamId" INTEGER NOT NULL,
|
|
"type" TEXT NOT NULL,
|
|
"payload" TEXT NOT NULL,
|
|
"status" "WebhookCallStatus" NOT NULL DEFAULT 'PENDING',
|
|
"attempt" INTEGER NOT NULL DEFAULT 0,
|
|
"nextAttemptAt" TIMESTAMP(3),
|
|
"lastError" TEXT,
|
|
"responseStatus" INTEGER,
|
|
"responseTimeMs" INTEGER,
|
|
"responseText" TEXT,
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "WebhookCall_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "Webhook_teamId_idx" ON "Webhook"("teamId");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "WebhookCall_teamId_webhookId_status_idx" ON "WebhookCall"("teamId", "webhookId", "status");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "WebhookCall_createdAt_idx" ON "WebhookCall"("createdAt" DESC);
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "Webhook" ADD CONSTRAINT "Webhook_teamId_fkey" FOREIGN KEY ("teamId") REFERENCES "Team"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "Webhook" ADD CONSTRAINT "Webhook_createdByUserId_fkey" FOREIGN KEY ("createdByUserId") REFERENCES "User"("id") ON DELETE SET NULL ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "WebhookCall" ADD CONSTRAINT "WebhookCall_webhookId_fkey" FOREIGN KEY ("webhookId") REFERENCES "Webhook"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "WebhookCall" ADD CONSTRAINT "WebhookCall_teamId_fkey" FOREIGN KEY ("teamId") REFERENCES "Team"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|