DOX sistem

This commit is contained in:
2026-06-13 11:51:36 +03:00
parent bb241bf050
commit 39f2439246
8 changed files with 347 additions and 139 deletions

53
configs/AGENTS.md Normal file
View File

@@ -0,0 +1,53 @@
# configs — TOML Configs
## Purpose
Configurațiile de rulare (ROI-uri, paletă, canary baseline, operating-hours,
alerts). Schema e definită și validată în `src/atm/config.py` (fail fast la load).
## Ownership
`*.toml` + `current.txt` (pointer la config-ul activ) + `example.toml` (template).
## Local Contracts
- **`current.txt`** — o singură linie: numele fișierului TOML activ. `atm run`
fără `--config` îl folosește pe acesta.
- Secretele **NU** stau în TOML — vin din env (`.env`). Vezi `notifier/AGENTS.md`.
- Schema (dataclass-uri în `config.py`): `dot_roi`, `colors{name→{rgb,tolerance}}`,
`canary{roi, baseline_phash}`, y-axis calib, `[options.operating_hours]`,
`[options.alerts]`. Modifici schema în `config.py` ⇒ actualizezi `example.toml`
+ acest doc în același commit.
### `[options.operating_hours]`
`enabled`, `timezone` (NYSE local, ex. `America/New_York`), `weekdays`,
`start_hhmm`, `stop_hhmm`. Timezone validat la load; `_tz_cache` reutilizat per
tick. Boundary crossings logează `market_open`/`market_closed` și notifică o dată.
Startup in-window e silent.
### `[options.alerts]`
`fire_on_phase_skip = true` (default) — tranziția ARMED→light_* directă (dark_*
ratat) emite totuși un `⚠️ PHASE SKIP`, cu FSM lockout ca să suprime spam-ul.
### `canary.baseline_phash`
Re-anchor prin comanda `/rebase confirm` (rescrie automat aici, păstrând
comentariile). Nu edita manual decât dacă știi exact ce faci.
## Work Guidance
- Config nou = copiezi `example.toml`, numești `{data}-{tag}.toml`, pui numele în
`current.txt`. Nu șterge config-urile vechi (audit trail al recalibrărilor).
## Verification
```bash
atm validate-calibration calibration/calibration_labels.json
atm debug --delay 5 # confirmă că config-ul activ încarcă & detectează
```
## Child DOX Index
(none — leaf)