fa404e98ec
Переиспользование одного DB-билдера в цикле накапливало where-клаузы → updateOrInsert уходил в INSERT существующей строки → SQLSTATE 23505 на проде при повторном сборе. Билдер теперь создаётся внутри цикла. + тест на 2 прогона. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
159 lines
11 KiB
Markdown
159 lines
11 KiB
Markdown
# Brain Status (auto-generated)
|
||
|
||
Last updated: 2026-06-28T04:26:08.585Z
|
||
|
||
| Контролёр | Состояние | Детали |
|
||
|---|---|---|
|
||
| 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 4 week(s) ago |
|
||
| C4 Сигнальный статус | ✅ | This file (self-reference) |
|
||
| C5 Observer-coverage | ⚠️ | 2354 episode(s) this month · observer-stop-hook NOT registered in .claude/settings.json Stop hook |
|
||
| C6 Chain map sync | ✅ | [chain-map-checker] OK — 17 chains in sync |
|
||
|
||
## Кто на посту (оборона М1–М6)
|
||
|
||
⚠️ **ПОСТ ПУСТОЙ** — не зарегистрированы: enforce-floor.mjs, enforce-supreme-gate.mjs, enforce-normative-content-rules.mjs, enforce-read-path-deny.mjs, enforce-mcp-classification.mjs, enforce-judge-gate.mjs, enforce-snapshot.mjs, enforce-floor-escape-consume.mjs, enforce-skill-journaler.mjs, enforce-verify-gate.mjs, enforce-criterion-gate.mjs, enforce-coverage-verify.mjs, enforce-todowrite-skill-verifier.mjs (оборона НЕ подтверждена; SE-B/Δ8)
|
||
|
||
Судья М4: **live-block** (inert $0 / shadow / floor-only / live-block)
|
||
|
||
| Машина / страж | Хук | Зарегистрирован |
|
||
|---|---|---|
|
||
| М5 Пол (вето-до-плана / content-floor) | `enforce-floor.mjs` | 🔴 |
|
||
| М2 Стена (действие = шаг плана) | `enforce-supreme-gate.mjs` | 🔴 |
|
||
| М1/М5 Нормативный страж (КАРТА/ЗАКОН) | `enforce-normative-content-rules.mjs` | 🔴 |
|
||
| М5 Read-exfil страж | `enforce-read-path-deny.mjs` | 🔴 |
|
||
| М5 Egress-exfil страж | `enforce-mcp-classification.mjs` | 🔴 |
|
||
| М4 Судья (приёмка + надзор) | `enforce-judge-gate.mjs` | 🔴 |
|
||
| М6 Снимок (точка отката) | `enforce-snapshot.mjs` | 🔴 |
|
||
| М6 Escape владельца (законная дверь) | `enforce-floor-escape-consume.mjs` | 🔴 |
|
||
| М1 Журналер навыков | `enforce-skill-journaler.mjs` | 🔴 |
|
||
| enforce-verify-gate.mjs | `enforce-verify-gate.mjs` | 🔴 |
|
||
| enforce-criterion-gate.mjs | `enforce-criterion-gate.mjs` | 🔴 |
|
||
| enforce-coverage-verify.mjs | `enforce-coverage-verify.mjs` | 🔴 |
|
||
| enforce-todowrite-skill-verifier.mjs | `enforce-todowrite-skill-verifier.mjs` | 🔴 |
|
||
|
||
Недавние escape владельца: 0 · Недавние блоки: 5
|
||
|
||
**Недавние блоки (детали):**
|
||
|
||
| Время | Действие | Причина |
|
||
|---|---|---|
|
||
| 2026-06-27T11:50:42.480Z | bash:cd "c:/моя/проекты/claude-brain" && git add -- "docs/superpowers/specs/2026-06-27-secretary-closing-doors-design.md | floor: опасная по содержанию команда без аварийного выхода — блок (правило 8); FLOOR-ESCAPE: bash:cd "c:/моя/проекты/cla |
|
||
| 2026-06-27T10:01:08.010Z | bash:git restore --staged docs/observer/STATUS.md 2>/dev/null; git diff --staged --name-only | floor: опасная по содержанию команда без аварийного выхода — блок (правило 8); FLOOR-ESCAPE: bash:git restore --staged d |
|
||
| 2026-06-27T09:25:54.127Z | bash:node -e "for (const d of ['протокол-наставника','проблема-закрытия-вопросов-протокола','содержит']) { try { const p | floor: опасная по содержанию команда без аварийного выхода — блок (правило 8); FLOOR-ESCAPE: bash:node -e "for (const d |
|
||
| 2026-06-27T07:03:56.852Z | bash:node -e "1" 2>/dev/null; for f in docs/secretary/*/protocol.md; do printf '%6s %s\n' "$(wc -l < "$f")" "$f"; done | floor: опасная по содержанию команда без аварийного выхода — блок (правило 8); FLOOR-ESCAPE: bash:node -e "1" 2>/dev/nul |
|
||
| 2026-06-27T05:45:19.915Z | bash:rm ~/.claude/runtime/secretary-mode-*.json | floor: опасная по содержанию команда без аварийного выхода — блок (правило 8); FLOOR-ESCAPE: bash:rm ~/.claude/runtime/s |
|
||
|
||
## Метрики (информационные, не алерты)
|
||
|
||
- Observer evidence: 2354 episodes this month, 0 observer_error markers, 8 PII matches before filter
|
||
- Legacy v1 episodes (not in factor analysis): 2354
|
||
- Last /brain-retro: 32 day(s) ago
|
||
- Использование узлов: см. `/brain-retro` (раз в спринт). missed_activations: 0. **Неиспользованные узлы — не алерт, если профильной задачи не было** (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.
|
||
|
||
| Тип задачи | Эпизодов | % с триггер-матчем | % через скил |
|
||
|---|---|---|---|
|
||
| planning | 258 | 5.0% | 16.3% |
|
||
| feature | 77 | 3.9% | 3.9% |
|
||
| bugfix | 61 | 6.6% | 13.1% |
|
||
| analysis | 50 | 6.0% | 2.0% |
|
||
| cleanup | 3 | 0.0% | 0.0% |
|
||
| refactor | 2 | 0.0% | 50.0% |
|
||
|
||
Router step distribution: 1: 1256, 2: 813, 3: 40, 5: 215
|
||
|
||
Boundaries applied (ADR / границы): 33 of 2324 эпизодов (1.4%).
|
||
|
||
## Активные многоэтапные проекты
|
||
|
||
- **Router discipline overhaul** ([spec](../superpowers/specs/2026-05-23-router-discipline-overhaul-design.md))
|
||
- Этап 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) | 68479/251178 | $3.97 |
|
||
| Self-assessment (Sonnet 4.6) | 0/0 | $0.00 |
|
||
| Reviewer (Opus 4.7 + fallback) | 0/0 | $0.00 |
|
||
| **Итого** | | **$3.97** |
|
||
|
||
## Аномалии классификатора
|
||
|
||
Аномалий нет.
|
||
|
||
## Авто-ретроспектива
|
||
|
||
Last self-retrospect: never ⚠️ (542 эпизодов с последнего запуска, порог 10)
|
||
Episodes since last run: 542 / threshold: 10
|
||
|
||
## Reviewer: субагент vs fallback
|
||
|
||
0 эпизодов проверено из 2354.
|
||
|
||
## Reviewer findings
|
||
|
||
(нет проверенных эпизодов в текущем периоде)
|
||
|
||
## Использование override-фраз
|
||
|
||
|
||
|
||
| Фраза | За всё время | За сегодня |
|
||
|---|---|---|
|
||
| `recovery` | 2302 | 0 |
|
||
| `без скилов` | 507 | 0 |
|
||
| `ремонт инфраструктуры` | 331 | 0 |
|
||
| `срочно` | 225 | 0 |
|
||
| `memory dump` | 46 | 0 |
|
||
| `direct ok` | 6 | 0 |
|
||
| `быстрый коммит` | 3 | 0 |
|
||
|
||
## System Health
|
||
|
||
Топ-3 процессов с CPU > 1ч:
|
||
|
||
| PID | Имя | CPU-время | Возраст |
|
||
|---|---|---|---|
|
||
| 3440 | MsMpEng | 17.07ч | 0.0ч |
|
||
| 21928 | Code | 7.36ч | 451351.4ч |
|
||
| 1212 | svchost | 4.38ч | NaNч |
|
||
|
||
⚠️ Проверь, не «осиротевшие» ли это процессы от завершённых Claude-сессий.
|
||
|
||
## Очередь обучения роутера
|
||
|
||
Очередь пуста — нет кандидатов на одобрение.
|
||
|
||
## Покрытие дверей
|
||
|
||
⚠️ Есть забытые двери (matcher: (хук НЕ зарегистрирован)).
|
||
|
||
Непокрытые мутирующие инструменты: Edit, Write, MultiEdit, NotebookEdit, Bash, Task, Skill
|
||
|
||
## Целостность журналов действий
|
||
|
||
🔴 Битые цепочки (3 из 120):
|
||
|
||
| session | broken at seq |
|
||
|---|---|
|
||
| `03437265-6d58-4622-aeed-c0eeac0f2c32` | 1 |
|
||
| `54594686-843c-4ea8-bcd3-5ae6a7244e30` | 14 |
|
||
| `9c02276d-dabb-40e4-9c04-44c18d47485a` | 14 |
|
||
|
||
## Алерт-индикаторы
|
||
|
||
✅ — норма ・ ⚠️ — внимание ・ 🔴 — действие требуется ・ ⚪ — не запускалось
|