v0.10.3.1: soft-disable state_511_atis* adapters instead of DELETE (FK blocked v0.10.3 migration) (#90)

Closes #90

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
malice 2026-06-06 18:39:33 -06:00 committed by GitHub
commit 7fa4f36e46
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 31 additions and 0 deletions

View file

@ -1,6 +1,13 @@
-- v0.10.3: rip out state_511_atis + state_511_atis_cameras (Castle Rock legacy -- v0.10.3: rip out state_511_atis + state_511_atis_cameras (Castle Rock legacy
-- shape EOL; superseded by itd_511 + itd_511_cameras from migration 031 / v0.10.0). -- shape EOL; superseded by itd_511 + itd_511_cameras from migration 031 / v0.10.0).
-- --
-- v0.10.3.1: Superseded by 033_soft_disable_state_511_atis_adapters.sql due to
-- the FK constraint events_adapter_fkey ON DELETE RESTRICT. Historical events
-- preserve referential integrity; the rows remain as soft-deleted tombstones
-- (enabled=false + paused_at=NOW()). This file is preserved as part of the
-- append-only migration ledger; running it on a fresh database still throws
-- the same FK error if any state_511_atis* events exist.
--
-- Idempotent: the DELETE succeeds whether the rows are present or not. Historical -- Idempotent: the DELETE succeeds whether the rows are present or not. Historical
-- events in public.events stay (preserved as historical record per Matt's call); -- events in public.events stay (preserved as historical record per Matt's call);
-- only the config.adapters rows that would otherwise be hot-reloaded into the -- only the config.adapters rows that would otherwise be hot-reloaded into the

View file

@ -0,0 +1,24 @@
-- v0.10.3.1: soft-disable state_511_atis + state_511_atis_cameras (Castle Rock
-- legacy shape EOL; superseded by itd_511 + itd_511_cameras from migration 031).
--
-- The original v0.10.3 plan was a hard DELETE in 032, but events_adapter_fkey
-- (ON DELETE RESTRICT) blocked it: 66 state_511_atis events + 2379
-- state_511_atis_cameras events still reference the adapter rows. Matt's
-- explicit rule was "preserve historical events as a record", so the rows must
-- stay -- they just become soft-deleted tombstones.
--
-- Effect on the supervisor: list_enabled_adapters() filters on enabled=true,
-- so these rows fall out of the startup adapter set naturally. The
-- "Unknown adapter type" WARNING lines from v0.10.3's degraded deploy go away
-- on the next supervisor restart.
--
-- Idempotent: re-running this on already-disabled rows updates paused_at to
-- the current timestamp, which is harmless (the row was already disabled).
--
-- Note: cursors.db cleanup ran as part of the v0.10.3 deploy already; not
-- repeated here.
UPDATE config.adapters
SET enabled = false,
paused_at = NOW()
WHERE name IN ('state_511_atis', 'state_511_atis_cameras');