Files
portal/docs/observer/STATUS.md
T
Дмитрий ea9430d8a7 feat(observer): session-length warning in STATUS.md (retro #5 candidate B)
Brain-retro #5 surfaced a correlation: long sessions (≥50 turns) correlate
with discipline drift. Reviewer pass showed regulated rate dropped 19% →
4.5% during a long session.

This commit adds:

  • computeSessionLengthBlock(episodes, opts?) — pure function that
    groups today's (UTC) episodes by task_id, finds the MAX session_turn
    per session, and surfaces sessions with ≥threshold turns (default 50)
    in a markdown block.

  • Wire-up in renderStatus + main CLI: new "## Длинные сессии" section
    inserted between disciplineBlock/activeProjects and costBlock.

  • 7 new unit tests (36/36 total green).

Behavior:
  • No sessions today →  "Ни одной сессии с >50 ходов".
  • One+ flagged → ⚠️ table { session_id, max turn, regulated %, last episode ts }.
  • Custom threshold via opts.threshold.

Per memory project_enforce_hard_rules.md: this is an indicator, not a hook;
no blocking, just observability. Owner can decide whether to restart when
regulated % drops in a long session.
2026-05-26 10:52:35 +03:00

5.6 KiB
Raw Blame History

Brain Status (auto-generated)

Last updated: 2026-05-26T07:52:20.201Z

Контролёр Состояние Детали
C1 L1-watcher [l1-watcher] OK — 0 drift
C2 Cross-ref consistency [cross-ref-checker] OK — 0 drift in 4 files
C3 Observer-of-observer [observer-of-observer] OK — last read 0 week(s) ago
C4 Сигнальный статус This file (self-reference)
C5 Observer-coverage ⚠️ 464 episode(s) this month · Stop-hook + post-commit OK · 21 missed activation(s) — see /brain-retro
C6 Chain map sync [chain-map-checker] OK — 16 chains in sync

Метрики (информационные, не алерты)

  • Observer evidence: 464 episodes this month, 0 observer_error markers, 74 PII matches before filter
  • Legacy v1 episodes (not in factor analysis): 325
  • Last /brain-retro: 0 day(s) ago
  • Использование узлов: см. /brain-retro (раз в спринт). missed_activations: 21. Неиспользованные узлы — не алерт, если профильной задачи не было (Pravila §16.4 v1.36; capability-readiness; см. memory feedback_brain_unused_tools_not_problem — outside-repo memory store).

Метрики дисциплины

Baseline дисциплины роутера (этап 2 router discipline overhaul, spec 2026-05-23). Цель — увидеть «точку До» перед enforcement-хуком этапа 3.

Тип задачи Эпизодов % с триггер-матчем % через скил
monitoring 22 0.0% 0.0%
analysis 20 40.0% 20.0%
feature 14 14.3% 0.0%
planning 11 18.2% 18.2%
bugfix 11 36.4% 45.5%
cleanup 4 0.0% 0.0%
refactor 1 0.0% 0.0%

Router step distribution: 1: 187, 2: 170, 3: 54, 5: 48

Boundaries applied (ADR / границы): 65 of 459 эпизодов (14.2%).

Активные многоэтапные проекты

  • Router discipline overhaul (spec)
    • Этап 1 (машиночитаемый реестр) закрыт 2026-05-23 — docs/registry/nodes.yaml (83 узла + 16 chains L1-L16), tools/registry-load.mjs + tools/registry-render.mjs (16 тестов), auto-render Tooling §4.0 + routing-off-phase, lefthook job 17 (warn-only).
    • Этап 2 (измерения + классификатор-парсер) закрыт 2026-05-24 + влит в main 2026-05-24 — discipline-metrics (3 среза), brain-retro-analyzer переключён на реестр, STATUS.md блок «Метрики дисциплины», baseline snapshot docs/observer/baselines/2026-05-24-pre-enforcement.md. Plan: docs/superpowers/plans/2026-05-24-router-overhaul-stage-2-measurements.md.
    • Этап 3 (принуждение — хук на routing) — Phase A+B (классификатор + 3 хука: router-prehook/tool-gate/stop-gate в .claude/settings.json) + влит в main 2026-05-24. Гейт работает в режиме warn-only (только stderr-предупреждения, никакой блокировки). Bug-fix bec69aa5: deriveRouterStep в tools/discipline-metrics.mjs — шаг роутера теперь выводится из наблюдаемых признаков (был захардкоженной константой 1). Follow-up 3 fixes 2026-05-24 (после ANTHROPIC_API_KEY + рестарта CC выявлены при инспекции state): (a) UTF-8 stdin helper tools/router-stdin-helper.mjs через StringDecoder + подключение к 3 хукам (русский в state-файл и Anthropic API без mojibake); (b) tools/observer-state-enricher.mjs — pure helper для чтения router-state-<session>.json; (c) parseTranscript обогащение primary_rationale 4 полями (recommended_node override + recommended_chain + chain_progress + chain_completed). 538 tools-тестов GREEN. Plan: docs/superpowers/plans/2026-05-24-router-stage3-three-fixes.md. CHECKPOINT B: дать warn-only накопить реальные наблюдения с починенным сторожем (план говорит «минимум 24 часа»), затем Task 9 — переключение в enforce + 2 новых метрики (domain-hit-rate / chain-completion). Plan: docs/superpowers/plans/2026-05-24-router-overhaul-stage-3-enforcement.md.
    • Этап 4 (уборка устаревших правил, deprecation observer-classification-map.json → удаление) — не начат.

Длинные сессии

Ни одной сессии с >50 ходов сегодня (UTC).

Стоимость месяца

Компонент Токены (in/out) USD
Classifier (Sonnet 4.6) 0/0 $0.00
Self-assessment (Sonnet 4.6) 0/0 $0.00
Reviewer (Opus 4.7 + fallback) 0/0 $0.00
Итого $0.00

Аномалии классификатора

Аномалий нет.

Авто-ретроспектива

Last self-retrospect: never ⚠️ (202 эпизодов с последнего запуска, порог 10) Episodes since last run: 202 / threshold: 10

Reviewer: субагент vs fallback

0 эпизодов проверено из 464.

Алерт-индикаторы

— норма ・ ⚠️ — внимание ・ 🔴 — действие требуется ・ — не запускалось