generated from coulomb/repo-seed
Adds preferred workplan REST/event surfaces, legacy-meter telemetry and weekly review summaries, documentation/dashboard terminology updates, dashboard API loading fixes, and close-out sync for STATE-WP-0052 and STATE-WP-0054.
108 lines
5.1 KiB
Python
108 lines
5.1 KiB
Python
"""add legacy meter tables
|
|
|
|
Revision ID: a4v5w6x7y8z0
|
|
Revises: z3u4v5w6x7y8
|
|
Create Date: 2026-06-04
|
|
|
|
"""
|
|
from alembic import op
|
|
import sqlalchemy as sa
|
|
from sqlalchemy.dialects.postgresql import UUID
|
|
|
|
revision = "a4v5w6x7y8z0"
|
|
down_revision = "z3u4v5w6x7y8"
|
|
branch_labels = None
|
|
depends_on = None
|
|
|
|
|
|
def upgrade() -> None:
|
|
op.create_table(
|
|
"legacy_interfaces",
|
|
sa.Column("id", UUID(as_uuid=True), primary_key=True),
|
|
sa.Column("interface_key", sa.String(length=300), nullable=False),
|
|
sa.Column("interface_kind", sa.String(length=40), nullable=False),
|
|
sa.Column("legacy_since", sa.DateTime(timezone=True), server_default=sa.text("now()"), nullable=False),
|
|
sa.Column("replacement_ref", sa.Text(), nullable=False),
|
|
sa.Column("owner_component", sa.String(length=100), server_default="state-hub", nullable=False),
|
|
sa.Column("status", sa.String(length=30), server_default="legacy", nullable=False),
|
|
sa.Column("replacement_verified", sa.Boolean(), server_default=sa.text("false"), nullable=False),
|
|
sa.Column("manual_hold", sa.Boolean(), server_default=sa.text("false"), nullable=False),
|
|
sa.Column("hold_reason", sa.Text(), nullable=True),
|
|
sa.Column("notes", sa.Text(), nullable=True),
|
|
sa.Column("retired_at", sa.DateTime(timezone=True), nullable=True),
|
|
sa.Column("created_at", sa.DateTime(timezone=True), server_default=sa.text("now()"), nullable=False),
|
|
sa.Column("updated_at", sa.DateTime(timezone=True), server_default=sa.text("now()"), nullable=False),
|
|
sa.UniqueConstraint("interface_key", name="uq_legacy_interfaces_interface_key"),
|
|
)
|
|
op.create_index("ix_legacy_interfaces_interface_key", "legacy_interfaces", ["interface_key"])
|
|
op.create_index("ix_legacy_interfaces_interface_kind", "legacy_interfaces", ["interface_kind"])
|
|
op.create_index("ix_legacy_interfaces_legacy_since", "legacy_interfaces", ["legacy_since"])
|
|
op.create_index("ix_legacy_interfaces_owner_component", "legacy_interfaces", ["owner_component"])
|
|
op.create_index("ix_legacy_interfaces_status", "legacy_interfaces", ["status"])
|
|
|
|
op.create_table(
|
|
"legacy_interface_usage_buckets",
|
|
sa.Column("id", UUID(as_uuid=True), primary_key=True),
|
|
sa.Column(
|
|
"legacy_interface_id",
|
|
UUID(as_uuid=True),
|
|
sa.ForeignKey("legacy_interfaces.id", ondelete="CASCADE"),
|
|
nullable=False,
|
|
),
|
|
sa.Column("period_start", sa.Date(), nullable=False),
|
|
sa.Column("bucket_kind", sa.String(length=30), nullable=False),
|
|
sa.Column("bucket_key", sa.String(length=200), nullable=False),
|
|
sa.Column("call_count", sa.Integer(), server_default="0", nullable=False),
|
|
sa.Column("first_seen_at", sa.DateTime(timezone=True), nullable=False),
|
|
sa.Column("last_seen_at", sa.DateTime(timezone=True), nullable=False),
|
|
sa.Column("created_at", sa.DateTime(timezone=True), server_default=sa.text("now()"), nullable=False),
|
|
sa.Column("updated_at", sa.DateTime(timezone=True), server_default=sa.text("now()"), nullable=False),
|
|
sa.UniqueConstraint(
|
|
"legacy_interface_id",
|
|
"period_start",
|
|
"bucket_kind",
|
|
"bucket_key",
|
|
name="uq_legacy_usage_bucket",
|
|
),
|
|
)
|
|
op.create_index(
|
|
"ix_legacy_interface_usage_buckets_legacy_interface_id",
|
|
"legacy_interface_usage_buckets",
|
|
["legacy_interface_id"],
|
|
)
|
|
op.create_index(
|
|
"ix_legacy_interface_usage_buckets_period_start",
|
|
"legacy_interface_usage_buckets",
|
|
["period_start"],
|
|
)
|
|
op.create_index(
|
|
"ix_legacy_interface_usage_buckets_last_seen_at",
|
|
"legacy_interface_usage_buckets",
|
|
["last_seen_at"],
|
|
)
|
|
op.create_index(
|
|
"ix_legacy_usage_interface_period",
|
|
"legacy_interface_usage_buckets",
|
|
["legacy_interface_id", "period_start"],
|
|
)
|
|
op.create_index(
|
|
"ix_legacy_usage_bucket_kind_key",
|
|
"legacy_interface_usage_buckets",
|
|
["bucket_kind", "bucket_key"],
|
|
)
|
|
|
|
|
|
def downgrade() -> None:
|
|
op.drop_index("ix_legacy_usage_bucket_kind_key", table_name="legacy_interface_usage_buckets")
|
|
op.drop_index("ix_legacy_usage_interface_period", table_name="legacy_interface_usage_buckets")
|
|
op.drop_index("ix_legacy_interface_usage_buckets_last_seen_at", table_name="legacy_interface_usage_buckets")
|
|
op.drop_index("ix_legacy_interface_usage_buckets_period_start", table_name="legacy_interface_usage_buckets")
|
|
op.drop_index("ix_legacy_interface_usage_buckets_legacy_interface_id", table_name="legacy_interface_usage_buckets")
|
|
op.drop_table("legacy_interface_usage_buckets")
|
|
op.drop_index("ix_legacy_interfaces_status", table_name="legacy_interfaces")
|
|
op.drop_index("ix_legacy_interfaces_owner_component", table_name="legacy_interfaces")
|
|
op.drop_index("ix_legacy_interfaces_legacy_since", table_name="legacy_interfaces")
|
|
op.drop_index("ix_legacy_interfaces_interface_kind", table_name="legacy_interfaces")
|
|
op.drop_index("ix_legacy_interfaces_interface_key", table_name="legacy_interfaces")
|
|
op.drop_table("legacy_interfaces")
|