Files
state-hub/migrations/versions/a4v5w6x7y8z0_legacy_meter.py
tegwick 166aedfa8d feat: add workplan aliases and legacy meter
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.
2026-06-04 08:25:31 +02:00

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")