Backend: auto-fix and format all ruff issues, manually fix B904/B023/ SIM117/B007/E741/F841 errors, suppress B008 (FastAPI Depends) and F821 (SQLAlchemy forward refs) in config. Frontend: allow constant exports, disable React compiler-specific rules (set-state-in-effect, preserve-manual-memoization). Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
70 lines
2.0 KiB
Python
70 lines
2.0 KiB
Python
"""add genlocke tables
|
|
|
|
Revision ID: b2c3d4e5f6a8
|
|
Revises: a1b2c3d4e5f8, b7c8d9e0f1a2
|
|
Create Date: 2026-02-09 14:00:00.000000
|
|
|
|
"""
|
|
|
|
from collections.abc import Sequence
|
|
|
|
import sqlalchemy as sa
|
|
from alembic import op
|
|
from sqlalchemy.dialects.postgresql import JSONB
|
|
|
|
# revision identifiers, used by Alembic.
|
|
revision: str = "b2c3d4e5f6a8"
|
|
down_revision: str | Sequence[str] | None = ("a1b2c3d4e5f8", "b7c8d9e0f1a2")
|
|
branch_labels: str | Sequence[str] | None = None
|
|
depends_on: str | Sequence[str] | None = None
|
|
|
|
|
|
def upgrade() -> None:
|
|
op.create_table(
|
|
"genlockes",
|
|
sa.Column("id", sa.Integer(), primary_key=True),
|
|
sa.Column("name", sa.String(100), nullable=False),
|
|
sa.Column("status", sa.String(20), nullable=False, index=True),
|
|
sa.Column("genlocke_rules", JSONB(), nullable=False, server_default="{}"),
|
|
sa.Column("nuzlocke_rules", JSONB(), nullable=False, server_default="{}"),
|
|
sa.Column(
|
|
"created_at",
|
|
sa.DateTime(timezone=True),
|
|
server_default=sa.func.now(),
|
|
nullable=False,
|
|
),
|
|
)
|
|
|
|
op.create_table(
|
|
"genlocke_legs",
|
|
sa.Column("id", sa.Integer(), primary_key=True),
|
|
sa.Column(
|
|
"genlocke_id",
|
|
sa.Integer(),
|
|
sa.ForeignKey("genlockes.id", ondelete="CASCADE"),
|
|
nullable=False,
|
|
index=True,
|
|
),
|
|
sa.Column(
|
|
"game_id",
|
|
sa.Integer(),
|
|
sa.ForeignKey("games.id"),
|
|
nullable=False,
|
|
index=True,
|
|
),
|
|
sa.Column(
|
|
"run_id",
|
|
sa.Integer(),
|
|
sa.ForeignKey("nuzlocke_runs.id"),
|
|
nullable=True,
|
|
index=True,
|
|
),
|
|
sa.Column("leg_order", sa.SmallInteger(), nullable=False),
|
|
sa.UniqueConstraint("genlocke_id", "leg_order", name="uq_genlocke_legs_order"),
|
|
)
|
|
|
|
|
|
def downgrade() -> None:
|
|
op.drop_table("genlocke_legs")
|
|
op.drop_table("genlockes")
|