@saulwade/swl-ses 1.6.0 → 1.6.3

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 (82) hide show
  1. package/CLAUDE.md +32 -61
  2. package/README.md +4 -4
  3. package/agentes/_intent-spec.md +73 -0
  4. package/agentes/auto-evolucion-swl.md +24 -0
  5. package/agentes/cloud-infra-swl.md +25 -0
  6. package/agentes/datos-swl.md +24 -1
  7. package/agentes/devops-ci-swl.md +24 -0
  8. package/agentes/frontend-angular-swl.md +7 -7
  9. package/agentes/frontend-css-swl.md +4 -4
  10. package/agentes/frontend-react-swl.md +7 -7
  11. package/agentes/frontend-swl.md +9 -9
  12. package/agentes/frontend-tailwind-swl.md +4 -4
  13. package/agentes/migrador-swl.md +22 -0
  14. package/agentes/pagos-swl.md +25 -0
  15. package/agentes/release-manager-swl.md +24 -0
  16. package/agentes/rendimiento-swl.md +2 -2
  17. package/agentes/sre-swl.md +24 -0
  18. package/comandos/swl/brainstorm.md +1 -0
  19. package/comandos/swl/compactar.md +1 -1
  20. package/comandos/swl/discutir-fase.md +15 -1
  21. package/comandos/swl/mapear-codebase.md +1 -1
  22. package/comandos/swl/nemesis.md +29 -0
  23. package/comandos/swl/planear-fase.md +18 -2
  24. package/comandos/swl/verificar.md +4 -4
  25. package/habilidades/aprender-de-git-diff/SKILL.md +288 -0
  26. package/habilidades/aprendizaje-continuo/SKILL.md +7 -1
  27. package/habilidades/diseno-herramientas-agente/SKILL.md +17 -0
  28. package/habilidades/doc-sync/SKILL.md +441 -1
  29. package/habilidades/doubt-driven-review/SKILL.md +177 -171
  30. package/habilidades/feynman-auditor-swl/SKILL.md +129 -123
  31. package/habilidades/infra-github-actions/SKILL.md +172 -166
  32. package/habilidades/meta-skills-estandar/SKILL.md +6 -0
  33. package/habilidades/meta-skills-estandar/recursos/skill-judge-rubrica.md +281 -0
  34. package/habilidades/meta-skills-estandar/recursos/skills-as-agents.md +163 -163
  35. package/habilidades/nemesis-evaluacion-json/SKILL.md +5 -0
  36. package/habilidades/nemesis-redistribuir/SKILL.md +5 -0
  37. package/habilidades/node-experto/SKILL.md +197 -3
  38. package/habilidades/prevencion-racionalizacion/SKILL.md +1 -0
  39. package/habilidades/privacy-memoria/SKILL.md +1 -0
  40. package/habilidades/proceso-autoverificacion-evidencias/SKILL.md +258 -0
  41. package/habilidades/proceso-confianza-pre-implementacion/SKILL.md +246 -0
  42. package/habilidades/proceso-ddia-fundamentos/SKILL.md +255 -0
  43. package/habilidades/proceso-ddia-streaming/SKILL.md +231 -0
  44. package/habilidades/proceso-intent-engineering/SKILL.md +269 -0
  45. package/habilidades/reducir-entropia/SKILL.md +219 -0
  46. package/habilidades/sre-patrones/SKILL.md +1 -1
  47. package/habilidades/state-inconsistency-auditor-swl/SKILL.md +172 -166
  48. package/habilidades/tdd-workflow/SKILL.md +178 -3
  49. package/habilidades/verificacion-evidencia/SKILL.md +1 -0
  50. package/habilidades/web-fetcher-routing/SKILL.md +81 -75
  51. package/habilidades/workflow-claude-code/SKILL.md +2 -2
  52. package/hooks/lib/task-budget.js +218 -0
  53. package/hooks/validar-intent-spec.js +222 -0
  54. package/manifiestos/hooks-config.json +9 -0
  55. package/manifiestos/modulos.json +12 -2
  56. package/manifiestos/skills-lock.json +1191 -1142
  57. package/package.json +5 -3
  58. package/plugin.json +9 -2
  59. package/reglas/auditorias-documentales-estructurales.md +205 -0
  60. package/reglas/fragmentos-compartidos.md +26 -0
  61. package/reglas/intent-engineering.md +214 -0
  62. package/reglas/registro-componentes-nuevos.md +38 -0
  63. package/schemas/agent-frontmatter.schema.json +294 -167
  64. package/schemas/agent-message.schema.json +73 -53
  65. package/schemas/agent-output-implementacion.schema.json +114 -85
  66. package/schemas/agent-output-planificacion.schema.json +150 -113
  67. package/schemas/agent-output-review.schema.json +98 -78
  68. package/schemas/diary-entry.schema.json +42 -10
  69. package/schemas/hook-profiles.schema.json +54 -39
  70. package/schemas/hooks-config.schema.json +89 -74
  71. package/schemas/instinct.schema.json +152 -115
  72. package/schemas/modulos.schema.json +38 -29
  73. package/schemas/perfiles.schema.json +36 -28
  74. package/schemas/plugin.schema.json +77 -64
  75. package/schemas/skill-evals.schema.json +119 -95
  76. package/schemas/skill-frontmatter.schema.json +245 -170
  77. package/scripts/generar-inventario.js +452 -420
  78. package/scripts/lib/schema-version.js +164 -0
  79. package/scripts/validar-manifest.js +1 -1
  80. package/scripts/validar.js +3 -2
  81. package/scripts/verificar-docs-vs-codigo.js +654 -425
  82. package/scripts/verificar-evolucion.js +19 -3
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@saulwade/swl-ses",
3
- "version": "1.6.0",
4
- "description": "Sistema de ingenieria de software auto-evolutivo multi-runtime polyglot con 60 agentes, 162 habilidades, 44 comandos, 66 reglas y 41 hooks. Soporta 11 lenguajes y 7 runtimes: Claude Code, OpenClaude, OpenCode, Gemini CLI, Cursor, Codex CLI (soporte completo); GitHub Copilot (soporte parcial). 100% en espanol (Mexico). Multi-target install (--target CSV / --all-runtimes), autoconfig MCP en Cursor/Codex con --with-mcp, agentes Codex en TOML, hooks Cursor (17 eventos) y Codex (6 eventos). Gateway bidireccional con relay Telegram y auditoria profunda Nemesis con loop evaluator-optimizer opt-in (ADR-0021) y 8 tools ejecutables.",
3
+ "version": "1.6.3",
4
+ "description": "Sistema de ingenieria de software auto-evolutivo multi-runtime polyglot con 60 agentes, 162 habilidades, 44 comandos, 67 reglas y 41 hooks. Soporta 11 lenguajes y 7 runtimes: Claude Code, OpenClaude, OpenCode, Gemini CLI, Cursor, Codex CLI (soporte completo); GitHub Copilot (soporte parcial). 100% en espanol (Mexico). Multi-target install (--target CSV / --all-runtimes), autoconfig MCP en Cursor/Codex con --with-mcp, agentes Codex en TOML, hooks Cursor (17 eventos) y Codex (6 eventos). Gateway bidireccional con relay Telegram y auditoria profunda Nemesis con loop evaluator-optimizer opt-in (ADR-0021) y 8 tools ejecutables. v1.6.2 integra 4 skills nuevos desde analisis de temp/ (proceso-confianza-pre-implementacion, proceso-autoverificacion-evidencias, aprender-de-git-diff, reducir-entropia) + helper task-budget.js — ADR-0025.",
5
5
  "bin": {
6
6
  "swl-ses": "bin/swl-ses.js",
7
7
  "swl-telegram-bot": "bin/swl-telegram-bot.js",
@@ -34,7 +34,7 @@
34
34
  "test:docs": "node scripts/verificar-docs-vs-codigo.js",
35
35
  "test:smoke": "node scripts/smoke-test.js",
36
36
  "test:aislamiento": "node scripts/validar-tests-aislamiento.js",
37
- "test:all": "npm test && node scripts/validar.js && node scripts/validar-manifest.js && node scripts/verificar-docs-vs-codigo.js",
37
+ "test:all": "npm test && node scripts/validar.js && node scripts/validar-manifest.js && node scripts/verificar-docs-vs-codigo.js && node scripts/derivar-feature-list.js --check",
38
38
  "test:userland": "node scripts/validar-userland-vacio.js",
39
39
  "test:release": "npm run test:all && npm run test:userland && npm run test:smoke",
40
40
  "doctor": "node scripts/doctor.js",
@@ -47,6 +47,8 @@
47
47
  "generate:docs": "node scripts/generar-inventario.js",
48
48
  "gen-checklists": "node scripts/generar-checklists-consolidados.js",
49
49
  "gen-checklists:check": "node scripts/generar-checklists-consolidados.js --check",
50
+ "gen:feature-list": "node scripts/derivar-feature-list.js",
51
+ "gen:feature-list:check": "node scripts/derivar-feature-list.js --check",
50
52
  "field-report": "node scripts/field-report.js",
51
53
  "configure:branch-protection": "node scripts/configurar-branch-protection.js"
52
54
  },
package/plugin.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "swl-ses",
3
- "version": "1.6.0",
4
- "description": "Sistema de ingenieria de software auto-evolutivo multi-runtime polyglot. 60 agentes, 162 habilidades, 44 comandos, 66 reglas y 41 hooks. 62 librerias. 11 lenguajes. Soporta Claude Code, Copilot, OpenCode, Codex y Gemini CLI. Loop evaluator-optimizer en /swl:nemesis (ADR-0021).",
3
+ "version": "1.6.3",
4
+ "description": "Sistema de ingenieria de software auto-evolutivo multi-runtime polyglot. 60 agentes, 169 habilidades, 44 comandos, 68 reglas y 42 hooks. 62 librerias. 11 lenguajes. Soporta Claude Code, Copilot, OpenCode, Codex y Gemini CLI. Loop evaluator-optimizer en /swl:nemesis (ADR-0021). v1.6.2 integra 4 skills nuevos desde analisis de temp/ (PM Agent + lesson-learned + reducing-entropy) y helper task-budget.js — ADR-0025.",
5
5
  "author": "Saul Wade Leon",
6
6
  "license": "MIT",
7
7
  "repository": "https://github.com/saul-wade/swl-ses",
@@ -13,6 +13,7 @@
13
13
  "habilidades/angular-avanzado",
14
14
  "habilidades/angular-moderno",
15
15
  "habilidades/api-rest-diseno",
16
+ "habilidades/aprender-de-git-diff",
16
17
  "habilidades/aprendizaje-continuo",
17
18
  "habilidades/async-python",
18
19
  "habilidades/auth-patrones",
@@ -127,6 +128,11 @@
127
128
  "habilidades/prevencion-racionalizacion",
128
129
  "habilidades/prevencion-sobreingenieria",
129
130
  "habilidades/privacy-memoria",
131
+ "habilidades/proceso-autoverificacion-evidencias",
132
+ "habilidades/proceso-confianza-pre-implementacion",
133
+ "habilidades/proceso-ddia-fundamentos",
134
+ "habilidades/proceso-ddia-streaming",
135
+ "habilidades/proceso-intent-engineering",
130
136
  "habilidades/prompt-engineering",
131
137
  "habilidades/protocolo-revision-swl",
132
138
  "habilidades/rag-arquitectura",
@@ -134,6 +140,7 @@
134
140
  "habilidades/react-experto",
135
141
  "habilidades/react-optimizacion",
136
142
  "habilidades/redis-experto",
143
+ "habilidades/reducir-entropia",
137
144
  "habilidades/release-semver",
138
145
  "habilidades/rust-experto",
139
146
  "habilidades/rust-patrones",
@@ -0,0 +1,205 @@
1
+ # Regla: Auditorías documentales estructurales en SWL
2
+
3
+ Esta regla es **OBLIGATORIA** y aplica a todo agente o agente humano que
4
+ ejecute, reporte o consuma resultados de:
5
+
6
+ - `node scripts/verificar-docs-vs-codigo.js` (verificador docs↔código)
7
+ - `node scripts/verificar-release.js` (gate pre-publish)
8
+ - `npm run test:manifest` (coherencia modulos/hooks)
9
+ - `/swl:claudemd audit` (auditoría de CLAUDE.md)
10
+ - Cualquier comando o script que reporte un veredicto agregado tipo
11
+ "N/N checks OK" como prueba de calidad documental.
12
+
13
+ Es la **versión específica al sistema SWL** de la regla global
14
+ `~/.claude/rules/arreglar-al-detectar.md § Aplicación a auditorías`.
15
+
16
+ ---
17
+
18
+ ## Principio
19
+
20
+ > Una auditoría documental no se declara "limpia" hasta que se ha medido
21
+ > **profundidad**, no solo **presencia**. El verificador automático puede
22
+ > dar verde con docs vacías o infra-documentadas si su métrica es laxa.
23
+ > El agente que reporta resultados al usuario es responsable de distinguir
24
+ > entre **gate formal pasado** y **dominio realmente sano**.
25
+
26
+ ---
27
+
28
+ ## Por qué existe esta regla
29
+
30
+ Sesión 2026-05-16, post-release v1.6.0: el agente ejecutó dos auditorías
31
+ documentales consecutivas (Opción C release v1.6.0 + auditoría tras
32
+ `/swl:exportar-vault`) y reportó "verde" en ambas. El usuario detectó que:
33
+
34
+ - `agent-browser` estaba en el sistema desde ADR-0018 (skill + manifest +
35
+ integración con `investigador-swl` y `web-fetcher-routing`) pero **ausente
36
+ en `MANUAL_USO.md`**.
37
+ - `ADR-0022` (TUI custom zero-deps, propio del release v1.6.0) **no estaba
38
+ referenciado** en `MANUAL_USO.md`.
39
+ - 22 de 58 variables `SWL_*` que existen en `hooks/` y `scripts/` **no
40
+ estaban documentadas** ni en `docs/variables-entorno.md` ni en
41
+ `MANUAL_USO.md`.
42
+ - El verificador `scripts/verificar-docs-vs-codigo.js` reportaba "9 checks
43
+ OK" porque sus checks de comandos contaban menciones (presencia), no
44
+ profundidad. WARN consolidado de comandos infra-documentados se reportaba
45
+ como "OK".
46
+
47
+ Las dos auditorías fueron **cosméticas**, no estructurales. El gate verde
48
+ ocultaba 22 variables huérfanas y 19 ADRs no referenciados.
49
+
50
+ ---
51
+
52
+ ## Gates de profundidad obligatorios
53
+
54
+ ### Para comandos `/swl:*`
55
+
56
+ Un comando se considera **infra-documentado** si en `MANUAL_USO.md`:
57
+
58
+ - Tiene **menos de 4 menciones** Y
59
+ - Es un comando "no trivial" (excluir `ayuda`, `salud`, `modelo`,
60
+ `contexto`, `dashboard` que son operacionales simples).
61
+
62
+ Un comando infra-documentado debe tener al menos:
63
+
64
+ 1. Una sección dedicada con encabezado `### \`/swl:<nombre>\``.
65
+ 2. Subsección "**Uso**" con el patrón completo de flags.
66
+ 3. Subsección "**¿Qué hace?**" con descripción funcional.
67
+ 4. Subsección "**Cuándo usarlo**" con casos de uso.
68
+ 5. Al menos un **ejemplo concreto** de invocación con output esperado.
69
+ 6. Subsección "**Gotchas**" o "**Troubleshooting**" si el comando tiene
70
+ dependencias externas (MCP, herramientas opt-in, paths críticos).
71
+
72
+ ### Para variables de entorno `SWL_*`
73
+
74
+ Cobertura **completa, no muestral**:
75
+
76
+ - Toda variable `SWL_*` que aparezca en `hooks/` o `scripts/` DEBE estar
77
+ documentada en `docs/variables-entorno.md` con: nombre, default, qué
78
+ activa, archivo que la consume.
79
+ - La verificación es objetiva: `grep -rohE 'SWL_[A-Z_]+' hooks/ scripts/ |
80
+ sort -u` debe ser un **subconjunto** del set de variables documentadas.
81
+ - **Sin excepciones**: variables internas de debug también se documentan
82
+ (ej. `SWL_DEBUG`, `SWL_SESSION_ID`).
83
+
84
+ ### Para ADRs
85
+
86
+ - Todo ADR nuevo `.planning/adrs/NNNN-*.md` que cambia comportamiento
87
+ observable del sistema debe ser **referenciado** en al menos:
88
+ - `MANUAL_USO.md` en la sección del feature que materializa, Y
89
+ - `CHANGELOG.md` en la versión que lo introduce.
90
+ - ADRs de proceso interno (deprecaciones, splits internos, refactors
91
+ ocultos) pueden documentarse solo en `.planning/adrs/README.md`.
92
+ - El criterio de "cambia comportamiento observable" se evalúa: ¿un usuario
93
+ del sistema percibirá la diferencia? Si sí, debe ir a `MANUAL_USO.md`.
94
+
95
+ ### Para integraciones opt-in (dependencias externas)
96
+
97
+ Toda dependencia externa opt-in (markitdown, code-review-graph,
98
+ agent-browser, @dbml/core, likec4, etc.) debe documentarse en
99
+ `MANUAL_USO.md § Dependencias externas` con la **estructura mínima**:
100
+
101
+ 1. Marcador obligatorio "**NO es dependencia técnica de swl-ses**"
102
+ (regla CLAUDE.md sobre dependencias educativas opt-in).
103
+ 2. **Qué es** y **por qué existe la integración** (no solo
104
+ instalación — eso es lo cosmético).
105
+ 3. **Beneficio cuantificado** vs alternativas (tokens, espacio,
106
+ tiempo, etc. — números, no adjetivos).
107
+ 4. **Cuándo vale la pena** vs **cuándo NO instalarlo**.
108
+ 5. **Cómo lo usa el sistema** internamente (qué agente, qué skill,
109
+ qué comando lo invoca).
110
+ 6. **Comportamiento si NO está instalado** (debe degradar
111
+ funcionalmente sin fallar — regla `arreglar-al-detectar`).
112
+ 7. **Limitaciones conocidas**.
113
+ 8. **Origen** (ADR, sesión, paper, repo).
114
+
115
+ ---
116
+
117
+ ## Procedimiento al ejecutar una auditoría documental
118
+
119
+ ### Antes de reportar "verde"
120
+
121
+ 1. **Listar qué mide cada check del verificador** y nombrar
122
+ explícitamente qué **NO** mide.
123
+ 2. **Hacer sondeo manual estructural** sobre 2-3 ítems aleatorios del
124
+ dominio auditado:
125
+ - Para comandos: tomar 2-3 al azar, contar menciones en MANUAL_USO,
126
+ verificar que tengan las 6 subsecciones obligatorias.
127
+ - Para variables: comparar lista de código (`grep -rohE`) contra
128
+ lista de docs.
129
+ - Para ADRs: cruzar `ls .planning/adrs/*.md` contra
130
+ `grep -oE "ADR-[0-9]+" MANUAL_USO.md`.
131
+ 3. **Reportar al usuario el desglose** entre:
132
+ - Gate formal pasado: "N/N checks OK" (cita textual del verificador).
133
+ - Drift estructural detectado en sondeo: "X gaps reales encontrados
134
+ fuera del scope del verificador".
135
+
136
+ ### Patrón de reporte correcto
137
+
138
+ ```
139
+ Verificador docs-vs-código: 9/9 OK formal.
140
+ Sondeo estructural manual:
141
+ - Comandos infra-documentados (<4 menciones): 3 detectados
142
+ → /swl:exportar-vault, /swl:nemesis (en COMANDOS.md), /swl:wiki
143
+ - Variables SWL_* huérfanas: 22 de 58
144
+ - ADRs nuevos no referenciados en MANUAL_USO: 19 de 22
145
+
146
+ Conclusión: gate formal pasado, drift estructural REAL detectado.
147
+ Recomendación: cerrar gaps antes de declarar docs sanas.
148
+ ```
149
+
150
+ ### Patrón de reporte INCORRECTO (a evitar)
151
+
152
+ ```
153
+ Verificador docs-vs-código: 9/9 OK.
154
+ Docs alineadas con código. ✓
155
+ ```
156
+
157
+ Esta segunda forma es la que el usuario detectó y corrigió en
158
+ sesión 2026-05-16. **No reincidir**.
159
+
160
+ ---
161
+
162
+ ## Anti-patrones específicos del sistema SWL
163
+
164
+ - **Aceptar "WARN no falla el verificador"**: el check #2 actual
165
+ reporta WARN sin bloquear cuando comandos no están documentados.
166
+ Eso es deuda preexistente legítima, pero **NUNCA** se reporta como
167
+ "OK" al usuario sin enumerar los WARN.
168
+ - **Confiar en el conteo agregado** (`44 comandos /swl:* documentados`)
169
+ sin verificar la profundidad de cada uno.
170
+ - **No cruzar el universo real**: el verificador chequea `comandos/swl/*.md`
171
+ contra `MANUAL_USO.md`. Pero NO chequea `MANUAL_USO.md` contra ADRs
172
+ ni contra variables del código. Esos universos quedan invisibles.
173
+ - **Whitelist hardcodeada en check #3**: solo 7 flags críticas. El
174
+ parser BOOLEANAS tiene más. Las flags no listadas en la whitelist
175
+ son drift invisible.
176
+ - **Reportar "✓ skip" como "✓ pass"**: si el TUI no está instalado
177
+ (pre-v1.6.0), el check #5 reporta éxito. Eso es correcto técnicamente
178
+ pero el agente NO debe sumarlo al conteo "N/N OK" sin matizar.
179
+
180
+ ---
181
+
182
+ ## Relación con otras reglas
183
+
184
+ - `~/.claude/rules/arreglar-al-detectar.md § Aplicación a auditorías` —
185
+ principio general; esta regla lo concreta para SWL.
186
+ - `~/.claude/rules/registro-componentes-nuevos.md` — define el registro
187
+ obligatorio de componentes en manifiestos. Esta regla extiende:
188
+ no basta con registrar, hay que documentarlo con profundidad.
189
+ - `~/.claude/rules/verificar-citas-normativas.md § Familia 2` —
190
+ verificar afirmaciones factuales del verificador antes de aceptar
191
+ el "verde" como hecho.
192
+ - `habilidades/doc-sync/SKILL.md` — implementación operativa del
193
+ verificador. Esta regla define qué debe medir.
194
+
195
+ ---
196
+
197
+ ## Origen de esta regla
198
+
199
+ Sesión 2026-05-16, post-release v1.6.0. Documentado en
200
+ `.planning/adrs/0023-auditorias-documentales-estructurales.md`.
201
+ Promovida tras feedback explícito del usuario:
202
+ *"en esta misma sesión se pidieron dos auditorías que has minimizado o
203
+ ignorado"*. Cierra el gap conceptual donde el agente aplicaba
204
+ `arreglar-al-detectar.md` a bugs durante implementación pero NO a
205
+ verificadores de docs que devuelven verde cosmético.
@@ -150,3 +150,29 @@ Para extraer un bloque duplicado a fragmento:
150
150
  - [ ] No es contenido invocable dinámicamente (eso es skill)
151
151
  - [ ] Cada agente que lo usa lo declara en `fragmentos: [...]`
152
152
  - [ ] `scripts/validar-manifest.js` no reporta errores
153
+
154
+ ## Implicaciones en scripts de auditoría/conteo de agentes
155
+
156
+ Cualquier script o hook que recorre `agentes/*.md` para contar o validar
157
+ agentes DEBE excluir fragmentos explícitamente con
158
+ `filter(f => f.endsWith('.md') && !f.startsWith('_'))`. Si no lo hace,
159
+ incluye fragmentos en el conteo y reporta cifras incorrectas o falla en la
160
+ validación de frontmatter (los fragmentos NO tienen frontmatter de agente).
161
+
162
+ Scripts y hooks SWL que aplican esta exclusión y deben mantenerla:
163
+
164
+ - `scripts/validar.js` — verifica frontmatter de agentes.
165
+ - `scripts/validar-manifest.js` — cruza `agentes/*.md` vs `modulos.json`.
166
+ - `scripts/generar-inventario.js` — cuenta agentes para INVENTARIO/SALUD.
167
+ - `hooks/validar-intent-spec.js` — regex `/\/agentes\/[^_][^/]*\.md$/`
168
+ con clase negada para fragmentos.
169
+ - Cualquier script futuro de auditoría de agentes.
170
+
171
+ **Caso de regresión histórico**: tras crear `agentes/_intent-spec.md`
172
+ (fragmento) en sesión 2026-05-18, `scripts/generar-inventario.js` contó
173
+ 61 agentes cuando real eran 60 (gate `verificar-release.js` lo detectó).
174
+ Fix: agregar el filtro al `readdirSync` del script.
175
+
176
+ **Consideración futura**: centralizar la lógica en
177
+ `scripts/lib/listar-agentes.js` con la exclusión por defecto evitaría que
178
+ el filtro se omita en scripts nuevos.
@@ -0,0 +1,214 @@
1
+ # Regla: Intent Engineering para agentes ALTO riesgo
2
+
3
+ Esta regla es **OBLIGATORIA** y aplica al crear, modificar o promover agentes
4
+ del sistema SWL cuyo `nivelRiesgo` sea `ALTO`. Implementa el framework
5
+ "Intent Engineering" de 8 partes de Pawel Huryn (*Lead Agents Like Humans*,
6
+ Product Compass, 2026-05).
7
+
8
+ ---
9
+
10
+ ## Principio
11
+
12
+ > Un agente con autonomía elevada que opera sin intent specification explícito
13
+ > falla silenciosamente por instrucciones ambiguas, deriva de scope o pérdida
14
+ > de health metrics. Los agentes ALTO riesgo del sistema SWL DEBEN declarar
15
+ > las 8 partes del framework de forma verificable (frontmatter + fragmento),
16
+ > no implícita.
17
+
18
+ Huryn lo resume:
19
+
20
+ > "Agents don't fail because the model is weak. They fail because intent is
21
+ > incomplete. Objectives are vague. Outcomes are implicit. Trade-offs are
22
+ > unstated. Constraints are treated as suggestions. Autonomy is granted
23
+ > without understanding risk." (Lead Agents Like Humans, línea 56)
24
+
25
+ SWL adopta el framework parcialmente: las partes 5 (Org Context) y 3
26
+ (Desired Outcomes) viven en `CLAUDE.md` y `PLAN.md` respectivamente, no en
27
+ cada agente. Las otras 6 son responsabilidad del autor del agente.
28
+
29
+ ---
30
+
31
+ ## Cuándo aplicar
32
+
33
+ OBLIGATORIO al:
34
+
35
+ - Crear un agente nuevo `nivelRiesgo: ALTO`.
36
+ - Modificar el frontmatter de un agente `nivelRiesgo: ALTO` existente.
37
+ - Promover un agente de `MEDIO` o `BAJO` a `ALTO`.
38
+ - Auditar agentes con `/swl:revisar` cuando se detecta deriva de scope.
39
+
40
+ NO aplicar al:
41
+
42
+ - Agentes `BAJO` o `MEDIO` riesgo (los campos son opcionales para ellos).
43
+ - Cambios cosméticos al cuerpo markdown del agente sin tocar frontmatter.
44
+ - Skills, hooks, comandos (la regla aplica solo a agentes).
45
+
46
+ ---
47
+
48
+ ## Lo que DEBE declarar un agente ALTO
49
+
50
+ ### En el frontmatter YAML
51
+
52
+ ```yaml
53
+ nivelRiesgo: ALTO # Parte 7 — Autonomy Boundaries
54
+ maxTurnos: <int> # Parte 8 — Stop Rules (cap iteraciones)
55
+ strategy: "<1-3 lineas>" # Parte 1 — Strategy (max 500 chars)
56
+ healthMetrics: # Parte 4 — qué NO debe degradar
57
+ - "<invariante 1>"
58
+ - "<invariante 2>"
59
+ steering: # Parte 6 — prompt-level constraints
60
+ - "<guía de comportamiento o @reglas/X.md>"
61
+ hardGuardrails: # Parte 6 — orchestration-level constraints
62
+ - "<restricción enforced por hook/schema o @reglas/X.md>"
63
+ fragmentos:
64
+ - _intent-spec # Importa el bloque compartido al system prompt
65
+ ```
66
+
67
+ ### En el cuerpo markdown
68
+
69
+ NO requerido pero recomendado: agregar sección breve "Health Metrics" o
70
+ "Constraints" si el rol del agente justifica explicación adicional.
71
+
72
+ ---
73
+
74
+ ## Criterios de calidad por campo
75
+
76
+ ### `strategy:`
77
+
78
+ - 1-3 líneas, máximo 500 caracteres.
79
+ - Nombra el tradeoff que el agente prioriza.
80
+ - NO es boilerplate genérico ("código limpio", "buenas prácticas").
81
+ - Hereda del proyecto cuando aplica; declara explícito cuando el rol impone
82
+ tradeoffs propios.
83
+
84
+ **Ejemplo válido** (`migrador-swl`):
85
+ ```yaml
86
+ strategy: >
87
+ Preservar integridad de datos por encima de velocidad de migración.
88
+ Expand-contract obligatorio sobre cambios destructivos. Rollback siempre
89
+ viable. Sin downtime es preferible a migración rápida.
90
+ ```
91
+
92
+ **Ejemplo inválido**:
93
+ ```yaml
94
+ strategy: "Migrar datos de forma segura." # boilerplate genérico
95
+ ```
96
+
97
+ ### `healthMetrics:`
98
+
99
+ - Lista de invariantes blandas que el agente protege mientras trabaja.
100
+ - Distintas de `outcomes`: outcomes se persiguen, health metrics se
101
+ protegen.
102
+ - Sin métrica = sin protección. Agentes ALTO sin health metrics violan
103
+ Goodhart's Law por construcción.
104
+ - Pueden ser cualitativas si no hay telemetría que las mida live ("sin
105
+ warnings nuevos de ORM").
106
+
107
+ ### `steering:`
108
+
109
+ - Soft constraints. El agente las lee como guía.
110
+ - Acepta texto inline o referencia a regla global (`@reglas/X.md`).
111
+ - NO duplicar contenido de `@reglas/X.md` — referenciar evita drift.
112
+
113
+ ### `hardGuardrails:`
114
+
115
+ - Hard constraints aplicadas por arquitectura (hooks, schemas, sandbox).
116
+ - Cada item DEBE referenciar el mecanismo que enforza:
117
+ - `@reglas/seguridad-agentes.md § Privilegio mínimo` (regla global)
118
+ - `@hooks/proteccion-rutas.js` (hook bloqueante)
119
+ - `@schemas/agent-frontmatter.schema.json#properties.tools` (validación)
120
+ - Si la restricción no tiene mecanismo de enforcement, NO es hard
121
+ guardrail — es steering.
122
+
123
+ ---
124
+
125
+ ## Excepciones legítimas
126
+
127
+ NO aplica la regla cuando:
128
+
129
+ 1. **El agente acaba de bajar de ALTO a MEDIO/BAJO**: si en una revisión se
130
+ determina que un agente puede operar con menos privilegio, primero baja
131
+ el `nivelRiesgo`, luego los campos se vuelven opcionales.
132
+
133
+ 2. **El agente está en proceso de deprecación**: agentes marcados
134
+ `evolvable: false` con plan de retiro documentado en ADR pueden quedar
135
+ sin las 8 partes hasta su retiro. Documentar excepción en commit.
136
+
137
+ 3. **Refactor cosmético reversible**: cambios al cuerpo markdown que no
138
+ modifican `nivelRiesgo:` ni los 4 campos nuevos no disparan la regla.
139
+
140
+ ---
141
+
142
+ ## Cómo verificar conformidad
143
+
144
+ ### Manualmente
145
+
146
+ Para auditar un agente ALTO:
147
+
148
+ ```bash
149
+ node -e "
150
+ const a = require('js-yaml').load(require('fs').readFileSync(process.argv[1], 'utf-8').match(/^---\n([\s\S]+?)\n---/)[1]);
151
+ if (a.nivelRiesgo !== 'ALTO') { console.log('NO-ALTO'); return; }
152
+ const faltan = ['strategy','healthMetrics','steering','hardGuardrails'].filter(k => !a[k]);
153
+ if (faltan.length) console.error('FALTAN:', faltan.join(','));
154
+ else console.log('OK');
155
+ " agentes/X-swl.md
156
+ ```
157
+
158
+ ### Automáticamente
159
+
160
+ Hook `hooks/validar-intent-spec.js` (creado en F3) ejecuta esta validación
161
+ en PostToolUse sobre `Write|Edit` de `agentes/*.md`. Modo inicial:
162
+ `blocking: false` (warn-only). Promoción a `blocking: true` tras 2 semanas
163
+ estables sin falsos positivos, documentada en ADR-0027.
164
+
165
+ ---
166
+
167
+ ## Anti-patrones
168
+
169
+ - **Declarar `steering` algo que requiere enforcement**: "no eliminar
170
+ archivos" sin hook que lo prevenga. Si importa, va en `hardGuardrails`
171
+ con apoyo arquitectural.
172
+ - **Copiar `@reglas/X.md` completa en `hardGuardrails`**: referenciar, no
173
+ duplicar. La regla evoluciona; la copia se queda atrás.
174
+ - **Health metrics como outcomes negados**: "latencia < 200ms" es outcome;
175
+ "no degradar latencia mientras trabajas" es health metric.
176
+ - **Strategy demasiado vaga**: si la strategy aplica a cualquier agente,
177
+ no es strategy de este agente. Borrar o especificar.
178
+ - **Promover a ALTO sin declarar las 6 partes**: violación directa de
179
+ esta regla; el hook F3 (cuando blocking=true) lo previene.
180
+
181
+ ---
182
+
183
+ ## Relación con otras reglas
184
+
185
+ - `reglas/seguridad-agentes.md § Privilegio mínimo` — los campos nuevos NO
186
+ escalan privilegios; son metadata declarativa.
187
+ - `reglas/fragmentos-compartidos.md` — el `_intent-spec` importado es un
188
+ fragmento legítimo.
189
+ - `reglas/skills-estandar.md` — los skills cargables (`proceso-intent-engineering`)
190
+ son la versión on-demand del fragmento.
191
+ - `reglas/registro-componentes-nuevos.md` — al agregar agente nuevo ALTO,
192
+ registrar en manifiestos sigue siendo obligatorio.
193
+
194
+ ---
195
+
196
+ ## Cargar para aprender el framework
197
+
198
+ ```
199
+ Skill("proceso-intent-engineering")
200
+ ```
201
+
202
+ El skill explica cada parte con ejemplos, mapea Huryn (4 tiers) a SWL (3
203
+ tiers), enumera anti-patrones y entrega tabla de referencia rápida.
204
+
205
+ ---
206
+
207
+ ## Origen
208
+
209
+ Regla creada el 2026-05-18 como parte de Opción B (ver ADR-0025). Cubre el
210
+ gap detectado en análisis del artículo Huryn: SWL cubría 5/8 partes pero
211
+ no enforzaba sistemáticamente las 3 restantes (Strategy, Health Metrics,
212
+ Constraints distinguidas). La regla aplica solo a agentes ALTO porque
213
+ costos de declaración no compensan en agentes BAJO/MEDIO (los 6 agentes
214
+ del CONTEXTO original que eran BAJO/MEDIO se dejan opcionales).
@@ -181,6 +181,43 @@ commit separado del fix actual.
181
181
 
182
182
  ---
183
183
 
184
+ ## Citas a módulos de manifest en ADRs y docs
185
+
186
+ Cuando un ADR o documento del sistema cita un nombre de módulo de
187
+ `manifiestos/modulos.json`, `manifiestos/hooks-config.json` o
188
+ `manifiestos/perfiles.json`, **el nombre DEBE verificarse contra el
189
+ archivo real antes de persistir el ADR/doc**. Citas redactadas "de
190
+ memoria" tienden a inventar nombres plausibles que no existen.
191
+
192
+ **Patrón verificador**:
193
+
194
+ ```bash
195
+ # Verificar en qué módulo está registrado un componente específico
196
+ node -e "
197
+ const m = require('./manifiestos/modulos.json');
198
+ for (const [k, v] of Object.entries(m.modulos || m)) {
199
+ if (v.archivos && v.archivos.includes('hooks/<NOMBRE>.js')) {
200
+ console.log('Módulo real:', k);
201
+ }
202
+ }
203
+ "
204
+
205
+ # Listar todos los nombres de módulos disponibles
206
+ node -e "console.log(Object.keys(require('./manifiestos/modulos.json').modulos))"
207
+ ```
208
+
209
+ **Caso de regresión histórico**: ADR-0027 (2026-05-18) inicialmente decía
210
+ "`manifiestos/modulos.json` en módulo `hooks-evolucion-instintos`" —
211
+ módulo **inexistente**. El hook real quedó en `hooks-core`. Pasó la
212
+ primera revisión porque el ADR se redactó de memoria. Fix retrospectivo
213
+ en commit `6919b01`.
214
+
215
+ **Aplicación**: la regla global `~/.claude/rules/verificar-citas-normativas.md
216
+ § Familia 2` cubre "citas archivo:línea" — esta regla extiende el patrón
217
+ al dominio interno del proyecto: citas a nombres de módulos en manifiestos.
218
+
219
+ ---
220
+
184
221
  ## Checklist antes de commitear un componente nuevo
185
222
 
186
223
  - [ ] El archivo del componente está en el directorio correcto (`agentes/`, `habilidades/`, `comandos/swl/`, etc.).
@@ -190,3 +227,4 @@ commit separado del fix actual.
190
227
  - [ ] `npm run test:all` pasa sin errores.
191
228
  - [ ] Si es release: `node scripts/verificar-release.js` pasa sin discrepancias.
192
229
  - [ ] El commit message menciona qué componente se agrega y, si aplica, en qué módulo.
230
+ - [ ] Si el ADR/doc cita un módulo de manifest, el nombre se verificó con `node -e` o `grep` contra el archivo real (no escrito "de memoria").