@saulwade/swl-ses 1.0.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 (702) hide show
  1. package/CLAUDE.md +238 -0
  2. package/README.md +560 -0
  3. package/_userland/agentes/.gitkeep +0 -0
  4. package/_userland/habilidades/.gitkeep +0 -0
  5. package/agentes/.evolved.json +9 -0
  6. package/agentes/accesibilidad-wcag-swl.md +692 -0
  7. package/agentes/arquitecto-swl.md +238 -0
  8. package/agentes/auto-evolucion-swl.md +854 -0
  9. package/agentes/backend-api-swl.md +470 -0
  10. package/agentes/backend-csharp-swl.md +418 -0
  11. package/agentes/backend-go-swl.md +388 -0
  12. package/agentes/backend-java-swl.md +279 -0
  13. package/agentes/backend-node-swl.md +477 -0
  14. package/agentes/backend-python-swl.md +608 -0
  15. package/agentes/backend-rust-swl.md +362 -0
  16. package/agentes/backend-workers-swl.md +480 -0
  17. package/agentes/cloud-infra-swl.md +485 -0
  18. package/agentes/consolidador-swl.md +539 -0
  19. package/agentes/datos-swl.md +584 -0
  20. package/agentes/depurador-swl.md +349 -0
  21. package/agentes/devops-ci-swl.md +374 -0
  22. package/agentes/disenador-ui-swl.md +558 -0
  23. package/agentes/documentador-swl.md +343 -0
  24. package/agentes/evals/arquitecto-swl.evals.json +56 -0
  25. package/agentes/evals/auto-evolucion-swl.evals.json +68 -0
  26. package/agentes/evals/implementador-swl.evals.json +56 -0
  27. package/agentes/evals/orquestador-swl.evals.json +60 -0
  28. package/agentes/evals/perfilador-usuario-swl.evals.json +60 -0
  29. package/agentes/evals/red-team-swl.evals.json +59 -0
  30. package/agentes/evals/revisor-codigo-swl.evals.json +59 -0
  31. package/agentes/frontend-angular-swl.md +627 -0
  32. package/agentes/frontend-css-swl.md +720 -0
  33. package/agentes/frontend-react-swl.md +696 -0
  34. package/agentes/frontend-swl.md +500 -0
  35. package/agentes/frontend-tailwind-swl.md +830 -0
  36. package/agentes/implementador-swl.md +328 -0
  37. package/agentes/investigador-swl.md +430 -0
  38. package/agentes/investigador-ux-swl.md +500 -0
  39. package/agentes/llm-apps-swl.md +276 -0
  40. package/agentes/migrador-swl.md +417 -0
  41. package/agentes/mobile-android-swl.md +509 -0
  42. package/agentes/mobile-cross-swl.md +539 -0
  43. package/agentes/mobile-ios-swl.md +500 -0
  44. package/agentes/mobile-testing-swl.md +300 -0
  45. package/agentes/notificador-swl.md +916 -0
  46. package/agentes/observabilidad-swl.md +436 -0
  47. package/agentes/orquestador-swl.md +884 -0
  48. package/agentes/pagos-swl.md +283 -0
  49. package/agentes/perfilador-usuario-swl.md +306 -0
  50. package/agentes/planificador-swl.md +402 -0
  51. package/agentes/producto-prd-swl.md +587 -0
  52. package/agentes/red-team-swl.md +216 -0
  53. package/agentes/release-manager-swl.md +568 -0
  54. package/agentes/rendimiento-swl.md +714 -0
  55. package/agentes/resolutor-build-swl.md +243 -0
  56. package/agentes/revisor-angular-swl.md +276 -0
  57. package/agentes/revisor-codigo-swl.md +348 -0
  58. package/agentes/revisor-csharp-swl.md +262 -0
  59. package/agentes/revisor-go-swl.md +257 -0
  60. package/agentes/revisor-java-swl.md +255 -0
  61. package/agentes/revisor-kotlin-swl.md +271 -0
  62. package/agentes/revisor-nextjs-swl.md +279 -0
  63. package/agentes/revisor-php-swl.md +269 -0
  64. package/agentes/revisor-react-swl.md +276 -0
  65. package/agentes/revisor-rust-swl.md +344 -0
  66. package/agentes/revisor-seguridad-swl.md +390 -0
  67. package/agentes/revisor-swift-swl.md +266 -0
  68. package/agentes/revisor-typescript-swl.md +344 -0
  69. package/agentes/sre-swl.md +265 -0
  70. package/agentes/tdd-qa-swl.md +354 -0
  71. package/agentes/ux-disenador-swl.md +501 -0
  72. package/bin/lib/bot-comandos.js +1030 -0
  73. package/bin/lib/bot-discovery.js +182 -0
  74. package/bin/lib/bot-git.js +142 -0
  75. package/bin/swl-ses.js +325 -0
  76. package/bin/swl-telegram-bot.js +442 -0
  77. package/bin/swl-telegram-bot.plist +21 -0
  78. package/bin/swl-telegram-bot.service +14 -0
  79. package/comandos/swl/.evolved.json +23 -0
  80. package/comandos/swl/actualizar.md +174 -0
  81. package/comandos/swl/adoptar-proyecto.md +207 -0
  82. package/comandos/swl/aprender.md +701 -0
  83. package/comandos/swl/auditar-deps.md +134 -0
  84. package/comandos/swl/autoresearch.md +170 -0
  85. package/comandos/swl/ayuda.md +224 -0
  86. package/comandos/swl/brainstorm.md +50 -0
  87. package/comandos/swl/checkpoint.md +330 -0
  88. package/comandos/swl/compactar.md +283 -0
  89. package/comandos/swl/configurar-ci.md +227 -0
  90. package/comandos/swl/contexto.md +112 -0
  91. package/comandos/swl/contribuir.md +233 -0
  92. package/comandos/swl/crear-skill.md +292 -0
  93. package/comandos/swl/cron.md +196 -0
  94. package/comandos/swl/dashboard.md +146 -0
  95. package/comandos/swl/discutir-fase.md +230 -0
  96. package/comandos/swl/ejecutar-fase.md +135 -0
  97. package/comandos/swl/evaluar-skill.md +487 -0
  98. package/comandos/swl/evolucion-estado.md +142 -0
  99. package/comandos/swl/evolucionar.md +259 -0
  100. package/comandos/swl/exportar-vault.md +189 -0
  101. package/comandos/swl/gateway.md +158 -0
  102. package/comandos/swl/inbox.md +116 -0
  103. package/comandos/swl/instalar.md +220 -0
  104. package/comandos/swl/instintos.md +86 -0
  105. package/comandos/swl/mapear-codebase.md +312 -0
  106. package/comandos/swl/mcp-status.md +175 -0
  107. package/comandos/swl/metricas.md +270 -0
  108. package/comandos/swl/modelo.md +102 -0
  109. package/comandos/swl/notificaciones.md +396 -0
  110. package/comandos/swl/nuevo-proyecto.md +154 -0
  111. package/comandos/swl/planear-fase.md +221 -0
  112. package/comandos/swl/plugins.md +256 -0
  113. package/comandos/swl/reflect-skills.md +125 -0
  114. package/comandos/swl/release.md +217 -0
  115. package/comandos/swl/revisar-impacto.md +206 -0
  116. package/comandos/swl/revisar.md +330 -0
  117. package/comandos/swl/salud.md +363 -0
  118. package/comandos/swl/sesiones.md +200 -0
  119. package/comandos/swl/skill-search.md +113 -0
  120. package/comandos/swl/verificar.md +585 -0
  121. package/comandos/swl/wiki.md +620 -0
  122. package/contextos/dev.md +32 -0
  123. package/contextos/research.md +30 -0
  124. package/contextos/review.md +31 -0
  125. package/habilidades/accesibilidad-a11y/SKILL.md +201 -0
  126. package/habilidades/accesibilidad-a11y/evals/evals.json +56 -0
  127. package/habilidades/accesibilidad-a11y/recursos/ejemplos-y-checklist-completo.md +441 -0
  128. package/habilidades/agent-browser/SKILL.md +218 -0
  129. package/habilidades/agentes-como-servicio/SKILL.md +218 -0
  130. package/habilidades/ai-runtime-security/SKILL.md +273 -0
  131. package/habilidades/angular-avanzado/SKILL.md +164 -0
  132. package/habilidades/angular-avanzado/recursos/ejemplos-avanzados.md +219 -0
  133. package/habilidades/angular-moderno/SKILL.md +186 -0
  134. package/habilidades/angular-moderno/evals/evals.json +45 -0
  135. package/habilidades/angular-moderno/recursos/ejemplos-avanzados.md +106 -0
  136. package/habilidades/api-rest-diseno/SKILL.md +191 -0
  137. package/habilidades/api-rest-diseno/recursos/openapi-template.yaml +506 -0
  138. package/habilidades/api-rest-diseno/recursos/referencia-api.md +140 -0
  139. package/habilidades/aprendizaje-continuo/SKILL.md +151 -0
  140. package/habilidades/aprendizaje-continuo/evals/evals.json +53 -0
  141. package/habilidades/aprendizaje-continuo/recursos/referencia-instintos.md +290 -0
  142. package/habilidades/async-python/SKILL.md +149 -0
  143. package/habilidades/async-python/evals/evals.json +47 -0
  144. package/habilidades/async-python/recursos/patrones-y-ejemplos-completos.md +292 -0
  145. package/habilidades/auth-patrones/.evolved.json +9 -0
  146. package/habilidades/auth-patrones/SKILL.md +413 -0
  147. package/habilidades/auth-patrones/recursos/implementaciones-completas.md +229 -0
  148. package/habilidades/auto-evolucion-protocolo/SKILL.md +276 -0
  149. package/habilidades/auto-evolucion-protocolo/evals/evals.json +55 -0
  150. package/habilidades/auto-evolucion-protocolo/recursos/referencia-completa.md +145 -0
  151. package/habilidades/autoresearch/SKILL.md +268 -0
  152. package/habilidades/autoresearch/evals/evals.json +41 -0
  153. package/habilidades/autoresearch/recursos/checklist-template.md +191 -0
  154. package/habilidades/autoresearch/scripts/calcular-score.js +88 -0
  155. package/habilidades/azure-cloud/SKILL.md +308 -0
  156. package/habilidades/azure-cloud/recursos/aks.md +327 -0
  157. package/habilidades/backend-mcp-servidor/SKILL.md +270 -0
  158. package/habilidades/backend-production-resilience/SKILL.md +288 -0
  159. package/habilidades/brainstorming/SKILL.md +295 -0
  160. package/habilidades/brainstorming/recursos/componentes-html.md +247 -0
  161. package/habilidades/build-errors-cpp/SKILL.md +270 -0
  162. package/habilidades/build-errors-csharp/SKILL.md +265 -0
  163. package/habilidades/build-errors-go/SKILL.md +306 -0
  164. package/habilidades/build-errors-java/SKILL.md +278 -0
  165. package/habilidades/build-errors-kotlin/SKILL.md +303 -0
  166. package/habilidades/build-errors-nextjs/SKILL.md +312 -0
  167. package/habilidades/build-errors-php/SKILL.md +270 -0
  168. package/habilidades/build-errors-python/SKILL.md +292 -0
  169. package/habilidades/build-errors-rust/SKILL.md +284 -0
  170. package/habilidades/build-errors-swift/SKILL.md +272 -0
  171. package/habilidades/build-errors-typescript/SKILL.md +369 -0
  172. package/habilidades/checklist-calidad/SKILL.md +271 -0
  173. package/habilidades/checklist-calidad/recursos/quality-report-template.md +148 -0
  174. package/habilidades/checklist-seguridad/SKILL.md +285 -0
  175. package/habilidades/checkpoints-verificacion/SKILL.md +298 -0
  176. package/habilidades/checkpoints-verificacion/recursos/checkpoint-templates.md +360 -0
  177. package/habilidades/ci-cd-pipelines/SKILL.md +157 -0
  178. package/habilidades/ci-cd-pipelines/recursos/github-actions-template.yaml +403 -0
  179. package/habilidades/ci-cd-pipelines/recursos/pipelines-completos.md +487 -0
  180. package/habilidades/cloud-aws/SKILL.md +142 -0
  181. package/habilidades/cloud-aws/recursos/servicios-aws-referencia.md +321 -0
  182. package/habilidades/compactacion-contexto/SKILL.md +247 -0
  183. package/habilidades/contenedores-docker/SKILL.md +137 -0
  184. package/habilidades/contenedores-docker/recursos/dockerfile-template.dockerfile +160 -0
  185. package/habilidades/contenedores-docker/recursos/ejemplos-y-configuraciones.md +327 -0
  186. package/habilidades/context-builder/SKILL.md +170 -0
  187. package/habilidades/control-profundidad/SKILL.md +128 -0
  188. package/habilidades/csharp-experto/SKILL.md +322 -0
  189. package/habilidades/csharp-patrones/SKILL.md +316 -0
  190. package/habilidades/csharp-testing/SKILL.md +286 -0
  191. package/habilidades/css-moderno/SKILL.md +166 -0
  192. package/habilidades/css-moderno/evals/evals.json +43 -0
  193. package/habilidades/css-moderno/recursos/ejemplos-y-patrones-completos.md +337 -0
  194. package/habilidades/datos-etl/SKILL.md +129 -0
  195. package/habilidades/datos-etl/recursos/implementaciones-completas.md +322 -0
  196. package/habilidades/dbml-experto/SKILL.md +339 -0
  197. package/habilidades/dbml-experto/evals/evals.json +56 -0
  198. package/habilidades/dependencias-auditoria/SKILL.md +320 -0
  199. package/habilidades/deprecacion-migracion/SKILL.md +169 -0
  200. package/habilidades/deprecacion-migracion/recursos/implementaciones-completas.md +220 -0
  201. package/habilidades/design-tokens/SKILL.md +158 -0
  202. package/habilidades/design-tokens/recursos/tokens-y-configuracion.md +363 -0
  203. package/habilidades/devsecops-pipeline-security/SKILL.md +309 -0
  204. package/habilidades/diagrama-arquitectura/SKILL.md +165 -0
  205. package/habilidades/diagrama-arquitectura/assets/template.html +276 -0
  206. package/habilidades/discutir-fase/SKILL.md +188 -0
  207. package/habilidades/diseno-herramientas-agente/SKILL.md +199 -0
  208. package/habilidades/diseno-responsivo/SKILL.md +186 -0
  209. package/habilidades/diseno-responsivo/recursos/ejemplos-layouts.md +156 -0
  210. package/habilidades/django-experto/SKILL.md +205 -0
  211. package/habilidades/django-experto/recursos/async-django.md +390 -0
  212. package/habilidades/django-experto/recursos/drf-patrones.md +438 -0
  213. package/habilidades/django-experto/recursos/orm-avanzado.md +382 -0
  214. package/habilidades/django-experto/recursos/referencia-completa.md +188 -0
  215. package/habilidades/django-experto/recursos/testing-django.md +415 -0
  216. package/habilidades/doc-sync/SKILL.md +280 -0
  217. package/habilidades/drift-detection/SKILL.md +179 -0
  218. package/habilidades/ejecutar-fase/SKILL.md +468 -0
  219. package/habilidades/estilo-sin-ai-isms/SKILL.md +775 -0
  220. package/habilidades/estilo-sin-ai-isms/evals/evals.json +63 -0
  221. package/habilidades/estilo-sin-ai-isms/scripts/detectar_aiisms.py +500 -0
  222. package/habilidades/estructura-proyecto-claude/SKILL.md +215 -0
  223. package/habilidades/estructura-proyecto-claude/recursos/claude-md-template.md +261 -0
  224. package/habilidades/estructura-proyecto-claude/recursos/configuracion-y-extensiones.md +176 -0
  225. package/habilidades/estructura-proyecto-claude/recursos/frontmatter-y-hooks-referencia.md +289 -0
  226. package/habilidades/estructura-proyecto-claude/recursos/mcp-json-template.json +77 -0
  227. package/habilidades/estructura-proyecto-claude/recursos/variantes-por-stack.md +177 -0
  228. package/habilidades/evaluacion-agentes/SKILL.md +314 -0
  229. package/habilidades/event-driven/SKILL.md +153 -0
  230. package/habilidades/event-driven/recursos/implementaciones-completas.md +423 -0
  231. package/habilidades/extraccion-documentos/SKILL.md +221 -0
  232. package/habilidades/extractor-de-aprendizajes/.evolved.json +9 -0
  233. package/habilidades/extractor-de-aprendizajes/SKILL.md +311 -0
  234. package/habilidades/extractor-de-aprendizajes/evals/evals.json +55 -0
  235. package/habilidades/fastapi-experto/SKILL.md +221 -0
  236. package/habilidades/fastapi-experto/recursos/async-patterns.md +438 -0
  237. package/habilidades/fastapi-experto/recursos/dependency-injection.md +330 -0
  238. package/habilidades/fastapi-experto/recursos/referencia-completa.md +79 -0
  239. package/habilidades/fastapi-experto/recursos/testing-httpx.md +420 -0
  240. package/habilidades/filament-admin/SKILL.md +290 -0
  241. package/habilidades/frontend-avanzado/SKILL.md +257 -0
  242. package/habilidades/frontend-avanzado/recursos/apis-nativas-ejemplos.md +341 -0
  243. package/habilidades/gcp-cloud/SKILL.md +260 -0
  244. package/habilidades/gcp-cloud/recursos/gke.md +234 -0
  245. package/habilidades/gcp-cloud/recursos/terraform-gcp.md +307 -0
  246. package/habilidades/generacion-mermaid/SKILL.md +229 -0
  247. package/habilidades/git-worktrees-paralelo/SKILL.md +270 -0
  248. package/habilidades/go-experto/SKILL.md +305 -0
  249. package/habilidades/go-patrones/SKILL.md +299 -0
  250. package/habilidades/go-testing/SKILL.md +291 -0
  251. package/habilidades/graphql-experto/SKILL.md +323 -0
  252. package/habilidades/guardrail-semantico/SKILL.md +282 -0
  253. package/habilidades/harness-claude-code/SKILL.md +299 -0
  254. package/habilidades/iam-secretos/SKILL.md +265 -0
  255. package/habilidades/iam-secretos/recursos/implementaciones-completas.md +356 -0
  256. package/habilidades/infra-github-actions/SKILL.md +166 -0
  257. package/habilidades/instalar-sistema/.evolved.json +9 -0
  258. package/habilidades/instalar-sistema/SKILL.md +221 -0
  259. package/habilidades/java-experto/SKILL.md +290 -0
  260. package/habilidades/java-patrones/SKILL.md +275 -0
  261. package/habilidades/java-testing/SKILL.md +288 -0
  262. package/habilidades/kotlin-compose/SKILL.md +278 -0
  263. package/habilidades/kotlin-compose/recursos/animaciones-performance.md +93 -0
  264. package/habilidades/kotlin-experto/SKILL.md +318 -0
  265. package/habilidades/kotlin-testing/SKILL.md +267 -0
  266. package/habilidades/kotlin-testing/recursos/testing-avanzado.md +74 -0
  267. package/habilidades/kubernetes-orquestacion/SKILL.md +152 -0
  268. package/habilidades/kubernetes-orquestacion/recursos/manifiestos-completos.md +452 -0
  269. package/habilidades/langchain-langraph/SKILL.md +386 -0
  270. package/habilidades/langchain-langraph/recursos/evaluacion-rag.md +321 -0
  271. package/habilidades/langchain-langraph/recursos/rag-maturity-model.md +225 -0
  272. package/habilidades/langchain-langraph/recursos/vectorstores.md +306 -0
  273. package/habilidades/legacy-code-rescue/SKILL.md +267 -0
  274. package/habilidades/likec4-experto/SKILL.md +412 -0
  275. package/habilidades/likec4-experto/evals/evals.json +69 -0
  276. package/habilidades/manejo-errores/.evolved.json +9 -0
  277. package/habilidades/manejo-errores/SKILL.md +407 -0
  278. package/habilidades/manejo-errores/recursos/implementaciones-completas.md +248 -0
  279. package/habilidades/mapear-codebase/SKILL.md +275 -0
  280. package/habilidades/memoria-busqueda/SKILL.md +194 -0
  281. package/habilidades/memoria-busqueda/evals/evals.json +44 -0
  282. package/habilidades/meta-skills-estandar/SKILL.md +298 -0
  283. package/habilidades/meta-skills-estandar/recursos/anti-patrones-y-leyes.md +205 -0
  284. package/habilidades/meta-skills-estandar/recursos/frameworks-seguridad.md +107 -0
  285. package/habilidades/meta-skills-estandar/recursos/idiomas-framework.md +60 -0
  286. package/habilidades/meta-skills-estandar/recursos/skills-as-agents.md +163 -0
  287. package/habilidades/microservicios/SKILL.md +155 -0
  288. package/habilidades/microservicios/recursos/patrones-y-ejemplos-completos.md +325 -0
  289. package/habilidades/mobile-flutter/SKILL.md +199 -0
  290. package/habilidades/mobile-flutter/recursos/ejemplos-completos.md +319 -0
  291. package/habilidades/mobile-react-native/SKILL.md +176 -0
  292. package/habilidades/mobile-react-native/recursos/ejemplos-completos.md +216 -0
  293. package/habilidades/mongodb-experto/SKILL.md +302 -0
  294. package/habilidades/monitoring-alertas/SKILL.md +201 -0
  295. package/habilidades/monitoring-alertas/recursos/instrumentacion-y-alertas.md +301 -0
  296. package/habilidades/nestjs-experto/SKILL.md +307 -0
  297. package/habilidades/nestjs-experto/recursos/guards-interceptors.md +339 -0
  298. package/habilidades/nestjs-experto/recursos/modulos-di.md +287 -0
  299. package/habilidades/nestjs-experto/recursos/testing-nestjs.md +354 -0
  300. package/habilidades/nextjs-experto/SKILL.md +335 -0
  301. package/habilidades/nextjs-patrones/SKILL.md +303 -0
  302. package/habilidades/nextjs-testing/SKILL.md +331 -0
  303. package/habilidades/node-experto/.evolved.json +9 -0
  304. package/habilidades/node-experto/SKILL.md +266 -0
  305. package/habilidades/node-experto/recursos/patrones-completos.md +283 -0
  306. package/habilidades/notificaciones-multicanal/SKILL.md +159 -0
  307. package/habilidades/notificaciones-multicanal/recursos/config-template.json +115 -0
  308. package/habilidades/notificaciones-multicanal/recursos/configuracion-y-templates.md +303 -0
  309. package/habilidades/nuevo-proyecto/SKILL.md +204 -0
  310. package/habilidades/orquestacion-async/SKILL.md +303 -0
  311. package/habilidades/paid-media-tracking/SKILL.md +269 -0
  312. package/habilidades/paid-media-tracking/recursos/auditoria-tracking.md +220 -0
  313. package/habilidades/paid-media-tracking/recursos/google-ads-api.md +215 -0
  314. package/habilidades/patrones-python/SKILL.md +228 -0
  315. package/habilidades/patrones-python/evals/evals.json +56 -0
  316. package/habilidades/patrones-python/recursos/patrones-avanzados.md +469 -0
  317. package/habilidades/patrones-python/recursos/referencia-completa.md +202 -0
  318. package/habilidades/perfil-usuario/SKILL.md +200 -0
  319. package/habilidades/perfil-usuario/evals/evals.json +55 -0
  320. package/habilidades/performance-baseline/SKILL.md +297 -0
  321. package/habilidades/php-experto/SKILL.md +291 -0
  322. package/habilidades/php-patrones/SKILL.md +306 -0
  323. package/habilidades/php-testing/SKILL.md +280 -0
  324. package/habilidades/planear-fase/SKILL.md +269 -0
  325. package/habilidades/postgresql-experto/SKILL.md +151 -0
  326. package/habilidades/postgresql-experto/evals/evals.json +53 -0
  327. package/habilidades/postgresql-experto/recursos/referencia-completa.md +215 -0
  328. package/habilidades/prevencion-racionalizacion/SKILL.md +175 -0
  329. package/habilidades/prevencion-sobreingenieria/SKILL.md +323 -0
  330. package/habilidades/privacy-memoria/SKILL.md +141 -0
  331. package/habilidades/privacy-memoria/evals/evals.json +43 -0
  332. package/habilidades/prompt-engineering/SKILL.md +518 -0
  333. package/habilidades/prompt-engineering/recursos/patrones-avanzados.md +467 -0
  334. package/habilidades/rag-arquitectura/SKILL.md +338 -0
  335. package/habilidades/rails-experto/SKILL.md +237 -0
  336. package/habilidades/rails-experto/recursos/active-record.md +260 -0
  337. package/habilidades/rails-experto/recursos/hotwire-turbo.md +293 -0
  338. package/habilidades/rails-experto/recursos/testing-rspec.md +362 -0
  339. package/habilidades/react-experto/SKILL.md +209 -0
  340. package/habilidades/react-experto/evals/evals.json +55 -0
  341. package/habilidades/react-experto/recursos/patrones-y-ejemplos-completos.md +240 -0
  342. package/habilidades/react-optimizacion/SKILL.md +174 -0
  343. package/habilidades/react-optimizacion/recursos/patrones-avanzados.md +138 -0
  344. package/habilidades/redis-experto/SKILL.md +305 -0
  345. package/habilidades/release-semver/.evolved.json +9 -0
  346. package/habilidades/release-semver/SKILL.md +248 -0
  347. package/habilidades/release-semver/scripts/generar-changelog.sh +238 -0
  348. package/habilidades/rust-experto/SKILL.md +400 -0
  349. package/habilidades/rust-patrones/SKILL.md +296 -0
  350. package/habilidades/rust-testing/SKILL.md +311 -0
  351. package/habilidades/seguridad-skills-ia/SKILL.md +262 -0
  352. package/habilidades/sql-optimizacion/SKILL.md +200 -0
  353. package/habilidades/sql-optimizacion/evals/evals.json +54 -0
  354. package/habilidades/sql-optimizacion/recursos/patrones-sql-avanzados.md +131 -0
  355. package/habilidades/sre-patrones/SKILL.md +333 -0
  356. package/habilidades/sre-patrones/recursos/chaos-engineering.md +241 -0
  357. package/habilidades/sre-patrones/recursos/oncall-design.md +236 -0
  358. package/habilidades/stripe-pagos/SKILL.md +550 -0
  359. package/habilidades/stripe-pagos/recursos/errores-reintentos.md +390 -0
  360. package/habilidades/stripe-pagos/recursos/stripe-connect.md +290 -0
  361. package/habilidades/structured-outputs/SKILL.md +343 -0
  362. package/habilidades/swift-experto/SKILL.md +320 -0
  363. package/habilidades/swift-experto/recursos/keychain-y-wrappers.md +110 -0
  364. package/habilidades/swift-patrones/SKILL.md +313 -0
  365. package/habilidades/swift-patrones/recursos/tca-ejemplo-completo.md +113 -0
  366. package/habilidades/swift-testing/SKILL.md +254 -0
  367. package/habilidades/swift-testing/recursos/xcuitest-planes.md +143 -0
  368. package/habilidades/swl-dashboard/SKILL.md +370 -0
  369. package/habilidades/swl-markitdown/SKILL.md +285 -0
  370. package/habilidades/swl-markitdown/evals/evals.json +52 -0
  371. package/habilidades/swl-revisar-impacto/SKILL.md +233 -0
  372. package/habilidades/tailwind-experto/SKILL.md +240 -0
  373. package/habilidades/tailwind-experto/recursos/referencia-completa.md +184 -0
  374. package/habilidades/tdd-workflow/SKILL.md +293 -0
  375. package/habilidades/terraform-experto/SKILL.md +321 -0
  376. package/habilidades/testing-python/SKILL.md +340 -0
  377. package/habilidades/testing-python/recursos/ejemplos-completos.md +167 -0
  378. package/habilidades/threat-model-lite/SKILL.md +246 -0
  379. package/habilidades/tracing-processor/SKILL.md +212 -0
  380. package/habilidades/tracking-measurement/SKILL.md +239 -0
  381. package/habilidades/tracking-measurement/recursos/consent-mode.md +231 -0
  382. package/habilidades/tracking-measurement/recursos/gtm-datalayer.md +216 -0
  383. package/habilidades/tracking-measurement/recursos/meta-capi.md +262 -0
  384. package/habilidades/typescript-avanzado/SKILL.md +144 -0
  385. package/habilidades/typescript-avanzado/evals/evals.json +55 -0
  386. package/habilidades/typescript-avanzado/recursos/patrones-y-ejemplos-completos.md +298 -0
  387. package/habilidades/typescript-diagnosticos/SKILL.md +513 -0
  388. package/habilidades/ux-diseno/SKILL.md +116 -0
  389. package/habilidades/ux-diseno/evals/evals.json +43 -0
  390. package/habilidades/ux-diseno/recursos/patrones-ux-referencia.md +214 -0
  391. package/habilidades/validacion-ci-sistema/SKILL.md +136 -0
  392. package/habilidades/validacion-ci-sistema/recursos/validadores-completos.md +369 -0
  393. package/habilidades/validacion-ci-sistema/scripts/validar-sistema.sh +286 -0
  394. package/habilidades/verificacion-evidencia/SKILL.md +160 -0
  395. package/habilidades/verificar-trabajo/SKILL.md +303 -0
  396. package/habilidades/verificar-trabajo/recursos/plantilla-verificacion.md +60 -0
  397. package/habilidades/wiki-conocimiento/SKILL.md +276 -0
  398. package/habilidades/wireframes-flujos/SKILL.md +212 -0
  399. package/habilidades/wireframes-flujos/recursos/referencia-completa.md +192 -0
  400. package/habilidades/workflow-claude-code/SKILL.md +260 -0
  401. package/habilidades/workflow-claude-code/recursos/referencia-completa.md +109 -0
  402. package/hooks/_run-hook.sh +57 -0
  403. package/hooks/actualizar-perfil-usuario.js +364 -0
  404. package/hooks/agente-lifecycle.js +71 -0
  405. package/hooks/aiisms-detector.js +173 -0
  406. package/hooks/audit-trail.js +204 -0
  407. package/hooks/auto-background.js +97 -0
  408. package/hooks/auto-consolidacion.js +178 -0
  409. package/hooks/auto-evolucion.js +666 -0
  410. package/hooks/auto-restaurar-settings.js +360 -0
  411. package/hooks/calidad-pre-commit.js +929 -0
  412. package/hooks/calidad-typescript.js +511 -0
  413. package/hooks/captura-feedback-usuario.js +148 -0
  414. package/hooks/check-update.js +211 -0
  415. package/hooks/clasificador-mensajes.js +271 -0
  416. package/hooks/degradacion-instintos.js +272 -0
  417. package/hooks/escaneo-secretos.js +389 -0
  418. package/hooks/extraccion-aprendizajes.js +763 -0
  419. package/hooks/grafo-contexto.js +129 -0
  420. package/hooks/graph-update.js +67 -0
  421. package/hooks/guardrail-modelo.js +247 -0
  422. package/hooks/inbox-aviso.js +75 -0
  423. package/hooks/inyeccion-contexto.js +246 -0
  424. package/hooks/lib/abort-registry.js +214 -0
  425. package/hooks/lib/agent-backend.js +210 -0
  426. package/hooks/lib/agent-comms.js +263 -0
  427. package/hooks/lib/agent-issue-codes.js +284 -0
  428. package/hooks/lib/agent-matcher.js +189 -0
  429. package/hooks/lib/async-hook-registry.js +252 -0
  430. package/hooks/lib/atomic-write.js +130 -0
  431. package/hooks/lib/auto-consolidator.js +335 -0
  432. package/hooks/lib/canary-skills.js +187 -0
  433. package/hooks/lib/consolidation-lock.js +291 -0
  434. package/hooks/lib/context-builder.js +430 -0
  435. package/hooks/lib/context-compressor.js +657 -0
  436. package/hooks/lib/convergence-detector.js +105 -0
  437. package/hooks/lib/delegation-tracker.js +198 -0
  438. package/hooks/lib/detectar-package-manager.js +423 -0
  439. package/hooks/lib/edit-accumulator.js +171 -0
  440. package/hooks/lib/error-classifier.js +308 -0
  441. package/hooks/lib/event-bus.js +112 -0
  442. package/hooks/lib/evolution-tracker.js +442 -0
  443. package/hooks/lib/execution-state.js +316 -0
  444. package/hooks/lib/fingerprint-id.js +135 -0
  445. package/hooks/lib/gateway-notify.js +116 -0
  446. package/hooks/lib/graph-security.js +75 -0
  447. package/hooks/lib/guardrail-metrics.js +202 -0
  448. package/hooks/lib/hook-circuit-breaker.js +206 -0
  449. package/hooks/lib/loop-detector.js +267 -0
  450. package/hooks/lib/mcp-health.js +184 -0
  451. package/hooks/lib/mcp-pool.js +436 -0
  452. package/hooks/lib/memory-search.js +506 -0
  453. package/hooks/lib/merkle-audit.js +96 -0
  454. package/hooks/lib/model-router.js +222 -0
  455. package/hooks/lib/normalize-error.js +324 -0
  456. package/hooks/lib/normalize-input.js +65 -0
  457. package/hooks/lib/nudge-tracker.js +306 -0
  458. package/hooks/lib/otlp-exporter.js +365 -0
  459. package/hooks/lib/performance-marks.js +239 -0
  460. package/hooks/lib/privacy-filter.js +128 -0
  461. package/hooks/lib/prompt-injection-scanner.js +209 -0
  462. package/hooks/lib/provenance-tracker.js +183 -0
  463. package/hooks/lib/rate-limit-tracker.js +253 -0
  464. package/hooks/lib/reflect-classifier.js +164 -0
  465. package/hooks/lib/resource-quota.js +122 -0
  466. package/hooks/lib/retry-jitter.js +165 -0
  467. package/hooks/lib/risk-engine.js +368 -0
  468. package/hooks/lib/run-log.js +408 -0
  469. package/hooks/lib/session-fts.js +379 -0
  470. package/hooks/lib/session-store.js +293 -0
  471. package/hooks/lib/singleton-guard.js +159 -0
  472. package/hooks/lib/skill-auditor.js +588 -0
  473. package/hooks/lib/sync-status.js +228 -0
  474. package/hooks/lib/taint-tracker.js +107 -0
  475. package/hooks/lib/task-service.js +295 -0
  476. package/hooks/lib/tech-skills-map.js +146 -0
  477. package/hooks/lib/telegram-cliente.js +159 -0
  478. package/hooks/lib/telegram-config.js +170 -0
  479. package/hooks/lib/token-budget.js +156 -0
  480. package/hooks/lib/token-estimator.js +420 -0
  481. package/hooks/lib/toon-compressor.js +245 -0
  482. package/hooks/lib/usage-model.js +183 -0
  483. package/hooks/lib/variable-resolver.js +230 -0
  484. package/hooks/linea-estado.js +324 -0
  485. package/hooks/metricas-evolucion.js +209 -0
  486. package/hooks/monitor-contexto.js +325 -0
  487. package/hooks/notificacion-sesion-stop.js +198 -0
  488. package/hooks/notificacion-telegram-notification.js +4 -0
  489. package/hooks/notificacion-telegram-subagent.js +4 -0
  490. package/hooks/notificacion-telegram.js +267 -0
  491. package/hooks/preservar-estado-pre-compact.js +150 -0
  492. package/hooks/proteccion-rutas.js +366 -0
  493. package/hooks/registro-turnos.js +209 -0
  494. package/hooks/resumen-sesion.js +249 -0
  495. package/hooks/risk-scoring.js +323 -0
  496. package/hooks/rotar-audit-auto.js +122 -0
  497. package/hooks/sugerir-regenerar-inventario.js +170 -0
  498. package/hooks/telemetria-agentes.js +167 -0
  499. package/hooks/tracking-costos.js +688 -0
  500. package/instintos/global.yaml +8 -0
  501. package/instintos/perfil-usuario.yaml +53 -0
  502. package/instintos/prompt-appendices.yaml +57 -0
  503. package/instintos/proyecto.yaml +372 -0
  504. package/manifiestos/gateway-config.json +77 -0
  505. package/manifiestos/handoff-context.json +223 -0
  506. package/manifiestos/hook-profiles.json +44 -0
  507. package/manifiestos/hooks-config.json +360 -0
  508. package/manifiestos/modulos.json +1173 -0
  509. package/manifiestos/perfiles.json +404 -0
  510. package/package.json +86 -0
  511. package/plantillas/ESTADO.md +109 -0
  512. package/plantillas/HOJA-RUTA.md +143 -0
  513. package/plantillas/PROYECTO.md +122 -0
  514. package/plantillas/REQUISITOS.md +132 -0
  515. package/plantillas/auditor-veto-template.md +105 -0
  516. package/plantillas/github-workflows/README.md +47 -0
  517. package/plantillas/github-workflows/release-please.yml +44 -0
  518. package/plantillas/github-workflows/swl-ci.yml +107 -0
  519. package/plantillas/github-workflows/swl-security.yml +51 -0
  520. package/plantillas/mcp-mineru.json +13 -0
  521. package/plantillas/research/ARQUITECTURA.md +220 -0
  522. package/plantillas/research/FUNCIONALIDADES.md +175 -0
  523. package/plantillas/research/RESUMEN.md +165 -0
  524. package/plantillas/research/STACK.md +233 -0
  525. package/plantillas/research/TRAMPAS.md +299 -0
  526. package/plantillas/skill-evals-template.json +44 -0
  527. package/plugin.json +343 -0
  528. package/reglas/accesibilidad.md +269 -0
  529. package/reglas/api-diseno.md +400 -0
  530. package/reglas/arquitectura.md +352 -0
  531. package/reglas/brevedad-output.md +124 -0
  532. package/reglas/cloud-infra.md +247 -0
  533. package/reglas/docs.md +245 -0
  534. package/reglas/estilo-codigo.md +201 -0
  535. package/reglas/git-workflow.md +245 -0
  536. package/reglas/gobernanza.md +271 -0
  537. package/reglas/harness-claude-code.md +213 -0
  538. package/reglas/hooks.md +186 -0
  539. package/reglas/lenguajes/csharp/estilo-codigo.md +231 -0
  540. package/reglas/lenguajes/csharp/hooks.md +281 -0
  541. package/reglas/lenguajes/csharp/patrones.md +226 -0
  542. package/reglas/lenguajes/csharp/seguridad.md +258 -0
  543. package/reglas/lenguajes/csharp/testing.md +176 -0
  544. package/reglas/lenguajes/go/estilo-codigo.md +195 -0
  545. package/reglas/lenguajes/go/hooks.md +249 -0
  546. package/reglas/lenguajes/go/patrones.md +249 -0
  547. package/reglas/lenguajes/go/seguridad.md +225 -0
  548. package/reglas/lenguajes/go/testing.md +272 -0
  549. package/reglas/lenguajes/java/estilo-codigo.md +217 -0
  550. package/reglas/lenguajes/java/hooks.md +251 -0
  551. package/reglas/lenguajes/java/patrones.md +226 -0
  552. package/reglas/lenguajes/java/seguridad.md +233 -0
  553. package/reglas/lenguajes/java/testing.md +238 -0
  554. package/reglas/lenguajes/kotlin/estilo-codigo.md +208 -0
  555. package/reglas/lenguajes/kotlin/hooks.md +245 -0
  556. package/reglas/lenguajes/kotlin/patrones.md +201 -0
  557. package/reglas/lenguajes/kotlin/seguridad.md +202 -0
  558. package/reglas/lenguajes/kotlin/testing.md +236 -0
  559. package/reglas/lenguajes/nextjs/estilo-codigo.md +175 -0
  560. package/reglas/lenguajes/nextjs/hooks.md +186 -0
  561. package/reglas/lenguajes/nextjs/patrones.md +225 -0
  562. package/reglas/lenguajes/nextjs/seguridad.md +216 -0
  563. package/reglas/lenguajes/nextjs/testing.md +193 -0
  564. package/reglas/lenguajes/php/estilo-codigo.md +228 -0
  565. package/reglas/lenguajes/php/hooks.md +165 -0
  566. package/reglas/lenguajes/php/patrones.md +233 -0
  567. package/reglas/lenguajes/php/seguridad.md +186 -0
  568. package/reglas/lenguajes/php/testing.md +205 -0
  569. package/reglas/lenguajes/rust/estilo-codigo.md +207 -0
  570. package/reglas/lenguajes/rust/hooks.md +240 -0
  571. package/reglas/lenguajes/rust/patrones.md +250 -0
  572. package/reglas/lenguajes/rust/seguridad.md +221 -0
  573. package/reglas/lenguajes/rust/testing.md +194 -0
  574. package/reglas/lenguajes/swift/estilo-codigo.md +238 -0
  575. package/reglas/lenguajes/swift/hooks.md +257 -0
  576. package/reglas/lenguajes/swift/patrones.md +235 -0
  577. package/reglas/lenguajes/swift/seguridad.md +248 -0
  578. package/reglas/lenguajes/swift/testing.md +242 -0
  579. package/reglas/markitdown.md +60 -0
  580. package/reglas/memoria-consolidada.md +209 -0
  581. package/reglas/patrones.md +225 -0
  582. package/reglas/performance.md +195 -0
  583. package/reglas/pruebas.md +159 -0
  584. package/reglas/seguridad-agentes.md +351 -0
  585. package/reglas/seguridad.md +151 -0
  586. package/reglas/skills-estandar.md +373 -0
  587. package/reglas/testing.md +193 -0
  588. package/schemas/agent-contract.json +176 -0
  589. package/schemas/agent-frontmatter.schema.json +149 -0
  590. package/schemas/agent-message.schema.json +53 -0
  591. package/schemas/agent-output-implementacion.schema.json +85 -0
  592. package/schemas/agent-output-planificacion.schema.json +113 -0
  593. package/schemas/agent-output-review.schema.json +78 -0
  594. package/schemas/diary-entry.schema.json +80 -0
  595. package/schemas/hook-profiles.schema.json +39 -0
  596. package/schemas/hooks-config.schema.json +74 -0
  597. package/schemas/instinct.schema.json +115 -0
  598. package/schemas/modulos.schema.json +29 -0
  599. package/schemas/perfiles.schema.json +28 -0
  600. package/schemas/plugin.schema.json +64 -0
  601. package/schemas/skill-evals.schema.json +95 -0
  602. package/schemas/skill-frontmatter.schema.json +170 -0
  603. package/scripts/actualizar.js +145 -0
  604. package/scripts/audit-skills.sh +78 -0
  605. package/scripts/auditar-agentes-gaps.js +149 -0
  606. package/scripts/auditar-cobertura-frameworks.js +241 -0
  607. package/scripts/auditar-skills-gaps.js +206 -0
  608. package/scripts/bootstrap-instintos.js +259 -0
  609. package/scripts/check-update.js +109 -0
  610. package/scripts/comandos/agents.js +105 -0
  611. package/scripts/comandos/info.js +108 -0
  612. package/scripts/comandos/install-asistido.js +186 -0
  613. package/scripts/comandos/skills.js +211 -0
  614. package/scripts/configurar-branch-protection.js +418 -0
  615. package/scripts/daemon-swl.py +388 -0
  616. package/scripts/desinstalar.js +130 -0
  617. package/scripts/doctor.js +559 -0
  618. package/scripts/field-report.js +199 -0
  619. package/scripts/generar-inventario.js +317 -0
  620. package/scripts/inbox-tmux-inject.js +161 -0
  621. package/scripts/inferir-herramientas-permitidas.js +586 -0
  622. package/scripts/inicializar.js +133 -0
  623. package/scripts/instalador.js +1031 -0
  624. package/scripts/instalar-git-hook.js +122 -0
  625. package/scripts/lib/agp-frontmatter.js +222 -0
  626. package/scripts/lib/append-con-marcadores.js +199 -0
  627. package/scripts/lib/artefactos-python.js +43 -0
  628. package/scripts/lib/audit-query.js +221 -0
  629. package/scripts/lib/autostart-linux.js +347 -0
  630. package/scripts/lib/autostart-macos.js +360 -0
  631. package/scripts/lib/autostart-windows.js +307 -0
  632. package/scripts/lib/budget-enforcer.js +252 -0
  633. package/scripts/lib/claude-sessions.js +285 -0
  634. package/scripts/lib/configurar-ci.js +380 -0
  635. package/scripts/lib/console-span-exporter.js +92 -0
  636. package/scripts/lib/contadores-inventario.js +217 -0
  637. package/scripts/lib/dashboard-widgets.js +290 -0
  638. package/scripts/lib/detectar-runtime.js +279 -0
  639. package/scripts/lib/detectar-stack.js +187 -0
  640. package/scripts/lib/diary-entry.js +234 -0
  641. package/scripts/lib/drift-detector.js +545 -0
  642. package/scripts/lib/estado.js +124 -0
  643. package/scripts/lib/gestor-componentes.js +243 -0
  644. package/scripts/lib/gitignore-manifest.js +305 -0
  645. package/scripts/lib/graph-analyze.py +556 -0
  646. package/scripts/lib/graph-builder.py +485 -0
  647. package/scripts/lib/graph-cluster.py +259 -0
  648. package/scripts/lib/health-row.js +168 -0
  649. package/scripts/lib/hooks-settings.js +789 -0
  650. package/scripts/lib/manifiestos.js +138 -0
  651. package/scripts/lib/mc-client.js +137 -0
  652. package/scripts/lib/notificaciones-telegram.js +1107 -0
  653. package/scripts/lib/npm-version.js +261 -0
  654. package/scripts/lib/paquetes-conocidos.js +50 -0
  655. package/scripts/lib/preservar-usuario.js +586 -0
  656. package/scripts/lib/prompt-builder.js +264 -0
  657. package/scripts/lib/resolver-externo.js +332 -0
  658. package/scripts/lib/schedule-parser.js +305 -0
  659. package/scripts/lib/scoring-instintos.js +240 -0
  660. package/scripts/lib/seguridad.js +160 -0
  661. package/scripts/lib/selector-interactivo.js +152 -0
  662. package/scripts/lib/semantic-search.js +242 -0
  663. package/scripts/lib/skill-discovery.js +234 -0
  664. package/scripts/lib/skill-metrics.js +246 -0
  665. package/scripts/lib/skill-normalizer.js +112 -0
  666. package/scripts/lib/skills-hub.js +340 -0
  667. package/scripts/lib/span-schema.js +134 -0
  668. package/scripts/lib/tool-cost-analyzer.js +255 -0
  669. package/scripts/lib/tracing-processor-interface.js +286 -0
  670. package/scripts/lib/transformadores/base.js +80 -0
  671. package/scripts/lib/transformadores/claude.js +124 -0
  672. package/scripts/lib/transformadores/codex.js +115 -0
  673. package/scripts/lib/transformadores/copilot.js +106 -0
  674. package/scripts/lib/transformadores/gemini.js +74 -0
  675. package/scripts/lib/transformadores/index.js +35 -0
  676. package/scripts/lib/transformadores/opencode.js +75 -0
  677. package/scripts/lib/ui.js +259 -0
  678. package/scripts/limpiar-artefactos-python.js +131 -0
  679. package/scripts/mcp-orchestrator.py +386 -0
  680. package/scripts/mcp-pool-manager.py +352 -0
  681. package/scripts/mcp-telemetry.py +378 -0
  682. package/scripts/poblar-evolvable.js +226 -0
  683. package/scripts/publicar.js +287 -0
  684. package/scripts/reflect-skills.js +403 -0
  685. package/scripts/rotar-audit-logs.js +185 -0
  686. package/scripts/run-skill-evals.js +242 -0
  687. package/scripts/smoke-test.js +374 -0
  688. package/scripts/token-analysis.py +471 -0
  689. package/scripts/validar-manifest.js +195 -0
  690. package/scripts/validar-memoria.js +321 -0
  691. package/scripts/validar-tests-aislamiento.js +184 -0
  692. package/scripts/validar-tokens-test.js +208 -0
  693. package/scripts/validar.js +147 -0
  694. package/scripts/validate-markdown.py +339 -0
  695. package/scripts/validate-skills.py +385 -0
  696. package/scripts/vendor/claude-usage/README.md +116 -0
  697. package/scripts/vendor/claude-usage/cli.py +334 -0
  698. package/scripts/vendor/claude-usage/dashboard.py +795 -0
  699. package/scripts/vendor/claude-usage/scanner.py +467 -0
  700. package/scripts/vendor/markitdown/cli.py +194 -0
  701. package/scripts/verificar-evolucion.js +289 -0
  702. package/scripts/verificar-release.js +494 -0
@@ -0,0 +1,916 @@
1
+ ---
2
+ name: notificador-swl
3
+ description: >
4
+ Envía notificaciones multicanal al usuario cuando eventos importantes ocurren
5
+ durante la ejecución del sistema SWL. Soporta: desktop nativo (claude-notifications-go),
6
+ Telegram, WhatsApp (via webhook), email, y webhooks genéricos. Invocar
7
+ automáticamente cuando: se requiere intervención humana (checkpoint:decision,
8
+ checkpoint:human-action), una fase completó exitosamente, una verificación falló
9
+ (score < 9.0), una tarea de larga duración terminó, un agente detectó riesgo alto,
10
+ o hay un error de API o rate limiting. NO invocar para eventos rutinarios (cada
11
+ commit, cada archivo escrito, cada log) ni cuando el usuario está activamente
12
+ interactuando en la misma sesión. Preferir claude-notifications-go para
13
+ notificaciones de desktop en Windows/macOS/Linux. Integra con
14
+ respositorios-git/claude-notifications-go para notificaciones nativas.
15
+ tools: Read, Write, Bash, Grep, Glob
16
+ model: claude-haiku-4-5-20251001
17
+ modeloAlterno: claude-haiku-4-5-20251001
18
+ ventanaContexto: 200k
19
+ color: amber
20
+ version: 1.0.0
21
+ nivelRiesgo: BAJO
22
+ skillsInvocables: notificaciones-multicanal, checkpoints-verificacion
23
+ skillsRestringidos: ninguno
24
+ permisosRed: true
25
+ permisosEscritura: true
26
+ permisosComandos: true
27
+ evolvable: true # nivelRiesgo=BAJO
28
+ evolvable_scope:
29
+ - description
30
+ - examples
31
+ - instructions
32
+ invariantes:
33
+ - campo: nivelRiesgo
34
+ operador: eq
35
+ valor: BAJO
36
+ razon: Notificador nunca escala — si requiere MEDIO/ALTO hay re-disenio, no evolucion.
37
+ - campo: permisosComandos
38
+ operador: eq
39
+ valor: true
40
+ razon: Necesita ejecutar binarios de notificacion (claude-notifications-go).
41
+ exclusiones:
42
+ - "No invocar para lógica de negocio o implementación de features — este agente solo envía notificaciones de estado del sistema SWL."
43
+ - "No invocar para decisiones de diseño o planificación — esas decisiones corresponden a planificador-swl o arquitecto-swl."
44
+ - "No invocar directamente por el usuario para tareas de ingeniería — este agente es invocado por otros agentes del sistema, no por el usuario."
45
+ ---
46
+ ## Cuándo NO invocarme
47
+
48
+ - Para lógica de negocio o implementación de features — este agente solo envía notificaciones de estado del sistema SWL.
49
+ - Para decisiones de diseño o planificación — esas decisiones corresponden a `planificador-swl` o `arquitecto-swl`.
50
+ - Directamente por el usuario para tareas de ingeniería — este agente es invocado por otros agentes del sistema, no por el usuario.
51
+
52
+ Eres el agente de notificaciones del sistema SWL. Tu trabajo es informar al
53
+ usuario en el momento correcto, por el canal correcto, con el mensaje correcto.
54
+ Demasiadas notificaciones = ruido que el usuario ignora. Muy pocas = el usuario
55
+ pierde eventos críticos. Calibra con precisión.
56
+
57
+ Nunca notifiques por notificar. Cada notificación que envías cuesta atención
58
+ del usuario. Si el evento no requiere una respuesta o decisión del usuario,
59
+ probablemente no merece una notificación.
60
+
61
+ ## Rol y responsabilidad
62
+
63
+ - Evaluar si un evento merece notificación (no todo evento lo merece)
64
+ - Seleccionar el canal apropiado según la prioridad del evento y la configuración
65
+ - Formatear el mensaje apropiadamente para cada canal
66
+ - Verificar que el canal destino está activo antes de enviar
67
+ - Manejar fallos de envío con reintentos limitados
68
+ - Respetar horarios de silencio configurados
69
+ - Aplicar rate limiting para no saturar al usuario
70
+
71
+ ## Canales soportados
72
+
73
+ ### 1. Desktop nativo (claude-notifications-go)
74
+
75
+ El canal primario para notificaciones de desktop. Usa el binario nativo de
76
+ `claude-notifications-go` que se integra con el sistema de notificaciones del OS.
77
+
78
+ **Ventajas**: Sin configuración de red, funciona offline, integrado con el OS
79
+ (Windows toast, macOS notification center, Linux libnotify).
80
+
81
+ **Configuración** en `.planning/config.json`:
82
+ ```json
83
+ {
84
+ "notifications": {
85
+ "desktop": {
86
+ "enabled": true,
87
+ "sound": true,
88
+ "volume": 1.0,
89
+ "clickToFocus": true
90
+ }
91
+ }
92
+ }
93
+ ```
94
+
95
+ **Envío via claude-notifications-go:**
96
+ El binario se invoca vía el hook-wrapper.sh. Para notificaciones programáticas
97
+ desde el agente, usar el protocolo de stdout del hook:
98
+
99
+ ```bash
100
+ # El binario acepta el evento por stdin en formato JSON
101
+ echo '{"message": "[mensaje]", "title": "[título]"}' | \
102
+ "$CLAUDE_PLUGIN_ROOT/plugin-root/hook-wrapper.sh" Notification
103
+ ```
104
+
105
+ ### 2. Telegram
106
+
107
+ Canal de alta prioridad. Llega al dispositivo móvil con Markdown completo.
108
+ Ideal para notificaciones que requieren respuesta o que el usuario debe ver fuera
109
+ de su computadora.
110
+
111
+ **Configuración** en `.planning/config.json`:
112
+ ```json
113
+ {
114
+ "canales": {
115
+ "telegram": {
116
+ "enabled": true,
117
+ "bot_token": "[TOKEN_DEL_BOT]",
118
+ "chat_id": "[CHAT_ID]",
119
+ "parse_mode": "Markdown"
120
+ }
121
+ }
122
+ }
123
+ ```
124
+
125
+ **Formato de mensaje Telegram** (Markdown v1):
126
+ ```
127
+ *Título del evento* — [emoji de prioridad]
128
+
129
+ Descripción del evento en 1-3 líneas.
130
+
131
+ `Proyecto`: nombre-del-proyecto
132
+ `Agente`: nombre-agente-swl
133
+ `Hora`: HH:MM
134
+
135
+ [Acción requerida si aplica]
136
+ ```
137
+
138
+ **Límites de Telegram:**
139
+ - Máximo 4096 caracteres por mensaje
140
+ - Rate limit: 30 mensajes por segundo a diferentes chats, 1 mensaje por segundo al mismo chat
141
+ - Markdown: `*negrita*`, `_cursiva_`, `` `código` ``, `[texto](url)`
142
+
143
+ **Envío via curl:**
144
+ ```bash
145
+ curl -s -X POST \
146
+ "https://api.telegram.org/bot${BOT_TOKEN}/sendMessage" \
147
+ -H "Content-Type: application/json" \
148
+ -d "{
149
+ \"chat_id\": \"${CHAT_ID}\",
150
+ \"text\": \"${MENSAJE}\",
151
+ \"parse_mode\": \"Markdown\"
152
+ }"
153
+ ```
154
+
155
+ **Verificar respuesta:**
156
+ ```json
157
+ {"ok": true, "result": {"message_id": 123}} → éxito
158
+ {"ok": false, "error_code": 400} → error — loggear y continuar
159
+ ```
160
+
161
+ ### 3. WhatsApp (via webhook)
162
+
163
+ Canal de alta prioridad para usuarios con WhatsApp Business API configurado.
164
+ Requiere configuración previa de un webhook compatible (Twilio, Meta Cloud API,
165
+ 360dialog, o servidor propio).
166
+
167
+ **Configuración** en `.planning/config.json`:
168
+ ```json
169
+ {
170
+ "canales": {
171
+ "whatsapp": {
172
+ "enabled": false,
173
+ "webhook_url": "[URL_DEL_WEBHOOK]",
174
+ "to": "+52[NÚMERO]",
175
+ "from": "[NÚMERO_SENDER]",
176
+ "auth_token": "[TOKEN]"
177
+ }
178
+ }
179
+ }
180
+ ```
181
+
182
+ **Formato de mensaje WhatsApp:**
183
+ Solo texto plano — WhatsApp no procesa Markdown en la API.
184
+ ```
185
+ [EMOJI PRIORIDAD] [TÍTULO]
186
+
187
+ [Descripción en 2-3 líneas máximo]
188
+
189
+ Proyecto: [nombre]
190
+ Agente: [nombre]
191
+ Hora: [HH:MM]
192
+ ```
193
+
194
+ **Envío via Twilio (si configurado):**
195
+ ```bash
196
+ curl -s -X POST \
197
+ "https://api.twilio.com/2010-04-01/Accounts/${ACCOUNT_SID}/Messages.json" \
198
+ --data-urlencode "From=whatsapp:${FROM}" \
199
+ --data-urlencode "To=whatsapp:${TO}" \
200
+ --data-urlencode "Body=${MENSAJE}" \
201
+ -u "${ACCOUNT_SID}:${AUTH_TOKEN}"
202
+ ```
203
+
204
+ ### 4. Email
205
+
206
+ Canal de menor urgencia. Apropiado para reportes completos, VPATs, resúmenes
207
+ de fase, o cualquier notificación que requiera contenido extenso o adjuntos.
208
+
209
+ **Configuración** en `.planning/config.json`:
210
+ ```json
211
+ {
212
+ "canales": {
213
+ "email": {
214
+ "enabled": false,
215
+ "smtp_host": "[HOST]",
216
+ "smtp_port": 587,
217
+ "smtp_user": "[USUARIO]",
218
+ "smtp_password": "[PASSWORD]",
219
+ "from": "[remitente@dominio.com]",
220
+ "to": ["[destinatario@dominio.com]"],
221
+ "subject_prefix": "[SWL]"
222
+ }
223
+ }
224
+ }
225
+ ```
226
+
227
+ **Formato de mensaje email:**
228
+ HTML para clientes que lo soportan, con fallback en texto plano.
229
+
230
+ ```html
231
+ <h2>[Emoji] [Título del Evento]</h2>
232
+ <p>[Descripción del evento]</p>
233
+ <table>
234
+ <tr><td><strong>Proyecto</strong></td><td>[nombre]</td></tr>
235
+ <tr><td><strong>Agente</strong></td><td>[nombre]</td></tr>
236
+ <tr><td><strong>Fecha y hora</strong></td><td>[ISO 8601]</td></tr>
237
+ <tr><td><strong>Prioridad</strong></td><td>[CRÍTICA|ALTA|MEDIA|BAJA]</td></tr>
238
+ </table>
239
+ [Detalles adicionales en párrafos o lista]
240
+ ```
241
+
242
+ **Envío via Python (disponible en el entorno):**
243
+ ```bash
244
+ python3 -c "
245
+ import smtplib, os
246
+ from email.mime.multipart import MIMEMultipart
247
+ from email.mime.text import MIMEText
248
+ msg = MIMEMultipart('alternative')
249
+ msg['Subject'] = '[SWL] $ASUNTO'
250
+ msg['From'] = '$FROM'
251
+ msg['To'] = '$TO'
252
+ msg.attach(MIMEText('$TEXTO_PLANO', 'plain'))
253
+ msg.attach(MIMEText('$HTML', 'html'))
254
+ with smtplib.SMTP('$SMTP_HOST', $SMTP_PORT) as s:
255
+ s.starttls()
256
+ s.login('$SMTP_USER', '$SMTP_PASSWORD')
257
+ s.send_message(msg)
258
+ print('enviado')
259
+ "
260
+ ```
261
+
262
+ ### 5. Webhook genérico
263
+
264
+ Canal flexible para integraciones custom: Slack, Discord, Teams, ntfy.sh,
265
+ Gotify, o cualquier servicio con API HTTP.
266
+
267
+ **Configuración** en `.planning/config.json`:
268
+ ```json
269
+ {
270
+ "canales": {
271
+ "webhook": {
272
+ "enabled": false,
273
+ "url": "[URL]",
274
+ "method": "POST",
275
+ "headers": {
276
+ "Content-Type": "application/json",
277
+ "Authorization": "Bearer [TOKEN]"
278
+ },
279
+ "payload_template": "{\"text\": \"{{mensaje}}\", \"channel\": \"#swl-notifs\"}",
280
+ "preset": "slack"
281
+ }
282
+ }
283
+ }
284
+ ```
285
+
286
+ **Presets disponibles:**
287
+
288
+ Slack:
289
+ ```json
290
+ {"text": "[mensaje]", "channel": "#canal", "username": "SWL Bot"}
291
+ ```
292
+
293
+ Discord:
294
+ ```json
295
+ {"content": "[mensaje]", "username": "SWL"}
296
+ ```
297
+
298
+ ntfy.sh:
299
+ ```bash
300
+ curl -s -H "Title: $TITULO" -H "Priority: $PRIORIDAD" \
301
+ -d "$MENSAJE" "https://ntfy.sh/$TOPIC"
302
+ ```
303
+
304
+ Microsoft Teams (webhook):
305
+ ```json
306
+ {
307
+ "@type": "MessageCard",
308
+ "@context": "http://schema.org/extensions",
309
+ "summary": "[resumen]",
310
+ "themeColor": "[color hex según prioridad]",
311
+ "title": "[título]",
312
+ "text": "[mensaje]"
313
+ }
314
+ ```
315
+
316
+ ## Clasificación de eventos por prioridad
317
+
318
+ ### CRÍTICA — Notificar inmediatamente, todos los canales activos
319
+
320
+ ```
321
+ Eventos:
322
+ - checkpoint:human-action → El sistema está detenido esperando acción física
323
+ - checkpoint:decision → Decisión de negocio requerida antes de continuar
324
+ - error:api-auth → Error de autenticación con la API (401)
325
+ - error:data-loss-risk → Riesgo de pérdida de datos detectado
326
+ - riesgo:alto-detectado → Cualquier agente detectó riesgo ALTO o CRÍTICO
327
+ - verificacion:bloqueante → La verificación detectó un problema que impide el lanzamiento
328
+
329
+ Comportamiento:
330
+ - Enviar a TODOS los canales habilitados en paralelo
331
+ - Sin rate limiting (la urgencia supera el riesgo de ruido)
332
+ - Sin horarios de silencio
333
+ - Incluir instrucción de acción concreta en el mensaje
334
+ ```
335
+
336
+ ### ALTA — Notificar en canales de alta prioridad
337
+
338
+ ```
339
+ Eventos:
340
+ - fase:completada → Una fase del proyecto terminó
341
+ - verificacion:fallo → Score de verificación < 9.0
342
+ - error:api-overload → Rate limiting o error 529 de la API
343
+ - tarea:larga-completada → Tarea de >15 minutos terminó
344
+ - build:fallo → El build o los tests fallaron en CI
345
+ - dependencia:vulnerable → Dependencia con CVE crítico detectada
346
+
347
+ Canales: Telegram + Desktop (si está habilitado)
348
+ Horario de silencio: respetado, pero guardar para enviar al salir del silencio
349
+ ```
350
+
351
+ ### MEDIA — Notificar en canal principal del usuario
352
+
353
+ ```
354
+ Eventos:
355
+ - fase:iniciada → Una fase nueva comenzó
356
+ - plan:generado → Un nuevo PLAN.md fue producido
357
+ - verificacion:pasa → Verificación pasó con score >= 9.0
358
+ - revision:completada → El revisor-codigo-swl terminó su revisión
359
+ - documentacion:actualizada → Documentación generada o actualizada
360
+
361
+ Canales: Telegram o Desktop (el que el usuario prefiera)
362
+ Horario de silencio: acumular y enviar en resumen al finalizar silencio
363
+ ```
364
+
365
+ ### BAJA — Notificación opcional, solo en modo verbose
366
+
367
+ ```
368
+ Eventos:
369
+ - commit:creado → Commit atómico realizado
370
+ - archivo:escrito → Archivo de código creado/modificado
371
+ - slice:completado → Un slice de implementación terminó
372
+
373
+ Canales: Desktop únicamente si `verbose_mode: true`
374
+ Por defecto: NO notificar eventos BAJA
375
+ ```
376
+
377
+ ## Mapeo evento → canal
378
+
379
+ ```
380
+ | Evento | CRÍTICA | ALTA | MEDIA | BAJA |
381
+ |--------|---------|------|-------|------|
382
+ | checkpoint:human-action | Todos | - | - | - |
383
+ | checkpoint:decision | Todos | - | - | - |
384
+ | verificacion:fallo | - | Telegram+Desktop | - | - |
385
+ | verificacion:pasa | - | - | Telegram|Desktop | - |
386
+ | fase:completada | - | Telegram+Desktop | - | - |
387
+ | tarea:larga-completada | - | Telegram+Desktop | - | - |
388
+ | error:api-auth | Todos | - | - | - |
389
+ | error:api-overload | - | Telegram+Desktop | - | - |
390
+ | riesgo:alto | Todos | - | - | - |
391
+ | plan:generado | - | - | Telegram|Desktop | - |
392
+ | commit:creado | - | - | - | Desktop(verbose) |
393
+ ```
394
+
395
+ ## Supresión y rate limiting
396
+
397
+ ### Rate limiting
398
+
399
+ Para evitar saturar al usuario con el mismo tipo de evento:
400
+
401
+ ```json
402
+ {
403
+ "rate_limiting": {
404
+ "min_segundos_entre_misma_prioridad": {
405
+ "CRITICA": 0,
406
+ "ALTA": 30,
407
+ "MEDIA": 120,
408
+ "BAJA": 300
409
+ },
410
+ "max_notificaciones_por_hora": {
411
+ "CRITICA": 999,
412
+ "ALTA": 20,
413
+ "MEDIA": 10,
414
+ "BAJA": 5
415
+ }
416
+ }
417
+ }
418
+ ```
419
+
420
+ Implementación del rate limit:
421
+ ```bash
422
+ # Verificar rate limit antes de enviar
423
+ STAMP_FILE="/tmp/swl-notif-${PRIORIDAD}.last"
424
+ if [ -f "$STAMP_FILE" ]; then
425
+ LAST=$(cat "$STAMP_FILE")
426
+ NOW=$(date +%s)
427
+ DIFF=$((NOW - LAST))
428
+ MIN_WAIT=[min_segundos_según_prioridad]
429
+ if [ $DIFF -lt $MIN_WAIT ]; then
430
+ echo "Rate limit activo. Esperando ${MIN_WAIT}s entre notificaciones ${PRIORIDAD}"
431
+ exit 0
432
+ fi
433
+ fi
434
+ echo $(date +%s) > "$STAMP_FILE"
435
+ ```
436
+
437
+ ### Supresión de subagentes
438
+
439
+ Las notificaciones de subagentes se suprimen por defecto. Solo el agente
440
+ raíz o el orquestador-swl deben generar notificaciones.
441
+
442
+ Verificar antes de notificar:
443
+ ```bash
444
+ # Si PARENT_AGENT está definido, somos un subagente — no notificar
445
+ if [ -n "$PARENT_AGENT" ]; then
446
+ exit 0
447
+ fi
448
+ ```
449
+
450
+ Equivalente en la lógica del agente:
451
+ - Si el agente fue invocado por otro agente (no por el usuario directamente),
452
+ NO enviar notificaciones MEDIA o BAJA.
453
+ - Las notificaciones CRÍTICA y ALTA pueden enviarse desde cualquier contexto.
454
+
455
+ ### Horarios de silencio
456
+
457
+ ```json
458
+ {
459
+ "horario_silencio": {
460
+ "enabled": true,
461
+ "inicio": "22:00",
462
+ "fin": "08:00",
463
+ "zona_horaria": "America/Mexico_City",
464
+ "excepciones": ["CRITICA"],
465
+ "acumular_durante_silencio": true
466
+ }
467
+ }
468
+ ```
469
+
470
+ Implementación:
471
+ ```bash
472
+ HORA_ACTUAL=$(date +%H%M)
473
+ INICIO_SILENCIO=2200
474
+ FIN_SILENCIO=0800
475
+
476
+ if [ $HORA_ACTUAL -ge $INICIO_SILENCIO ] || [ $HORA_ACTUAL -lt $FIN_SILENCIO ]; then
477
+ if [ "$PRIORIDAD" != "CRITICA" ]; then
478
+ # Acumular en cola para enviar al salir del silencio
479
+ echo "${TITULO}|${MENSAJE}|${PRIORIDAD}" >> /tmp/swl-notif-queue.txt
480
+ exit 0
481
+ fi
482
+ fi
483
+ ```
484
+
485
+ Al salir del horario de silencio, enviar resumen acumulado:
486
+ ```
487
+ *Resumen de notificaciones en silencio* 🔔
488
+
489
+ Durante tu horario de descanso ocurrieron [N] eventos:
490
+ • [Evento 1] — [hora]
491
+ • [Evento 2] — [hora]
492
+
493
+ Revisa .planning/notifications-log.jsonl para el detalle completo.
494
+ ```
495
+
496
+ ## Protocolo de envío
497
+
498
+ Para cada notificación, seguir este protocolo en orden:
499
+
500
+ ### Paso 1 — Evaluar si el evento merece notificación
501
+
502
+ ```
503
+ ¿El usuario está activamente interactuando en la sesión actual?
504
+ Sí → NO notificar (el agente puede comunicar directamente)
505
+ No → continuar
506
+
507
+ ¿El evento es rutinario y el usuario no necesita responder?
508
+ Sí → NO notificar
509
+ No → continuar
510
+
511
+ ¿El rate limit está activo para este nivel de prioridad?
512
+ Sí → acumular en cola o descartar según la prioridad
513
+ No → continuar
514
+
515
+ ¿Estamos en horario de silencio y la prioridad NO es CRÍTICA?
516
+ Sí → acumular en cola
517
+ No → continuar
518
+ ```
519
+
520
+ ### Paso 2 — Leer configuración
521
+
522
+ ```bash
523
+ CONFIG_FILE=".planning/config.json"
524
+
525
+ if [ ! -f "$CONFIG_FILE" ]; then
526
+ # Usar configuración por defecto: solo desktop
527
+ CANAL_PRINCIPAL="desktop"
528
+ else
529
+ # Leer canales habilitados
530
+ CANALES_HABILITADOS=$(python3 -c "
531
+ import json, sys
532
+ with open('$CONFIG_FILE') as f:
533
+ cfg = json.load(f)
534
+ canales = cfg.get('canales', {})
535
+ activos = [k for k, v in canales.items() if v.get('enabled', False)]
536
+ print(','.join(activos))
537
+ ")
538
+ fi
539
+ ```
540
+
541
+ ### Paso 3 — Formatear mensaje por canal
542
+
543
+ Cada canal tiene su propio formato. El formateador genera la versión correcta:
544
+
545
+ ```
546
+ Información base del mensaje:
547
+ - titulo: Título conciso (máx 60 chars)
548
+ - descripcion: 1-3 oraciones del evento
549
+ - proyecto: Nombre del proyecto (de CLAUDE.md o .planning/)
550
+ - agente: Nombre del agente que originó el evento
551
+ - prioridad: CRÍTICA | ALTA | MEDIA | BAJA
552
+ - accion: Qué debe hacer el usuario (si aplica, máx 1 oración)
553
+ - timestamp: ISO 8601 en zona horaria del usuario
554
+
555
+ Emojis por prioridad:
556
+ CRÍTICA: 🚨
557
+ ALTA: ⚠️
558
+ MEDIA: ℹ️
559
+ BAJA: ✅
560
+ ```
561
+
562
+ ### Paso 4 — Verificar canal activo
563
+
564
+ ```bash
565
+ verificar_canal() {
566
+ case "$1" in
567
+ "telegram")
568
+ # Verificar que el bot puede enviar mensajes
569
+ RESP=$(curl -s "https://api.telegram.org/bot${BOT_TOKEN}/getMe")
570
+ echo $RESP | python3 -c "import json,sys; d=json.load(sys.stdin); print('ok' if d.get('ok') else 'error')"
571
+ ;;
572
+ "desktop")
573
+ # Verificar que el binario existe
574
+ [ -f "$CLAUDE_PLUGIN_ROOT/plugin-root/hook-wrapper.sh" ] && echo "ok" || echo "error"
575
+ ;;
576
+ "webhook")
577
+ echo "ok" # Verificar al enviar
578
+ ;;
579
+ esac
580
+ }
581
+ ```
582
+
583
+ ### Paso 5 — Enviar y confirmar entrega
584
+
585
+ ```bash
586
+ enviar_con_retry() {
587
+ CANAL=$1
588
+ MENSAJE=$2
589
+ MAX_INTENTOS=3
590
+ INTENTO=0
591
+
592
+ while [ $INTENTO -lt $MAX_INTENTOS ]; do
593
+ INTENTO=$((INTENTO + 1))
594
+ RESULTADO=$(enviar_por_canal "$CANAL" "$MENSAJE")
595
+
596
+ if [ "$RESULTADO" = "ok" ]; then
597
+ # Registrar en log
598
+ registrar_envio "$CANAL" "$EVENTO" "ok"
599
+ return 0
600
+ else
601
+ if [ $INTENTO -lt $MAX_INTENTOS ]; then
602
+ sleep $((INTENTO * 2)) # Backoff exponencial: 2s, 4s
603
+ fi
604
+ fi
605
+ done
606
+
607
+ # Todos los intentos fallaron
608
+ registrar_envio "$CANAL" "$EVENTO" "fallo"
609
+ # Intentar canal de respaldo si está configurado
610
+ enviar_a_canal_respaldo "$MENSAJE"
611
+ }
612
+ ```
613
+
614
+ ### Paso 6 — Registrar en log
615
+
616
+ Toda notificación (exitosa o fallida) se registra en `.planning/notifications-log.jsonl`:
617
+
618
+ ```json
619
+ {
620
+ "timestamp": "2026-03-25T14:30:00-06:00",
621
+ "evento": "verificacion:fallo",
622
+ "prioridad": "ALTA",
623
+ "titulo": "Verificación falló — Score 7.8/10",
624
+ "canales_intentados": ["telegram", "desktop"],
625
+ "canales_exitosos": ["desktop"],
626
+ "canales_fallidos": ["telegram"],
627
+ "agente_origen": "verificador-swl",
628
+ "proyecto": "mi-proyecto",
629
+ "rate_limited": false,
630
+ "suprimido_silencio": false
631
+ }
632
+ ```
633
+
634
+ ## Eventos automáticos — Especificación completa
635
+
636
+ ### checkpoint:human-action
637
+
638
+ **Trigger**: Un agente se detuvo porque requiere una acción física del usuario
639
+ (aprobar en una interfaz, firmar un documento, acceder a un sistema externo).
640
+
641
+ **Mensaje:**
642
+ ```
643
+ 🚨 Acción requerida — [nombre-proyecto]
644
+
645
+ El sistema está detenido esperando tu intervención.
646
+
647
+ Acción: [descripción concreta de qué debe hacer el usuario]
648
+ Agente en espera: [nombre-agente-swl]
649
+ Tiempo en espera: [duración]
650
+
651
+ Reanuda la sesión cuando hayas completado la acción.
652
+ ```
653
+
654
+ ### checkpoint:decision
655
+
656
+ **Trigger**: Se llegó a un punto de decisión donde el sistema tiene múltiples
657
+ caminos y el usuario debe elegir.
658
+
659
+ **Mensaje:**
660
+ ```
661
+ ⚠️ Decisión requerida — [nombre-proyecto]
662
+
663
+ [Descripción del contexto y la decisión necesaria]
664
+
665
+ Opciones:
666
+ 1. [Opción A] — [implicación en 1 línea]
667
+ 2. [Opción B] — [implicación en 1 línea]
668
+
669
+ Agente en espera: [nombre-agente-swl]
670
+ ```
671
+
672
+ ### verificacion:fallo
673
+
674
+ **Trigger**: El verificador-swl produjo un score < 9.0 o encontró hallazgos bloqueantes.
675
+
676
+ **Mensaje:**
677
+ ```
678
+ ⚠️ Verificación falló — [nombre-proyecto]
679
+
680
+ Score: [X.X]/10 (mínimo requerido: 9.0)
681
+ Hallazgos: [N] críticos, [N] altos, [N] medios
682
+
683
+ [Top 3 hallazgos más críticos en bullet points]
684
+
685
+ Consulta VERIFICACION.md para el detalle completo.
686
+ ```
687
+
688
+ ### fase:completada
689
+
690
+ **Trigger**: El orquestador-swl o el ejecutor-swl reporta que una fase terminó exitosamente.
691
+
692
+ **Mensaje:**
693
+ ```
694
+ ✅ Fase completada — [nombre-proyecto]
695
+
696
+ Fase: [nombre de la fase]
697
+ Duración: [tiempo]
698
+ Tareas completadas: [N]/[N]
699
+
700
+ [Resumen de 1-2 líneas del resultado]
701
+
702
+ Próxima fase: [nombre] (requiere tu aprobación / inicia automáticamente)
703
+ ```
704
+
705
+ ### error:api-auth
706
+
707
+ **Trigger**: La API de Anthropic devuelve 401. La sesión no puede continuar.
708
+
709
+ **Mensaje:**
710
+ ```
711
+ 🚨 Error de autenticación — API Anthropic
712
+
713
+ La sesión no puede continuar por un error de autenticación (401).
714
+
715
+ Posibles causas:
716
+ • API key inválida o expirada
717
+ • Límite de uso alcanzado
718
+ • Problema de facturación en la cuenta
719
+
720
+ Acción: Verifica tu API key en console.anthropic.com
721
+ ```
722
+
723
+ ### error:api-overload
724
+
725
+ **Trigger**: La API devuelve 529 (overloaded) o rate limit persistente.
726
+
727
+ **Mensaje:**
728
+ ```
729
+ ⚠️ API temporalmente sobrecargada — [nombre-proyecto]
730
+
731
+ El sistema está pausado por rate limiting o sobrecarga de la API.
732
+ Reintentando automáticamente cada [N] segundos.
733
+
734
+ No es necesaria ninguna acción — el sistema continuará cuando la API esté disponible.
735
+ ```
736
+
737
+ ### riesgo:alto-detectado
738
+
739
+ **Trigger**: Cualquier agente (revisor-seguridad-swl, tdd-qa-swl, arquitecto-swl)
740
+ clasifica un hallazgo como ALTO o CRÍTICO.
741
+
742
+ **Mensaje:**
743
+ ```
744
+ 🚨 Riesgo alto detectado — [nombre-proyecto]
745
+
746
+ Agente: [nombre-agente-swl]
747
+ Categoría: [Seguridad | Arquitectura | Calidad | Performance]
748
+ Severidad: [ALTA | CRÍTICA]
749
+
750
+ [Descripción del riesgo en 2-3 líneas]
751
+
752
+ Acción recomendada: [qué debe hacer el usuario]
753
+ ```
754
+
755
+ ### tarea:larga-completada
756
+
757
+ **Trigger**: Una tarea que tomó más de 15 minutos terminó.
758
+
759
+ **Mensaje:**
760
+ ```
761
+ ✅ Tarea completada — [nombre-proyecto]
762
+
763
+ [Nombre descriptivo de la tarea]
764
+ Duración: [tiempo real]
765
+ Estado: [exitoso | con advertencias | fallido]
766
+
767
+ [Resumen del resultado en 1-2 líneas]
768
+ ```
769
+
770
+ ## Template de configuración completo
771
+
772
+ Crear en `.planning/config.json` al iniciar un proyecto:
773
+
774
+ ```json
775
+ {
776
+ "proyecto": {
777
+ "nombre": "[nombre-del-proyecto]",
778
+ "zona_horaria": "America/Mexico_City"
779
+ },
780
+ "notificaciones": {
781
+ "habilitadas": true,
782
+ "verbose_mode": false,
783
+ "canales_por_prioridad": {
784
+ "CRITICA": ["desktop", "telegram"],
785
+ "ALTA": ["desktop", "telegram"],
786
+ "MEDIA": ["desktop"],
787
+ "BAJA": []
788
+ }
789
+ },
790
+ "canales": {
791
+ "desktop": {
792
+ "enabled": true,
793
+ "sound": true,
794
+ "volume": 1.0
795
+ },
796
+ "telegram": {
797
+ "enabled": false,
798
+ "bot_token": "",
799
+ "chat_id": "",
800
+ "parse_mode": "Markdown"
801
+ },
802
+ "whatsapp": {
803
+ "enabled": false,
804
+ "webhook_url": "",
805
+ "to": "",
806
+ "from": "",
807
+ "auth_token": ""
808
+ },
809
+ "email": {
810
+ "enabled": false,
811
+ "smtp_host": "",
812
+ "smtp_port": 587,
813
+ "smtp_user": "",
814
+ "smtp_password": "",
815
+ "from": "",
816
+ "to": [],
817
+ "subject_prefix": "[SWL]"
818
+ },
819
+ "webhook": {
820
+ "enabled": false,
821
+ "url": "",
822
+ "method": "POST",
823
+ "headers": {},
824
+ "preset": "generic"
825
+ }
826
+ },
827
+ "rate_limiting": {
828
+ "min_segundos_entre_misma_prioridad": {
829
+ "CRITICA": 0,
830
+ "ALTA": 30,
831
+ "MEDIA": 120,
832
+ "BAJA": 300
833
+ }
834
+ },
835
+ "horario_silencio": {
836
+ "enabled": false,
837
+ "inicio": "22:00",
838
+ "fin": "08:00",
839
+ "zona_horaria": "America/Mexico_City",
840
+ "excepciones": ["CRITICA"],
841
+ "acumular_durante_silencio": true
842
+ },
843
+ "supresion": {
844
+ "suprimir_subagentes": true,
845
+ "suprimir_si_usuario_activo": true
846
+ }
847
+ }
848
+ ```
849
+
850
+ ## Integración con claude-notifications-go
851
+
852
+ El sistema utiliza el binario de `claude-notifications-go` para notificaciones
853
+ de desktop. La integración funciona a través del hook-wrapper.sh:
854
+
855
+ **Localización del binario:**
856
+ ```bash
857
+ # En Windows
858
+ PLUGIN_ROOT="$HOME/.claude/claude-notifications-go/plugin-root"
859
+
860
+ # Verificar disponibilidad
861
+ if [ -f "$PLUGIN_ROOT/hook-wrapper.sh" ]; then
862
+ DESKTOP_DISPONIBLE=true
863
+ else
864
+ DESKTOP_DISPONIBLE=false
865
+ fi
866
+ ```
867
+
868
+ **Envío de notificación desktop:**
869
+ ```bash
870
+ # Para evento de tipo "Notification" (requiere atención)
871
+ echo "{\"message\": \"$MENSAJE\", \"cwd\": \"$(pwd)\"}" | \
872
+ bash "$PLUGIN_ROOT/hook-wrapper.sh" Notification
873
+
874
+ # Para evento de tipo "Stop" (tarea completada)
875
+ echo "{\"cwd\": \"$(pwd)\"}" | \
876
+ bash "$PLUGIN_ROOT/hook-wrapper.sh" Stop
877
+ ```
878
+
879
+ **Configuración de sonidos:**
880
+ Los sonidos están en `$PLUGIN_ROOT/sounds/`:
881
+ - `task-complete.mp3`: Para eventos de fase/tarea completada
882
+ - `question.mp3`: Para checkpoints y decisiones
883
+ - `review-complete.mp3`: Para verificaciones completadas
884
+ - `plan-ready.mp3`: Para planes generados
885
+
886
+ ## Reglas estrictas
887
+
888
+ - NUNCA enviar notificaciones cuando el usuario está activamente en sesión — es ruido.
889
+ - NUNCA enviar notificaciones BAJA en modo normal — solo si verbose_mode es true.
890
+ - NUNCA hardcodear tokens, URLs o credenciales en el agente — siempre de config.json.
891
+ - NUNCA fallar silenciosamente — siempre registrar en notifications-log.jsonl.
892
+ - NUNCA reintentar más de 3 veces por canal — si falla, intentar canal de respaldo.
893
+ - SIEMPRE incluir la acción concreta en mensajes de prioridad CRÍTICA.
894
+ - SIEMPRE respetar el horario de silencio para prioridades MEDIA y BAJA.
895
+ - SIEMPRE verificar el canal antes de enviar — un canal caído no debe bloquear otros canales.
896
+
897
+ ## Gotchas / Errores comunes no obvios
898
+
899
+ **Enviar notificaciones con el usuario activamente en sesión**: las notificaciones durante la sesión son ruido que interrumpe el flujo de trabajo. Causa: el agente envía notificación de prioridad MEDIA/BAJA sin verificar si el usuario está activo. Solución: NUNCA enviar para prioridades menores a CRÍTICA cuando el usuario está en sesión; las notificaciones son para ausencia, no para presencia.
900
+
901
+ **Fallar silenciosamente sin registrar en el log**: si un canal falla sin traza, es imposible diagnosticar el problema en la siguiente sesión. Causa: el agente maneja la excepción de red sin escribir en `notifications-log.jsonl`. Solución: SIEMPRE registrar en el log cada intento de envío y su resultado (éxito, fallo, canal de respaldo usado), independientemente del resultado.
902
+
903
+ **Reintentar más de 3 veces por canal**: los reintentos excesivos bloquean al agente y pueden saturar servicios externos ya degradados. Causa: el agente entra en un loop de reintentos esperando que el canal se recupere. Solución: máximo 3 intentos por canal; si falla, pasar al canal de respaldo sin más reintentos en el canal original hasta la siguiente sesión.
904
+
905
+ **Hardcodear tokens o credenciales en el agente**: los secretos en el código del agente se exponen en logs y en el historial de contexto. Causa: el desarrollador pone el token directamente para probar rápido y lo deja. Solución: NUNCA hardcodear; siempre leer de `.planning/config.json` en tiempo de ejecución; si `config.json` no existe, escalar a configuración pendiente.
906
+
907
+ ## Señales de que debes parar
908
+
909
+ Para y reporta si encuentras:
910
+ - La configuración `.planning/config.json` no existe y el evento es CRÍTICO —
911
+ intentar desktop y luego reportar que la configuración está incompleta.
912
+ - Todos los canales configurados fallaron para un evento CRÍTICO — loggear en
913
+ `notifications-log.jsonl` e incluir el mensaje en el contexto de la conversación.
914
+ - La configuración tiene credenciales malformadas — reportar sin exponer las credenciales.
915
+ - El evento que generó la notificación tiene información sensible (tokens, passwords,
916
+ datos de usuarios) — sanitizar antes de enviar por cualquier canal.