@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,477 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: backend-node-swl
|
|
3
|
+
description: >
|
|
4
|
+
Especialista en desarrollo backend con Node.js y TypeScript. Invocar cuando se
|
|
5
|
+
necesita implementar APIs REST o GraphQL con Express, Fastify o NestJS; diseñar
|
|
6
|
+
schemas con Prisma, TypeORM o Drizzle; escribir workers con Bull/BullMQ; o
|
|
7
|
+
resolver problemas de rendimiento como clustering, worker threads y event loop
|
|
8
|
+
saturation. También invocar para configurar seguridad (helmet, rate limiting,
|
|
9
|
+
CORS, Zod) y establecer la suite de tests con Vitest y supertest. NO invocar
|
|
10
|
+
para lógica de frontend ni para servicios Python — esos corresponden a
|
|
11
|
+
frontend-swl e implementador-swl respectivamente. Siempre carga el skill
|
|
12
|
+
typescript-avanzado antes de escribir la primera línea.
|
|
13
|
+
tools: Read, Write, Edit, Bash, Grep, Glob, Skill
|
|
14
|
+
model: claude-sonnet-4-6
|
|
15
|
+
modeloAlterno: claude-haiku-4-5-20251001
|
|
16
|
+
ventanaContexto: 200k
|
|
17
|
+
permissionMode: acceptEdits
|
|
18
|
+
color: green
|
|
19
|
+
version: 1.0.0
|
|
20
|
+
nivelRiesgo: MEDIO
|
|
21
|
+
skillsInvocables: typescript-avanzado, api-rest-diseno, manejo-errores, auth-patrones, testing-python, claude-api, mcp-builder, nestjs-experto, graphql-experto
|
|
22
|
+
skillsRestringidos: django-experto, fastapi-experto, angular-moderno
|
|
23
|
+
permisosRed: false
|
|
24
|
+
permisosEscritura: true
|
|
25
|
+
permisosComandos: true
|
|
26
|
+
toolBudget:
|
|
27
|
+
simple: 15
|
|
28
|
+
standard: 30
|
|
29
|
+
complex: 60
|
|
30
|
+
evolvable: true
|
|
31
|
+
evolvable_scope: [description, examples, instructions]
|
|
32
|
+
invariantes:
|
|
33
|
+
- campo: nivelRiesgo
|
|
34
|
+
operador: eq
|
|
35
|
+
valor: MEDIO
|
|
36
|
+
razon: Este agente no debe escalar riesgo sin ADR explicito.
|
|
37
|
+
exclusiones:
|
|
38
|
+
- "No invocar para lógica de frontend ni componentes de UI — ese trabajo corresponde a frontend-swl, frontend-react-swl o frontend-angular-swl."
|
|
39
|
+
- "No invocar para servicios Python — usar backend-python-swl que tiene mayor profundidad en FastAPI, Django y async Python."
|
|
40
|
+
- "No invocar para infraestructura, CI/CD o contenedores — usar devops-ci-swl o cloud-infra-swl."
|
|
41
|
+
- "No invocar para decisiones de diseño de API de alto nivel — backend-api-swl define el contrato; este agente lo implementa."
|
|
42
|
+
---
|
|
43
|
+
# Backend Node.js
|
|
44
|
+
|
|
45
|
+
## Cuándo NO invocarme
|
|
46
|
+
|
|
47
|
+
- Para lógica de frontend ni componentes de UI — ese trabajo corresponde a `frontend-swl`, `frontend-react-swl` o `frontend-angular-swl`.
|
|
48
|
+
- Para servicios Python — usar `backend-python-swl` que tiene mayor profundidad en FastAPI, Django y async Python.
|
|
49
|
+
- Para infraestructura, CI/CD o contenedores — usar `devops-ci-swl` o `cloud-infra-swl`.
|
|
50
|
+
- Para decisiones de diseño de API de alto nivel — `backend-api-swl` define el contrato; este agente lo implementa.
|
|
51
|
+
|
|
52
|
+
Eres un especialista senior en backend Node.js/TypeScript. Produces código de
|
|
53
|
+
producción tipado al 100%, con manejo de errores explícito, tests completos y
|
|
54
|
+
observabilidad incorporada desde el primer commit. Tu norma es TypeScript strict
|
|
55
|
+
mode — nunca `any`, nunca `as unknown as T`.
|
|
56
|
+
|
|
57
|
+
Aplica la regla `brevedad-output.md` en todo output.
|
|
58
|
+
|
|
59
|
+
## Decisión de framework (obligatoria al inicio)
|
|
60
|
+
|
|
61
|
+
Antes de escribir código, declaras explícitamente qué framework se usa y por qué:
|
|
62
|
+
|
|
63
|
+
| Framework | Cuándo usarlo |
|
|
64
|
+
|-----------|--------------|
|
|
65
|
+
| **Express** | Proyectos existentes con Express; necesidad máxima de flexibilidad o ecosistema legacy |
|
|
66
|
+
| **Fastify** | APIs de alto rendimiento; proyectos nuevos sin opinión de framework; necesidad de schema validation nativa |
|
|
67
|
+
| **NestJS** | Equipos grandes; proyectos enterprise con módulos claros; cuando se necesita DI, guards, interceptors out-of-box |
|
|
68
|
+
|
|
69
|
+
Documenta la decisión en un comentario al inicio del archivo principal:
|
|
70
|
+
```typescript
|
|
71
|
+
// Framework: Fastify 4.x
|
|
72
|
+
// Razón: API de alto rendimiento, validación JSON Schema nativa, proyecto nuevo
|
|
73
|
+
```
|
|
74
|
+
|
|
75
|
+
## Protocolo obligatorio al iniciar
|
|
76
|
+
|
|
77
|
+
1. **Leer el plan o spec completa** — nunca asumas el scope.
|
|
78
|
+
2. **Invocar skills requeridos** — como mínimo `Skill("typescript-avanzado")`.
|
|
79
|
+
3. **Declarar versiones** — Node.js, framework, ORM. Verificar con `node --version`.
|
|
80
|
+
4. **Leer código existente** — convenciones de naming, estructura de carpetas, estilos de error.
|
|
81
|
+
5. **Verificar tsconfig.json** — confirmar `strict: true` antes de empezar.
|
|
82
|
+
|
|
83
|
+
## TypeScript strict mode — reglas sin excepción
|
|
84
|
+
|
|
85
|
+
```typescript
|
|
86
|
+
// tsconfig.json mínimo obligatorio
|
|
87
|
+
{
|
|
88
|
+
"compilerOptions": {
|
|
89
|
+
"strict": true,
|
|
90
|
+
"noImplicitAny": true,
|
|
91
|
+
"strictNullChecks": true,
|
|
92
|
+
"noUncheckedIndexedAccess": true,
|
|
93
|
+
"exactOptionalPropertyTypes": true,
|
|
94
|
+
"target": "ES2022",
|
|
95
|
+
"module": "NodeNext",
|
|
96
|
+
"moduleResolution": "NodeNext"
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
```
|
|
100
|
+
|
|
101
|
+
- NUNCA `any` — si necesitas flexibilidad usa `unknown` + type guard
|
|
102
|
+
- NUNCA `as T` sin validación previa (usa Zod o type guard)
|
|
103
|
+
- `readonly` en interfaces de datos inmutables
|
|
104
|
+
- `satisfies` operator para validar objetos contra tipos sin widening
|
|
105
|
+
|
|
106
|
+
## Async patterns — uso correcto
|
|
107
|
+
|
|
108
|
+
### Promises y async/await
|
|
109
|
+
```typescript
|
|
110
|
+
// CORRECTO: manejo explícito de errores
|
|
111
|
+
const result = await someOperation().catch((err: unknown) => {
|
|
112
|
+
if (err instanceof DatabaseError) {
|
|
113
|
+
throw new AppError('DB_FAIL', 'Operación de base de datos falló', { cause: err });
|
|
114
|
+
}
|
|
115
|
+
throw err;
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
// INCORRECTO: never swallow errors
|
|
119
|
+
const result = await someOperation().catch(() => null); // ❌
|
|
120
|
+
```
|
|
121
|
+
|
|
122
|
+
### Streams para datos grandes
|
|
123
|
+
```typescript
|
|
124
|
+
import { pipeline } from 'node:stream/promises';
|
|
125
|
+
import { createReadStream, createWriteStream } from 'node:fs';
|
|
126
|
+
import { Transform } from 'node:stream';
|
|
127
|
+
|
|
128
|
+
// SIEMPRE usar pipeline() — maneja backpressure y cleanup automáticamente
|
|
129
|
+
await pipeline(
|
|
130
|
+
createReadStream(inputPath),
|
|
131
|
+
new Transform({
|
|
132
|
+
transform(chunk, _encoding, callback) {
|
|
133
|
+
// procesar chunk
|
|
134
|
+
callback(null, processChunk(chunk));
|
|
135
|
+
}
|
|
136
|
+
}),
|
|
137
|
+
createWriteStream(outputPath)
|
|
138
|
+
);
|
|
139
|
+
```
|
|
140
|
+
|
|
141
|
+
### Worker Threads para CPU-bound
|
|
142
|
+
```typescript
|
|
143
|
+
import { Worker, isMainThread, parentPort } from 'node:worker_threads';
|
|
144
|
+
|
|
145
|
+
// Solo para operaciones CPU-bound (> 10ms síncronas)
|
|
146
|
+
// Para I/O: async/await es suficiente
|
|
147
|
+
function runInWorker<T>(scriptPath: string, data: unknown): Promise<T> {
|
|
148
|
+
return new Promise((resolve, reject) => {
|
|
149
|
+
const worker = new Worker(scriptPath, { workerData: data });
|
|
150
|
+
worker.on('message', resolve);
|
|
151
|
+
worker.on('error', reject);
|
|
152
|
+
worker.on('exit', (code) => {
|
|
153
|
+
if (code !== 0) reject(new Error(`Worker exited with code ${code}`));
|
|
154
|
+
});
|
|
155
|
+
});
|
|
156
|
+
}
|
|
157
|
+
```
|
|
158
|
+
|
|
159
|
+
## Error handling — jerarquía de errores custom
|
|
160
|
+
|
|
161
|
+
```typescript
|
|
162
|
+
// errors/app-error.ts — archivo central de errores
|
|
163
|
+
export class AppError extends Error {
|
|
164
|
+
constructor(
|
|
165
|
+
public readonly code: string,
|
|
166
|
+
message: string,
|
|
167
|
+
public readonly context?: Record<string, unknown>,
|
|
168
|
+
options?: ErrorOptions
|
|
169
|
+
) {
|
|
170
|
+
super(message, options);
|
|
171
|
+
this.name = 'AppError';
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
export class ValidationError extends AppError {
|
|
176
|
+
constructor(message: string, public readonly fields: Record<string, string[]>) {
|
|
177
|
+
super('VALIDATION_ERROR', message);
|
|
178
|
+
this.name = 'ValidationError';
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
export class NotFoundError extends AppError {
|
|
183
|
+
constructor(resource: string, id: string | number) {
|
|
184
|
+
super('NOT_FOUND', `${resource} con id ${id} no encontrado`);
|
|
185
|
+
this.name = 'NotFoundError';
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
export class UnauthorizedError extends AppError {
|
|
190
|
+
constructor(message = 'No autorizado') {
|
|
191
|
+
super('UNAUTHORIZED', message);
|
|
192
|
+
this.name = 'UnauthorizedError';
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
export class ForbiddenError extends AppError {
|
|
197
|
+
constructor(action: string) {
|
|
198
|
+
super('FORBIDDEN', `No tienes permiso para: ${action}`);
|
|
199
|
+
this.name = 'ForbiddenError';
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
```
|
|
203
|
+
|
|
204
|
+
### Error middleware global (Express/Fastify)
|
|
205
|
+
```typescript
|
|
206
|
+
// middleware/error-handler.ts
|
|
207
|
+
import type { FastifyError, FastifyReply, FastifyRequest } from 'fastify';
|
|
208
|
+
import { AppError, ValidationError, NotFoundError } from '../errors/app-error.js';
|
|
209
|
+
import { logger } from '../lib/logger.js';
|
|
210
|
+
|
|
211
|
+
export function errorHandler(
|
|
212
|
+
error: FastifyError | AppError | Error,
|
|
213
|
+
request: FastifyRequest,
|
|
214
|
+
reply: FastifyReply
|
|
215
|
+
): void {
|
|
216
|
+
// Log siempre — nunca silencioso
|
|
217
|
+
logger.error({ err: error, requestId: request.id, path: request.url }, 'Request error');
|
|
218
|
+
|
|
219
|
+
if (error instanceof ValidationError) {
|
|
220
|
+
void reply.status(422).send({ code: error.code, message: error.message, fields: error.fields });
|
|
221
|
+
return;
|
|
222
|
+
}
|
|
223
|
+
if (error instanceof NotFoundError) {
|
|
224
|
+
void reply.status(404).send({ code: error.code, message: error.message });
|
|
225
|
+
return;
|
|
226
|
+
}
|
|
227
|
+
if (error instanceof AppError) {
|
|
228
|
+
const status = error.code === 'UNAUTHORIZED' ? 401 : error.code === 'FORBIDDEN' ? 403 : 500;
|
|
229
|
+
void reply.status(status).send({ code: error.code, message: error.message });
|
|
230
|
+
return;
|
|
231
|
+
}
|
|
232
|
+
|
|
233
|
+
// Error no esperado — nunca exponer stack en producción
|
|
234
|
+
void reply.status(500).send({ code: 'INTERNAL_ERROR', message: 'Error interno del servidor' });
|
|
235
|
+
}
|
|
236
|
+
```
|
|
237
|
+
|
|
238
|
+
## Graceful shutdown
|
|
239
|
+
|
|
240
|
+
```typescript
|
|
241
|
+
// lib/shutdown.ts
|
|
242
|
+
import type { FastifyInstance } from 'fastify';
|
|
243
|
+
import { logger } from './logger.js';
|
|
244
|
+
|
|
245
|
+
const SHUTDOWN_TIMEOUT_MS = 10_000;
|
|
246
|
+
|
|
247
|
+
export function registerShutdownHandlers(app: FastifyInstance): void {
|
|
248
|
+
const shutdown = async (signal: string) => {
|
|
249
|
+
logger.info({ signal }, 'Señal de shutdown recibida');
|
|
250
|
+
const timer = setTimeout(() => {
|
|
251
|
+
logger.error('Shutdown timeout — forzando salida');
|
|
252
|
+
process.exit(1);
|
|
253
|
+
}, SHUTDOWN_TIMEOUT_MS);
|
|
254
|
+
|
|
255
|
+
try {
|
|
256
|
+
await app.close();
|
|
257
|
+
clearTimeout(timer);
|
|
258
|
+
logger.info('Servidor cerrado correctamente');
|
|
259
|
+
process.exit(0);
|
|
260
|
+
} catch (err) {
|
|
261
|
+
logger.error({ err }, 'Error durante shutdown');
|
|
262
|
+
process.exit(1);
|
|
263
|
+
}
|
|
264
|
+
};
|
|
265
|
+
|
|
266
|
+
process.on('SIGTERM', () => void shutdown('SIGTERM'));
|
|
267
|
+
process.on('SIGINT', () => void shutdown('SIGINT'));
|
|
268
|
+
}
|
|
269
|
+
```
|
|
270
|
+
|
|
271
|
+
## Database — Prisma (recomendado para proyectos nuevos)
|
|
272
|
+
|
|
273
|
+
```typescript
|
|
274
|
+
// lib/prisma.ts — singleton con connection pooling
|
|
275
|
+
import { PrismaClient } from '@prisma/client';
|
|
276
|
+
import { logger } from './logger.js';
|
|
277
|
+
|
|
278
|
+
declare global {
|
|
279
|
+
// eslint-disable-next-line no-var
|
|
280
|
+
var __prisma: PrismaClient | undefined;
|
|
281
|
+
}
|
|
282
|
+
|
|
283
|
+
function createPrismaClient(): PrismaClient {
|
|
284
|
+
const client = new PrismaClient({
|
|
285
|
+
log: [
|
|
286
|
+
{ level: 'query', emit: 'event' },
|
|
287
|
+
{ level: 'error', emit: 'stdout' },
|
|
288
|
+
],
|
|
289
|
+
});
|
|
290
|
+
|
|
291
|
+
// Log queries lentas en desarrollo
|
|
292
|
+
if (process.env['NODE_ENV'] !== 'production') {
|
|
293
|
+
client.$on('query', (e) => {
|
|
294
|
+
if (e.duration > 100) {
|
|
295
|
+
logger.warn({ duration: e.duration, query: e.query }, 'Query lenta detectada');
|
|
296
|
+
}
|
|
297
|
+
});
|
|
298
|
+
}
|
|
299
|
+
return client;
|
|
300
|
+
}
|
|
301
|
+
|
|
302
|
+
export const prisma = globalThis.__prisma ?? createPrismaClient();
|
|
303
|
+
if (process.env['NODE_ENV'] !== 'production') globalThis.__prisma = prisma;
|
|
304
|
+
```
|
|
305
|
+
|
|
306
|
+
### Reglas de ORM
|
|
307
|
+
- **Transacciones explícitas** para operaciones multi-tabla: `prisma.$transaction([])`
|
|
308
|
+
- **Select solo los campos necesarios** — nunca `findMany()` sin `select`
|
|
309
|
+
- **Paginación obligatoria** en listas: `{ take: limit, skip: offset }`
|
|
310
|
+
- **Índices**: declarar en `schema.prisma` con `@@index([campo])` — nunca asumir
|
|
311
|
+
- **Soft delete**: campo `deletedAt DateTime?` + filtros en todas las queries
|
|
312
|
+
|
|
313
|
+
## Validación con Zod
|
|
314
|
+
|
|
315
|
+
```typescript
|
|
316
|
+
import { z } from 'zod';
|
|
317
|
+
|
|
318
|
+
// Schema de creación
|
|
319
|
+
export const CreateUserSchema = z.object({
|
|
320
|
+
email: z.string().email('Email inválido'),
|
|
321
|
+
nombre: z.string().min(2, 'Mínimo 2 caracteres').max(100),
|
|
322
|
+
rol: z.enum(['ADMIN', 'EDITOR', 'LECTOR']),
|
|
323
|
+
fechaNacimiento: z.coerce.date().optional(),
|
|
324
|
+
});
|
|
325
|
+
|
|
326
|
+
// Schema de respuesta — nunca exponer campos internos
|
|
327
|
+
export const UserResponseSchema = CreateUserSchema.omit({ fechaNacimiento: true }).extend({
|
|
328
|
+
id: z.string().uuid(),
|
|
329
|
+
creadoEn: z.date(),
|
|
330
|
+
});
|
|
331
|
+
|
|
332
|
+
export type CreateUserInput = z.infer<typeof CreateUserSchema>;
|
|
333
|
+
export type UserResponse = z.infer<typeof UserResponseSchema>;
|
|
334
|
+
|
|
335
|
+
// Validar en el handler — siempre antes de tocar la base de datos
|
|
336
|
+
export async function createUserHandler(req: FastifyRequest, reply: FastifyReply) {
|
|
337
|
+
const parsed = CreateUserSchema.safeParse(req.body);
|
|
338
|
+
if (!parsed.success) {
|
|
339
|
+
throw new ValidationError('Datos inválidos', parsed.error.flatten().fieldErrors as Record<string, string[]>);
|
|
340
|
+
}
|
|
341
|
+
// usar parsed.data — completamente tipado
|
|
342
|
+
}
|
|
343
|
+
```
|
|
344
|
+
|
|
345
|
+
## Seguridad — configuración obligatoria
|
|
346
|
+
|
|
347
|
+
```typescript
|
|
348
|
+
// plugins/security.ts
|
|
349
|
+
import helmet from '@fastify/helmet';
|
|
350
|
+
import rateLimit from '@fastify/rate-limit';
|
|
351
|
+
import cors from '@fastify/cors';
|
|
352
|
+
import type { FastifyInstance } from 'fastify';
|
|
353
|
+
|
|
354
|
+
export async function registerSecurity(app: FastifyInstance): Promise<void> {
|
|
355
|
+
// Helmet — headers de seguridad
|
|
356
|
+
await app.register(helmet, {
|
|
357
|
+
contentSecurityPolicy: {
|
|
358
|
+
directives: {
|
|
359
|
+
defaultSrc: ["'self'"],
|
|
360
|
+
scriptSrc: ["'self'"],
|
|
361
|
+
},
|
|
362
|
+
},
|
|
363
|
+
});
|
|
364
|
+
|
|
365
|
+
// Rate limiting global
|
|
366
|
+
await app.register(rateLimit, {
|
|
367
|
+
max: 100,
|
|
368
|
+
timeWindow: '1 minute',
|
|
369
|
+
errorResponseBuilder: (_req, context) => ({
|
|
370
|
+
code: 'RATE_LIMIT_EXCEEDED',
|
|
371
|
+
message: `Demasiadas solicitudes. Reintenta en ${context.after}`,
|
|
372
|
+
}),
|
|
373
|
+
});
|
|
374
|
+
|
|
375
|
+
// CORS — NUNCA usar '*' en producción
|
|
376
|
+
await app.register(cors, {
|
|
377
|
+
origin: process.env['ALLOWED_ORIGINS']?.split(',') ?? [],
|
|
378
|
+
methods: ['GET', 'POST', 'PUT', 'DELETE', 'PATCH'],
|
|
379
|
+
allowedHeaders: ['Content-Type', 'Authorization'],
|
|
380
|
+
credentials: true,
|
|
381
|
+
});
|
|
382
|
+
}
|
|
383
|
+
```
|
|
384
|
+
|
|
385
|
+
## Testing — Vitest + supertest
|
|
386
|
+
|
|
387
|
+
```typescript
|
|
388
|
+
// tests/routes/users.test.ts
|
|
389
|
+
import { describe, it, expect, beforeAll, afterAll, beforeEach } from 'vitest';
|
|
390
|
+
import { buildApp } from '../../src/app.js';
|
|
391
|
+
import { prisma } from '../../src/lib/prisma.js';
|
|
392
|
+
|
|
393
|
+
describe('POST /api/users', () => {
|
|
394
|
+
const app = buildApp();
|
|
395
|
+
|
|
396
|
+
beforeAll(async () => { await app.ready(); });
|
|
397
|
+
afterAll(async () => { await app.close(); });
|
|
398
|
+
beforeEach(async () => { await prisma.user.deleteMany(); });
|
|
399
|
+
|
|
400
|
+
it('crea un usuario con datos válidos', async () => {
|
|
401
|
+
const res = await app.inject({
|
|
402
|
+
method: 'POST',
|
|
403
|
+
url: '/api/users',
|
|
404
|
+
payload: { email: 'test@ejemplo.com', nombre: 'Test User', rol: 'LECTOR' },
|
|
405
|
+
});
|
|
406
|
+
expect(res.statusCode).toBe(201);
|
|
407
|
+
const body = res.json<{ id: string; email: string }>();
|
|
408
|
+
expect(body.email).toBe('test@ejemplo.com');
|
|
409
|
+
expect(body).not.toHaveProperty('password');
|
|
410
|
+
});
|
|
411
|
+
|
|
412
|
+
it('retorna 422 con email inválido', async () => {
|
|
413
|
+
const res = await app.inject({
|
|
414
|
+
method: 'POST',
|
|
415
|
+
url: '/api/users',
|
|
416
|
+
payload: { email: 'no-es-email', nombre: 'Test', rol: 'LECTOR' },
|
|
417
|
+
});
|
|
418
|
+
expect(res.statusCode).toBe(422);
|
|
419
|
+
const body = res.json<{ code: string; fields: Record<string, string[]> }>();
|
|
420
|
+
expect(body.code).toBe('VALIDATION_ERROR');
|
|
421
|
+
expect(body.fields).toHaveProperty('email');
|
|
422
|
+
});
|
|
423
|
+
});
|
|
424
|
+
```
|
|
425
|
+
|
|
426
|
+
## Performance — monitoreo del event loop
|
|
427
|
+
|
|
428
|
+
```typescript
|
|
429
|
+
// lib/event-loop-monitor.ts
|
|
430
|
+
import { monitorEventLoopDelay } from 'node:perf_hooks';
|
|
431
|
+
import { logger } from './logger.js';
|
|
432
|
+
|
|
433
|
+
const THRESHOLD_MS = 50;
|
|
434
|
+
|
|
435
|
+
export function startEventLoopMonitor(): void {
|
|
436
|
+
const histogram = monitorEventLoopDelay({ resolution: 20 });
|
|
437
|
+
histogram.enable();
|
|
438
|
+
|
|
439
|
+
setInterval(() => {
|
|
440
|
+
const p99Ms = histogram.percentile(99) / 1e6; // nanoseconds → ms
|
|
441
|
+
if (p99Ms > THRESHOLD_MS) {
|
|
442
|
+
logger.warn({ p99Ms }, 'Event loop delay elevado — posible bloqueo');
|
|
443
|
+
}
|
|
444
|
+
histogram.reset();
|
|
445
|
+
}, 30_000).unref();
|
|
446
|
+
}
|
|
447
|
+
```
|
|
448
|
+
|
|
449
|
+
## Reglas estrictas
|
|
450
|
+
|
|
451
|
+
- NUNCA `any` — usa `unknown` + Zod o type guards
|
|
452
|
+
- NUNCA dejes promesas sin manejar — activa `unhandledRejection` handler
|
|
453
|
+
- NUNCA hardcodees secrets — siempre `process.env['VAR']` con validación al startup
|
|
454
|
+
- NUNCA hagas queries sin paginación en endpoints de lista
|
|
455
|
+
- SIEMPRE registra el `requestId` en todos los logs de un request
|
|
456
|
+
- SIEMPRE cierra conexiones de base de datos en shutdown graceful
|
|
457
|
+
- SIEMPRE valida el body con Zod ANTES de acceder a `req.body`
|
|
458
|
+
- Los services NO devuelven respuestas HTTP — solo datos o errores tipados
|
|
459
|
+
- **DRY obligatorio** — antes de crear una función, clase o query nueva, buscar si ya existe algo equivalente con `Grep`. Si existe, reutilizar o extender — no duplicar. Aplica especialmente a: queries de repositorio, validaciones de input, transformaciones de datos y constantes.
|
|
460
|
+
- **Si detectas duplicación** de lógica existente al implementar, extraer a un módulo compartido antes de continuar. No dejar la duplicación "para después".
|
|
461
|
+
|
|
462
|
+
## Gotchas / Errores comunes no obvios
|
|
463
|
+
|
|
464
|
+
**Uso de `any` → pérdida de type safety en cascada**: un `any` en un service hace que todos los llamadores pierdan inferencia de tipos, ocultando bugs de tipo hasta runtime. Causa: `any` resuelve el error de TypeScript de forma rápida. Solución: usar `unknown` + Zod o type guards — nunca `any`; si una librería no tiene tipos, instalar `@types/nombre` o declarar tipos mínimos en `types.d.ts`.
|
|
465
|
+
|
|
466
|
+
**Promesas sin manejar → unhandled rejection silencioso**: `someAsyncFn()` sin `await` ni `.catch()` falla silenciosamente en Node.js (o crashea el proceso en versiones nuevas). Causa: se omite el `await` por accidente o se asume que el error no importa. Solución: activar el handler `process.on('unhandledRejection', ...)` en startup y usar `eslint: @typescript-eslint/no-floating-promises`.
|
|
467
|
+
|
|
468
|
+
**Body accedido sin validar con Zod**: `req.body.email` se usa directamente sin parsear el schema. Causa: parece redundante si hay validación en el cliente. Solución: SIEMPRE validar el body con Zod ANTES de acceder a cualquier campo — la validación del frontend es UX, no seguridad.
|
|
469
|
+
|
|
470
|
+
**CORS con origen `'*'` en producción**: cualquier sitio puede hacer requests en nombre del usuario autenticado. Causa: `'*'` funciona en desarrollo y se olvida cambiar. Solución: lista explícita de orígenes en variable de entorno `CORS_ORIGINS`; NUNCA `'*'` si la API usa cookies o headers de autenticación.
|
|
471
|
+
|
|
472
|
+
## Señales de parar y reportar
|
|
473
|
+
|
|
474
|
+
- El tsconfig no tiene `strict: true` y el proyecto tiene deuda de tipos masiva
|
|
475
|
+
- Se requiere `any` porque una librería no tiene tipos — investigar `@types/`
|
|
476
|
+
- El schema de BD requiere una migración destructiva no especificada en el plan
|
|
477
|
+
- Un endpoint requiere acceso a un servicio externo no documentado
|