@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.
- package/CLAUDE.md +238 -0
- package/README.md +560 -0
- package/_userland/agentes/.gitkeep +0 -0
- package/_userland/habilidades/.gitkeep +0 -0
- package/agentes/.evolved.json +9 -0
- package/agentes/accesibilidad-wcag-swl.md +692 -0
- package/agentes/arquitecto-swl.md +238 -0
- package/agentes/auto-evolucion-swl.md +854 -0
- package/agentes/backend-api-swl.md +470 -0
- package/agentes/backend-csharp-swl.md +418 -0
- package/agentes/backend-go-swl.md +388 -0
- package/agentes/backend-java-swl.md +279 -0
- package/agentes/backend-node-swl.md +477 -0
- package/agentes/backend-python-swl.md +608 -0
- package/agentes/backend-rust-swl.md +362 -0
- package/agentes/backend-workers-swl.md +480 -0
- package/agentes/cloud-infra-swl.md +485 -0
- package/agentes/consolidador-swl.md +539 -0
- package/agentes/datos-swl.md +584 -0
- package/agentes/depurador-swl.md +349 -0
- package/agentes/devops-ci-swl.md +374 -0
- package/agentes/disenador-ui-swl.md +558 -0
- package/agentes/documentador-swl.md +343 -0
- package/agentes/evals/arquitecto-swl.evals.json +56 -0
- package/agentes/evals/auto-evolucion-swl.evals.json +68 -0
- package/agentes/evals/implementador-swl.evals.json +56 -0
- package/agentes/evals/orquestador-swl.evals.json +60 -0
- package/agentes/evals/perfilador-usuario-swl.evals.json +60 -0
- package/agentes/evals/red-team-swl.evals.json +59 -0
- package/agentes/evals/revisor-codigo-swl.evals.json +59 -0
- package/agentes/frontend-angular-swl.md +627 -0
- package/agentes/frontend-css-swl.md +720 -0
- package/agentes/frontend-react-swl.md +696 -0
- package/agentes/frontend-swl.md +500 -0
- package/agentes/frontend-tailwind-swl.md +830 -0
- package/agentes/implementador-swl.md +328 -0
- package/agentes/investigador-swl.md +430 -0
- package/agentes/investigador-ux-swl.md +500 -0
- package/agentes/llm-apps-swl.md +276 -0
- package/agentes/migrador-swl.md +417 -0
- package/agentes/mobile-android-swl.md +509 -0
- package/agentes/mobile-cross-swl.md +539 -0
- package/agentes/mobile-ios-swl.md +500 -0
- package/agentes/mobile-testing-swl.md +300 -0
- package/agentes/notificador-swl.md +916 -0
- package/agentes/observabilidad-swl.md +436 -0
- package/agentes/orquestador-swl.md +884 -0
- package/agentes/pagos-swl.md +283 -0
- package/agentes/perfilador-usuario-swl.md +306 -0
- package/agentes/planificador-swl.md +402 -0
- package/agentes/producto-prd-swl.md +587 -0
- package/agentes/red-team-swl.md +216 -0
- package/agentes/release-manager-swl.md +568 -0
- package/agentes/rendimiento-swl.md +714 -0
- package/agentes/resolutor-build-swl.md +243 -0
- package/agentes/revisor-angular-swl.md +276 -0
- package/agentes/revisor-codigo-swl.md +348 -0
- package/agentes/revisor-csharp-swl.md +262 -0
- package/agentes/revisor-go-swl.md +257 -0
- package/agentes/revisor-java-swl.md +255 -0
- package/agentes/revisor-kotlin-swl.md +271 -0
- package/agentes/revisor-nextjs-swl.md +279 -0
- package/agentes/revisor-php-swl.md +269 -0
- package/agentes/revisor-react-swl.md +276 -0
- package/agentes/revisor-rust-swl.md +344 -0
- package/agentes/revisor-seguridad-swl.md +390 -0
- package/agentes/revisor-swift-swl.md +266 -0
- package/agentes/revisor-typescript-swl.md +344 -0
- package/agentes/sre-swl.md +265 -0
- package/agentes/tdd-qa-swl.md +354 -0
- package/agentes/ux-disenador-swl.md +501 -0
- package/bin/lib/bot-comandos.js +1030 -0
- package/bin/lib/bot-discovery.js +182 -0
- package/bin/lib/bot-git.js +142 -0
- package/bin/swl-ses.js +325 -0
- package/bin/swl-telegram-bot.js +442 -0
- package/bin/swl-telegram-bot.plist +21 -0
- package/bin/swl-telegram-bot.service +14 -0
- package/comandos/swl/.evolved.json +23 -0
- package/comandos/swl/actualizar.md +174 -0
- package/comandos/swl/adoptar-proyecto.md +207 -0
- package/comandos/swl/aprender.md +701 -0
- package/comandos/swl/auditar-deps.md +134 -0
- package/comandos/swl/autoresearch.md +170 -0
- package/comandos/swl/ayuda.md +224 -0
- package/comandos/swl/brainstorm.md +50 -0
- package/comandos/swl/checkpoint.md +330 -0
- package/comandos/swl/compactar.md +283 -0
- package/comandos/swl/configurar-ci.md +227 -0
- package/comandos/swl/contexto.md +112 -0
- package/comandos/swl/contribuir.md +233 -0
- package/comandos/swl/crear-skill.md +292 -0
- package/comandos/swl/cron.md +196 -0
- package/comandos/swl/dashboard.md +146 -0
- package/comandos/swl/discutir-fase.md +230 -0
- package/comandos/swl/ejecutar-fase.md +135 -0
- package/comandos/swl/evaluar-skill.md +487 -0
- package/comandos/swl/evolucion-estado.md +142 -0
- package/comandos/swl/evolucionar.md +259 -0
- package/comandos/swl/exportar-vault.md +189 -0
- package/comandos/swl/gateway.md +158 -0
- package/comandos/swl/inbox.md +116 -0
- package/comandos/swl/instalar.md +220 -0
- package/comandos/swl/instintos.md +86 -0
- package/comandos/swl/mapear-codebase.md +312 -0
- package/comandos/swl/mcp-status.md +175 -0
- package/comandos/swl/metricas.md +270 -0
- package/comandos/swl/modelo.md +102 -0
- package/comandos/swl/notificaciones.md +396 -0
- package/comandos/swl/nuevo-proyecto.md +154 -0
- package/comandos/swl/planear-fase.md +221 -0
- package/comandos/swl/plugins.md +256 -0
- package/comandos/swl/reflect-skills.md +125 -0
- package/comandos/swl/release.md +217 -0
- package/comandos/swl/revisar-impacto.md +206 -0
- package/comandos/swl/revisar.md +330 -0
- package/comandos/swl/salud.md +363 -0
- package/comandos/swl/sesiones.md +200 -0
- package/comandos/swl/skill-search.md +113 -0
- package/comandos/swl/verificar.md +585 -0
- package/comandos/swl/wiki.md +620 -0
- package/contextos/dev.md +32 -0
- package/contextos/research.md +30 -0
- package/contextos/review.md +31 -0
- package/habilidades/accesibilidad-a11y/SKILL.md +201 -0
- package/habilidades/accesibilidad-a11y/evals/evals.json +56 -0
- package/habilidades/accesibilidad-a11y/recursos/ejemplos-y-checklist-completo.md +441 -0
- package/habilidades/agent-browser/SKILL.md +218 -0
- package/habilidades/agentes-como-servicio/SKILL.md +218 -0
- package/habilidades/ai-runtime-security/SKILL.md +273 -0
- package/habilidades/angular-avanzado/SKILL.md +164 -0
- package/habilidades/angular-avanzado/recursos/ejemplos-avanzados.md +219 -0
- package/habilidades/angular-moderno/SKILL.md +186 -0
- package/habilidades/angular-moderno/evals/evals.json +45 -0
- package/habilidades/angular-moderno/recursos/ejemplos-avanzados.md +106 -0
- package/habilidades/api-rest-diseno/SKILL.md +191 -0
- package/habilidades/api-rest-diseno/recursos/openapi-template.yaml +506 -0
- package/habilidades/api-rest-diseno/recursos/referencia-api.md +140 -0
- package/habilidades/aprendizaje-continuo/SKILL.md +151 -0
- package/habilidades/aprendizaje-continuo/evals/evals.json +53 -0
- package/habilidades/aprendizaje-continuo/recursos/referencia-instintos.md +290 -0
- package/habilidades/async-python/SKILL.md +149 -0
- package/habilidades/async-python/evals/evals.json +47 -0
- package/habilidades/async-python/recursos/patrones-y-ejemplos-completos.md +292 -0
- package/habilidades/auth-patrones/.evolved.json +9 -0
- package/habilidades/auth-patrones/SKILL.md +413 -0
- package/habilidades/auth-patrones/recursos/implementaciones-completas.md +229 -0
- package/habilidades/auto-evolucion-protocolo/SKILL.md +276 -0
- package/habilidades/auto-evolucion-protocolo/evals/evals.json +55 -0
- package/habilidades/auto-evolucion-protocolo/recursos/referencia-completa.md +145 -0
- package/habilidades/autoresearch/SKILL.md +268 -0
- package/habilidades/autoresearch/evals/evals.json +41 -0
- package/habilidades/autoresearch/recursos/checklist-template.md +191 -0
- package/habilidades/autoresearch/scripts/calcular-score.js +88 -0
- package/habilidades/azure-cloud/SKILL.md +308 -0
- package/habilidades/azure-cloud/recursos/aks.md +327 -0
- package/habilidades/backend-mcp-servidor/SKILL.md +270 -0
- package/habilidades/backend-production-resilience/SKILL.md +288 -0
- package/habilidades/brainstorming/SKILL.md +295 -0
- package/habilidades/brainstorming/recursos/componentes-html.md +247 -0
- package/habilidades/build-errors-cpp/SKILL.md +270 -0
- package/habilidades/build-errors-csharp/SKILL.md +265 -0
- package/habilidades/build-errors-go/SKILL.md +306 -0
- package/habilidades/build-errors-java/SKILL.md +278 -0
- package/habilidades/build-errors-kotlin/SKILL.md +303 -0
- package/habilidades/build-errors-nextjs/SKILL.md +312 -0
- package/habilidades/build-errors-php/SKILL.md +270 -0
- package/habilidades/build-errors-python/SKILL.md +292 -0
- package/habilidades/build-errors-rust/SKILL.md +284 -0
- package/habilidades/build-errors-swift/SKILL.md +272 -0
- package/habilidades/build-errors-typescript/SKILL.md +369 -0
- package/habilidades/checklist-calidad/SKILL.md +271 -0
- package/habilidades/checklist-calidad/recursos/quality-report-template.md +148 -0
- package/habilidades/checklist-seguridad/SKILL.md +285 -0
- package/habilidades/checkpoints-verificacion/SKILL.md +298 -0
- package/habilidades/checkpoints-verificacion/recursos/checkpoint-templates.md +360 -0
- package/habilidades/ci-cd-pipelines/SKILL.md +157 -0
- package/habilidades/ci-cd-pipelines/recursos/github-actions-template.yaml +403 -0
- package/habilidades/ci-cd-pipelines/recursos/pipelines-completos.md +487 -0
- package/habilidades/cloud-aws/SKILL.md +142 -0
- package/habilidades/cloud-aws/recursos/servicios-aws-referencia.md +321 -0
- package/habilidades/compactacion-contexto/SKILL.md +247 -0
- package/habilidades/contenedores-docker/SKILL.md +137 -0
- package/habilidades/contenedores-docker/recursos/dockerfile-template.dockerfile +160 -0
- package/habilidades/contenedores-docker/recursos/ejemplos-y-configuraciones.md +327 -0
- package/habilidades/context-builder/SKILL.md +170 -0
- package/habilidades/control-profundidad/SKILL.md +128 -0
- package/habilidades/csharp-experto/SKILL.md +322 -0
- package/habilidades/csharp-patrones/SKILL.md +316 -0
- package/habilidades/csharp-testing/SKILL.md +286 -0
- package/habilidades/css-moderno/SKILL.md +166 -0
- package/habilidades/css-moderno/evals/evals.json +43 -0
- package/habilidades/css-moderno/recursos/ejemplos-y-patrones-completos.md +337 -0
- package/habilidades/datos-etl/SKILL.md +129 -0
- package/habilidades/datos-etl/recursos/implementaciones-completas.md +322 -0
- package/habilidades/dbml-experto/SKILL.md +339 -0
- package/habilidades/dbml-experto/evals/evals.json +56 -0
- package/habilidades/dependencias-auditoria/SKILL.md +320 -0
- package/habilidades/deprecacion-migracion/SKILL.md +169 -0
- package/habilidades/deprecacion-migracion/recursos/implementaciones-completas.md +220 -0
- package/habilidades/design-tokens/SKILL.md +158 -0
- package/habilidades/design-tokens/recursos/tokens-y-configuracion.md +363 -0
- package/habilidades/devsecops-pipeline-security/SKILL.md +309 -0
- package/habilidades/diagrama-arquitectura/SKILL.md +165 -0
- package/habilidades/diagrama-arquitectura/assets/template.html +276 -0
- package/habilidades/discutir-fase/SKILL.md +188 -0
- package/habilidades/diseno-herramientas-agente/SKILL.md +199 -0
- package/habilidades/diseno-responsivo/SKILL.md +186 -0
- package/habilidades/diseno-responsivo/recursos/ejemplos-layouts.md +156 -0
- package/habilidades/django-experto/SKILL.md +205 -0
- package/habilidades/django-experto/recursos/async-django.md +390 -0
- package/habilidades/django-experto/recursos/drf-patrones.md +438 -0
- package/habilidades/django-experto/recursos/orm-avanzado.md +382 -0
- package/habilidades/django-experto/recursos/referencia-completa.md +188 -0
- package/habilidades/django-experto/recursos/testing-django.md +415 -0
- package/habilidades/doc-sync/SKILL.md +280 -0
- package/habilidades/drift-detection/SKILL.md +179 -0
- package/habilidades/ejecutar-fase/SKILL.md +468 -0
- package/habilidades/estilo-sin-ai-isms/SKILL.md +775 -0
- package/habilidades/estilo-sin-ai-isms/evals/evals.json +63 -0
- package/habilidades/estilo-sin-ai-isms/scripts/detectar_aiisms.py +500 -0
- package/habilidades/estructura-proyecto-claude/SKILL.md +215 -0
- package/habilidades/estructura-proyecto-claude/recursos/claude-md-template.md +261 -0
- package/habilidades/estructura-proyecto-claude/recursos/configuracion-y-extensiones.md +176 -0
- package/habilidades/estructura-proyecto-claude/recursos/frontmatter-y-hooks-referencia.md +289 -0
- package/habilidades/estructura-proyecto-claude/recursos/mcp-json-template.json +77 -0
- package/habilidades/estructura-proyecto-claude/recursos/variantes-por-stack.md +177 -0
- package/habilidades/evaluacion-agentes/SKILL.md +314 -0
- package/habilidades/event-driven/SKILL.md +153 -0
- package/habilidades/event-driven/recursos/implementaciones-completas.md +423 -0
- package/habilidades/extraccion-documentos/SKILL.md +221 -0
- package/habilidades/extractor-de-aprendizajes/.evolved.json +9 -0
- package/habilidades/extractor-de-aprendizajes/SKILL.md +311 -0
- package/habilidades/extractor-de-aprendizajes/evals/evals.json +55 -0
- package/habilidades/fastapi-experto/SKILL.md +221 -0
- package/habilidades/fastapi-experto/recursos/async-patterns.md +438 -0
- package/habilidades/fastapi-experto/recursos/dependency-injection.md +330 -0
- package/habilidades/fastapi-experto/recursos/referencia-completa.md +79 -0
- package/habilidades/fastapi-experto/recursos/testing-httpx.md +420 -0
- package/habilidades/filament-admin/SKILL.md +290 -0
- package/habilidades/frontend-avanzado/SKILL.md +257 -0
- package/habilidades/frontend-avanzado/recursos/apis-nativas-ejemplos.md +341 -0
- package/habilidades/gcp-cloud/SKILL.md +260 -0
- package/habilidades/gcp-cloud/recursos/gke.md +234 -0
- package/habilidades/gcp-cloud/recursos/terraform-gcp.md +307 -0
- package/habilidades/generacion-mermaid/SKILL.md +229 -0
- package/habilidades/git-worktrees-paralelo/SKILL.md +270 -0
- package/habilidades/go-experto/SKILL.md +305 -0
- package/habilidades/go-patrones/SKILL.md +299 -0
- package/habilidades/go-testing/SKILL.md +291 -0
- package/habilidades/graphql-experto/SKILL.md +323 -0
- package/habilidades/guardrail-semantico/SKILL.md +282 -0
- package/habilidades/harness-claude-code/SKILL.md +299 -0
- package/habilidades/iam-secretos/SKILL.md +265 -0
- package/habilidades/iam-secretos/recursos/implementaciones-completas.md +356 -0
- package/habilidades/infra-github-actions/SKILL.md +166 -0
- package/habilidades/instalar-sistema/.evolved.json +9 -0
- package/habilidades/instalar-sistema/SKILL.md +221 -0
- package/habilidades/java-experto/SKILL.md +290 -0
- package/habilidades/java-patrones/SKILL.md +275 -0
- package/habilidades/java-testing/SKILL.md +288 -0
- package/habilidades/kotlin-compose/SKILL.md +278 -0
- package/habilidades/kotlin-compose/recursos/animaciones-performance.md +93 -0
- package/habilidades/kotlin-experto/SKILL.md +318 -0
- package/habilidades/kotlin-testing/SKILL.md +267 -0
- package/habilidades/kotlin-testing/recursos/testing-avanzado.md +74 -0
- package/habilidades/kubernetes-orquestacion/SKILL.md +152 -0
- package/habilidades/kubernetes-orquestacion/recursos/manifiestos-completos.md +452 -0
- package/habilidades/langchain-langraph/SKILL.md +386 -0
- package/habilidades/langchain-langraph/recursos/evaluacion-rag.md +321 -0
- package/habilidades/langchain-langraph/recursos/rag-maturity-model.md +225 -0
- package/habilidades/langchain-langraph/recursos/vectorstores.md +306 -0
- package/habilidades/legacy-code-rescue/SKILL.md +267 -0
- package/habilidades/likec4-experto/SKILL.md +412 -0
- package/habilidades/likec4-experto/evals/evals.json +69 -0
- package/habilidades/manejo-errores/.evolved.json +9 -0
- package/habilidades/manejo-errores/SKILL.md +407 -0
- package/habilidades/manejo-errores/recursos/implementaciones-completas.md +248 -0
- package/habilidades/mapear-codebase/SKILL.md +275 -0
- package/habilidades/memoria-busqueda/SKILL.md +194 -0
- package/habilidades/memoria-busqueda/evals/evals.json +44 -0
- package/habilidades/meta-skills-estandar/SKILL.md +298 -0
- package/habilidades/meta-skills-estandar/recursos/anti-patrones-y-leyes.md +205 -0
- package/habilidades/meta-skills-estandar/recursos/frameworks-seguridad.md +107 -0
- package/habilidades/meta-skills-estandar/recursos/idiomas-framework.md +60 -0
- package/habilidades/meta-skills-estandar/recursos/skills-as-agents.md +163 -0
- package/habilidades/microservicios/SKILL.md +155 -0
- package/habilidades/microservicios/recursos/patrones-y-ejemplos-completos.md +325 -0
- package/habilidades/mobile-flutter/SKILL.md +199 -0
- package/habilidades/mobile-flutter/recursos/ejemplos-completos.md +319 -0
- package/habilidades/mobile-react-native/SKILL.md +176 -0
- package/habilidades/mobile-react-native/recursos/ejemplos-completos.md +216 -0
- package/habilidades/mongodb-experto/SKILL.md +302 -0
- package/habilidades/monitoring-alertas/SKILL.md +201 -0
- package/habilidades/monitoring-alertas/recursos/instrumentacion-y-alertas.md +301 -0
- package/habilidades/nestjs-experto/SKILL.md +307 -0
- package/habilidades/nestjs-experto/recursos/guards-interceptors.md +339 -0
- package/habilidades/nestjs-experto/recursos/modulos-di.md +287 -0
- package/habilidades/nestjs-experto/recursos/testing-nestjs.md +354 -0
- package/habilidades/nextjs-experto/SKILL.md +335 -0
- package/habilidades/nextjs-patrones/SKILL.md +303 -0
- package/habilidades/nextjs-testing/SKILL.md +331 -0
- package/habilidades/node-experto/.evolved.json +9 -0
- package/habilidades/node-experto/SKILL.md +266 -0
- package/habilidades/node-experto/recursos/patrones-completos.md +283 -0
- package/habilidades/notificaciones-multicanal/SKILL.md +159 -0
- package/habilidades/notificaciones-multicanal/recursos/config-template.json +115 -0
- package/habilidades/notificaciones-multicanal/recursos/configuracion-y-templates.md +303 -0
- package/habilidades/nuevo-proyecto/SKILL.md +204 -0
- package/habilidades/orquestacion-async/SKILL.md +303 -0
- package/habilidades/paid-media-tracking/SKILL.md +269 -0
- package/habilidades/paid-media-tracking/recursos/auditoria-tracking.md +220 -0
- package/habilidades/paid-media-tracking/recursos/google-ads-api.md +215 -0
- package/habilidades/patrones-python/SKILL.md +228 -0
- package/habilidades/patrones-python/evals/evals.json +56 -0
- package/habilidades/patrones-python/recursos/patrones-avanzados.md +469 -0
- package/habilidades/patrones-python/recursos/referencia-completa.md +202 -0
- package/habilidades/perfil-usuario/SKILL.md +200 -0
- package/habilidades/perfil-usuario/evals/evals.json +55 -0
- package/habilidades/performance-baseline/SKILL.md +297 -0
- package/habilidades/php-experto/SKILL.md +291 -0
- package/habilidades/php-patrones/SKILL.md +306 -0
- package/habilidades/php-testing/SKILL.md +280 -0
- package/habilidades/planear-fase/SKILL.md +269 -0
- package/habilidades/postgresql-experto/SKILL.md +151 -0
- package/habilidades/postgresql-experto/evals/evals.json +53 -0
- package/habilidades/postgresql-experto/recursos/referencia-completa.md +215 -0
- package/habilidades/prevencion-racionalizacion/SKILL.md +175 -0
- package/habilidades/prevencion-sobreingenieria/SKILL.md +323 -0
- package/habilidades/privacy-memoria/SKILL.md +141 -0
- package/habilidades/privacy-memoria/evals/evals.json +43 -0
- package/habilidades/prompt-engineering/SKILL.md +518 -0
- package/habilidades/prompt-engineering/recursos/patrones-avanzados.md +467 -0
- package/habilidades/rag-arquitectura/SKILL.md +338 -0
- package/habilidades/rails-experto/SKILL.md +237 -0
- package/habilidades/rails-experto/recursos/active-record.md +260 -0
- package/habilidades/rails-experto/recursos/hotwire-turbo.md +293 -0
- package/habilidades/rails-experto/recursos/testing-rspec.md +362 -0
- package/habilidades/react-experto/SKILL.md +209 -0
- package/habilidades/react-experto/evals/evals.json +55 -0
- package/habilidades/react-experto/recursos/patrones-y-ejemplos-completos.md +240 -0
- package/habilidades/react-optimizacion/SKILL.md +174 -0
- package/habilidades/react-optimizacion/recursos/patrones-avanzados.md +138 -0
- package/habilidades/redis-experto/SKILL.md +305 -0
- package/habilidades/release-semver/.evolved.json +9 -0
- package/habilidades/release-semver/SKILL.md +248 -0
- package/habilidades/release-semver/scripts/generar-changelog.sh +238 -0
- package/habilidades/rust-experto/SKILL.md +400 -0
- package/habilidades/rust-patrones/SKILL.md +296 -0
- package/habilidades/rust-testing/SKILL.md +311 -0
- package/habilidades/seguridad-skills-ia/SKILL.md +262 -0
- package/habilidades/sql-optimizacion/SKILL.md +200 -0
- package/habilidades/sql-optimizacion/evals/evals.json +54 -0
- package/habilidades/sql-optimizacion/recursos/patrones-sql-avanzados.md +131 -0
- package/habilidades/sre-patrones/SKILL.md +333 -0
- package/habilidades/sre-patrones/recursos/chaos-engineering.md +241 -0
- package/habilidades/sre-patrones/recursos/oncall-design.md +236 -0
- package/habilidades/stripe-pagos/SKILL.md +550 -0
- package/habilidades/stripe-pagos/recursos/errores-reintentos.md +390 -0
- package/habilidades/stripe-pagos/recursos/stripe-connect.md +290 -0
- package/habilidades/structured-outputs/SKILL.md +343 -0
- package/habilidades/swift-experto/SKILL.md +320 -0
- package/habilidades/swift-experto/recursos/keychain-y-wrappers.md +110 -0
- package/habilidades/swift-patrones/SKILL.md +313 -0
- package/habilidades/swift-patrones/recursos/tca-ejemplo-completo.md +113 -0
- package/habilidades/swift-testing/SKILL.md +254 -0
- package/habilidades/swift-testing/recursos/xcuitest-planes.md +143 -0
- package/habilidades/swl-dashboard/SKILL.md +370 -0
- package/habilidades/swl-markitdown/SKILL.md +285 -0
- package/habilidades/swl-markitdown/evals/evals.json +52 -0
- package/habilidades/swl-revisar-impacto/SKILL.md +233 -0
- package/habilidades/tailwind-experto/SKILL.md +240 -0
- package/habilidades/tailwind-experto/recursos/referencia-completa.md +184 -0
- package/habilidades/tdd-workflow/SKILL.md +293 -0
- package/habilidades/terraform-experto/SKILL.md +321 -0
- package/habilidades/testing-python/SKILL.md +340 -0
- package/habilidades/testing-python/recursos/ejemplos-completos.md +167 -0
- package/habilidades/threat-model-lite/SKILL.md +246 -0
- package/habilidades/tracing-processor/SKILL.md +212 -0
- package/habilidades/tracking-measurement/SKILL.md +239 -0
- package/habilidades/tracking-measurement/recursos/consent-mode.md +231 -0
- package/habilidades/tracking-measurement/recursos/gtm-datalayer.md +216 -0
- package/habilidades/tracking-measurement/recursos/meta-capi.md +262 -0
- package/habilidades/typescript-avanzado/SKILL.md +144 -0
- package/habilidades/typescript-avanzado/evals/evals.json +55 -0
- package/habilidades/typescript-avanzado/recursos/patrones-y-ejemplos-completos.md +298 -0
- package/habilidades/typescript-diagnosticos/SKILL.md +513 -0
- package/habilidades/ux-diseno/SKILL.md +116 -0
- package/habilidades/ux-diseno/evals/evals.json +43 -0
- package/habilidades/ux-diseno/recursos/patrones-ux-referencia.md +214 -0
- package/habilidades/validacion-ci-sistema/SKILL.md +136 -0
- package/habilidades/validacion-ci-sistema/recursos/validadores-completos.md +369 -0
- package/habilidades/validacion-ci-sistema/scripts/validar-sistema.sh +286 -0
- package/habilidades/verificacion-evidencia/SKILL.md +160 -0
- package/habilidades/verificar-trabajo/SKILL.md +303 -0
- package/habilidades/verificar-trabajo/recursos/plantilla-verificacion.md +60 -0
- package/habilidades/wiki-conocimiento/SKILL.md +276 -0
- package/habilidades/wireframes-flujos/SKILL.md +212 -0
- package/habilidades/wireframes-flujos/recursos/referencia-completa.md +192 -0
- package/habilidades/workflow-claude-code/SKILL.md +260 -0
- package/habilidades/workflow-claude-code/recursos/referencia-completa.md +109 -0
- package/hooks/_run-hook.sh +57 -0
- package/hooks/actualizar-perfil-usuario.js +364 -0
- package/hooks/agente-lifecycle.js +71 -0
- package/hooks/aiisms-detector.js +173 -0
- package/hooks/audit-trail.js +204 -0
- package/hooks/auto-background.js +97 -0
- package/hooks/auto-consolidacion.js +178 -0
- package/hooks/auto-evolucion.js +666 -0
- package/hooks/auto-restaurar-settings.js +360 -0
- package/hooks/calidad-pre-commit.js +929 -0
- package/hooks/calidad-typescript.js +511 -0
- package/hooks/captura-feedback-usuario.js +148 -0
- package/hooks/check-update.js +211 -0
- package/hooks/clasificador-mensajes.js +271 -0
- package/hooks/degradacion-instintos.js +272 -0
- package/hooks/escaneo-secretos.js +389 -0
- package/hooks/extraccion-aprendizajes.js +763 -0
- package/hooks/grafo-contexto.js +129 -0
- package/hooks/graph-update.js +67 -0
- package/hooks/guardrail-modelo.js +247 -0
- package/hooks/inbox-aviso.js +75 -0
- package/hooks/inyeccion-contexto.js +246 -0
- package/hooks/lib/abort-registry.js +214 -0
- package/hooks/lib/agent-backend.js +210 -0
- package/hooks/lib/agent-comms.js +263 -0
- package/hooks/lib/agent-issue-codes.js +284 -0
- package/hooks/lib/agent-matcher.js +189 -0
- package/hooks/lib/async-hook-registry.js +252 -0
- package/hooks/lib/atomic-write.js +130 -0
- package/hooks/lib/auto-consolidator.js +335 -0
- package/hooks/lib/canary-skills.js +187 -0
- package/hooks/lib/consolidation-lock.js +291 -0
- package/hooks/lib/context-builder.js +430 -0
- package/hooks/lib/context-compressor.js +657 -0
- package/hooks/lib/convergence-detector.js +105 -0
- package/hooks/lib/delegation-tracker.js +198 -0
- package/hooks/lib/detectar-package-manager.js +423 -0
- package/hooks/lib/edit-accumulator.js +171 -0
- package/hooks/lib/error-classifier.js +308 -0
- package/hooks/lib/event-bus.js +112 -0
- package/hooks/lib/evolution-tracker.js +442 -0
- package/hooks/lib/execution-state.js +316 -0
- package/hooks/lib/fingerprint-id.js +135 -0
- package/hooks/lib/gateway-notify.js +116 -0
- package/hooks/lib/graph-security.js +75 -0
- package/hooks/lib/guardrail-metrics.js +202 -0
- package/hooks/lib/hook-circuit-breaker.js +206 -0
- package/hooks/lib/loop-detector.js +267 -0
- package/hooks/lib/mcp-health.js +184 -0
- package/hooks/lib/mcp-pool.js +436 -0
- package/hooks/lib/memory-search.js +506 -0
- package/hooks/lib/merkle-audit.js +96 -0
- package/hooks/lib/model-router.js +222 -0
- package/hooks/lib/normalize-error.js +324 -0
- package/hooks/lib/normalize-input.js +65 -0
- package/hooks/lib/nudge-tracker.js +306 -0
- package/hooks/lib/otlp-exporter.js +365 -0
- package/hooks/lib/performance-marks.js +239 -0
- package/hooks/lib/privacy-filter.js +128 -0
- package/hooks/lib/prompt-injection-scanner.js +209 -0
- package/hooks/lib/provenance-tracker.js +183 -0
- package/hooks/lib/rate-limit-tracker.js +253 -0
- package/hooks/lib/reflect-classifier.js +164 -0
- package/hooks/lib/resource-quota.js +122 -0
- package/hooks/lib/retry-jitter.js +165 -0
- package/hooks/lib/risk-engine.js +368 -0
- package/hooks/lib/run-log.js +408 -0
- package/hooks/lib/session-fts.js +379 -0
- package/hooks/lib/session-store.js +293 -0
- package/hooks/lib/singleton-guard.js +159 -0
- package/hooks/lib/skill-auditor.js +588 -0
- package/hooks/lib/sync-status.js +228 -0
- package/hooks/lib/taint-tracker.js +107 -0
- package/hooks/lib/task-service.js +295 -0
- package/hooks/lib/tech-skills-map.js +146 -0
- package/hooks/lib/telegram-cliente.js +159 -0
- package/hooks/lib/telegram-config.js +170 -0
- package/hooks/lib/token-budget.js +156 -0
- package/hooks/lib/token-estimator.js +420 -0
- package/hooks/lib/toon-compressor.js +245 -0
- package/hooks/lib/usage-model.js +183 -0
- package/hooks/lib/variable-resolver.js +230 -0
- package/hooks/linea-estado.js +324 -0
- package/hooks/metricas-evolucion.js +209 -0
- package/hooks/monitor-contexto.js +325 -0
- package/hooks/notificacion-sesion-stop.js +198 -0
- package/hooks/notificacion-telegram-notification.js +4 -0
- package/hooks/notificacion-telegram-subagent.js +4 -0
- package/hooks/notificacion-telegram.js +267 -0
- package/hooks/preservar-estado-pre-compact.js +150 -0
- package/hooks/proteccion-rutas.js +366 -0
- package/hooks/registro-turnos.js +209 -0
- package/hooks/resumen-sesion.js +249 -0
- package/hooks/risk-scoring.js +323 -0
- package/hooks/rotar-audit-auto.js +122 -0
- package/hooks/sugerir-regenerar-inventario.js +170 -0
- package/hooks/telemetria-agentes.js +167 -0
- package/hooks/tracking-costos.js +688 -0
- package/instintos/global.yaml +8 -0
- package/instintos/perfil-usuario.yaml +53 -0
- package/instintos/prompt-appendices.yaml +57 -0
- package/instintos/proyecto.yaml +372 -0
- package/manifiestos/gateway-config.json +77 -0
- package/manifiestos/handoff-context.json +223 -0
- package/manifiestos/hook-profiles.json +44 -0
- package/manifiestos/hooks-config.json +360 -0
- package/manifiestos/modulos.json +1173 -0
- package/manifiestos/perfiles.json +404 -0
- package/package.json +86 -0
- package/plantillas/ESTADO.md +109 -0
- package/plantillas/HOJA-RUTA.md +143 -0
- package/plantillas/PROYECTO.md +122 -0
- package/plantillas/REQUISITOS.md +132 -0
- package/plantillas/auditor-veto-template.md +105 -0
- package/plantillas/github-workflows/README.md +47 -0
- package/plantillas/github-workflows/release-please.yml +44 -0
- package/plantillas/github-workflows/swl-ci.yml +107 -0
- package/plantillas/github-workflows/swl-security.yml +51 -0
- package/plantillas/mcp-mineru.json +13 -0
- package/plantillas/research/ARQUITECTURA.md +220 -0
- package/plantillas/research/FUNCIONALIDADES.md +175 -0
- package/plantillas/research/RESUMEN.md +165 -0
- package/plantillas/research/STACK.md +233 -0
- package/plantillas/research/TRAMPAS.md +299 -0
- package/plantillas/skill-evals-template.json +44 -0
- package/plugin.json +343 -0
- package/reglas/accesibilidad.md +269 -0
- package/reglas/api-diseno.md +400 -0
- package/reglas/arquitectura.md +352 -0
- package/reglas/brevedad-output.md +124 -0
- package/reglas/cloud-infra.md +247 -0
- package/reglas/docs.md +245 -0
- package/reglas/estilo-codigo.md +201 -0
- package/reglas/git-workflow.md +245 -0
- package/reglas/gobernanza.md +271 -0
- package/reglas/harness-claude-code.md +213 -0
- package/reglas/hooks.md +186 -0
- package/reglas/lenguajes/csharp/estilo-codigo.md +231 -0
- package/reglas/lenguajes/csharp/hooks.md +281 -0
- package/reglas/lenguajes/csharp/patrones.md +226 -0
- package/reglas/lenguajes/csharp/seguridad.md +258 -0
- package/reglas/lenguajes/csharp/testing.md +176 -0
- package/reglas/lenguajes/go/estilo-codigo.md +195 -0
- package/reglas/lenguajes/go/hooks.md +249 -0
- package/reglas/lenguajes/go/patrones.md +249 -0
- package/reglas/lenguajes/go/seguridad.md +225 -0
- package/reglas/lenguajes/go/testing.md +272 -0
- package/reglas/lenguajes/java/estilo-codigo.md +217 -0
- package/reglas/lenguajes/java/hooks.md +251 -0
- package/reglas/lenguajes/java/patrones.md +226 -0
- package/reglas/lenguajes/java/seguridad.md +233 -0
- package/reglas/lenguajes/java/testing.md +238 -0
- package/reglas/lenguajes/kotlin/estilo-codigo.md +208 -0
- package/reglas/lenguajes/kotlin/hooks.md +245 -0
- package/reglas/lenguajes/kotlin/patrones.md +201 -0
- package/reglas/lenguajes/kotlin/seguridad.md +202 -0
- package/reglas/lenguajes/kotlin/testing.md +236 -0
- package/reglas/lenguajes/nextjs/estilo-codigo.md +175 -0
- package/reglas/lenguajes/nextjs/hooks.md +186 -0
- package/reglas/lenguajes/nextjs/patrones.md +225 -0
- package/reglas/lenguajes/nextjs/seguridad.md +216 -0
- package/reglas/lenguajes/nextjs/testing.md +193 -0
- package/reglas/lenguajes/php/estilo-codigo.md +228 -0
- package/reglas/lenguajes/php/hooks.md +165 -0
- package/reglas/lenguajes/php/patrones.md +233 -0
- package/reglas/lenguajes/php/seguridad.md +186 -0
- package/reglas/lenguajes/php/testing.md +205 -0
- package/reglas/lenguajes/rust/estilo-codigo.md +207 -0
- package/reglas/lenguajes/rust/hooks.md +240 -0
- package/reglas/lenguajes/rust/patrones.md +250 -0
- package/reglas/lenguajes/rust/seguridad.md +221 -0
- package/reglas/lenguajes/rust/testing.md +194 -0
- package/reglas/lenguajes/swift/estilo-codigo.md +238 -0
- package/reglas/lenguajes/swift/hooks.md +257 -0
- package/reglas/lenguajes/swift/patrones.md +235 -0
- package/reglas/lenguajes/swift/seguridad.md +248 -0
- package/reglas/lenguajes/swift/testing.md +242 -0
- package/reglas/markitdown.md +60 -0
- package/reglas/memoria-consolidada.md +209 -0
- package/reglas/patrones.md +225 -0
- package/reglas/performance.md +195 -0
- package/reglas/pruebas.md +159 -0
- package/reglas/seguridad-agentes.md +351 -0
- package/reglas/seguridad.md +151 -0
- package/reglas/skills-estandar.md +373 -0
- package/reglas/testing.md +193 -0
- package/schemas/agent-contract.json +176 -0
- package/schemas/agent-frontmatter.schema.json +149 -0
- package/schemas/agent-message.schema.json +53 -0
- package/schemas/agent-output-implementacion.schema.json +85 -0
- package/schemas/agent-output-planificacion.schema.json +113 -0
- package/schemas/agent-output-review.schema.json +78 -0
- package/schemas/diary-entry.schema.json +80 -0
- package/schemas/hook-profiles.schema.json +39 -0
- package/schemas/hooks-config.schema.json +74 -0
- package/schemas/instinct.schema.json +115 -0
- package/schemas/modulos.schema.json +29 -0
- package/schemas/perfiles.schema.json +28 -0
- package/schemas/plugin.schema.json +64 -0
- package/schemas/skill-evals.schema.json +95 -0
- package/schemas/skill-frontmatter.schema.json +170 -0
- package/scripts/actualizar.js +145 -0
- package/scripts/audit-skills.sh +78 -0
- package/scripts/auditar-agentes-gaps.js +149 -0
- package/scripts/auditar-cobertura-frameworks.js +241 -0
- package/scripts/auditar-skills-gaps.js +206 -0
- package/scripts/bootstrap-instintos.js +259 -0
- package/scripts/check-update.js +109 -0
- package/scripts/comandos/agents.js +105 -0
- package/scripts/comandos/info.js +108 -0
- package/scripts/comandos/install-asistido.js +186 -0
- package/scripts/comandos/skills.js +211 -0
- package/scripts/configurar-branch-protection.js +418 -0
- package/scripts/daemon-swl.py +388 -0
- package/scripts/desinstalar.js +130 -0
- package/scripts/doctor.js +559 -0
- package/scripts/field-report.js +199 -0
- package/scripts/generar-inventario.js +317 -0
- package/scripts/inbox-tmux-inject.js +161 -0
- package/scripts/inferir-herramientas-permitidas.js +586 -0
- package/scripts/inicializar.js +133 -0
- package/scripts/instalador.js +1031 -0
- package/scripts/instalar-git-hook.js +122 -0
- package/scripts/lib/agp-frontmatter.js +222 -0
- package/scripts/lib/append-con-marcadores.js +199 -0
- package/scripts/lib/artefactos-python.js +43 -0
- package/scripts/lib/audit-query.js +221 -0
- package/scripts/lib/autostart-linux.js +347 -0
- package/scripts/lib/autostart-macos.js +360 -0
- package/scripts/lib/autostart-windows.js +307 -0
- package/scripts/lib/budget-enforcer.js +252 -0
- package/scripts/lib/claude-sessions.js +285 -0
- package/scripts/lib/configurar-ci.js +380 -0
- package/scripts/lib/console-span-exporter.js +92 -0
- package/scripts/lib/contadores-inventario.js +217 -0
- package/scripts/lib/dashboard-widgets.js +290 -0
- package/scripts/lib/detectar-runtime.js +279 -0
- package/scripts/lib/detectar-stack.js +187 -0
- package/scripts/lib/diary-entry.js +234 -0
- package/scripts/lib/drift-detector.js +545 -0
- package/scripts/lib/estado.js +124 -0
- package/scripts/lib/gestor-componentes.js +243 -0
- package/scripts/lib/gitignore-manifest.js +305 -0
- package/scripts/lib/graph-analyze.py +556 -0
- package/scripts/lib/graph-builder.py +485 -0
- package/scripts/lib/graph-cluster.py +259 -0
- package/scripts/lib/health-row.js +168 -0
- package/scripts/lib/hooks-settings.js +789 -0
- package/scripts/lib/manifiestos.js +138 -0
- package/scripts/lib/mc-client.js +137 -0
- package/scripts/lib/notificaciones-telegram.js +1107 -0
- package/scripts/lib/npm-version.js +261 -0
- package/scripts/lib/paquetes-conocidos.js +50 -0
- package/scripts/lib/preservar-usuario.js +586 -0
- package/scripts/lib/prompt-builder.js +264 -0
- package/scripts/lib/resolver-externo.js +332 -0
- package/scripts/lib/schedule-parser.js +305 -0
- package/scripts/lib/scoring-instintos.js +240 -0
- package/scripts/lib/seguridad.js +160 -0
- package/scripts/lib/selector-interactivo.js +152 -0
- package/scripts/lib/semantic-search.js +242 -0
- package/scripts/lib/skill-discovery.js +234 -0
- package/scripts/lib/skill-metrics.js +246 -0
- package/scripts/lib/skill-normalizer.js +112 -0
- package/scripts/lib/skills-hub.js +340 -0
- package/scripts/lib/span-schema.js +134 -0
- package/scripts/lib/tool-cost-analyzer.js +255 -0
- package/scripts/lib/tracing-processor-interface.js +286 -0
- package/scripts/lib/transformadores/base.js +80 -0
- package/scripts/lib/transformadores/claude.js +124 -0
- package/scripts/lib/transformadores/codex.js +115 -0
- package/scripts/lib/transformadores/copilot.js +106 -0
- package/scripts/lib/transformadores/gemini.js +74 -0
- package/scripts/lib/transformadores/index.js +35 -0
- package/scripts/lib/transformadores/opencode.js +75 -0
- package/scripts/lib/ui.js +259 -0
- package/scripts/limpiar-artefactos-python.js +131 -0
- package/scripts/mcp-orchestrator.py +386 -0
- package/scripts/mcp-pool-manager.py +352 -0
- package/scripts/mcp-telemetry.py +378 -0
- package/scripts/poblar-evolvable.js +226 -0
- package/scripts/publicar.js +287 -0
- package/scripts/reflect-skills.js +403 -0
- package/scripts/rotar-audit-logs.js +185 -0
- package/scripts/run-skill-evals.js +242 -0
- package/scripts/smoke-test.js +374 -0
- package/scripts/token-analysis.py +471 -0
- package/scripts/validar-manifest.js +195 -0
- package/scripts/validar-memoria.js +321 -0
- package/scripts/validar-tests-aislamiento.js +184 -0
- package/scripts/validar-tokens-test.js +208 -0
- package/scripts/validar.js +147 -0
- package/scripts/validate-markdown.py +339 -0
- package/scripts/validate-skills.py +385 -0
- package/scripts/vendor/claude-usage/README.md +116 -0
- package/scripts/vendor/claude-usage/cli.py +334 -0
- package/scripts/vendor/claude-usage/dashboard.py +795 -0
- package/scripts/vendor/claude-usage/scanner.py +467 -0
- package/scripts/vendor/markitdown/cli.py +194 -0
- package/scripts/verificar-evolucion.js +289 -0
- package/scripts/verificar-release.js +494 -0
|
@@ -0,0 +1,221 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: swl:planear-fase
|
|
3
|
+
description: Recibe el número de una fase y genera un plan de implementación detallado y accionable. Delega al agente planificador-swl, verifica el plan con el revisor y permite hasta 3 iteraciones de refinamiento.
|
|
4
|
+
allowed_tools: ["Read", "Write", "Edit", "Bash", "Glob", "Grep"]
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# /swl:planear-fase <n> — Generar plan detallado de implementación
|
|
8
|
+
|
|
9
|
+
Eres el coordinador de planeación SWL. Tu trabajo es orquestar la generación de un plan de implementación de alta calidad para una fase específica, usando el agente planificador-swl y validando el resultado con el revisor antes de presentarlo al usuario.
|
|
10
|
+
|
|
11
|
+
## Uso
|
|
12
|
+
|
|
13
|
+
```
|
|
14
|
+
/swl:planear-fase 1
|
|
15
|
+
/swl:planear-fase 2
|
|
16
|
+
```
|
|
17
|
+
|
|
18
|
+
## Paso 0 — Carga de habilidades
|
|
19
|
+
|
|
20
|
+
```
|
|
21
|
+
Skill("planear-fase")
|
|
22
|
+
```
|
|
23
|
+
|
|
24
|
+
Si no existe, carga `Skill("python-patterns")` si el stack es Python, o `Skill("angular-component")` si el stack es Angular/TS. Siempre carga también:
|
|
25
|
+
|
|
26
|
+
```
|
|
27
|
+
Skill("api-design-principles")
|
|
28
|
+
```
|
|
29
|
+
|
|
30
|
+
## Paso 1 — Verificación de prerrequisitos
|
|
31
|
+
|
|
32
|
+
Verifica los siguientes archivos en orden. Si alguno falta, detente con un error claro:
|
|
33
|
+
|
|
34
|
+
1. `.planning/PROYECTO.md` — debe existir. Sin esto: "Ejecuta `/swl:nuevo-proyecto` primero."
|
|
35
|
+
2. `.planning/HOJA-RUTA.md` — debe existir y la fase N debe estar listada.
|
|
36
|
+
3. `.planning/fases/0N-CONTEXTO.md` — debe existir. Sin esto: "Ejecuta `/swl:discutir-fase N` primero para capturar el contexto de la fase."
|
|
37
|
+
|
|
38
|
+
Lee los tres archivos completos antes de continuar.
|
|
39
|
+
|
|
40
|
+
Verifica también:
|
|
41
|
+
- Si existe `.planning/fases/0N-PLAN.md` ya — si existe, pregunta al usuario: "Ya existe un plan para esta fase. ¿Deseas regenerarlo desde cero o refinar el existente?" Espera respuesta.
|
|
42
|
+
- Lee `CLAUDE.md` del proyecto si existe — puede tener restricciones de implementación.
|
|
43
|
+
- Si hay fases anteriores con PLAN.md o RESUMEN.md, léelas para entender patrones establecidos.
|
|
44
|
+
|
|
45
|
+
## Paso 2 — Análisis del contexto
|
|
46
|
+
|
|
47
|
+
Antes de delegar, analiza el CONTEXTO.md de la fase y extrae:
|
|
48
|
+
|
|
49
|
+
1. **Tipo de trabajo predominante**: backend, frontend, infraestructura, integración, mixto.
|
|
50
|
+
2. **Complejidad estimada**: BAJA (1-3 días), MEDIA (1-2 semanas), ALTA (>2 semanas).
|
|
51
|
+
3. **Dependencias externas**: ¿hay APIs de terceros, bases de datos nuevas, servicios cloud?
|
|
52
|
+
4. **Riesgos que afectan la planeación**: lista los riesgos marcados como ALTO del CONTEXTO.md.
|
|
53
|
+
5. **Decisiones pendientes**: si hay decisiones marcadas como "[POR DEFINIR]", enuméralas aquí.
|
|
54
|
+
|
|
55
|
+
Si hay más de 2 decisiones "[POR DEFINIR]" en áreas críticas (arquitectura, modelo de datos, permisos), detente y pregunta al usuario:
|
|
56
|
+
|
|
57
|
+
```
|
|
58
|
+
Encontré [N] decisiones pendientes que afectan la arquitectura del plan:
|
|
59
|
+
1. [decisión 1]
|
|
60
|
+
2. [decisión 2]
|
|
61
|
+
|
|
62
|
+
Estas deben resolverse antes de planear. ¿Puedes darme tu decisión para cada una?
|
|
63
|
+
```
|
|
64
|
+
|
|
65
|
+
## Paso 3 — Delegación al agente planificador-swl
|
|
66
|
+
|
|
67
|
+
Delega al agente `planificador-swl` con el siguiente contexto:
|
|
68
|
+
|
|
69
|
+
**Instrucción al agente planificador-swl:**
|
|
70
|
+
|
|
71
|
+
```
|
|
72
|
+
Genera un PLAN.md detallado para la Fase N del proyecto [nombre].
|
|
73
|
+
|
|
74
|
+
Archivos de contexto a leer:
|
|
75
|
+
- .planning/PROYECTO.md
|
|
76
|
+
- .planning/HOJA-RUTA.md
|
|
77
|
+
- .planning/REQUISITOS.md
|
|
78
|
+
- .planning/fases/0N-CONTEXTO.md
|
|
79
|
+
[si aplica] - .planning/research/ARQUITECTURA.md
|
|
80
|
+
[si aplica] - .planning/fases/0(N-1)-RESUMEN.md (fase anterior)
|
|
81
|
+
|
|
82
|
+
El plan debe seguir el formato especificado en la sección "Formato del PLAN.md" de este comando.
|
|
83
|
+
|
|
84
|
+
Restricciones adicionales detectadas:
|
|
85
|
+
[lista de restricciones del PROYECTO.md y CLAUDE.md]
|
|
86
|
+
|
|
87
|
+
Riesgos que deben reflejarse en el plan:
|
|
88
|
+
[lista de riesgos ALTO del CONTEXTO.md]
|
|
89
|
+
```
|
|
90
|
+
|
|
91
|
+
Mientras el agente trabaja, monitorea el progreso. El agente debe producir `.planning/fases/0N-PLAN.md`.
|
|
92
|
+
|
|
93
|
+
## Paso 4 — Formato del PLAN.md
|
|
94
|
+
|
|
95
|
+
El agente planificador-swl debe generar el plan con esta estructura exacta:
|
|
96
|
+
|
|
97
|
+
```markdown
|
|
98
|
+
# Plan de implementación — Fase N: [nombre]
|
|
99
|
+
|
|
100
|
+
**Proyecto**: [nombre]
|
|
101
|
+
**Fase**: N de M
|
|
102
|
+
**Fecha de generación**: [fecha]
|
|
103
|
+
**Iteración del plan**: 1
|
|
104
|
+
**Estimación total**: [rango de días/horas]
|
|
105
|
+
|
|
106
|
+
## Resumen ejecutivo
|
|
107
|
+
[2-4 oraciones describiendo qué se va a construir y cómo]
|
|
108
|
+
|
|
109
|
+
## Orden de implementación (vertical slices)
|
|
110
|
+
|
|
111
|
+
### Slice 1 — [nombre del slice]
|
|
112
|
+
**Tipo**: AFK | HITL
|
|
113
|
+
**Estimación**: [horas]
|
|
114
|
+
**Descripción**: [qué hace este slice]
|
|
115
|
+
|
|
116
|
+
#### Tareas
|
|
117
|
+
1. [ ] [tarea específica con archivo o componente objetivo]
|
|
118
|
+
2. [ ] [tarea específica]
|
|
119
|
+
...
|
|
120
|
+
|
|
121
|
+
#### Criterio de verificación
|
|
122
|
+
[cómo saber que este slice está completo y funciona]
|
|
123
|
+
|
|
124
|
+
#### Dependencias
|
|
125
|
+
[qué slices o archivos deben existir antes]
|
|
126
|
+
|
|
127
|
+
### Slice 2 — [nombre]
|
|
128
|
+
[misma estructura]
|
|
129
|
+
|
|
130
|
+
...
|
|
131
|
+
|
|
132
|
+
## Modelos y esquemas de datos
|
|
133
|
+
[tablas, campos, tipos, constraints — si la fase introduce datos nuevos]
|
|
134
|
+
|
|
135
|
+
## Endpoints a implementar
|
|
136
|
+
| Método | Ruta | Descripción | Roles permitidos |
|
|
137
|
+
|--------|------|-------------|-----------------|
|
|
138
|
+
[si aplica]
|
|
139
|
+
|
|
140
|
+
## Componentes frontend a implementar
|
|
141
|
+
| Componente | Ruta del archivo | Propósito |
|
|
142
|
+
|------------|-----------------|-----------|
|
|
143
|
+
[si aplica]
|
|
144
|
+
|
|
145
|
+
## Tests requeridos
|
|
146
|
+
[lista de tests que deben existir al finalizar la fase]
|
|
147
|
+
|
|
148
|
+
## Riesgos y mitigaciones
|
|
149
|
+
| Riesgo | Impacto | Probabilidad | Mitigación |
|
|
150
|
+
|--------|---------|-------------|-----------|
|
|
151
|
+
|
|
152
|
+
## Criterios de aceptación de la fase
|
|
153
|
+
[copia del CONTEXTO.md, verificados contra el plan]
|
|
154
|
+
|
|
155
|
+
## Comandos de verificación
|
|
156
|
+
[comandos concretos para verificar que la fase funciona: cómo correr tests, cómo verificar endpoints, etc.]
|
|
157
|
+
```
|
|
158
|
+
|
|
159
|
+
## Paso 5 — Revisión del plan generado
|
|
160
|
+
|
|
161
|
+
Una vez que el agente planificador-swl produce el PLAN.md, ejecuta una revisión con el revisor. Verifica los siguientes puntos de calidad:
|
|
162
|
+
|
|
163
|
+
### Checklist de revisión del plan
|
|
164
|
+
|
|
165
|
+
- [ ] ¿Cada tarea es atómica y tiene un archivo o componente destino claro?
|
|
166
|
+
- [ ] ¿El orden de implementación respeta las dependencias (BD → service → endpoint → frontend)?
|
|
167
|
+
- [ ] ¿Hay criterios de verificación para cada slice?
|
|
168
|
+
- [ ] ¿Los criterios de aceptación de la fase están cubiertos por los slices?
|
|
169
|
+
- [ ] ¿Los riesgos ALTO del CONTEXTO.md están mitigados en el plan?
|
|
170
|
+
- [ ] ¿Hay tests especificados para cada área crítica?
|
|
171
|
+
- [ ] ¿Hay tareas HITL claramente marcadas?
|
|
172
|
+
- [ ] ¿Los modelos de datos son consistentes con los requisitos del CONTEXTO.md?
|
|
173
|
+
- [ ] ¿El estimado de tiempo es realista dado el número y complejidad de tareas?
|
|
174
|
+
|
|
175
|
+
Si hay deficiencias en el plan (más de 2 puntos fallidos del checklist), itera.
|
|
176
|
+
|
|
177
|
+
## Paso 6 — Bucle de iteración (máximo 3 rondas)
|
|
178
|
+
|
|
179
|
+
Mantén un contador de iteraciones. Para cada iteración:
|
|
180
|
+
|
|
181
|
+
1. Identifica los problemas específicos del plan.
|
|
182
|
+
2. Genera instrucciones de mejora precisas para el agente planificador-swl.
|
|
183
|
+
3. El agente regenera o ajusta el PLAN.md.
|
|
184
|
+
4. Vuelve al Paso 5.
|
|
185
|
+
|
|
186
|
+
Si después de 3 iteraciones el plan aún tiene problemas:
|
|
187
|
+
- Guarda el plan como está con nota "[REQUIERE REVISIÓN HUMANA]" al inicio.
|
|
188
|
+
- Reporta al usuario los problemas encontrados con detalle.
|
|
189
|
+
- Pregunta si quiere continuar con el plan imperfecto o abortar la planeación.
|
|
190
|
+
|
|
191
|
+
Actualiza el campo `**Iteración del plan**` en el PLAN.md con cada ciclo.
|
|
192
|
+
|
|
193
|
+
## Paso 7 — Actualización del HOJA-RUTA.md
|
|
194
|
+
|
|
195
|
+
Una vez aprobado el plan, actualiza el estado de la fase N en `.planning/HOJA-RUTA.md`:
|
|
196
|
+
- Cambia el estado de "Pendiente" a "Planeada"
|
|
197
|
+
- Agrega la fecha de planeación
|
|
198
|
+
- Agrega el número de slices y estimación total
|
|
199
|
+
|
|
200
|
+
## Paso 8 — Reporte al usuario
|
|
201
|
+
|
|
202
|
+
Al terminar, reporta:
|
|
203
|
+
|
|
204
|
+
1. Ruta absoluta del PLAN.md generado.
|
|
205
|
+
2. Resumen del plan:
|
|
206
|
+
- Número de slices
|
|
207
|
+
- Número total de tareas
|
|
208
|
+
- Estimación de tiempo total
|
|
209
|
+
- Número de tareas HITL (si hay, listarlas — requieren decisión humana)
|
|
210
|
+
3. Iteraciones que tomó el plan (1 = ideal, 2-3 = normal, 3 con advertencia = revisar contexto).
|
|
211
|
+
4. Si hay tareas HITL, presentarlas como lista de decisiones pendientes.
|
|
212
|
+
5. Próximo paso: "Cuando estés listo, ejecuta `/swl:ejecutar-fase N`"
|
|
213
|
+
|
|
214
|
+
## Reglas de comportamiento
|
|
215
|
+
|
|
216
|
+
- NUNCA generes código fuente en este paso — solo el plan de implementación.
|
|
217
|
+
- El plan debe ser ejecutable por cualquier desarrollador que lo lea, sin conocer la conversación.
|
|
218
|
+
- Si una tarea es ambigua en el plan, el revisor DEBE rechazarla hasta que sea específica.
|
|
219
|
+
- Las estimaciones de tiempo deben ser honestas — no subestimes para complacer al usuario.
|
|
220
|
+
- Tareas HITL son aquellas que requieren decisión humana: elección de tecnología, cambio de arquitectura, aprobación de modelo de datos. Márcalas explícitamente.
|
|
221
|
+
- NUNCA marques una tarea como completa en el plan — eso lo hace `/swl:ejecutar-fase`.
|
|
@@ -0,0 +1,256 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: swl:plugins
|
|
3
|
+
description: Gestiona plugins de usuario instalados en _userland/. Instala, desinstala, lista y valida plugins SWL desde directorios locales. Cargar cuando el usuario quiera instalar componentes externos (agentes, skills, reglas, hooks) sin modificar el sistema base.
|
|
4
|
+
allowed_tools: ["Read", "Write", "Edit", "Bash", "Glob", "Grep"]
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# /swl:plugins — Gestión de plugins de usuario
|
|
8
|
+
|
|
9
|
+
Gestiona el ciclo de vida completo de plugins SWL instalados en `_userland/plugins/`.
|
|
10
|
+
Un plugin es un directorio con `plugin.json` que agrupa agentes, skills, reglas y/o
|
|
11
|
+
hooks de terceros o del equipo, sin tocar los componentes del sistema base.
|
|
12
|
+
|
|
13
|
+
## Cuándo usar
|
|
14
|
+
|
|
15
|
+
- Para instalar skills o agentes de dominio específico del proyecto
|
|
16
|
+
- Para incorporar extensiones de equipo sin mezclarlas con el sistema SWL base
|
|
17
|
+
- Para validar un plugin antes de distribuirlo
|
|
18
|
+
- Para limpiar plugins obsoletos
|
|
19
|
+
|
|
20
|
+
## Subcomandos
|
|
21
|
+
|
|
22
|
+
```
|
|
23
|
+
/swl:plugins — Lista plugins instalados (resumen)
|
|
24
|
+
/swl:plugins list — Lista plugins con detalle de componentes
|
|
25
|
+
/swl:plugins install <ruta> — Instala plugin desde directorio local
|
|
26
|
+
/swl:plugins remove <nombre> — Desinstala plugin
|
|
27
|
+
/swl:plugins validate <ruta> — Valida plugin.json contra schema
|
|
28
|
+
```
|
|
29
|
+
|
|
30
|
+
---
|
|
31
|
+
|
|
32
|
+
## install — Instalar un plugin
|
|
33
|
+
|
|
34
|
+
### Paso 1 — Leer y validar el manifiesto
|
|
35
|
+
|
|
36
|
+
```bash
|
|
37
|
+
cat <ruta>/plugin.json
|
|
38
|
+
```
|
|
39
|
+
|
|
40
|
+
Verificar que `plugin.json` existe y leerlo. Luego validar contra el schema:
|
|
41
|
+
|
|
42
|
+
```bash
|
|
43
|
+
# Verificar campos obligatorios: name, version, description
|
|
44
|
+
# El name debe cumplir ^[a-z][a-z0-9-]+$ y no usar palabras reservadas:
|
|
45
|
+
# anthropic, claude, swl
|
|
46
|
+
```
|
|
47
|
+
|
|
48
|
+
Si falta `plugin.json` o no cumple el schema en `schemas/plugin.schema.json`:
|
|
49
|
+
reportar los campos inválidos y abortar sin realizar cambios.
|
|
50
|
+
|
|
51
|
+
### Paso 2 — Verificar archivos referenciados
|
|
52
|
+
|
|
53
|
+
Recorrer los arrays `agents`, `skills`, `rules`, `hooks` del manifiesto y
|
|
54
|
+
verificar que cada ruta referenciada existe dentro del directorio del plugin:
|
|
55
|
+
|
|
56
|
+
```bash
|
|
57
|
+
ls <ruta>/<archivo-referenciado>
|
|
58
|
+
```
|
|
59
|
+
|
|
60
|
+
Si algún archivo referenciado no existe: reportar y abortar.
|
|
61
|
+
|
|
62
|
+
### Paso 2B — Verificación de seguridad del plugin
|
|
63
|
+
|
|
64
|
+
**Carga**: `Skill("seguridad-skills-ia")` — patrones de detección de amenazas.
|
|
65
|
+
|
|
66
|
+
Escanear el contenido completo del plugin antes de copiar al destino:
|
|
67
|
+
|
|
68
|
+
1. **Agentes del plugin**: verificar que ningún agente declara `nivelRiesgo: ALTO`
|
|
69
|
+
ni `permisosRed: irrestricto` sin documentación explícita en el manifiesto
|
|
70
|
+
2. **Hooks con `blocking: true`**: listar y advertir al usuario — requieren
|
|
71
|
+
aprobación explícita antes de activarse
|
|
72
|
+
3. **Skills del plugin**: aplicar los patrones de detección del skill
|
|
73
|
+
`seguridad-skills-ia` sobre cada SKILL.md y sus scripts/
|
|
74
|
+
4. **Reglas del plugin**: verificar que no contradicen reglas base del sistema
|
|
75
|
+
(precedencia de capas: reglas base > reglas de plugin)
|
|
76
|
+
|
|
77
|
+
Resultado del escaneo:
|
|
78
|
+
- **Score ≥ 8.0**: proceder con instalación
|
|
79
|
+
- **Score 5.0-7.9**: advertir hallazgos y pedir confirmación explícita
|
|
80
|
+
- **Score < 5.0**: BLOQUEAR instalación, reportar hallazgos detallados
|
|
81
|
+
|
|
82
|
+
Registrar el resultado del escaneo en `.planning/AUDITORIA.md`:
|
|
83
|
+
```markdown
|
|
84
|
+
## [YYYY-MM-DD HH:MM] plugin-security-scan
|
|
85
|
+
|
|
86
|
+
**Plugin**: nombre-plugin vX.Y.Z
|
|
87
|
+
**Score**: N.N/10.0
|
|
88
|
+
**Veredicto**: SEGURO | SOSPECHOSO | INSEGURO
|
|
89
|
+
**Hallazgos**: [lista o "ninguno"]
|
|
90
|
+
**Acción**: instalado | bloqueado | instalado con advertencias
|
|
91
|
+
```
|
|
92
|
+
|
|
93
|
+
### Paso 3 — Resolver dependencias
|
|
94
|
+
|
|
95
|
+
Si `plugin.json` tiene `dependencies`:
|
|
96
|
+
1. Verificar que cada dependencia está instalada en `_userland/plugins/`
|
|
97
|
+
2. Si falta alguna: reportar nombre y versión requerida, abortar con instrucción:
|
|
98
|
+
`Instalar primero: /swl:plugins install <ruta-dependencia>`
|
|
99
|
+
|
|
100
|
+
### Paso 4 — Copiar al destino
|
|
101
|
+
|
|
102
|
+
```bash
|
|
103
|
+
mkdir -p _userland/plugins/<nombre>/
|
|
104
|
+
cp -r <ruta>/* _userland/plugins/<nombre>/
|
|
105
|
+
```
|
|
106
|
+
|
|
107
|
+
### Paso 5 — Registrar en .claude/settings.json
|
|
108
|
+
|
|
109
|
+
Leer `.claude/settings.json`. Para cada componente del plugin:
|
|
110
|
+
|
|
111
|
+
- **skills**: agregar path en `mcpServers` o en la lista de skills según configuración activa
|
|
112
|
+
- **rules**: agregar path en `rules` si la configuración lo soporta
|
|
113
|
+
- **hooks**: agregar entrada en `hooks` con el evento correspondiente
|
|
114
|
+
|
|
115
|
+
Si `.claude/settings.json` no existe o no soporta registro dinámico, documentar
|
|
116
|
+
los paths en `.planning/PLUGINS.md` para referencia manual.
|
|
117
|
+
|
|
118
|
+
### Paso 6 — Verificar integridad post-instalación
|
|
119
|
+
|
|
120
|
+
```bash
|
|
121
|
+
echo "Plugin <nombre> v<version> instalado en _userland/plugins/<nombre>/"
|
|
122
|
+
echo "Componentes: agentes=$(count), skills=$(count), reglas=$(count), hooks=$(count)"
|
|
123
|
+
```
|
|
124
|
+
|
|
125
|
+
Indicar al usuario que ejecute `/swl:salud` para verificar integridad global.
|
|
126
|
+
|
|
127
|
+
---
|
|
128
|
+
|
|
129
|
+
## remove — Desinstalar un plugin
|
|
130
|
+
|
|
131
|
+
### Paso 1 — Verificar existencia
|
|
132
|
+
|
|
133
|
+
```bash
|
|
134
|
+
ls _userland/plugins/<nombre>/
|
|
135
|
+
cat _userland/plugins/<nombre>/plugin.json
|
|
136
|
+
```
|
|
137
|
+
|
|
138
|
+
Si no existe: reportar y terminar.
|
|
139
|
+
|
|
140
|
+
### Paso 2 — Verificar dependientes
|
|
141
|
+
|
|
142
|
+
Buscar otros plugins instalados que declaren `<nombre>` en sus `dependencies`:
|
|
143
|
+
|
|
144
|
+
```bash
|
|
145
|
+
grep -r '"<nombre>"' _userland/plugins/*/plugin.json
|
|
146
|
+
```
|
|
147
|
+
|
|
148
|
+
Si hay dependientes activos: advertir y pedir confirmación antes de continuar.
|
|
149
|
+
|
|
150
|
+
### Paso 3 — Des-registrar de settings.json
|
|
151
|
+
|
|
152
|
+
Revertir los registros realizados durante `install`:
|
|
153
|
+
- Remover skills del listado
|
|
154
|
+
- Remover reglas del listado
|
|
155
|
+
- Remover hooks del listado
|
|
156
|
+
|
|
157
|
+
### Paso 4 — Eliminar directorio
|
|
158
|
+
|
|
159
|
+
```bash
|
|
160
|
+
rm -rf _userland/plugins/<nombre>/
|
|
161
|
+
```
|
|
162
|
+
|
|
163
|
+
Confirmar: `Plugin <nombre> desinstalado correctamente.`
|
|
164
|
+
|
|
165
|
+
---
|
|
166
|
+
|
|
167
|
+
## validate — Validar plugin sin instalar
|
|
168
|
+
|
|
169
|
+
### Paso 1 — Verificar estructura mínima
|
|
170
|
+
|
|
171
|
+
```bash
|
|
172
|
+
ls <ruta>/plugin.json
|
|
173
|
+
```
|
|
174
|
+
|
|
175
|
+
### Paso 2 — Validar campos del manifiesto
|
|
176
|
+
|
|
177
|
+
Leer `plugin.json` y verificar:
|
|
178
|
+
|
|
179
|
+
| Campo | Regla |
|
|
180
|
+
|-------|-------|
|
|
181
|
+
| `name` | presente, `^[a-z][a-z0-9-]+$`, máximo 64 chars |
|
|
182
|
+
| `version` | presente, `^\d+\.\d+\.\d+$` |
|
|
183
|
+
| `description` | presente, 10–500 chars |
|
|
184
|
+
| `agents[]` | cada ruta existe en el directorio |
|
|
185
|
+
| `skills[]` | cada ruta existe y contiene `SKILL.md` |
|
|
186
|
+
| `rules[]` | cada ruta existe y termina en `.md` |
|
|
187
|
+
| `hooks[]` | cada ruta existe y termina en `.js` |
|
|
188
|
+
| `dependencies` | cada valor es SemVer válido |
|
|
189
|
+
|
|
190
|
+
### Paso 3 — Reportar resultado
|
|
191
|
+
|
|
192
|
+
Si pasa todas las verificaciones:
|
|
193
|
+
```
|
|
194
|
+
✓ plugin.json válido
|
|
195
|
+
✓ X archivos referenciados verificados
|
|
196
|
+
✓ El plugin puede instalarse con: /swl:plugins install <ruta>
|
|
197
|
+
```
|
|
198
|
+
|
|
199
|
+
Si hay problemas: listar cada problema con campo y descripción del error.
|
|
200
|
+
|
|
201
|
+
---
|
|
202
|
+
|
|
203
|
+
## list — Listar plugins instalados
|
|
204
|
+
|
|
205
|
+
```bash
|
|
206
|
+
ls _userland/plugins/ 2>/dev/null || echo "(ningún plugin instalado)"
|
|
207
|
+
```
|
|
208
|
+
|
|
209
|
+
Para cada plugin encontrado, leer su `plugin.json` y mostrar:
|
|
210
|
+
|
|
211
|
+
```
|
|
212
|
+
nombre versión autor componentes
|
|
213
|
+
──────────────────────────────────────────────────────
|
|
214
|
+
mi-dominio 1.2.0 Equipo A 3 skills, 1 agente
|
|
215
|
+
otro-plugin 0.5.1 Dev externo 2 reglas, 1 hook
|
|
216
|
+
```
|
|
217
|
+
|
|
218
|
+
Si no hay plugins instalados: indicar cómo instalar uno.
|
|
219
|
+
|
|
220
|
+
---
|
|
221
|
+
|
|
222
|
+
## Estructura de un plugin
|
|
223
|
+
|
|
224
|
+
```
|
|
225
|
+
mi-plugin/
|
|
226
|
+
plugin.json — Manifiesto (requerido)
|
|
227
|
+
agentes/ — Agentes custom (.md con frontmatter YAML)
|
|
228
|
+
habilidades/ — Skills custom (directorios con SKILL.md)
|
|
229
|
+
reglas/ — Reglas custom (.md)
|
|
230
|
+
hooks/ — Hooks custom (.js)
|
|
231
|
+
```
|
|
232
|
+
|
|
233
|
+
### Ejemplo de plugin.json válido
|
|
234
|
+
|
|
235
|
+
```json
|
|
236
|
+
{
|
|
237
|
+
"name": "facturacion-sat",
|
|
238
|
+
"version": "1.0.0",
|
|
239
|
+
"description": "Skills y agentes para integración con el SAT mexicano.",
|
|
240
|
+
"author": "Equipo Fiscal",
|
|
241
|
+
"license": "MIT",
|
|
242
|
+
"skills": ["habilidades/cfdi-4"],
|
|
243
|
+
"agents": ["agentes/validador-sat.md"],
|
|
244
|
+
"rules": ["reglas/cumplimiento-sat.md"]
|
|
245
|
+
}
|
|
246
|
+
```
|
|
247
|
+
|
|
248
|
+
---
|
|
249
|
+
|
|
250
|
+
## Notas de gobernanza
|
|
251
|
+
|
|
252
|
+
- Los plugins instalados en `_userland/` nunca modifican los componentes del sistema base.
|
|
253
|
+
- Los hooks de plugins con `blocking: true` requieren aprobación antes de activarse
|
|
254
|
+
(ver `reglas/gobernanza.md`).
|
|
255
|
+
- Los plugins auto-generados por `/swl:evolucionar` se instalan primero aquí como
|
|
256
|
+
período de prueba antes de promoverse al sistema base.
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: swl:reflect-skills
|
|
3
|
+
description: Analiza el historial de sesiones de Claude Code para detectar patrones de uso repetidos que sean candidatos a convertirse en nuevos skills, comandos o agentes del sistema SWL. Inspirado en el patrón Reflect de claude-reflect (Karpathy). Sin dependencias externas.
|
|
4
|
+
allowed_tools: ["Read", "Write", "Edit", "Bash", "Grep", "Glob"]
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# /swl:reflect-skills — Descubrimiento de skills emergentes
|
|
8
|
+
|
|
9
|
+
Analiza los archivos JSONL del historial de Claude Code (`~/.claude/projects/<proyecto>/*.jsonl`) y la cola de feedback del usuario (`.planning/evolucion/feedback-queue.jsonl`) para detectar intenciones repetidas que podrían formalizarse como skills, comandos o agentes nuevos del sistema SWL.
|
|
10
|
+
|
|
11
|
+
Complementa a `/swl:aprender` (que trabaja sobre la sesión actual) y a `/swl:evolucionar` (que opera sobre metadatos de agentes/skills existentes). Este comando mira el **historial acumulado** y propone componentes emergentes basándose en la frecuencia real de uso.
|
|
12
|
+
|
|
13
|
+
## Cuándo usar este comando
|
|
14
|
+
|
|
15
|
+
- Cada 2-4 semanas, para identificar nuevos dominios donde el usuario está pidiendo cosas recurrentes sin un skill dedicado.
|
|
16
|
+
- Antes de publicar una versión MINOR del sistema SWL, para decidir si vale la pena formalizar algún patrón emergente.
|
|
17
|
+
- Después de un proyecto grande, para extraer el know-how ganado como componentes reutilizables.
|
|
18
|
+
- Cuando `auto-evolucion.js` reporte alta densidad de acciones sin skill asociado.
|
|
19
|
+
|
|
20
|
+
## Cuándo NO usar
|
|
21
|
+
|
|
22
|
+
- Para extraer aprendizajes de la sesión actual → usar `/swl:aprender`.
|
|
23
|
+
- Para mejorar un agente/skill existente basado en métricas de fallo → usar `/swl:evolucionar`.
|
|
24
|
+
- Para actualizar el perfil del usuario → usar el agente `perfilador-usuario-swl`.
|
|
25
|
+
- Para buscar conocimiento ya registrado → usar `/swl:wiki query` o `Skill("memoria-busqueda")`.
|
|
26
|
+
|
|
27
|
+
## Flujo
|
|
28
|
+
|
|
29
|
+
### Paso 1 — Ejecutar el análisis
|
|
30
|
+
|
|
31
|
+
Corre el script determinista que lee los JSONL del proyecto actual y clusteriza intenciones:
|
|
32
|
+
|
|
33
|
+
```bash
|
|
34
|
+
node scripts/reflect-skills.js --ventana 30 --umbral 3
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
Parámetros:
|
|
38
|
+
- `--ventana N` — días de historial a analizar (default: 30)
|
|
39
|
+
- `--umbral N` — mínimo de ocurrencias para reportar cluster (default: 3)
|
|
40
|
+
- `--json` — salida estructurada en JSON
|
|
41
|
+
|
|
42
|
+
El script produce:
|
|
43
|
+
- Reporte textual en stdout
|
|
44
|
+
- Archivo estructurado en `.planning/evolucion/reflect-skills-report.json`
|
|
45
|
+
|
|
46
|
+
### Paso 2 — Leer y clasificar los candidatos
|
|
47
|
+
|
|
48
|
+
Lee el reporte generado y clasifica cada candidato en una de estas categorías:
|
|
49
|
+
|
|
50
|
+
| Categoría | Acción recomendada |
|
|
51
|
+
|-----------|-------------------|
|
|
52
|
+
| Patrón técnico nuevo (ej. "integrar redis cache") | Proponer como skill en el dominio correspondiente (`backend-`, `frontend-`, etc.) |
|
|
53
|
+
| Operación repetida con pasos fijos (ej. "ejecuta pruebas de carga") | Proponer como comando `/swl:<nombre>` |
|
|
54
|
+
| Tarea que cruza varios agentes (ej. "audita dependencias + actualiza CHANGELOG") | Proponer como flujo del `orquestador-swl` |
|
|
55
|
+
| Corrección del usuario repetida | Enviar al `perfilador-usuario-swl` |
|
|
56
|
+
| Falso positivo (prompt genérico, ruido) | Ignorar y anotar en la bitácora del comando |
|
|
57
|
+
|
|
58
|
+
### Paso 3 — Validar con el usuario
|
|
59
|
+
|
|
60
|
+
Presenta al usuario los top 3-5 candidatos con:
|
|
61
|
+
- Nombre propuesto y tipo (skill / comando / flujo)
|
|
62
|
+
- Cantidad de ocurrencias en la ventana
|
|
63
|
+
- 2-3 ejemplos de prompts reales
|
|
64
|
+
- Justificación de por qué formalizarlo
|
|
65
|
+
|
|
66
|
+
**Esperar aprobación explícita** antes de generar componentes. No crear skills automáticamente sin confirmación.
|
|
67
|
+
|
|
68
|
+
### Paso 4 — Crear los componentes aprobados
|
|
69
|
+
|
|
70
|
+
Para cada candidato aprobado:
|
|
71
|
+
|
|
72
|
+
- **Skill**: invocar `/swl:crear-skill` con el dominio correspondiente.
|
|
73
|
+
- **Comando**: delegar al agente `orquestador-swl` para crear `comandos/swl/<nombre>.md` siguiendo la plantilla.
|
|
74
|
+
- **Flujo**: delegar al `auto-evolucion-swl` para proponer evolución al orquestador.
|
|
75
|
+
|
|
76
|
+
Registrar la decisión en `.planning/APRENDIZAJES.md` bajo la sección **Patrones emergentes**.
|
|
77
|
+
|
|
78
|
+
### Paso 5 — Cerrar ciclo
|
|
79
|
+
|
|
80
|
+
- Actualizar `CLAUDE.md` si se agregó un componente al sistema (tabla de comandos, skills por dominio).
|
|
81
|
+
- Bumpar versión del sistema si procede (MINOR para skill/comando nuevo, ver `git-workflow.md`).
|
|
82
|
+
- Commit atómico con mensaje: `feat(sistema): agrega <componente> desde /swl:reflect-skills`.
|
|
83
|
+
|
|
84
|
+
## Salida esperada
|
|
85
|
+
|
|
86
|
+
Reporte legible como:
|
|
87
|
+
|
|
88
|
+
```
|
|
89
|
+
━━━ Reflect Skills — análisis de historial ━━━
|
|
90
|
+
Ventana: últimos 30 días
|
|
91
|
+
Prompts analizados: 412
|
|
92
|
+
Umbral de repetición: 3
|
|
93
|
+
|
|
94
|
+
2 candidato(s) detectado(s):
|
|
95
|
+
|
|
96
|
+
1. [SKILL] redis-cache-integrar
|
|
97
|
+
Intención: "integrar redis" (5×)
|
|
98
|
+
Motivo: Intención "integrar redis" repetida 5× → candidato a skill que encapsule el patrón.
|
|
99
|
+
Ejemplos:
|
|
100
|
+
• integra redis como cache layer en el endpoint de productos
|
|
101
|
+
• integrar redis con invalidation por tags
|
|
102
|
+
• quiero integrar redis stream para workers
|
|
103
|
+
|
|
104
|
+
2. [COMANDO] release-verificar
|
|
105
|
+
Intención: "verificar release" (4×)
|
|
106
|
+
Motivo: Verbo operativo "verificar" repetido 4× → candidato a automatización por comando slash.
|
|
107
|
+
Ejemplos:
|
|
108
|
+
• verifica que el release esté listo
|
|
109
|
+
• verificar release antes de publicar
|
|
110
|
+
• verificar release 5.10.5
|
|
111
|
+
|
|
112
|
+
Feedback del usuario capturado: 7 entradas
|
|
113
|
+
- correccion: 3
|
|
114
|
+
- preferencia: 2
|
|
115
|
+
- memoria: 2
|
|
116
|
+
→ Revisar con perfilador-usuario-swl y /swl:aprender.
|
|
117
|
+
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
118
|
+
```
|
|
119
|
+
|
|
120
|
+
## Notas
|
|
121
|
+
|
|
122
|
+
- El clustering es heurístico (tokens + verbos de acción), **no semántico con embeddings**. Busca simplicidad y zero-deps sobre precisión absoluta.
|
|
123
|
+
- Si un candidato tiene nombre similar a un skill/comando existente, revisar primero si se puede **extender** en lugar de crear uno nuevo.
|
|
124
|
+
- El comando NO escribe a APRENDIZAJES.md automáticamente — el usuario decide qué formalizar.
|
|
125
|
+
- Para el modo con embeddings (SentenceTransformers + ChromaDB), ver `Skill("wiki-conocimiento")` y `/swl:wiki` que ya implementan el patrón Karpathy completo.
|