mirror of
https://github.com/zvx-echo6/meshai.git
synced 2026-06-10 17:04:45 +02:00
feat(v0.6-phase2): rip out quiet hours entirely -- dashboard toggle, config schema, pipeline checks. Per Matt's repeated feedback (saved as feedback-quiet-hours-trash.md): silent is better than ugly, mesh users who need a fire alert at 3 AM need it at 3 AM. No replacement.
Backend removals:
meshai/config.py
- NotificationRuleConfig.override_quiet field
- NotificationToggle.quiet_hours_override field
- NotificationsConfig.quiet_hours_enabled / quiet_hours_start /
quiet_hours_end fields
- _default_toggles() no longer sets quiet_hours_override=True
- rule migration helper no longer copies override_quiet
meshai/notifications/router.py
- self._quiet_enabled / _quiet_start / _quiet_end instance vars
- _in_quiet_hours() method (deleted entirely)
- The dispatch-time check that suppressed non-overriding rules
during quiet hours
- 'override_quiet': False dropped from subscription rule dicts
meshai/notifications/pipeline/dispatcher.py
- _toggle_to_rule() no longer passes override_quiet=... to the
NotificationRuleConfig constructor
Test changes:
tests/test_notification_toggles.py
- RecChannel.deliver() no longer records override_quiet
- test_quiet_hours_override_immediate_only deleted (only tested the
removed feature)
Frontend removals (dashboard-frontend/src/pages/Notifications.tsx):
- The 'Enable Quiet Hours' card with its time-range inputs deleted
- 'Override Quiet Hours' per-rule toggle deleted
- 'Quiet-hours override (immediate only)' per-toggle field deleted
- quiet_hours_* fields removed from TS interfaces
- quietHoursEnabled prop + state plumbing removed from the RuleEditor
- All override_quiet: false defaults dropped from rule scaffolds
- Unused Moon icon import dropped
Verification (post-strip):
grep -rn 'quiet_hours\|override_quiet' meshai/*.py meshai/**/*.py
-> 0 hits
grep -rn 'quiet_hours\|override_quiet\|quietHours' dashboard-frontend/src
-> 0 hits
Test count: 830 -> 829 (-1: test_quiet_hours_override_immediate_only
deleted; no other regressions).
No replacement. Mesh users who need a fire alert at 3 AM need it at 3 AM.
This commit is contained in:
parent
90783376e8
commit
b948ed775f
8 changed files with 88 additions and 205 deletions
|
|
@ -17,7 +17,6 @@ class RecChannel:
|
|||
"name": rule.name,
|
||||
"broadcast_channel": rule.broadcast_channel,
|
||||
"node_ids": list(rule.node_ids),
|
||||
"override_quiet": rule.override_quiet,
|
||||
})
|
||||
return True
|
||||
|
||||
|
|
@ -115,14 +114,6 @@ def test_digest_channel_skipped_in_live_dispatch():
|
|||
assert [r["delivery_type"] for r in rec] == ["mesh_broadcast"] # digest not live-dispatched
|
||||
|
||||
|
||||
def test_quiet_hours_override_immediate_only():
|
||||
cfg = _cfg(min_severity="routine",
|
||||
severity_channels={"priority": ["mesh_broadcast"], "immediate": ["mesh_broadcast"]})
|
||||
cfg.notifications.toggles["weather"].quiet_hours_override = True
|
||||
assert _dispatch(cfg, _ev(severity="priority"))[0]["override_quiet"] is False
|
||||
assert _dispatch(cfg, _ev(severity="immediate"))[0]["override_quiet"] is True
|
||||
|
||||
|
||||
def test_category_maps_to_correct_family():
|
||||
# seismic family toggle handles earthquake_event via get_toggle fallback
|
||||
cfg = Config(); cfg.notifications.rules = []
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue