45 lines
1.5 KiB
SQL
45 lines
1.5 KiB
SQL
-- CreateEnum
|
|
CREATE TYPE "IntegrationScope" AS ENUM ('DELIVERABLES_READ', 'CLIENTS_READ');
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "integration_api_keys" (
|
|
"id" TEXT NOT NULL,
|
|
"name" TEXT NOT NULL,
|
|
"hashed_key" TEXT NOT NULL,
|
|
"last_four_chars" TEXT NOT NULL,
|
|
"scopes" "IntegrationScope"[],
|
|
"is_active" BOOLEAN NOT NULL DEFAULT true,
|
|
"expires_at" TIMESTAMP(3),
|
|
"last_used_at" TIMESTAMP(3),
|
|
"rate_limit_per_minute" INTEGER NOT NULL DEFAULT 60,
|
|
"created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updated_at" TIMESTAMP(3) NOT NULL,
|
|
"created_by" TEXT,
|
|
"updated_by" TEXT,
|
|
|
|
CONSTRAINT "integration_api_keys_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "integration_api_key_usage" (
|
|
"id" TEXT NOT NULL,
|
|
"api_key_id" TEXT NOT NULL,
|
|
"endpoint" TEXT NOT NULL,
|
|
"status_code" INTEGER NOT NULL,
|
|
"ip_address" TEXT,
|
|
"user_agent" TEXT,
|
|
"created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
|
|
CONSTRAINT "integration_api_key_usage_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "integration_api_keys_hashed_key_key" ON "integration_api_keys"("hashed_key");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "integration_api_key_usage_api_key_id_idx" ON "integration_api_key_usage"("api_key_id");
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "integration_api_key_usage" ADD CONSTRAINT "integration_api_key_usage_api_key_id_fkey" FOREIGN KEY ("api_key_id") REFERENCES "integration_api_keys"("id") ON DELETE RESTRICT ON UPDATE CASCADE;
|
|
|