@saulwade/swl-ses 1.9.0 → 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (142) hide show
  1. package/CLAUDE.md +196 -196
  2. package/README.md +579 -579
  3. package/agentes/_propose-step.md +90 -0
  4. package/agentes/accesibilidad-wcag-swl.md +3 -3
  5. package/agentes/auto-evolucion-swl.md +908 -908
  6. package/agentes/disenador-ui-swl.md +6 -5
  7. package/agentes/frontend-angular-swl.md +2 -2
  8. package/agentes/frontend-css-swl.md +2 -2
  9. package/agentes/frontend-react-swl.md +4 -4
  10. package/agentes/frontend-swl.md +6 -6
  11. package/agentes/implementador-swl.md +2 -0
  12. package/agentes/investigador-ux-swl.md +5 -5
  13. package/agentes/orquestador-swl.md +9 -7
  14. package/agentes/perfilador-usuario-swl.md +321 -308
  15. package/agentes/producto-prd-swl.md +1 -1
  16. package/agentes/red-team-swl.md +218 -218
  17. package/agentes/tdd-qa-swl.md +17 -1
  18. package/bin/swl-ses.js +1 -1
  19. package/comandos/swl/actualizar.md +1 -1
  20. package/comandos/swl/aprender.md +2 -2
  21. package/comandos/swl/aprobar-plan.md +153 -0
  22. package/comandos/swl/ayuda.md +3 -3
  23. package/comandos/swl/briefing.md +122 -0
  24. package/comandos/swl/compactar.md +29 -2
  25. package/comandos/swl/discutir-fase.md +23 -2
  26. package/comandos/swl/ejecutar-fase.md +59 -6
  27. package/comandos/swl/evolucionar.md +1 -1
  28. package/comandos/swl/inbox.md +1 -1
  29. package/comandos/swl/instalar.md +1 -1
  30. package/comandos/swl/nemesis.md +1 -1
  31. package/comandos/swl/planear-fase.md +19 -1
  32. package/comandos/swl/plugins.md +1 -1
  33. package/comandos/swl/release.md +47 -1
  34. package/comandos/swl/status.md +348 -0
  35. package/comandos/swl/verificar.md +27 -1
  36. package/habilidades/ai-runtime-security/SKILL.md +1 -1
  37. package/habilidades/auto-evolucion-protocolo/SKILL.md +276 -276
  38. package/habilidades/benchmark-memoria/SKILL.md +1 -1
  39. package/habilidades/calidad-contract-testing/SKILL.md +165 -0
  40. package/habilidades/changelog-generator/SKILL.md +9 -2
  41. package/habilidades/changelog-generator/scripts/parse-commits.js +13 -1
  42. package/habilidades/diagrama-arquitectura/SKILL.md +1 -1
  43. package/habilidades/drift-detection/SKILL.md +179 -179
  44. package/habilidades/ejecutar-fase/SKILL.md +541 -468
  45. package/habilidades/estructura-proyecto-claude/SKILL.md +17 -14
  46. package/habilidades/estructura-proyecto-claude/recursos/configuracion-y-extensiones.md +34 -23
  47. package/habilidades/estructura-proyecto-claude/recursos/frontmatter-y-hooks-referencia.md +70 -53
  48. package/habilidades/estructura-proyecto-claude/recursos/mcp-json-template.json +57 -77
  49. package/habilidades/extractor-de-aprendizajes/SKILL.md +9 -5
  50. package/habilidades/harness-claude-code/SKILL.md +10 -7
  51. package/{reglas/harness-claude-code.md → habilidades/harness-claude-code/recursos/disciplina-harness-regla.md} +2 -2
  52. package/habilidades/instalar-sistema/SKILL.md +3 -3
  53. package/habilidades/meta-skills-estandar/recursos/frameworks-seguridad.md +1 -1
  54. package/habilidades/perfil-usuario/SKILL.md +200 -200
  55. package/habilidades/planear-fase/SKILL.md +26 -4
  56. package/habilidades/proceso-ddia-fundamentos/SKILL.md +1 -1
  57. package/habilidades/proceso-ddia-streaming/SKILL.md +4 -4
  58. package/habilidades/proceso-debate-adversarial/SKILL.md +2 -2
  59. package/habilidades/protocolo-revision-swl/SKILL.md +1 -1
  60. package/habilidades/seguridad-skills-ia/SKILL.md +1 -1
  61. package/habilidades/swl-claudemd/SKILL.md +50 -210
  62. package/habilidades/swl-claudemd/recursos/contrato-aprender.md +83 -0
  63. package/habilidades/swl-claudemd/recursos/duplicacion-reglas-globales.md +85 -0
  64. package/habilidades/swl-claudemd/recursos/plantillas-init.md +94 -0
  65. package/habilidades/swl-dashboard/SKILL.md +9 -9
  66. package/habilidades/swl-revisar-impacto/SKILL.md +1 -1
  67. package/habilidades/tdd-workflow/SKILL.md +715 -673
  68. package/habilidades/validacion-ci-sistema/SKILL.md +20 -4
  69. package/hooks/calidad-pre-commit.js +344 -3
  70. package/hooks/check-update.js +39 -1
  71. package/hooks/ciclo-evolucion-subagente.js +26 -0
  72. package/hooks/ciclo-evolucion.js +26 -0
  73. package/hooks/extraccion-aprendizajes.js +13 -0
  74. package/hooks/lib/autonomia.js +208 -0
  75. package/hooks/lib/briefing.js +474 -0
  76. package/hooks/lib/ciclo-evolucion.js +47 -0
  77. package/hooks/{auto-evolucion.js → lib/etapa-auto-evolucion.js} +701 -700
  78. package/hooks/{metricas-evolucion.js → lib/etapa-metricas.js} +388 -376
  79. package/hooks/{actualizar-perfil-usuario.js → lib/etapa-perfil-usuario.js} +376 -364
  80. package/hooks/lib/evolution-tracker.js +24 -3
  81. package/hooks/lib/propose-step.js +357 -0
  82. package/hooks/session-briefing.js +98 -0
  83. package/hooks/spec-gate.js +211 -0
  84. package/hooks/tdd-gate.js +241 -0
  85. package/hooks/telemetria-skill-routing.js +100 -0
  86. package/hooks/validar-intent-spec.js +30 -10
  87. package/instintos/autonomia.yaml +27 -0
  88. package/llms.txt +6 -6
  89. package/manifiestos/hooks-config.json +44 -17
  90. package/manifiestos/modulos.json +40 -15
  91. package/manifiestos/skills-lock.json +64 -57
  92. package/package.json +93 -93
  93. package/plugin.json +371 -375
  94. package/reglas/accesibilidad.md +10 -0
  95. package/reglas/analizar-directorios-antes-de-escribir.md +228 -0
  96. package/reglas/api-diseno.md +9 -0
  97. package/reglas/auditorias-documentales-estructurales.md +7 -0
  98. package/reglas/cloud-infra.md +8 -0
  99. package/reglas/consultar-vault-primero.md +195 -0
  100. package/reglas/debatir-antes-de-aceptar.md +158 -0
  101. package/reglas/fragmentos-compartidos.md +5 -0
  102. package/reglas/git-coauthor.md +100 -0
  103. package/reglas/gobernanza.md +4 -4
  104. package/reglas/hooks.md +6 -0
  105. package/reglas/intent-engineering.md +4 -0
  106. package/reglas/markitdown.md +8 -0
  107. package/reglas/memoria-consolidada.md +1 -1
  108. package/reglas/monitor-ci.md +309 -0
  109. package/reglas/patrones.md +6 -0
  110. package/reglas/registro-componentes-nuevos.md +39 -2
  111. package/reglas/seguridad-agentes.md +1 -1
  112. package/reglas/sesiones-paralelas.md +180 -0
  113. package/reglas/skills-estandar.md +6 -0
  114. package/reglas/testing.md +7 -0
  115. package/reglas/tests-cleanup.md +4 -0
  116. package/reglas/usar-code-review-graph.md +155 -0
  117. package/reglas/usar-sistema-swl.md +1 -1
  118. package/reglas/verificar-citas-normativas.md +548 -0
  119. package/scripts/instalador.js +52 -6
  120. package/scripts/lib/ci-reader.js +193 -0
  121. package/scripts/lib/detectar-host-swl.js +175 -0
  122. package/scripts/lib/evidencia-release.js +322 -0
  123. package/scripts/lib/gate-hooks-requires.js +249 -0
  124. package/scripts/lib/gate-licencias.js +212 -0
  125. package/scripts/lib/git-metricas.js +257 -0
  126. package/scripts/lib/gitignore-manifest.js +29 -1
  127. package/scripts/lib/metricas-dora.js +204 -0
  128. package/scripts/lib/plan-lock.js +275 -0
  129. package/scripts/migrar-fase-dominio.js +0 -1
  130. package/scripts/tui/ejecutores.js +1 -1
  131. package/scripts/validar-manifest.js +92 -1
  132. package/scripts/verificar-evolucion.js +54 -4
  133. package/scripts/verificar-release.js +102 -0
  134. package/scripts/verificar-trazabilidad.js +298 -0
  135. package/agentes/ux-disenador-swl.md +0 -503
  136. package/comandos/swl/dashboard.md +0 -146
  137. package/comandos/swl/evolucion-estado.md +0 -191
  138. package/comandos/swl/metricas.md +0 -376
  139. package/comandos/swl/salud.md +0 -481
  140. package/reglas/arquitectura.evolved.json +0 -7
  141. package/reglas/seguridad.evolved.json +0 -7
  142. package/reglas/verificar-citas-temporales.md +0 -139
@@ -0,0 +1,348 @@
1
+ ---
2
+ name: swl:status
3
+ description: Comando unificado de observabilidad del sistema y la sesión. Enruta a subcomandos [salud | metricas | loops | evolucion | historico | dashboard] que reportan salud del sistema SWL, métricas de la sesión actual, trayectorias de loops iterativos, estado del ciclo de auto-evolución y dashboard histórico multi-sesión. Reemplaza los comandos previos /swl:salud, /swl:metricas, /swl:dashboard y /swl:evolucion-estado (fusionados en este desde la Fase 09).
4
+ allowed_tools: ["Read", "Write", "Bash", "Glob", "Grep"]
5
+ ---
6
+
7
+ # /swl:status <subcomando> — Observabilidad unificada
8
+
9
+ Punto único de observabilidad de swl-ses. Fusiona los cuatro comandos previos de
10
+ diagnóstico en un router con subcomandos. Cada subcomando delega exactamente en
11
+ la misma lógica (skill o script) que usaba el comando original — sin pérdida de
12
+ funcionalidad ni de flags.
13
+
14
+ ## Uso
15
+
16
+ ```
17
+ /swl:status salud — Diagnóstico de salud del sistema SWL (genera SALUD.md)
18
+ /swl:status metricas — Métricas de la sesión actual (tokens, costo, herramientas)
19
+ /swl:status metricas detalle — Desglose completo por herramienta, agente y timeline
20
+ /swl:status metricas fases — Progreso de fases del proyecto (desde feature-list.json)
21
+ /swl:status loops — Trayectorias de loops iterativos (.planning/loops/)
22
+ /swl:status evolucion — Estado del ciclo de auto-evolución (health_score, nudges…)
23
+ /swl:status evolucion --json — JSON crudo de metricas.json (para pipes)
24
+ /swl:status evolucion --dias=N — Regenera métricas con ventana de N días (default 14)
25
+ /swl:status evolucion --regenerar — Fuerza recomputo del hook ciclo-evolucion.js (etapa métricas)
26
+ /swl:status dora — Métricas DORA del proyecto destino (deploy freq, lead time, CFR, MTTR)
27
+ /swl:status dora --dias=N — Ventana de medición de N días (default 30)
28
+ /swl:status historico — Dashboard histórico multi-sesión (web, auto-puerto)
29
+ /swl:status dashboard — Alias de historico
30
+ /swl:status dashboard --port 9090 — Fuerza puerto específico del dashboard
31
+ /swl:status dashboard today — Resumen de consumo del día (terminal)
32
+ /swl:status dashboard stats — Estadísticas históricas all-time (terminal)
33
+ /swl:status dashboard scan — Sincroniza JSONL → SQLite sin abrir el dashboard
34
+ ```
35
+
36
+ Sin subcomando: pide al usuario cuál quiere, o muestra `salud` + `metricas`
37
+ como vista por defecto si el contexto lo sugiere.
38
+
39
+ ## Tabla de enrutamiento (delegación 1:1)
40
+
41
+ | Subcomando | Delega en | Origen previo |
42
+ |------------|-----------|---------------|
43
+ | `salud` | `Skill("validacion-ci-sistema")` | `/swl:salud` |
44
+ | `metricas` (+ `detalle`, `fases`) | scripts de métricas de sesión + `derivar-feature-list.js` | `/swl:metricas` |
45
+ | `loops` | `hooks/lib/loop-telemetry.js` | `/swl:metricas loops` |
46
+ | `evolucion` | `hooks/ciclo-evolucion.js` (etapa métricas) + `.planning/evolution/metricas.json` | `/swl:evolucion-estado` |
47
+ | `dora` | `scripts/lib/metricas-dora.js` + `.planning/evolution/metricas-dora.json` | nuevo (Fase 15, ADR-0039) |
48
+ | `historico` / `dashboard` | `Skill("swl-dashboard")` | `/swl:dashboard` |
49
+
50
+ ---
51
+
52
+ ## Subcomando: `salud`
53
+
54
+ Diagnóstico de salud del sistema SWL con **verificaciones deterministas**
55
+ (conteos, existencia de campos, sintaxis). Genera `SALUD.md` con score objetivo.
56
+ **Solo lectura** — no modifica nada salvo `SALUD.md`. Para corregir problemas,
57
+ usar `/swl:evolucionar`.
58
+
59
+ **Paso 0 — Detección host vs consumidor (gate determinista, OBLIGATORIO)**:
60
+
61
+ `salud` audita los componentes del sistema SWL con un score ponderado. Ese score
62
+ solo tiene sentido en el repo que **hospeda** los componentes (swl-ses o un fork).
63
+ En un proyecto **consumidor** (usa las convenciones SWL vía `~/.claude/` pero no
64
+ aloja `agentes/`, `habilidades/`, `comandos/swl/`, `reglas/`, `hooks/`), el
65
+ inventario daría 0 y un score `0/100` sería señal falsa. Esta distinción es
66
+ **determinista**, NO juicio del agente:
67
+
68
+ ```bash
69
+ node scripts/lib/detectar-host-swl.js --json
70
+ ```
71
+
72
+ - Si `esHost: true` → continuar con el diagnóstico normal (Carga + pasos siguientes).
73
+ - Si `esHost: false` → **NO** calcular score de componentes ni generar `SALUD.md`
74
+ con `0/100`. Reportar el campo `razon` y la lista `sugerencias` (subcomandos de
75
+ `/swl:status` que sí aplican aquí: `metricas`, `loops`, `evolucion`, `dashboard`).
76
+ Ofrecer ejecutar uno de ellos. Terminar sin penalizar el score.
77
+
78
+ **Carga**: `Skill("validacion-ci-sistema")` — contiene las reglas de validación
79
+ por componente (agentes, skills, hooks, comandos, reglas), la tabla de exit codes
80
+ y el checklist de integridad. Toda la lógica de verificación vive en el skill.
81
+
82
+ **Cuándo usar**: antes de iniciar proyecto nuevo, tras modificar agentes/skills
83
+ manualmente, tras merge/pull, o como mantenimiento mensual.
84
+
85
+ **Score global ponderado**:
86
+ ```
87
+ Score = agentes×0.30 + skills×0.25 + comandos×0.20 + reglas×0.15 + hooks×0.10
88
+ 90-100 Excelente · 75-89 Saludable · 60-74 Funcional · <60 Crítico
89
+ ```
90
+
91
+ **Pasos siempre activos**: inventario determinista, detección de tier del proyecto
92
+ (Simple <500 / Standard 500-5000 / Complex >5000 archivos), diagnóstico de los 5
93
+ componentes, y calidad de `CLAUDE.md` (ADR-0016):
94
+ ```bash
95
+ npx -y @saulwade/swl-ses@latest audit-claudemd --json
96
+ ```
97
+ Umbrales ajustables: `SWL_CLAUDEMD_MAX_LINES` (default 200),
98
+ `SWL_CLAUDEMD_MAX_BULLET_CHARS` (default 1000).
99
+
100
+ **Auditorías opt-in** (cada una se activa con su variable de entorno; si no está
101
+ definida, el paso se omite sin afectar el score — diseño zero-config):
102
+
103
+ | Variable | Qué audita | Comando |
104
+ |----------|-----------|---------|
105
+ | `SWL_AUDIT_SKILLS=1` | Prompt injection, secretos, URLs sospechosas y estructura en SKILL.md | `bash scripts/audit-skills.sh` (requiere `uv`) |
106
+ | `SWL_AUDIT_FRAMEWORKS=1` | Cobertura de NIST CSF/AI RMF, MITRE ATLAS/ATT&CK, D3FEND en skills de seguridad | `npx -y @saulwade/swl-ses@latest audit-coverage-frameworks --resumen` |
107
+ | `SWL_AUDIT_AGENTES=1` | Agentes sin Exclusion Clause o Gotchas (anti agent-hijacking) | `npx -y @saulwade/swl-ses@latest audit-agents-gaps --resumen` |
108
+
109
+ **Verificación de drift de skills** (si existe `manifiestos/skills-lock.json`):
110
+ ```bash
111
+ npx -y @saulwade/swl-ses@latest generate-skills-lock --check
112
+ ```
113
+
114
+ **Smoke test de MCP** (si hay servers en `.claude/settings.json` o configs globales):
115
+ ```bash
116
+ python scripts/mcp-orchestrator.py status --json 2>/dev/null
117
+ ```
118
+ Detecta drift de apiKeys (`40101`), binarios faltantes y `"env": {}` que rompe la
119
+ herencia de variables — antes de que fallen en uso interactivo.
120
+
121
+ Formato de salida enriquecido vía `scripts/lib/health-row.js` (barras Unicode;
122
+ respeta `NO_COLOR` y `SWL_ASCII_SIMPLE=1`). Genera `SALUD.md` con los datos
123
+ exactos de los scripts — sin ajustar el score "porque parece sano".
124
+
125
+ ---
126
+
127
+ ## Subcomando: `metricas`
128
+
129
+ Métricas acumuladas de la **sesión actual**: tokens, costo estimado USD, tool
130
+ calls y distribución por herramienta, más el estado del presupuesto configurado.
131
+
132
+ **Fuentes de datos**:
133
+ ```bash
134
+ # 1. Bridge de tracking de la sesión (generado por el hook de costos)
135
+ ls /tmp/swl-costs-*.json 2>/dev/null | sort -t- -k3 -n | tail -1
136
+ # 2. Métricas persistidas del proyecto
137
+ cat .planning/METRICAS.md 2>/dev/null || echo "(sin métricas previas)"
138
+ # 3. Presupuesto configurado
139
+ node -e "const c=require('./manifiestos/hooks-config.json').costBudget||{}; console.log('maxUsd:',c.maxUsd??'no configurado','| maxTokens:',c.maxTokens??'no configurado','| alertAt:',c.alertAt??'no configurado')"
140
+ ```
141
+
142
+ Construir el resumen con: tool calls totales, tokens, costo estimado, modelo
143
+ predominante, estado de presupuesto (`OK`/`ALERTA`/`EXCEDIDO`) y top 5
144
+ herramientas por costo. Si el estado es ALERTA (≥ `alertAt`), sugerir
145
+ `/swl:compactar`. Si EXCEDIDO, recomendar revisar `manifiestos/hooks-config.json`.
146
+
147
+ ### `metricas detalle`
148
+
149
+ Desglose completo: tabla por herramienta (calls, tokens entrada/salida, costo),
150
+ desglose por agente SWL desde `costePorAgente` del bridge, comparativa histórica
151
+ contra `~/.claude/usage.db` (últimos 30 días) y timeline de actividad por bloques
152
+ de 5 minutos.
153
+
154
+ ### `metricas fases`
155
+
156
+ Progreso de fases del proyecto. Regenera primero el JSON derivado de
157
+ `HOJA-RUTA.md` (fuente de verdad) y lo lee:
158
+ ```bash
159
+ node scripts/derivar-feature-list.js
160
+ cat .planning/feature-list.json
161
+ ```
162
+ Reporta totales por estado canónico (`completado`, `en_progreso`, `pendiente`,
163
+ `bloqueado`, `spec_listo`), lista de fases con marca visual y artefactos
164
+ presentes (`[PLAN]`/`[RESUMEN]`), y timestamp de generación. Detección de drift:
165
+ `node scripts/derivar-feature-list.js --check` (exit 2 si drift).
166
+
167
+ ### Notas de precisión
168
+
169
+ Los costos son estimaciones según precios publicados de la API de Anthropic. El
170
+ real varía por modelo efectivo, caché de prompt y región/plan. Para costos
171
+ exactos, el dashboard de Anthropic Console.
172
+
173
+ ---
174
+
175
+ ## Subcomando: `loops`
176
+
177
+ Trayectorias de loops iterativos registradas por `hooks/lib/loop-telemetry.js`
178
+ en `.planning/loops/`:
179
+ ```bash
180
+ node -e "
181
+ const fs = require('fs'), path = require('path');
182
+ const lt = require('./hooks/lib/loop-telemetry');
183
+ const base = path.join(process.cwd(), lt.DIR_LOOPS);
184
+ let dirs = [];
185
+ try { dirs = fs.readdirSync(base).map(d => path.join(base, d)).filter(d => fs.statSync(d).isDirectory()); } catch {}
186
+ if (dirs.length === 0) { console.log('(sin corridas de loops registradas)'); process.exit(0); }
187
+ for (const dir of dirs.sort().slice(-10)) {
188
+ try {
189
+ const t = lt.analizarTrayectoria(dir);
190
+ const h = lt.leerHandoff(dir);
191
+ console.log(path.basename(dir) + ' | iters: ' + t.totalIteraciones +
192
+ ' | keep/revert: ' + t.keeps + '/' + t.reverts +
193
+ ' | métrica: ' + t.metricaInicial + ' → ' + t.metricaFinal +
194
+ ' | plateau: ' + (t.plateau ? 'SÍ' : 'no') +
195
+ ' | status: ' + (h ? h.status : 'en curso'));
196
+ } catch (e) { console.log(path.basename(dir) + ' | (ilegible: ' + e.message + ')'); }
197
+ }
198
+ "
199
+ ```
200
+ Reportar en tabla: corrida, iteraciones, keep/revert rate, métrica inicial →
201
+ final, plateau y status. Si una corrida activa muestra plateau, sugerir cerrarla
202
+ — iterar sin mejora quema tokens.
203
+
204
+ ---
205
+
206
+ ## Subcomando: `evolucion`
207
+
208
+ Estado del ciclo de auto-evolución en la ventana reciente (default 14 días).
209
+ Responde con datos a "¿el sistema está aprendiendo?".
210
+
211
+ **Flags**: `--json` (emite el JSON crudo de `metricas.json`), `--dias=N`
212
+ (ventana de N días), `--regenerar` (fuerza recomputo del hook).
213
+
214
+ **Paso 0 — métricas frescas** (si `--regenerar` o `metricas.json` > 24h):
215
+ ```bash
216
+ echo '{}' | node hooks/ciclo-evolucion.js
217
+ ```
218
+
219
+ **Paso 1 — cargar**:
220
+ ```bash
221
+ cat .planning/evolution/metricas.json
222
+ ```
223
+ Si no existe, ejecutar el regenerado; si sigue sin existir, reportar que el ciclo
224
+ no ha corrido aún.
225
+
226
+ **Dashboard** (formato humano) con secciones: health_score + badge, NUDGES
227
+ (emitidos/accionados/pendientes por tipo), INSTINTOS (proyecto/global/perfil),
228
+ AGENTES (runs/fallos/tasa), EVOLUCIONES (aplicadas/revertidas/rollback ratio),
229
+ CALIDAD CONDUCTUAL (fallos por tipo, reintentos, latencia), ALERTAS PERSISTENTES
230
+ y KERNEL (gobernanza: política evolvable, último ADR kernel, ratio
231
+ `evolvable=false`/total).
232
+
233
+ **Badges**: ≥90 🏆 Óptimo · ≥75 🥇 Saludable · ≥60 🥈 Parcial · ≥40 🥉 Esqueleto
234
+ · <40 ⚠️ Dormido.
235
+
236
+ **Recomendaciones contextuales** (máx 3, al final): bootstrap de instintos si
237
+ `instintos.proyecto==0` y `aprendizajes>10`; revisar alertas si `tasaAccion<0.3`;
238
+ candidatos a `/swl:evolucionar` si `tasaExito<70`; etc.
239
+
240
+ **Anti-substitution**: el archivo de métricas es **siempre**
241
+ `.planning/evolution/metricas.json` (nunca `.planning/metricas.json` ni variantes);
242
+ el hook que regenera es **siempre** `hooks/ciclo-evolucion.js` (etapa métricas, Fase 11); para forzar
243
+ regen usar el pipe `echo '{}' | node ...`, nunca `require()` directo.
244
+
245
+ **Response discipline**: con `--json`, la respuesta es el contenido crudo del
246
+ archivo, sin prosa.
247
+
248
+ ---
249
+
250
+ ## Subcomando: `dora`
251
+
252
+ Métricas DORA (DevOps Research and Assessment) del **proyecto destino** donde SWL
253
+ está instalado: deployment frequency, lead time for changes, change failure rate
254
+ y MTTR, cada una clasificada en elite/high/medium/low (umbrales DORA Report 2023).
255
+ Mide **velocidad de entrega**, ortogonal a la reliability en runtime de
256
+ `observabilidad-swl`/`sre-swl`. Solo lectura salvo el JSON de storage.
257
+
258
+ **Portabilidad** (D-15-01): deployment frequency + lead time se derivan de git
259
+ (tags de release + commits) y están **siempre** disponibles. Change failure rate
260
+ + MTTR requieren `gh` (GitHub CLI) autenticado; si `gh` falta, no está autenticado,
261
+ o el repo no tiene remoto GitHub, esas dos reportan "no disponible" **sin fallar**.
262
+
263
+ **Paso 0 — calcular/regenerar**:
264
+ ```bash
265
+ node scripts/lib/metricas-dora.js --json [--dias=N]
266
+ ```
267
+ Regenera siempre que se invoque el subcomando (la medición es barata) o cuando se
268
+ pase `--dias=N` (ventana en días, default 30). El script persiste el informe en
269
+ `.planning/evolution/metricas-dora.json` (runtime, gitignored).
270
+
271
+ **Paso 1 — render**: presentar las 4 métricas con su valor y clasificación:
272
+
273
+ ```
274
+ Métricas DORA — ventana de 30 días
275
+
276
+ Deployment frequency: 2.30 deploys/semana [high]
277
+ Lead time (p50): 18.4 h [high]
278
+ Change failure rate: no disponible (gh ausente)
279
+ MTTR: no disponible (gh ausente)
280
+ ```
281
+
282
+ Reglas de render:
283
+ - Si una métrica git reporta `sinDatos: true` (proyecto sin tags de release),
284
+ mostrar "sin datos" — distinto de "frecuencia baja". El informe NO penaliza:
285
+ un proyecto sin releases no es "low", es "sin datos".
286
+ - Si `changeFailureRate`/`mttr` traen `disponible: false`, mostrar
287
+ "no disponible (gh ausente)" con la `razon` si ayuda — nunca como error.
288
+ - Tras el render, si CFR/MTTR no están disponibles, sugerir (1 línea) instalar y
289
+ autenticar `gh` para habilitarlas; no es obligatorio.
290
+
291
+ **Anti-substitution**: el archivo de storage es **siempre**
292
+ `.planning/evolution/metricas-dora.json` (nunca `metricas.json`, que es del ciclo
293
+ de evolución); el script es **siempre** `scripts/lib/metricas-dora.js`.
294
+
295
+ ---
296
+
297
+ ## Subcomando: `historico` / `dashboard`
298
+
299
+ Dashboard histórico multi-sesión vía `claude-usage` (vendored). Complementa
300
+ `metricas` (sesión actual) con perspectiva multi-sesión y gráficos interactivos.
301
+
302
+ **Carga**: `Skill("swl-dashboard")` con el subcomando indicado:
303
+ - (vacío) o `historico` → dashboard web (auto-detecta puerto: 8888, 9090, 9191…)
304
+ - `--port N` → fuerza un puerto
305
+ - `today` → resumen del día en terminal
306
+ - `stats` → estadísticas históricas all-time en terminal
307
+ - `scan` → solo sincroniza JSONL → SQLite sin abrir el dashboard
308
+
309
+ ### Integración con Mission Control (opt-in)
310
+
311
+ Dashboard web externo para orquestación de flotas de agentes. **Completamente
312
+ opcional** — el dashboard local funciona igual sin configurarlo.
313
+
314
+ | Variable | Descripción | Ejemplo |
315
+ |----------|-------------|---------|
316
+ | `SWL_MC_URL` | URL base de la instancia de MC | `http://localhost:3000` |
317
+ | `SWL_MC_TOKEN` | API key de MC (si hay auth) | `mc-key-abc123` |
318
+
319
+ - Con `SWL_MC_URL` definida: el comando detecta MC (vía `scripts/lib/mc-client.js`)
320
+ y ofrece redirigir al panel web. Si MC no responde en 2s, fallback graceful al
321
+ dashboard local con mensaje informativo (sin crash ni degradación silenciosa).
322
+ - Sin `SWL_MC_URL`: dashboard local sin cambios (zero-config).
323
+
324
+ Instalar MC (opcional): `git clone https://github.com/builderzlabs/mission-control`
325
+ → `docker compose up` (requiere Node ≥22, pnpm; genera su API key al primer
326
+ arranque). MC expone además un **servidor MCP con ~49 tools** (agentes, memoria,
327
+ soul, tareas, sesiones, tokens/costos, skills, cron, runs/evals). swl-ses **NO**
328
+ modifica `.claude/settings.json` automáticamente — el registro del MCP es manual.
329
+
330
+ **Seguridad**: el MCP de MC incluye tools de **escritura** (`mc_create_task`,
331
+ `mc_write_memory`, `mc_write_soul`…). Antes de activarlo, evaluar exposición de
332
+ red, permisos mínimos de la API key y confianza en los agentes que lo invocarán.
333
+ La regla `seguridad-agentes.md` recomienda documentarlo en
334
+ `.planning/MCP_REGISTRY.md`.
335
+
336
+ ---
337
+
338
+ ## Reglas de comportamiento
339
+
340
+ - `salud` y `evolucion` son **solo lectura** (salvo que `salud` genera `SALUD.md`).
341
+ Para corregir, usar `/swl:evolucionar`.
342
+ - Las verificaciones de `salud` son scripts deterministas — no usar juicio
343
+ subjetivo ni ajustar scores "porque parece sano".
344
+ - Los reportes opt-in de auditoría (`SWL_AUDIT_SKILLS`, `SWL_AUDIT_FRAMEWORKS`,
345
+ `SWL_AUDIT_AGENTES`) nunca bloquean el diagnóstico: si fallan (red,
346
+ dependencia, paquete no publicado), el flujo continúa.
347
+ - Respetar `--json` como salida cruda sin prosa donde aplique (`evolucion`).
348
+ - No reintroducir los comandos eliminados: este comando los reemplaza.
@@ -409,7 +409,7 @@ Además del estado estructurado de 4.6.5, cada corrida del loop registra su
409
409
  trayectoria en el formato estándar de telemetría de loops
410
410
  (`hooks/lib/loop-telemetry.js`), que habilita: inyección de estado por el hook
411
411
  `contexto-iteracion.js` (anti-context-rot en sesiones largas), detección de
412
- plateau, y lectura por `/swl:metricas`.
412
+ plateau, y lectura por `/swl:status metricas`.
413
413
 
414
414
  Al iniciar el loop (antes de la pasada 1):
415
415
 
@@ -494,6 +494,32 @@ Sin `--until-converge`, el comportamiento del comando es idéntico al actual: un
494
494
 
495
495
  ## Paso 5 — Verificación de criterios de aceptación
496
496
 
497
+ ### 5.0 — Trazabilidad REQ→T→commit→test (si el CONTEXTO tiene REQ-IDs)
498
+
499
+ Si la sección de criterios del CONTEXTO usa IDs `REQ-NN:` (fases 10-11) o
500
+ `REQ-<fase>-NN:` (namespaceados, fases ≥12), ejecuta el validador de cadena
501
+ ANTES de la verificación criterio por criterio:
502
+
503
+ ```bash
504
+ node scripts/verificar-trazabilidad.js --fase=N
505
+ ```
506
+
507
+ - Exit 0 → cadena completa; adjunta la tabla REQ→tareas/commits/tests al VERIFICACION.md.
508
+ - Exit 1 → **cada REQ huérfano es hallazgo CRÍTICO** (requisito sin implementar,
509
+ sin commit trazable o sin test que lo verifique). Listarlos en el VERIFICACION.md
510
+ con la dirección del gap (sin tarea / sin commit / sin test).
511
+ - Exit 2 → error de invocación; reportar sin bloquear el resto de la verificación.
512
+
513
+ En CONTEXTOs legacy sin REQ-IDs el script sale 0 con nota — continuar normal.
514
+
515
+ ### 5.0b — Contract testing (si la fase declaró schemas en el PLAN)
516
+
517
+ Si el PLAN declara schemas (Pydantic/Zod/JSON Schema/OpenAPI) o la fase expone
518
+ una API consumida por otro componente, cargar `Skill("calidad-contract-testing")`
519
+ y verificar que la implementación honra el contrato (schema-based con
520
+ schemathesis/Dredd contra la API real, o validación de forma con el modelo en
521
+ el test de integración). Cada violación de contrato = hallazgo CRÍTICO.
522
+
497
523
  Lee los criterios de aceptación del `.planning/fases/0N-CONTEXTO.md` y verifica cada uno:
498
524
 
499
525
  Para cada criterio:
@@ -141,7 +141,7 @@ Checklist para cualquier aplicación LLM en producción:
141
141
  | Tiempo | Estático (pre-incorporación) | Dinámico (runtime) |
142
142
  | Objetivo | Artefactos (SKILL.md, scripts) | Sesiones del agente en producción |
143
143
  | Amenazas cubiertas | Supply chain, credenciales hardcodeadas, autonomy abuse declarada | Prompt injection directo/indirecto, context poisoning, tool abuse en runtime |
144
- | Cuándo ejecuta | `/swl:crear-skill`, `/swl:plugins install`, `/swl:salud` | Durante cada request del agente en producción |
144
+ | Cuándo ejecuta | `/swl:crear-skill`, `/swl:plugins install`, `/swl:status salud` | Durante cada request del agente en producción |
145
145
  | Herramientas recomendadas | Grep, SAST sobre SKILL.md | Regex + heurístico + clasificador + guardrails |
146
146
 
147
147
  Ambos skills son necesarios. Ninguno reemplaza al otro.