rwadurian/backend/services/blockchain-service/prisma/migrations/20241207000000_init/migration.sql

142 lines
4.8 KiB
SQL

-- CreateTable
CREATE TABLE "monitored_addresses" (
"address_id" BIGSERIAL NOT NULL,
"chain_type" VARCHAR(20) NOT NULL,
"address" VARCHAR(42) NOT NULL,
"user_id" BIGINT NOT NULL,
"is_active" BOOLEAN NOT NULL DEFAULT true,
"created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
"updated_at" TIMESTAMP(3) NOT NULL,
CONSTRAINT "monitored_addresses_pkey" PRIMARY KEY ("address_id")
);
-- CreateTable
CREATE TABLE "deposit_transactions" (
"deposit_id" BIGSERIAL NOT NULL,
"chain_type" VARCHAR(20) NOT NULL,
"tx_hash" VARCHAR(66) NOT NULL,
"from_address" VARCHAR(42) NOT NULL,
"to_address" VARCHAR(42) NOT NULL,
"token_contract" VARCHAR(42) NOT NULL,
"amount" DECIMAL(36,18) NOT NULL,
"amount_formatted" DECIMAL(20,8) NOT NULL,
"block_number" BIGINT NOT NULL,
"block_timestamp" TIMESTAMP(3) NOT NULL,
"log_index" INTEGER NOT NULL,
"confirmations" INTEGER NOT NULL DEFAULT 0,
"status" VARCHAR(20) NOT NULL DEFAULT 'DETECTED',
"address_id" BIGINT NOT NULL,
"user_id" BIGINT NOT NULL,
"notified_at" TIMESTAMP(3),
"notify_attempts" INTEGER NOT NULL DEFAULT 0,
"last_notify_error" TEXT,
"created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
"updated_at" TIMESTAMP(3) NOT NULL,
CONSTRAINT "deposit_transactions_pkey" PRIMARY KEY ("deposit_id")
);
-- CreateTable
CREATE TABLE "block_checkpoints" (
"checkpoint_id" BIGSERIAL NOT NULL,
"chain_type" VARCHAR(20) NOT NULL,
"last_scanned_block" BIGINT NOT NULL,
"last_scanned_at" TIMESTAMP(3) NOT NULL,
"is_healthy" BOOLEAN NOT NULL DEFAULT true,
"last_error" TEXT,
"created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
"updated_at" TIMESTAMP(3) NOT NULL,
CONSTRAINT "block_checkpoints_pkey" PRIMARY KEY ("checkpoint_id")
);
-- CreateTable
CREATE TABLE "transaction_requests" (
"request_id" BIGSERIAL NOT NULL,
"chain_type" VARCHAR(20) NOT NULL,
"source_service" VARCHAR(50) NOT NULL,
"source_order_id" VARCHAR(100) NOT NULL,
"from_address" VARCHAR(42) NOT NULL,
"to_address" VARCHAR(42) NOT NULL,
"value" DECIMAL(36,18) NOT NULL,
"data" TEXT,
"signed_tx" TEXT,
"tx_hash" VARCHAR(66),
"status" VARCHAR(20) NOT NULL DEFAULT 'PENDING',
"gas_limit" BIGINT,
"gas_price" DECIMAL(36,18),
"nonce" INTEGER,
"error_message" TEXT,
"retry_count" INTEGER NOT NULL DEFAULT 0,
"created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
"updated_at" TIMESTAMP(3) NOT NULL,
CONSTRAINT "transaction_requests_pkey" PRIMARY KEY ("request_id")
);
-- CreateTable
CREATE TABLE "blockchain_events" (
"event_id" BIGSERIAL NOT NULL,
"event_type" VARCHAR(50) NOT NULL,
"aggregate_id" VARCHAR(100) NOT NULL,
"aggregate_type" VARCHAR(50) NOT NULL,
"event_data" JSONB NOT NULL,
"chain_type" VARCHAR(20),
"tx_hash" VARCHAR(66),
"occurred_at" TIMESTAMP(6) NOT NULL DEFAULT CURRENT_TIMESTAMP,
CONSTRAINT "blockchain_events_pkey" PRIMARY KEY ("event_id")
);
-- CreateIndex
CREATE INDEX "idx_user" ON "monitored_addresses"("user_id");
-- CreateIndex
CREATE INDEX "idx_chain_active" ON "monitored_addresses"("chain_type", "is_active");
-- CreateIndex
CREATE UNIQUE INDEX "monitored_addresses_chain_type_address_key" ON "monitored_addresses"("chain_type", "address");
-- CreateIndex
CREATE UNIQUE INDEX "deposit_transactions_tx_hash_key" ON "deposit_transactions"("tx_hash");
-- CreateIndex
CREATE INDEX "idx_chain_status" ON "deposit_transactions"("chain_type", "status");
-- CreateIndex
CREATE INDEX "idx_deposit_user" ON "deposit_transactions"("user_id");
-- CreateIndex
CREATE INDEX "idx_block" ON "deposit_transactions"("block_number");
-- CreateIndex
CREATE INDEX "idx_pending_notify" ON "deposit_transactions"("status", "notified_at");
-- CreateIndex
CREATE UNIQUE INDEX "block_checkpoints_chain_type_key" ON "block_checkpoints"("chain_type");
-- CreateIndex
CREATE INDEX "idx_tx_chain_status" ON "transaction_requests"("chain_type", "status");
-- CreateIndex
CREATE INDEX "idx_tx_hash" ON "transaction_requests"("tx_hash");
-- CreateIndex
CREATE UNIQUE INDEX "transaction_requests_source_service_source_order_id_key" ON "transaction_requests"("source_service", "source_order_id");
-- CreateIndex
CREATE INDEX "idx_event_aggregate" ON "blockchain_events"("aggregate_type", "aggregate_id");
-- CreateIndex
CREATE INDEX "idx_event_type" ON "blockchain_events"("event_type");
-- CreateIndex
CREATE INDEX "idx_event_chain" ON "blockchain_events"("chain_type");
-- CreateIndex
CREATE INDEX "idx_event_occurred" ON "blockchain_events"("occurred_at");
-- AddForeignKey
ALTER TABLE "deposit_transactions" ADD CONSTRAINT "deposit_transactions_address_id_fkey" FOREIGN KEY ("address_id") REFERENCES "monitored_addresses"("address_id") ON DELETE RESTRICT ON UPDATE CASCADE;