@saulwade/swl-ses 1.4.1 → 1.5.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 (136) hide show
  1. package/CLAUDE.md +3 -3
  2. package/README.md +561 -560
  3. package/agentes/nemesis-auditor-swl.md +161 -161
  4. package/bin/swl-mcp-server.js +49 -22
  5. package/bin/swl-ses.js +74 -0
  6. package/comandos/swl/.evolved.json +22 -22
  7. package/comandos/swl/contribuir.md +233 -233
  8. package/comandos/swl/ejecutar-fase.md +33 -4
  9. package/comandos/swl/metricas.md +72 -0
  10. package/comandos/swl/nemesis.md +122 -122
  11. package/gateway/lib/event-channel.js +191 -191
  12. package/habilidades/backend-production-resilience/SKILL.md +288 -288
  13. package/habilidades/benchmark-memoria/SKILL.md +186 -186
  14. package/habilidades/diagrama-arquitectura/assets/template.html +276 -276
  15. package/habilidades/discutir-fase/SKILL.md +50 -2
  16. package/habilidades/doubt-driven-review/SKILL.md +171 -171
  17. package/habilidades/doubt-driven-review/recursos/EXAMPLES.md +130 -130
  18. package/habilidades/ejecutar-task-iterativo/SKILL.md +278 -0
  19. package/habilidades/eval-framework/SKILL.md +212 -212
  20. package/habilidades/feynman-auditor-swl/SKILL.md +123 -123
  21. package/habilidades/feynman-auditor-swl/recursos/preguntas-language-agnostic.md +108 -108
  22. package/habilidades/harness-claude-code/SKILL.md +299 -299
  23. package/habilidades/infra-github-actions/SKILL.md +166 -166
  24. package/habilidades/legacy-code-rescue/SKILL.md +267 -267
  25. package/habilidades/manejo-errores/.evolved.json +8 -8
  26. package/habilidades/meta-skills-estandar/recursos/convencion-examples.md +93 -93
  27. package/habilidades/meta-skills-estandar/recursos/skills-as-agents.md +163 -163
  28. package/habilidades/patrones-python/SKILL.md +229 -229
  29. package/habilidades/patrones-python/recursos/patrones-avanzados.md +469 -469
  30. package/habilidades/planear-fase/SKILL.md +319 -319
  31. package/habilidades/protocolo-revision-swl/SKILL.md +276 -0
  32. package/habilidades/release-semver/.evolved.json +8 -8
  33. package/habilidades/state-inconsistency-auditor-swl/SKILL.md +166 -166
  34. package/habilidades/state-inconsistency-auditor-swl/recursos/coupled-state-patterns.md +147 -147
  35. package/habilidades/testing-python/SKILL.md +340 -340
  36. package/habilidades/verificar-trabajo/SKILL.md +49 -5
  37. package/habilidades/web-fetcher-routing/SKILL.md +75 -75
  38. package/hooks/claudemd-bloat-detector.js +161 -161
  39. package/hooks/lib/agent-routing.js +107 -107
  40. package/hooks/lib/auto-consolidator.js +335 -335
  41. package/hooks/lib/error-classifier.js +308 -308
  42. package/hooks/lib/merkle-audit.js +96 -96
  43. package/hooks/lib/provenance-tracker.js +191 -191
  44. package/hooks/lib/rate-limit-tracker.js +253 -253
  45. package/hooks/lib/resource-quota.js +122 -122
  46. package/hooks/lib/retry-jitter.js +165 -165
  47. package/hooks/lib/security-net.js +201 -201
  48. package/hooks/lib/skill-auditor.js +588 -588
  49. package/hooks/lib/sync-status.js +228 -228
  50. package/hooks/lib/taint-tracker.js +107 -107
  51. package/hooks/lib/text-similarity.js +241 -241
  52. package/hooks/lib/toon-compressor.js +245 -245
  53. package/hooks/registro-turnos.js +209 -209
  54. package/hooks/sugerir-regenerar-inventario.js +170 -170
  55. package/hooks/validar-formato-post-subagente.js +140 -140
  56. package/hooks/validar-memoria-hook.js +218 -218
  57. package/instintos/prompt-appendices.yaml +57 -57
  58. package/manifiestos/agent-output-schemas.json +57 -57
  59. package/manifiestos/modulos.json +1321 -1262
  60. package/manifiestos/perfiles.json +2 -1
  61. package/manifiestos/skills-lock.json +1114 -1114
  62. package/package.json +3 -3
  63. package/plantillas/auditor-veto-template.md +105 -105
  64. package/plantillas/github-workflows/README.md +47 -47
  65. package/plantillas/github-workflows/release-please.yml +44 -44
  66. package/plantillas/github-workflows/swl-ci.yml +107 -107
  67. package/plantillas/github-workflows/swl-security.yml +51 -51
  68. package/plugin.json +351 -343
  69. package/reglas/analisis-previo-tareas-grandes.md +172 -172
  70. package/reglas/arreglar-al-detectar.md +147 -147
  71. package/reglas/fragmentos-compartidos.md +152 -152
  72. package/reglas/harness-claude-code.md +213 -213
  73. package/reglas/usar-context7.md +226 -226
  74. package/schemas/diary-entry.schema.json +80 -80
  75. package/scripts/audit-tools/audit-history.js +330 -330
  76. package/scripts/audit-tools/bundle-tracker.js +290 -290
  77. package/scripts/audit-tools/canary-monitor.js +352 -352
  78. package/scripts/audit-tools/code-profiler.js +605 -605
  79. package/scripts/audit-tools/dep-doctor.js +320 -320
  80. package/scripts/audit-tools/env-validator.js +206 -206
  81. package/scripts/audit-tools/lib/fs-walk.js +48 -48
  82. package/scripts/audit-tools/lib/output.js +23 -23
  83. package/scripts/audit-tools/migration-checker.js +392 -392
  84. package/scripts/audit-tools/pentest-scanner.js +1436 -1436
  85. package/scripts/benchmark-memoria.js +167 -167
  86. package/scripts/configurar-branch-protection.js +418 -418
  87. package/scripts/derivar-feature-list.js +489 -0
  88. package/scripts/detectar-aprendizajes-duplicados.js +151 -151
  89. package/scripts/doctor.js +31 -4
  90. package/scripts/field-report.js +199 -199
  91. package/scripts/generar-checklists-consolidados.js +273 -273
  92. package/scripts/generar-inventario.js +420 -420
  93. package/scripts/generar-matriz-lenguajes.js +271 -271
  94. package/scripts/instalador.js +56 -5
  95. package/scripts/lib/artefactos-python.js +43 -43
  96. package/scripts/lib/benchmark-metrics.js +160 -160
  97. package/scripts/lib/budget-enforcer.js +252 -252
  98. package/scripts/lib/configurar-ci.js +380 -380
  99. package/scripts/lib/contadores-inventario.js +217 -217
  100. package/scripts/lib/detectar-runtime.js +75 -9
  101. package/scripts/lib/detectar-stack-detallado.js +307 -307
  102. package/scripts/lib/diary-entry.js +234 -234
  103. package/scripts/lib/estado.js +13 -1
  104. package/scripts/lib/eval-metrics-store.js +218 -218
  105. package/scripts/lib/eval-quality.js +171 -171
  106. package/scripts/lib/eval-schemas.js +144 -144
  107. package/scripts/lib/eval-self-correct.js +106 -106
  108. package/scripts/lib/eval-validator.js +185 -185
  109. package/scripts/lib/expandir-targets.js +71 -0
  110. package/scripts/lib/jaccard-similarity.js +98 -98
  111. package/scripts/lib/longmemeval-runner.js +125 -125
  112. package/scripts/lib/manifiestos.js +42 -1
  113. package/scripts/lib/npm-version.js +261 -261
  114. package/scripts/lib/paquetes-conocidos.js +50 -50
  115. package/scripts/lib/parsear-opciones.js +3 -0
  116. package/scripts/lib/prompt-builder.js +264 -264
  117. package/scripts/lib/rrf-fusion.js +175 -175
  118. package/scripts/lib/scoring-instintos.js +277 -277
  119. package/scripts/lib/semantic-search.js +252 -252
  120. package/scripts/lib/toml-merge.js +204 -0
  121. package/scripts/lib/transformadores/base.js +43 -9
  122. package/scripts/lib/transformadores/codex.js +375 -115
  123. package/scripts/lib/transformadores/cursor.js +359 -0
  124. package/scripts/lib/transformadores/index.js +2 -0
  125. package/scripts/limpiar-artefactos-python.js +131 -131
  126. package/scripts/mcp-server/README.md +122 -80
  127. package/scripts/mcp-server/auth.js +105 -0
  128. package/scripts/mcp-server/cache.js +106 -0
  129. package/scripts/mcp-server/handlers.js +386 -206
  130. package/scripts/mcp-server/telemetry.js +78 -0
  131. package/scripts/migrar-csv-a-array.js +168 -168
  132. package/scripts/migrar-fase-dominio.js +201 -201
  133. package/scripts/publicar.js +511 -511
  134. package/scripts/run-eval.js +141 -141
  135. package/scripts/validar-manifest.js +231 -195
  136. package/scripts/validar-userland-vacio.js +110 -110
@@ -1,166 +1,166 @@
1
- ---
2
- name: infra-github-actions
3
- description: >
4
- GitHub Actions CI/CD para proyectos que usan swl-ses. Cubre los tres workflows
5
- distribuidos (swl-security.yml, swl-ci.yml, release-please.yml), setup del secret
6
- CLAUDE_API_KEY, branch protection y troubleshooting. Cargar cuando se configura
7
- CI/CD con GitHub Actions en un proyecto donde está instalado swl-ses.
8
- ---
9
-
10
- # infra-github-actions — GitHub Actions con swl-ses
11
-
12
- ## Cuándo cargar
13
-
14
- - Al ejecutar `/swl:configurar-ci init` y necesitar guía de setup
15
- - Al depurar un workflow que no dispara o falla por API key
16
- - Al configurar branch protection en el proyecto
17
- - Al decidir si adoptar release-please vs el flujo manual actual
18
-
19
- ## Cuándo NO cargar
20
-
21
- - El proyecto usa Azure DevOps Pipelines o GitLab CI — esos tienen su propia configuración
22
- - El objetivo es Kubernetes, Terraform o infraestructura cloud (cargar `kubernetes-orquestacion` o `terraform-experto`)
23
- - La tarea es solo correr tests localmente sin CI
24
- - El proyecto no usa GitHub como repositorio
25
-
26
- ---
27
-
28
- ## Workflows distribuidos por swl-ses
29
-
30
- | Archivo | Propósito | Secrets requeridos |
31
- |---------|-----------|-------------------|
32
- | `swl-security.yml` | Revisión semántica de seguridad con Claude en cada PR | `CLAUDE_API_KEY` |
33
- | `swl-ci.yml` | Lint + tests en push y PRs. Node 22+24, Python/Rust/Go comentados | Ninguno |
34
- | `release-please.yml` | Release PR automático + tag + GitHub Release | Ninguno (`GITHUB_TOKEN` automático) |
35
-
36
- Instalación con: `/swl:configurar-ci init`
37
-
38
- ---
39
-
40
- ## Reglas obligatorias
41
-
42
- **NUNCA** commitear API keys en código ni en archivos de workflow.
43
- Todo secret va en GitHub Settings → Secrets and variables → Actions.
44
-
45
- **Permisos mínimos siempre**: declarar solo `contents: read` y `pull-requests: write`
46
- en el nivel del workflow. Nunca `permissions: write-all`.
47
-
48
- **Los workflows de forks externos no reciben secrets** por diseño de GitHub.
49
- La revisión de seguridad con Claude solo funciona en PRs desde ramas del mismo repo,
50
- no desde repos forked. Es un comportamiento de GitHub, no un bug.
51
-
52
- **No hardcodear nombres de rama** más allá de `main`. Si el proyecto usa otra rama
53
- por defecto, editar el `on: push: branches` en los workflows copiados.
54
-
55
- ---
56
-
57
- ## Setup de CLAUDE_API_KEY
58
-
59
- 1. Ir a https://console.anthropic.com y crear o copiar la API key
60
- 2. En GitHub: Settings → Secrets and variables → Actions → New repository secret
61
- - Nombre: `CLAUDE_API_KEY`
62
- - Valor: la API key
63
- 3. La key necesita permisos tanto para Claude API como para Claude Code
64
-
65
- Verificar con gh CLI si el secret ya existe:
66
- ```bash
67
- gh secret list | grep CLAUDE_API_KEY
68
- ```
69
-
70
- Para configurar vía CLI (valor desde stdin, no queda en historial):
71
- ```bash
72
- gh secret set CLAUDE_API_KEY
73
- ```
74
-
75
- ---
76
-
77
- ## Branch protection
78
-
79
- Aplicar después de tener CI funcionando. El script del repo swl-ses:
80
-
81
- ```bash
82
- # Ver qué haría sin aplicar cambios
83
- node scripts/configurar-branch-protection.js --dry-run
84
-
85
- # Aplicar
86
- node scripts/configurar-branch-protection.js
87
- ```
88
-
89
- Requiere `gh` CLI autenticado y permisos de admin en el repositorio.
90
-
91
- Configura: require PR, status checks (`test (22)`, `test (24)`, `smoke`),
92
- 1 approval, bloquea force-push y deletions.
93
-
94
- ---
95
-
96
- ## Adoptar release-please (opt-in)
97
-
98
- Ver `docs/RELEASE-PLEASE-MIGRATION.md` para comparativa completa.
99
-
100
- El flujo actual del repo swl-ses usa `scripts/publicar.js` (manual). release-please
101
- es una alternativa automática viable para proyectos de usuarios.
102
-
103
- Instalar:
104
- ```
105
- /swl:configurar-ci --with-release-please
106
- ```
107
-
108
- Una vez activo, el flujo es:
109
- 1. Hacer merge de commits convencionales a main
110
- 2. release-please abre un "Release PR" automático con bump de versión y CHANGELOG
111
- 3. Al mergear ese PR → tag git + GitHub Release creado automáticamente
112
-
113
- ---
114
-
115
- ## Gotchas / Errores comunes no obvios
116
-
117
- **GitHub Free + repo privado → 403 en branch protection Y Rulesets**: tanto el endpoint legacy
118
- `/repos/.../branches/{}/protection` como el endpoint moderno `/repos/.../rulesets` requieren
119
- **plan de pago** en repos privados (HTTP 403 "Upgrade to GitHub Pro or make this repository public"
120
- en ambos). Mi documentación inicial afirmó incorrectamente que Rulesets era gratis para repos
121
- privados Free — verificación empírica posterior confirmó que NO. Ambos endpoints están bloqueados.
122
-
123
- Planes que destraban la feature en privado:
124
- - **Pro** ($4/mes): aplica a repos en cuenta personal del titular Pro.
125
- - **Team** ($4/usuario/mes): aplica solo a repos **de la organización** que paga Team. NO aplica
126
- a repos en la cuenta personal del admin de la org. Para que Team aplique al repo, transferirlo:
127
- `gh repo transfer cuenta-personal/repo --new-owner org`.
128
-
129
- Sin plan de pago y manteniendo repo privado, las opciones son: pre-push hook local
130
- (bypasseable con `--no-verify`) y workflow advisory (no bloquea push, crea issue post-hoc).
131
-
132
- **Push directo a main bloqueado tras activar branch protection**: si configuraste
133
- branch protection antes de que tu usuario tuviera al menos un PR mergeado con los
134
- status checks pasando, el repo puede quedar en estado donde nadie puede mergear.
135
- Causa: GitHub verifica los status checks declarados antes de permitir el merge; si
136
- los checks no han corrido en el branch, el botón de merge queda bloqueado.
137
- Fix: crear una rama temporal con un cambio trivial, abrir PR, dejar que los checks
138
- corran, y mergear. Luego ya funciona el flujo normal.
139
-
140
- **GITHUB_TOKEN no puede aprobar su propio PR** al usar release-please: release-please
141
- crea un Release PR con el GITHUB_TOKEN del bot — ese mismo token no puede aprobarlo
142
- si el repo requiere al menos 1 approval humano. Causa: GitHub bloquea la auto-aprobación
143
- con el token de Actions por defecto.
144
- Fix: crear un Personal Access Token (PAT) con scope `repo` y usarlo en el workflow:
145
- `token: ${{ secrets.MY_RELEASE_TOKEN }}`. O reducir el required approvals a 0 para
146
- el Release PR (no recomendado en repos con múltiples contribuidores).
147
-
148
- **`anthropics/claude-code-security-review@main` falla con "API key not set"**: el
149
- secret `CLAUDE_API_KEY` no está configurado o el nombre no coincide exactamente.
150
- La action es sensible a mayúsculas — `claude_api_key` (minúsculas) no funciona.
151
- Fix: verificar con `gh secret list`. El nombre debe ser exactamente `CLAUDE_API_KEY`.
152
-
153
- **El workflow `swl-ci.yml` pasa localmente pero falla en CI con "lint script not found"**:
154
- el campo `lint` no está definido en `package.json` del proyecto del usuario. La plantilla
155
- usa `npm run lint --if-present` precisamente para ser tolerante, pero si el proyecto
156
- tiene un nombre distinto (ej: `eslint`, `check`) el step se salta silenciosamente.
157
- Fix: agregar el script `"lint": "..."` en `package.json` o editar el workflow para usar
158
- el nombre correcto.
159
-
160
- **release-please genera changelog con commits `chore(release)` del repo padre swl-ses**:
161
- si el proyecto del usuario adoptó los mensajes de commit de swl-ses que incluyen
162
- `chore(release): v5.X.Y`, release-please los interpreta como commits de release
163
- y puede generar bumps incorrectos.
164
- Fix: usar mensajes de commit convencionales estándar para el proyecto del usuario,
165
- separados del estilo de swl-ses. Los prefijos `feat:`, `fix:`, `chore:` sin el
166
- patrón `(release): vX.Y.Z` no causan conflicto.
1
+ ---
2
+ name: infra-github-actions
3
+ description: >
4
+ GitHub Actions CI/CD para proyectos que usan swl-ses. Cubre los tres workflows
5
+ distribuidos (swl-security.yml, swl-ci.yml, release-please.yml), setup del secret
6
+ CLAUDE_API_KEY, branch protection y troubleshooting. Cargar cuando se configura
7
+ CI/CD con GitHub Actions en un proyecto donde está instalado swl-ses.
8
+ ---
9
+
10
+ # infra-github-actions — GitHub Actions con swl-ses
11
+
12
+ ## Cuándo cargar
13
+
14
+ - Al ejecutar `/swl:configurar-ci init` y necesitar guía de setup
15
+ - Al depurar un workflow que no dispara o falla por API key
16
+ - Al configurar branch protection en el proyecto
17
+ - Al decidir si adoptar release-please vs el flujo manual actual
18
+
19
+ ## Cuándo NO cargar
20
+
21
+ - El proyecto usa Azure DevOps Pipelines o GitLab CI — esos tienen su propia configuración
22
+ - El objetivo es Kubernetes, Terraform o infraestructura cloud (cargar `kubernetes-orquestacion` o `terraform-experto`)
23
+ - La tarea es solo correr tests localmente sin CI
24
+ - El proyecto no usa GitHub como repositorio
25
+
26
+ ---
27
+
28
+ ## Workflows distribuidos por swl-ses
29
+
30
+ | Archivo | Propósito | Secrets requeridos |
31
+ |---------|-----------|-------------------|
32
+ | `swl-security.yml` | Revisión semántica de seguridad con Claude en cada PR | `CLAUDE_API_KEY` |
33
+ | `swl-ci.yml` | Lint + tests en push y PRs. Node 22+24, Python/Rust/Go comentados | Ninguno |
34
+ | `release-please.yml` | Release PR automático + tag + GitHub Release | Ninguno (`GITHUB_TOKEN` automático) |
35
+
36
+ Instalación con: `/swl:configurar-ci init`
37
+
38
+ ---
39
+
40
+ ## Reglas obligatorias
41
+
42
+ **NUNCA** commitear API keys en código ni en archivos de workflow.
43
+ Todo secret va en GitHub Settings → Secrets and variables → Actions.
44
+
45
+ **Permisos mínimos siempre**: declarar solo `contents: read` y `pull-requests: write`
46
+ en el nivel del workflow. Nunca `permissions: write-all`.
47
+
48
+ **Los workflows de forks externos no reciben secrets** por diseño de GitHub.
49
+ La revisión de seguridad con Claude solo funciona en PRs desde ramas del mismo repo,
50
+ no desde repos forked. Es un comportamiento de GitHub, no un bug.
51
+
52
+ **No hardcodear nombres de rama** más allá de `main`. Si el proyecto usa otra rama
53
+ por defecto, editar el `on: push: branches` en los workflows copiados.
54
+
55
+ ---
56
+
57
+ ## Setup de CLAUDE_API_KEY
58
+
59
+ 1. Ir a https://console.anthropic.com y crear o copiar la API key
60
+ 2. En GitHub: Settings → Secrets and variables → Actions → New repository secret
61
+ - Nombre: `CLAUDE_API_KEY`
62
+ - Valor: la API key
63
+ 3. La key necesita permisos tanto para Claude API como para Claude Code
64
+
65
+ Verificar con gh CLI si el secret ya existe:
66
+ ```bash
67
+ gh secret list | grep CLAUDE_API_KEY
68
+ ```
69
+
70
+ Para configurar vía CLI (valor desde stdin, no queda en historial):
71
+ ```bash
72
+ gh secret set CLAUDE_API_KEY
73
+ ```
74
+
75
+ ---
76
+
77
+ ## Branch protection
78
+
79
+ Aplicar después de tener CI funcionando. El script del repo swl-ses:
80
+
81
+ ```bash
82
+ # Ver qué haría sin aplicar cambios
83
+ node scripts/configurar-branch-protection.js --dry-run
84
+
85
+ # Aplicar
86
+ node scripts/configurar-branch-protection.js
87
+ ```
88
+
89
+ Requiere `gh` CLI autenticado y permisos de admin en el repositorio.
90
+
91
+ Configura: require PR, status checks (`test (22)`, `test (24)`, `smoke`),
92
+ 1 approval, bloquea force-push y deletions.
93
+
94
+ ---
95
+
96
+ ## Adoptar release-please (opt-in)
97
+
98
+ Ver `docs/RELEASE-PLEASE-MIGRATION.md` para comparativa completa.
99
+
100
+ El flujo actual del repo swl-ses usa `scripts/publicar.js` (manual). release-please
101
+ es una alternativa automática viable para proyectos de usuarios.
102
+
103
+ Instalar:
104
+ ```
105
+ /swl:configurar-ci --with-release-please
106
+ ```
107
+
108
+ Una vez activo, el flujo es:
109
+ 1. Hacer merge de commits convencionales a main
110
+ 2. release-please abre un "Release PR" automático con bump de versión y CHANGELOG
111
+ 3. Al mergear ese PR → tag git + GitHub Release creado automáticamente
112
+
113
+ ---
114
+
115
+ ## Gotchas / Errores comunes no obvios
116
+
117
+ **GitHub Free + repo privado → 403 en branch protection Y Rulesets**: tanto el endpoint legacy
118
+ `/repos/.../branches/{}/protection` como el endpoint moderno `/repos/.../rulesets` requieren
119
+ **plan de pago** en repos privados (HTTP 403 "Upgrade to GitHub Pro or make this repository public"
120
+ en ambos). Mi documentación inicial afirmó incorrectamente que Rulesets era gratis para repos
121
+ privados Free — verificación empírica posterior confirmó que NO. Ambos endpoints están bloqueados.
122
+
123
+ Planes que destraban la feature en privado:
124
+ - **Pro** ($4/mes): aplica a repos en cuenta personal del titular Pro.
125
+ - **Team** ($4/usuario/mes): aplica solo a repos **de la organización** que paga Team. NO aplica
126
+ a repos en la cuenta personal del admin de la org. Para que Team aplique al repo, transferirlo:
127
+ `gh repo transfer cuenta-personal/repo --new-owner org`.
128
+
129
+ Sin plan de pago y manteniendo repo privado, las opciones son: pre-push hook local
130
+ (bypasseable con `--no-verify`) y workflow advisory (no bloquea push, crea issue post-hoc).
131
+
132
+ **Push directo a main bloqueado tras activar branch protection**: si configuraste
133
+ branch protection antes de que tu usuario tuviera al menos un PR mergeado con los
134
+ status checks pasando, el repo puede quedar en estado donde nadie puede mergear.
135
+ Causa: GitHub verifica los status checks declarados antes de permitir el merge; si
136
+ los checks no han corrido en el branch, el botón de merge queda bloqueado.
137
+ Fix: crear una rama temporal con un cambio trivial, abrir PR, dejar que los checks
138
+ corran, y mergear. Luego ya funciona el flujo normal.
139
+
140
+ **GITHUB_TOKEN no puede aprobar su propio PR** al usar release-please: release-please
141
+ crea un Release PR con el GITHUB_TOKEN del bot — ese mismo token no puede aprobarlo
142
+ si el repo requiere al menos 1 approval humano. Causa: GitHub bloquea la auto-aprobación
143
+ con el token de Actions por defecto.
144
+ Fix: crear un Personal Access Token (PAT) con scope `repo` y usarlo en el workflow:
145
+ `token: ${{ secrets.MY_RELEASE_TOKEN }}`. O reducir el required approvals a 0 para
146
+ el Release PR (no recomendado en repos con múltiples contribuidores).
147
+
148
+ **`anthropics/claude-code-security-review@main` falla con "API key not set"**: el
149
+ secret `CLAUDE_API_KEY` no está configurado o el nombre no coincide exactamente.
150
+ La action es sensible a mayúsculas — `claude_api_key` (minúsculas) no funciona.
151
+ Fix: verificar con `gh secret list`. El nombre debe ser exactamente `CLAUDE_API_KEY`.
152
+
153
+ **El workflow `swl-ci.yml` pasa localmente pero falla en CI con "lint script not found"**:
154
+ el campo `lint` no está definido en `package.json` del proyecto del usuario. La plantilla
155
+ usa `npm run lint --if-present` precisamente para ser tolerante, pero si el proyecto
156
+ tiene un nombre distinto (ej: `eslint`, `check`) el step se salta silenciosamente.
157
+ Fix: agregar el script `"lint": "..."` en `package.json` o editar el workflow para usar
158
+ el nombre correcto.
159
+
160
+ **release-please genera changelog con commits `chore(release)` del repo padre swl-ses**:
161
+ si el proyecto del usuario adoptó los mensajes de commit de swl-ses que incluyen
162
+ `chore(release): v5.X.Y`, release-please los interpreta como commits de release
163
+ y puede generar bumps incorrectos.
164
+ Fix: usar mensajes de commit convencionales estándar para el proyecto del usuario,
165
+ separados del estilo de swl-ses. Los prefijos `feat:`, `fix:`, `chore:` sin el
166
+ patrón `(release): vX.Y.Z` no causan conflicto.