142 lines
4.8 KiB
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;
|