@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.
- package/CLAUDE.md +32 -61
- package/README.md +4 -4
- package/agentes/_intent-spec.md +73 -0
- package/agentes/auto-evolucion-swl.md +24 -0
- package/agentes/cloud-infra-swl.md +25 -0
- package/agentes/datos-swl.md +24 -1
- package/agentes/devops-ci-swl.md +24 -0
- package/agentes/frontend-angular-swl.md +7 -7
- package/agentes/frontend-css-swl.md +4 -4
- package/agentes/frontend-react-swl.md +7 -7
- package/agentes/frontend-swl.md +9 -9
- package/agentes/frontend-tailwind-swl.md +4 -4
- package/agentes/migrador-swl.md +22 -0
- package/agentes/pagos-swl.md +25 -0
- package/agentes/release-manager-swl.md +24 -0
- package/agentes/rendimiento-swl.md +2 -2
- package/agentes/sre-swl.md +24 -0
- package/comandos/swl/brainstorm.md +1 -0
- package/comandos/swl/compactar.md +1 -1
- package/comandos/swl/discutir-fase.md +15 -1
- package/comandos/swl/mapear-codebase.md +1 -1
- package/comandos/swl/nemesis.md +29 -0
- package/comandos/swl/planear-fase.md +18 -2
- package/comandos/swl/verificar.md +4 -4
- package/habilidades/aprender-de-git-diff/SKILL.md +288 -0
- package/habilidades/aprendizaje-continuo/SKILL.md +7 -1
- package/habilidades/diseno-herramientas-agente/SKILL.md +17 -0
- package/habilidades/doc-sync/SKILL.md +441 -1
- package/habilidades/doubt-driven-review/SKILL.md +177 -171
- package/habilidades/feynman-auditor-swl/SKILL.md +129 -123
- package/habilidades/infra-github-actions/SKILL.md +172 -166
- package/habilidades/meta-skills-estandar/SKILL.md +6 -0
- package/habilidades/meta-skills-estandar/recursos/skill-judge-rubrica.md +281 -0
- package/habilidades/meta-skills-estandar/recursos/skills-as-agents.md +163 -163
- package/habilidades/nemesis-evaluacion-json/SKILL.md +5 -0
- package/habilidades/nemesis-redistribuir/SKILL.md +5 -0
- package/habilidades/node-experto/SKILL.md +197 -3
- package/habilidades/prevencion-racionalizacion/SKILL.md +1 -0
- package/habilidades/privacy-memoria/SKILL.md +1 -0
- package/habilidades/proceso-autoverificacion-evidencias/SKILL.md +258 -0
- package/habilidades/proceso-confianza-pre-implementacion/SKILL.md +246 -0
- package/habilidades/proceso-ddia-fundamentos/SKILL.md +255 -0
- package/habilidades/proceso-ddia-streaming/SKILL.md +231 -0
- package/habilidades/proceso-intent-engineering/SKILL.md +269 -0
- package/habilidades/reducir-entropia/SKILL.md +219 -0
- package/habilidades/sre-patrones/SKILL.md +1 -1
- package/habilidades/state-inconsistency-auditor-swl/SKILL.md +172 -166
- package/habilidades/tdd-workflow/SKILL.md +178 -3
- package/habilidades/verificacion-evidencia/SKILL.md +1 -0
- package/habilidades/web-fetcher-routing/SKILL.md +81 -75
- package/habilidades/workflow-claude-code/SKILL.md +2 -2
- package/hooks/lib/task-budget.js +218 -0
- package/hooks/validar-intent-spec.js +222 -0
- package/manifiestos/hooks-config.json +9 -0
- package/manifiestos/modulos.json +12 -2
- package/manifiestos/skills-lock.json +1191 -1142
- package/package.json +5 -3
- package/plugin.json +9 -2
- package/reglas/auditorias-documentales-estructurales.md +205 -0
- package/reglas/fragmentos-compartidos.md +26 -0
- package/reglas/intent-engineering.md +214 -0
- package/reglas/registro-componentes-nuevos.md +38 -0
- package/schemas/agent-frontmatter.schema.json +294 -167
- package/schemas/agent-message.schema.json +73 -53
- package/schemas/agent-output-implementacion.schema.json +114 -85
- package/schemas/agent-output-planificacion.schema.json +150 -113
- package/schemas/agent-output-review.schema.json +98 -78
- package/schemas/diary-entry.schema.json +42 -10
- package/schemas/hook-profiles.schema.json +54 -39
- package/schemas/hooks-config.schema.json +89 -74
- package/schemas/instinct.schema.json +152 -115
- package/schemas/modulos.schema.json +38 -29
- package/schemas/perfiles.schema.json +36 -28
- package/schemas/plugin.schema.json +77 -64
- package/schemas/skill-evals.schema.json +119 -95
- package/schemas/skill-frontmatter.schema.json +245 -170
- package/scripts/generar-inventario.js +452 -420
- package/scripts/lib/schema-version.js +164 -0
- package/scripts/validar-manifest.js +1 -1
- package/scripts/validar.js +3 -2
- package/scripts/verificar-docs-vs-codigo.js +654 -425
- 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.
|
|
4
|
-
"description": "Sistema de ingenieria de software auto-evolutivo multi-runtime polyglot con 60 agentes, 162 habilidades, 44 comandos,
|
|
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.
|
|
4
|
-
"description": "Sistema de ingenieria de software auto-evolutivo multi-runtime polyglot. 60 agentes,
|
|
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").
|