1a02b4b5f2
ADR-013: 4 узла A1 (#64-67) + границы BT1-BT9 + постуры. NightOwl DEFERRED (native-Windows нет pcntl/posix + OSS без MCP + hosted 152-ФЗ) -> Linux/Б-1. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
58 lines
4.9 KiB
Markdown
58 lines
4.9 KiB
Markdown
# ADR-013: A1 backend-tooling — наполнение раздела карты A1
|
||
|
||
**Status:** Accepted
|
||
**Date:** 2026-05-20
|
||
**Контекст:** эпик A1 backend-tooling, spec `docs/superpowers/specs/2026-05-20-a1-backend-tooling-design.md`.
|
||
|
||
## Context
|
||
|
||
Раздел карты A1 «Программирование — backend» был тонким — 3 узла: Boost #10
|
||
(Laravel-контекст), Pint #11 (стиль), Larastan #12 (типы). Backend-смежное уехало
|
||
в другие разделы (Pest→A5, squawk/pg_partman→A9, deptrac→A6, openapi→A3, Sentry/Redis→A7).
|
||
Дефициты чистого A1: авто-рефакторинг, метрики сложности/архитектуры, кодифицированные
|
||
backend-конвенции Лидерры, коррелированная runtime-телеметрия. На Anthropic-marketplace
|
||
чистого backend-кодинга нет (knowledge-work + meta); A1 закрывается GitHub PHP-экосистемой
|
||
плюс одним self-authored скилом.
|
||
|
||
## Decision
|
||
|
||
1. **Rector (#64)** — `rector/rector` + `driftingly/rector-laravel` (Composer dev-dep).
|
||
Авто-рефакторинг + version-aware апгрейды. Конфиг `app/rector.php` — консервативный
|
||
старт (`deadCode` + `codeQuality`, БЕЗ type-declaration наборов и LaravelSetProvider).
|
||
- **Постура: manual/CI** (`composer rector` / `composer rector:fix`), **НЕ** блокирующий
|
||
lefthook. Spike dry-run = **16 файлов** (>5 порога → код-мутирующий инструмент не гейтит
|
||
коммит; прецедент promptfoo ML1). LaravelSetProvider — для разовых апгрейдов вручную.
|
||
2. **PHP Insights (#65)** — `nunomaduro/phpinsights` (Composer dev-dep). Метрики
|
||
complexity / architecture / maintainability. Конфиг `app/phpinsights.php`.
|
||
- **Постура: on-demand/CI** (`composer insights` с порогами `--min-*`), **НЕ** блокирующий
|
||
lefthook (BT9 — избегаем четверного гейта Pint/Larastan/deptrac/Rector). Style-ось
|
||
выключена (владелец стиля — Pint); акцент Complexity + Architecture.
|
||
3. **laravel-backend-patterns (#66)** — self-authored project-скил (`.claude/skills/`).
|
||
Кодификация backend-конвенций Лидерры (слоистость / RLS-aware / bcmath-деньги /
|
||
идемпотентность / partition-aware). Активен.
|
||
4. **NightOwl (#67)** — self-hosted runtime-телеметрия. **DEFERRED** (pending Б-1 / Linux).
|
||
Блокер: native-Windows без `pcntl`/`posix` (агент не запускается); OSS-версия без MCP
|
||
(MCP только managed); hosted = риск 152-ФЗ. Spike + условия активации:
|
||
`docs/backend/nightowl-spike.md`. Прецедент: Sentry #34 / Figma #44 / Jupyter #50.
|
||
|
||
## Boundaries (конфликт-аудит)
|
||
|
||
- **BT1** Rector ↔ Pint: трансформация vs форматирование — разные операции.
|
||
- **BT2** Rector ↔ Larastan: Rector чинит, Larastan находит — комплементарны.
|
||
- **BT3** Rector ↔ deptrac: трансформация кода vs граф слоёв — ортогональны.
|
||
- **BT4** PHP Insights ↔ Pint/Larastan: style/code оси выключены; уникум = complexity + architecture.
|
||
- **BT5** backend-patterns ↔ architecture-patterns #38: project-specific vs generic.
|
||
- **BT6** backend-patterns ↔ billing-audit #62: генерация (как писать) vs аудит (проверка денег) — ссылка.
|
||
- **BT7** NightOwl ↔ Sentry #34: коррелированный трейс vs ошибки/трейсбэки.
|
||
- **BT8** NightOwl ↔ Pail / Boost: сквозной трейс vs tail / снапшот по требованию.
|
||
- **BT9** PHP Insights blocking? — нет (избегаем четверного гейта); on-demand/CI.
|
||
|
||
## Consequences
|
||
|
||
- A1 непуст: 3 → 6 узлов активных (Boost/Pint/Larastan + Rector/PHP Insights/backend-patterns) + 1 DEFERRED (NightOwl).
|
||
- Новая off-phase подкатегория `backend-tooling` (16-я).
|
||
- Rector и PHP Insights **не гейтят коммит** (manual/CI) — осознанно, чтобы не дублировать
|
||
существующие блокирующие гейты (Pint/Larastan/deptrac) и не авто-мутировать код на коммите.
|
||
- Rector оставляет разовый задел чистки (16 файлов) — применяется вручную через `composer rector:fix` с ревью + полным прогоном тестов, не в этом эпике.
|
||
- NightOwl — capability-readiness: задокументирован, активация при появлении Linux/боевого сервера (Б-1).
|