left4me/l4d2web/alembic/versions
mwiegand e25e7098f6
refactor(live-state): drop redundant ix_sps_server_recent index
The two indexes ix_sps_server_open and ix_sps_server_recent were
byte-identical because SQLAlchemy's Index(name, *cols) form drops the
DESC ordering the spec intended. Rather than reach for text("left_at
DESC"), drop the second index entirely — SQLite scans the ASC index
backwards at no measurable cost. Spec and plan updated to match.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-12 21:27:01 +02:00
..
0001_initial.py chore(l4d2): flatten component layout 2026-05-05 23:47:06 +02:00
0002_workshop_overlays.py feat(l4d2-web): typed overlays + workshop schema migration 2026-05-07 16:35:13 +02:00
0003_global_map_overlays.py feat(l4d2-web): managed global map overlays with daily refresh 2026-05-08 08:05:14 +02:00
0004_drop_legacy_external_overlay_type.py refactor(l4d2-web): remove legacy external overlay type 2026-05-08 09:31:04 +02:00
0005_script_overlays.py feat(l4d2-web): script overlay schema — add overlay.script + last_build_status, drop globals tables 2026-05-08 15:33:04 +02:00
0006_server_name_per_user.py feat(l4d2-web): server identity by id, name as display label 2026-05-08 19:22:09 +02:00
0007_blueprint_overlay_expose_server_cfg.py feat(l4d2-web): per-overlay server.cfg aliases — expose checkbox + auto-exec 2026-05-09 01:26:31 +02:00
0008_user_active.py models: add User.active column for soft-delete (deactivation) 2026-05-10 21:12:27 +02:00
0009_user_password_changed_at.py alembic: add users.password_changed_at column 2026-05-11 21:44:39 +02:00
0010_server_live_state.py refactor(live-state): drop redundant ix_sps_server_recent index 2026-05-12 21:27:01 +02:00
b2c684fddbd3_make_server_port_unique.py fix: enable batch operations in alembic for sqlite unique constraints 2026-05-06 20:59:18 +02:00