-- 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;