@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,270 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: backend-mcp-servidor
|
|
3
|
+
description: >
|
|
4
|
+
Diseño de servidores MCP (Model Context Protocol) para exponer capacidades
|
|
5
|
+
a Claude y otros clientes compatibles. Cubre los cinco patrones de producción
|
|
6
|
+
de Anthropic: servidores remotos first, agrupación de tools por intención,
|
|
7
|
+
code orchestration en sandbox para APIs grandes, elicitation mid-tool-call,
|
|
8
|
+
y autenticación con CIMD + Vaults. Cargar cuando se diseñe o revise un
|
|
9
|
+
servidor MCP, cuando se integre una API externa a agentes vía MCP en lugar
|
|
10
|
+
de tool use directo, o cuando un servicio deba ser alcanzable desde Claude,
|
|
11
|
+
ChatGPT, Cursor o VS Code sin rehacer la integración por cliente.
|
|
12
|
+
version: "1.0.0"
|
|
13
|
+
herramientasPermitidas: [Read, Write, Edit, Bash]
|
|
14
|
+
exclusiones:
|
|
15
|
+
- "No cargar para diseñar el consumo de un servidor MCP existente — eso es tool use estándar, no diseño de servidor; este skill cubre SOLO el lado del servidor."
|
|
16
|
+
- "No cargar para integraciones locales vía CLI (stdio transport) con ~10 tools — el overhead de diseñar un servidor MCP solo vale para casos con alcance multi-cliente o >50 tools."
|
|
17
|
+
- "No cargar para reemplazar un API REST existente — un servidor MCP complementa APIs, no las sustituye; diseña primero la API REST y luego decide si exponerla vía MCP."
|
|
18
|
+
- "No cargar para flujos de auth simples (API key estática) — MCP se beneficia de OAuth+CIMD; si el caso admite API key fija, un endpoint REST es más simple que un servidor MCP completo."
|
|
19
|
+
evolvable: true
|
|
20
|
+
---
|
|
21
|
+
|
|
22
|
+
# backend-mcp-servidor — Diseño de servidores MCP para producción
|
|
23
|
+
|
|
24
|
+
Diseñas servidores MCP que puedan alcanzar múltiples clientes (Claude, ChatGPT,
|
|
25
|
+
Cursor, VS Code) sin rehacer la integración para cada uno. El enfoque viene del
|
|
26
|
+
artículo de Anthropic sobre agentes en producción con MCP (2026-04) y de las
|
|
27
|
+
convenciones del MCP SDK oficial.
|
|
28
|
+
|
|
29
|
+
## Cuándo cargar
|
|
30
|
+
|
|
31
|
+
- Al diseñar un servidor MCP nuevo que expondrá una API interna a agentes.
|
|
32
|
+
- Al revisar un servidor MCP existente buscando reducir tokens en contexto.
|
|
33
|
+
- Al evaluar si un caso amerita MCP vs tool use directo con la API de Anthropic.
|
|
34
|
+
- Al integrar una API externa grande (>50 endpoints) como Cloudflare, GitHub,
|
|
35
|
+
Notion con agentes.
|
|
36
|
+
- Al decidir la estrategia de autenticación de un servidor MCP multi-tenant.
|
|
37
|
+
|
|
38
|
+
## Cuándo NO cargar
|
|
39
|
+
|
|
40
|
+
- Integraciones con pocas tools (≤10) y un solo cliente (Claude Code local) —
|
|
41
|
+
stdio transport con tool use directo es más simple.
|
|
42
|
+
- Reemplazo de una API REST existente — MCP complementa, no sustituye.
|
|
43
|
+
- Flujos de autenticación con API key estática sin OAuth — un endpoint HTTP
|
|
44
|
+
básico es más ligero.
|
|
45
|
+
- Diseño del lado del consumidor — este skill es para el servidor; el consumo
|
|
46
|
+
usa tool use estándar.
|
|
47
|
+
|
|
48
|
+
## Reglas obligatorias
|
|
49
|
+
|
|
50
|
+
1. **Remote-first si hay más de un cliente objetivo** — porque un servidor
|
|
51
|
+
local con stdio transport solo alcanza un cliente; remoto (SSE o HTTP) con
|
|
52
|
+
TLS alcanza cualquier cliente compatible con MCP y se despliega una sola vez.
|
|
53
|
+
2. **Agrupar tools por intención, no por endpoints** — porque un agente razona
|
|
54
|
+
mejor con una tool de alto nivel (`create_issue_from_thread`) que con tres
|
|
55
|
+
primitivos encadenados (`get_thread` → `parse_messages` → `create_issue`);
|
|
56
|
+
menos pasos implican menos alucinaciones y menos tokens.
|
|
57
|
+
3. **Code orchestration para APIs con más de 50 endpoints** — porque listar
|
|
58
|
+
500+ tools en contexto costaría miles de tokens y el modelo se pierde entre
|
|
59
|
+
alternativas; 2 tools (`search` + `execute`) ejecutando scripts en sandbox
|
|
60
|
+
son la solución probada (referencia: Cloudflare MCP server con ~2,500
|
|
61
|
+
endpoints reducidos a ~1K tokens).
|
|
62
|
+
4. **Elicitation solo para acciones destructivas o de pago** — porque pausar
|
|
63
|
+
la ejecución para pedir confirmación quiebra el flujo del agente; usarlo
|
|
64
|
+
únicamente cuando la reversibilidad o el costo justifican la fricción.
|
|
65
|
+
5. **Autenticación OAuth con CIMD; NUNCA embeber credenciales en tool_input** —
|
|
66
|
+
porque los parámetros de una tool se registran en logs, se muestran al
|
|
67
|
+
usuario y quedan en el historial del agente; los tokens OAuth deben vivir
|
|
68
|
+
en el servidor vía Vaults o gestor de secretos, no en el protocolo MCP.
|
|
69
|
+
|
|
70
|
+
## Patrón 1 — Remote-first vs local
|
|
71
|
+
|
|
72
|
+
Un servidor MCP local (stdio) solo lo ejecuta un cliente a la vez. Un servidor
|
|
73
|
+
remoto (SSE/HTTP con TLS) atiende a todos los clientes de todos los usuarios.
|
|
74
|
+
|
|
75
|
+
| Transporte | Cuándo |
|
|
76
|
+
|---|---|
|
|
77
|
+
| `stdio` | Desarrollo local, integraciones con CLI tools, ≤10 tools, un cliente |
|
|
78
|
+
| `SSE` (Server-Sent Events) | Producción single-tenant con streaming bidireccional |
|
|
79
|
+
| `HTTP streamable` | Producción multi-tenant con autenticación OAuth |
|
|
80
|
+
|
|
81
|
+
**Heurística:** si el servicio tiene clientes humanos y agentes, diseñar
|
|
82
|
+
directamente HTTP streamable. Nunca "empezar local y migrar después" — el
|
|
83
|
+
costo de reescribir auth y state management supera el beneficio.
|
|
84
|
+
|
|
85
|
+
## Patrón 2 — Tool grouping por intención
|
|
86
|
+
|
|
87
|
+
MAL (expone endpoints):
|
|
88
|
+
|
|
89
|
+
```python
|
|
90
|
+
@mcp.tool()
|
|
91
|
+
def get_thread(thread_id: str) -> dict: ...
|
|
92
|
+
|
|
93
|
+
@mcp.tool()
|
|
94
|
+
def parse_messages(thread: dict) -> list: ...
|
|
95
|
+
|
|
96
|
+
@mcp.tool()
|
|
97
|
+
def create_issue(title: str, body: str, labels: list[str]) -> str: ...
|
|
98
|
+
```
|
|
99
|
+
|
|
100
|
+
BIEN (expone intenciones):
|
|
101
|
+
|
|
102
|
+
```python
|
|
103
|
+
@mcp.tool()
|
|
104
|
+
def create_issue_from_thread(
|
|
105
|
+
thread_id: str,
|
|
106
|
+
extra_labels: list[str] | None = None,
|
|
107
|
+
) -> IssueCreated:
|
|
108
|
+
"""Crea un issue a partir de un hilo de Slack/Discord/email.
|
|
109
|
+
|
|
110
|
+
Extrae automáticamente el título, el cuerpo y las etiquetas
|
|
111
|
+
relevantes del hilo, crea el issue en el tracker configurado
|
|
112
|
+
y retorna su URL.
|
|
113
|
+
"""
|
|
114
|
+
```
|
|
115
|
+
|
|
116
|
+
Criterio: si un agente invocaría las 3 tools primitivas siempre en el mismo
|
|
117
|
+
orden y con los mismos parámetros derivados, eso es UNA intención. Exponer solo
|
|
118
|
+
la intención reduce tokens y decisiones del modelo.
|
|
119
|
+
|
|
120
|
+
## Patrón 3 — Code orchestration para APIs grandes
|
|
121
|
+
|
|
122
|
+
Cuando la API tiene >50 endpoints, exponer dos tools que permitan al agente
|
|
123
|
+
descubrir y ejecutar dinámicamente:
|
|
124
|
+
|
|
125
|
+
```python
|
|
126
|
+
@mcp.tool()
|
|
127
|
+
def search(query: str, limit: int = 10) -> list[ToolDescriptor]:
|
|
128
|
+
"""Busca endpoints disponibles por descripción."""
|
|
129
|
+
|
|
130
|
+
@mcp.tool()
|
|
131
|
+
def execute(script: str, inputs: dict) -> ExecutionResult:
|
|
132
|
+
"""Ejecuta un script Python que compone llamadas a la API
|
|
133
|
+
real en un sandbox aislado. El script recibe un cliente
|
|
134
|
+
pre-autenticado como variable `api` y retorna JSON."""
|
|
135
|
+
```
|
|
136
|
+
|
|
137
|
+
Ejecución en sandbox (obligatorio — porque código arbitrario del agente
|
|
138
|
+
sin aislamiento es inyección confirmada): `subprocess` con `timeout`,
|
|
139
|
+
`resource` limits de CPU/memoria, sin acceso a filesystem del host,
|
|
140
|
+
red filtrada al dominio del API destino únicamente.
|
|
141
|
+
|
|
142
|
+
Cloudflare usa este patrón con sus ~2,500 endpoints, reduciendo la huella
|
|
143
|
+
en contexto a ~1K tokens vs >50K con tools individuales.
|
|
144
|
+
|
|
145
|
+
## Patrón 4 — Elicitation mid-tool-call
|
|
146
|
+
|
|
147
|
+
Permite pausar la ejecución de una tool para pedir input estructurado al
|
|
148
|
+
usuario (formulario) o mostrar una URL (flujo OAuth, pago):
|
|
149
|
+
|
|
150
|
+
```python
|
|
151
|
+
@mcp.tool()
|
|
152
|
+
async def transfer_funds(
|
|
153
|
+
from_account: str,
|
|
154
|
+
to_account: str,
|
|
155
|
+
amount: Decimal,
|
|
156
|
+
) -> TransferResult:
|
|
157
|
+
# Pausa: pide confirmación antes de ejecutar
|
|
158
|
+
confirmation = await ctx.elicit(
|
|
159
|
+
mode="form",
|
|
160
|
+
schema={
|
|
161
|
+
"type": "object",
|
|
162
|
+
"properties": {
|
|
163
|
+
"confirm": {"type": "boolean", "title": "¿Confirmas la transferencia?"},
|
|
164
|
+
},
|
|
165
|
+
"required": ["confirm"],
|
|
166
|
+
},
|
|
167
|
+
)
|
|
168
|
+
if not confirmation["confirm"]:
|
|
169
|
+
return TransferResult(status="cancelled_by_user")
|
|
170
|
+
# Ejecuta solo si el usuario confirmó
|
|
171
|
+
return await _ejecutar_transferencia(from_account, to_account, amount)
|
|
172
|
+
```
|
|
173
|
+
|
|
174
|
+
Modos: `form` (JSON Schema → UI de formulario), `url` (abrir navegador para
|
|
175
|
+
OAuth o pago), `text` (texto libre).
|
|
176
|
+
|
|
177
|
+
Criterio de uso: solo para operaciones irreversibles o con costo económico.
|
|
178
|
+
Pausar cada tool rompe la autonomía del agente y frustra al usuario.
|
|
179
|
+
|
|
180
|
+
## Patrón 5 — Autenticación OAuth con CIMD + Vaults
|
|
181
|
+
|
|
182
|
+
CIMD (Client ID Metadata Documents) estandariza el OAuth entre clientes MCP
|
|
183
|
+
sin que cada uno registre su app por separado.
|
|
184
|
+
|
|
185
|
+
Flujo recomendado:
|
|
186
|
+
|
|
187
|
+
1. El cliente MCP descubre el servidor → obtiene el manifiesto con
|
|
188
|
+
`authorization_servers`.
|
|
189
|
+
2. Redirige al usuario al authorization server con CIMD del cliente.
|
|
190
|
+
3. El token emitido se guarda en el Vault del servidor MCP (no en el cliente,
|
|
191
|
+
no en los parámetros de tools).
|
|
192
|
+
4. Cada tool_call del cliente incluye un session_id; el servidor resuelve
|
|
193
|
+
las credenciales desde el Vault usando ese session_id.
|
|
194
|
+
|
|
195
|
+
Never hacer:
|
|
196
|
+
|
|
197
|
+
- Embeber `api_key` en los parámetros de una tool — queda en logs y
|
|
198
|
+
en el historial del agente.
|
|
199
|
+
- Devolver tokens en el response de una tool — el modelo puede filtrarlos en
|
|
200
|
+
su razonamiento visible.
|
|
201
|
+
- Usar una API key compartida para múltiples usuarios — rompe auditoría
|
|
202
|
+
y el principio de menor privilegio.
|
|
203
|
+
|
|
204
|
+
## Estructura mínima del servidor
|
|
205
|
+
|
|
206
|
+
```
|
|
207
|
+
mi-mcp-servidor/
|
|
208
|
+
├── pyproject.toml # mcp>=1.0.0, fastmcp, httpx
|
|
209
|
+
├── src/
|
|
210
|
+
│ ├── server.py # entry point con FastMCP
|
|
211
|
+
│ ├── tools/ # una tool de intención por archivo
|
|
212
|
+
│ ├── auth/ # manejo de CIMD + Vault
|
|
213
|
+
│ ├── sandbox/ # execute() si usa code orchestration
|
|
214
|
+
│ └── resources/ # MCP resources (si aplica)
|
|
215
|
+
├── tests/
|
|
216
|
+
│ ├── test_tools_integration.py # contra un cliente MCP real
|
|
217
|
+
│ └── test_auth_flow.py
|
|
218
|
+
└── README.md
|
|
219
|
+
```
|
|
220
|
+
|
|
221
|
+
Dependencias mínimas: `mcp` (SDK oficial Python) o `@modelcontextprotocol/sdk`
|
|
222
|
+
(TypeScript). Evitar abstracciones propietarias sobre MCP — el estándar
|
|
223
|
+
evoluciona y los wrappers se rompen.
|
|
224
|
+
|
|
225
|
+
## Gotchas
|
|
226
|
+
|
|
227
|
+
- **Tool search defiere carga, no la elimina** — los tools siguen existiendo;
|
|
228
|
+
el modelo los pide por descripción cuando los necesita. Si el conteo es
|
|
229
|
+
absurdo (>1,000), rediseñar con code orchestration; tool search sola no
|
|
230
|
+
arregla un catálogo mal agrupado.
|
|
231
|
+
- **Elicitation no suspende el timeout del agente** — si el usuario tarda 5
|
|
232
|
+
minutos en confirmar, el agente sigue consumiendo el reloj del cliente.
|
|
233
|
+
Configurar timeouts explícitos en el servidor para reiniciar el diálogo si
|
|
234
|
+
el usuario abandona.
|
|
235
|
+
- **Programmatic tool calling requiere que la API destino sea idempotente** —
|
|
236
|
+
si el script del sandbox falla a la mitad, el re-run duplica efectos. Para
|
|
237
|
+
operaciones no idempotentes, combinar con elicitation.
|
|
238
|
+
- **Vaults no son gratis en latencia** — resolver el secreto por session_id
|
|
239
|
+
agrega ~5-20ms por tool_call. Cachear con TTL corto (60s) dentro del
|
|
240
|
+
servidor, nunca en el cliente.
|
|
241
|
+
- **SSE vs HTTP streamable** — SSE es más simple pero no soporta request
|
|
242
|
+
body grande; para inputs de tool_call con payload >1MB (documentos,
|
|
243
|
+
imágenes), usar HTTP streamable.
|
|
244
|
+
- **Cualquier herramienta que toma credenciales como parámetro es una vulnerabilidad** —
|
|
245
|
+
porque quedan en logs de request, en transcripts del agente y en historial
|
|
246
|
+
del cliente. Siempre resolver credenciales por identidad del usuario, nunca
|
|
247
|
+
aceptarlas como input.
|
|
248
|
+
- **MCP Apps con interfaces ricas requieren capability negotiation** — no todo
|
|
249
|
+
cliente soporta renderizado de formularios o gráficos. El servidor debe
|
|
250
|
+
degradar a respuesta texto plano cuando `capabilities.ui` está ausente.
|
|
251
|
+
|
|
252
|
+
## Integración con SWL
|
|
253
|
+
|
|
254
|
+
- **`reglas/seguridad-agentes.md`** — sección "Gobernanza de MCP" define
|
|
255
|
+
cómo evaluar un servidor MCP antes de conectarlo desde SWL; este skill cubre
|
|
256
|
+
el lado servidor correspondiente.
|
|
257
|
+
- **`/swl:mcp-status`** — valida salud de servidores MCP conectados; útil
|
|
258
|
+
cuando desarrolles tu propio servidor para probar descubrimiento.
|
|
259
|
+
- **`backend-api-swl`** — agente que diseña APIs; invocar antes de este skill
|
|
260
|
+
si la API base aún no existe.
|
|
261
|
+
- **`arquitecto-swl`** — si la decisión "MCP vs REST vs GraphQL" aún no está
|
|
262
|
+
tomada, producir un ADR antes de cargar este skill.
|
|
263
|
+
|
|
264
|
+
## Referencias
|
|
265
|
+
|
|
266
|
+
- Artículo Anthropic 2026-04: "Building agents that reach production systems with MCP".
|
|
267
|
+
- MCP SDK oficial Python: https://github.com/modelcontextprotocol/python-sdk
|
|
268
|
+
- MCP SDK oficial TypeScript: https://github.com/modelcontextprotocol/typescript-sdk
|
|
269
|
+
- Directorio público de servidores MCP: https://github.com/modelcontextprotocol/servers
|
|
270
|
+
- Cloudflare MCP server (referencia de code orchestration).
|
|
@@ -0,0 +1,288 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: backend-production-resilience
|
|
3
|
+
description: >
|
|
4
|
+
Patrones de resiliencia para servicios backend en producción. Cubre timeouts
|
|
5
|
+
obligatorios, retries con jitter+backoff e idempotency, circuit breakers,
|
|
6
|
+
bulkheads, backpressure, graceful degradation, blast radius, fault isolation
|
|
7
|
+
y observabilidad operacional. Cargar cuando se diseñe o revise un servicio
|
|
8
|
+
que llame a dependencias externas (BD, APIs, colas, caches), cuando se
|
|
9
|
+
diagnostique un incidente de producción, o cuando se quiera endurecer
|
|
10
|
+
endpoints contra sobrecarga, latencia y fallas en cascada.
|
|
11
|
+
version: "1.0.0"
|
|
12
|
+
evolved: false
|
|
13
|
+
herramientasPermitidas: [Read]
|
|
14
|
+
exclusiones:
|
|
15
|
+
- "No cargar para resiliencia de agentes IA o cadenas de delegación — cargar `seguridad-agentes` o `guardrail-semantico`. Este skill cubre servicios web/API/backend, no orquestación de agentes."
|
|
16
|
+
- "No cargar para definición de SLO/SLI o error budgets — cargar `sre-patrones`. Este skill cubre patrones de implementación; SRE cubre el framework de confiabilidad."
|
|
17
|
+
- "No cargar para configuración de monitoreo (Prometheus, Grafana, alertas) — cargar `monitoring-alertas`. Este skill cubre qué emitir desde el código; monitoreo cubre cómo capturarlo y graficarlo."
|
|
18
|
+
- "No cargar para manejo de errores genérico (jerarquía de excepciones, códigos de dominio) — cargar `manejo-errores`. Este skill asume que ese ya está aplicado y agrega patrones de resiliencia operacional encima."
|
|
19
|
+
evolvable: true
|
|
20
|
+
---
|
|
21
|
+
|
|
22
|
+
# Backend Production Resilience
|
|
23
|
+
|
|
24
|
+
## Cuándo cargar
|
|
25
|
+
|
|
26
|
+
- Se diseña o revisa un servicio que llama dependencias externas (BD, APIs HTTP, colas, caches, filesystem remoto).
|
|
27
|
+
- Se diagnostica un incidente de producción: latencia, timeouts en cascada, OOM, retry storms.
|
|
28
|
+
- Se prepara un endpoint público para tráfico real (no solo el happy path).
|
|
29
|
+
- Se va a integrar un nuevo cliente HTTP o driver de BD: aplicar timeouts y circuit breaker desde el inicio.
|
|
30
|
+
- Se hace code review de un PR que toca integración con sistemas externos.
|
|
31
|
+
|
|
32
|
+
## Cuándo NO cargar
|
|
33
|
+
|
|
34
|
+
- La tarea es definir SLO/SLI o calcular error budgets — usar `sre-patrones`.
|
|
35
|
+
- La tarea es configurar dashboards o alertas en Prometheus/Grafana — usar `monitoring-alertas`.
|
|
36
|
+
- El problema es resiliencia de cadenas de agentes IA o blast radius de delegación — usar `seguridad-agentes`.
|
|
37
|
+
- El servicio aún no maneja errores correctamente — primero cargar `manejo-errores` y aplicar la jerarquía base; este skill asume manejo de errores ya correcto.
|
|
38
|
+
|
|
39
|
+
## Directiva primaria
|
|
40
|
+
|
|
41
|
+
**La producción es desordenada por defecto.** Toda dependencia externa puede ser
|
|
42
|
+
lenta, no estar disponible o devolver datos incorrectos. Toda cola se llena.
|
|
43
|
+
Todo cache puede fallar o sufrir stampede. Todo timeout puede cascadear.
|
|
44
|
+
|
|
45
|
+
Diseñar para que el servicio:
|
|
46
|
+
|
|
47
|
+
1. **Falle visible** en lugar de colgarse en silencio.
|
|
48
|
+
2. **Limite el blast radius** en lugar de propagar la falla.
|
|
49
|
+
3. **Descarte carga** en lugar de colapsar bajo presión.
|
|
50
|
+
4. **Preserve servicios core** cuando hay degradación.
|
|
51
|
+
5. **Permita diagnóstico** desde los logs, métricas y trazas.
|
|
52
|
+
|
|
53
|
+
No diseñar solo para el happy path.
|
|
54
|
+
|
|
55
|
+
## Mindset de estabilidad — 6 axiomas
|
|
56
|
+
|
|
57
|
+
1. Toda dependencia puede ser lenta, no responder o estar mal.
|
|
58
|
+
2. Toda cola se puede llenar.
|
|
59
|
+
3. Todo cache puede fallar o sufrir stampede.
|
|
60
|
+
4. Todo timeout puede cascadear hacia arriba.
|
|
61
|
+
5. Todo caller puede reintentar mal (DDoSearte sin querer).
|
|
62
|
+
6. Todo estado "temporal degradado" puede convertirse en normal por horas.
|
|
63
|
+
|
|
64
|
+
El código debe asumir estas condiciones por construcción, no tolerarlas por accidente.
|
|
65
|
+
|
|
66
|
+
---
|
|
67
|
+
|
|
68
|
+
## Timeouts — obligatorios, no opcionales
|
|
69
|
+
|
|
70
|
+
- Toda llamada de salida (HTTP, DB query, cache get, cola publish) DEBE tener
|
|
71
|
+
un timeout explícito.
|
|
72
|
+
- El timeout va en el código, NO se hereda del default de la librería.
|
|
73
|
+
Los defaults suelen ser infinitos o demasiado largos.
|
|
74
|
+
- Distintas dependencias pueden tener distintos presupuestos de timeout
|
|
75
|
+
según su SLA conocido. No usar un único valor global.
|
|
76
|
+
- Esperas infinitas están prohibidas. Sin excepción.
|
|
77
|
+
|
|
78
|
+
```python
|
|
79
|
+
# MAL — sin timeout, defaults dependen de la librería
|
|
80
|
+
async with httpx.AsyncClient() as client:
|
|
81
|
+
r = await client.get(url) # puede colgar indefinidamente
|
|
82
|
+
|
|
83
|
+
# BIEN — timeout explícito por nivel (connect, read, write, pool)
|
|
84
|
+
TIMEOUT = httpx.Timeout(connect=2.0, read=5.0, write=2.0, pool=1.0)
|
|
85
|
+
async with httpx.AsyncClient(timeout=TIMEOUT) as client:
|
|
86
|
+
r = await client.get(url)
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
Para BD: el timeout va en el statement (`statement_timeout` en PostgreSQL,
|
|
90
|
+
`maxTimeMS` en MongoDB), no solo en el connection pool.
|
|
91
|
+
|
|
92
|
+
---
|
|
93
|
+
|
|
94
|
+
## Retries — disciplinados o ninguno
|
|
95
|
+
|
|
96
|
+
- Reintenta solo operaciones **idempotentes** (GET, PUT, DELETE) o
|
|
97
|
+
explícitamente diseñadas con idempotency key (POST con header
|
|
98
|
+
`Idempotency-Key: <uuid>`).
|
|
99
|
+
- Acotar el conteo de reintentos Y el tiempo total de reintentos.
|
|
100
|
+
- Aplicar **jitter** y **backoff exponencial** para evitar tormentas de
|
|
101
|
+
reintentos sincronizados.
|
|
102
|
+
- NUNCA reintentes errores 4xx (client error). Reintenta solo 408, 429,
|
|
103
|
+
5xx (excepto 501, 505) y errores de red transitorios.
|
|
104
|
+
- Si el caller también reintenta, los reintentos se multiplican
|
|
105
|
+
exponencialmente — preferir un solo nivel de retry en la cadena.
|
|
106
|
+
|
|
107
|
+
```python
|
|
108
|
+
import random
|
|
109
|
+
async def retry_con_jitter(fn, intentos=3, base_delay=0.5, max_delay=8.0):
|
|
110
|
+
"""Backoff exponencial completo + jitter aleatorio (AWS Architecture Blog)."""
|
|
111
|
+
for intento in range(intentos):
|
|
112
|
+
try:
|
|
113
|
+
return await fn()
|
|
114
|
+
except (httpx.TimeoutException, httpx.NetworkError) as e:
|
|
115
|
+
if intento == intentos - 1:
|
|
116
|
+
raise
|
|
117
|
+
cap = min(max_delay, base_delay * (2 ** intento))
|
|
118
|
+
await asyncio.sleep(random.uniform(0, cap)) # full jitter
|
|
119
|
+
```
|
|
120
|
+
|
|
121
|
+
---
|
|
122
|
+
|
|
123
|
+
## Circuit breakers
|
|
124
|
+
|
|
125
|
+
Cuando una dependencia está fallando, **dejar de llamarla** durante un
|
|
126
|
+
período corto en lugar de seguir intentando y consumir threads/conexiones.
|
|
127
|
+
|
|
128
|
+
Estados:
|
|
129
|
+
- **CLOSED**: peticiones pasan normalmente.
|
|
130
|
+
- **OPEN**: peticiones fallan inmediatamente (no se llama a la dependencia).
|
|
131
|
+
- **HALF_OPEN**: tras un timeout, se permiten N peticiones de prueba; si
|
|
132
|
+
pasan, vuelve a CLOSED; si fallan, vuelve a OPEN.
|
|
133
|
+
|
|
134
|
+
Reglas:
|
|
135
|
+
- Definir thresholds explícitos: tasa de error (ej: ≥50% de las últimas
|
|
136
|
+
20 llamadas) y tiempo de cooldown (ej: 30s).
|
|
137
|
+
- El circuit breaker DEBE emitir métricas con el cambio de estado para
|
|
138
|
+
que se monitoree.
|
|
139
|
+
- En estado OPEN, devolver una respuesta degradada (cache, default, error
|
|
140
|
+
visible al caller) — nunca colgar.
|
|
141
|
+
- Probar el comportamiento del CB con tests específicos: simular dependencia
|
|
142
|
+
caída y verificar que el CB abre, sostiene y vuelve a HALF_OPEN.
|
|
143
|
+
|
|
144
|
+
Librerías recomendadas: `pybreaker` (Python), `opossum` (Node.js),
|
|
145
|
+
`resilience4j` (Java).
|
|
146
|
+
|
|
147
|
+
---
|
|
148
|
+
|
|
149
|
+
## Bulkheads — aislamiento de fallos
|
|
150
|
+
|
|
151
|
+
Aislar pools de recursos por dependencia para que una dependencia lenta
|
|
152
|
+
no agote todos los threads/conexiones del servicio:
|
|
153
|
+
|
|
154
|
+
- Pools separados de conexiones HTTP por upstream crítico.
|
|
155
|
+
- Pools separados de threads/workers por tipo de tarea.
|
|
156
|
+
- Tamaño máximo del pool acotado: si hay tráfico que excede capacidad,
|
|
157
|
+
fallar rápido en lugar de hacer cola infinita.
|
|
158
|
+
|
|
159
|
+
```python
|
|
160
|
+
# Cliente HTTP con pool dedicado por upstream (httpx)
|
|
161
|
+
cliente_pagos = httpx.AsyncClient(
|
|
162
|
+
timeout=TIMEOUT_PAGOS,
|
|
163
|
+
limits=httpx.Limits(max_connections=20, max_keepalive_connections=10),
|
|
164
|
+
)
|
|
165
|
+
cliente_inventario = httpx.AsyncClient(
|
|
166
|
+
timeout=TIMEOUT_INVENTARIO,
|
|
167
|
+
limits=httpx.Limits(max_connections=50, max_keepalive_connections=20),
|
|
168
|
+
)
|
|
169
|
+
```
|
|
170
|
+
|
|
171
|
+
Sin bulkheads, una dependencia lenta puede consumir todos los workers y
|
|
172
|
+
dejar al servicio sin capacidad para responder otros endpoints.
|
|
173
|
+
|
|
174
|
+
---
|
|
175
|
+
|
|
176
|
+
## Backpressure y descarte de carga
|
|
177
|
+
|
|
178
|
+
Cuando el servicio recibe más peticiones de las que puede procesar, debe
|
|
179
|
+
DESCARTAR carga rápidamente en lugar de hacer cola y degradar a todos.
|
|
180
|
+
|
|
181
|
+
Patrones:
|
|
182
|
+
- **Rate limiting** por cliente/endpoint (token bucket, sliding window).
|
|
183
|
+
Devolver `429 Too Many Requests` con header `Retry-After`.
|
|
184
|
+
- **Cola acotada**: si la cola interna excede N items, rechazar nuevas
|
|
185
|
+
con `503 Service Unavailable`.
|
|
186
|
+
- **Load shedding**: bajo CPU/memoria altos, rechazar peticiones no-críticas
|
|
187
|
+
primero, preservar servicios core.
|
|
188
|
+
- **Admission control**: rechazar peticiones que probablemente excederán
|
|
189
|
+
el deadline antes de empezar a procesarlas.
|
|
190
|
+
|
|
191
|
+
NO usar colas en memoria ilimitadas — un upstream lento las llena hasta
|
|
192
|
+
provocar OOM.
|
|
193
|
+
|
|
194
|
+
---
|
|
195
|
+
|
|
196
|
+
## Graceful degradation
|
|
197
|
+
|
|
198
|
+
Cuando una dependencia no-crítica falla, el servicio debe seguir
|
|
199
|
+
funcionando con funcionalidad reducida en lugar de devolver error
|
|
200
|
+
completo:
|
|
201
|
+
|
|
202
|
+
- Catalogar dependencias en críticas vs. mejoradoras (recommendations,
|
|
203
|
+
analytics, notifications son típicamente mejoradoras).
|
|
204
|
+
- Si una dependencia mejoradora falla: registrar la falla, devolver
|
|
205
|
+
resultado degradado (sin recommendations, sin notification enviada
|
|
206
|
+
pero encolada para retry).
|
|
207
|
+
- El cliente debe poder distinguir entre respuesta completa y
|
|
208
|
+
respuesta degradada (ej: header `X-Service-Degraded: notifications`).
|
|
209
|
+
|
|
210
|
+
Antipatrón: si el servicio de notifications falla, fallar la operación
|
|
211
|
+
de checkout completa. Eso convierte una dependencia mejoradora en
|
|
212
|
+
crítica.
|
|
213
|
+
|
|
214
|
+
---
|
|
215
|
+
|
|
216
|
+
## Blast radius — contención del impacto
|
|
217
|
+
|
|
218
|
+
Diseñar para que una falla aislada NO se propague a todo el sistema:
|
|
219
|
+
|
|
220
|
+
- Particionar usuarios/tenants en shards independientes (un shard caído
|
|
221
|
+
no tira a otros tenants).
|
|
222
|
+
- Separar workloads críticos de no-críticos en infraestructura distinta
|
|
223
|
+
(un job de reportes pesado no debe usar el mismo pool que el checkout).
|
|
224
|
+
- Limitar el alcance de cambios deployable: feature flags por usuario o
|
|
225
|
+
porcentaje, canary deployments, blue-green.
|
|
226
|
+
|
|
227
|
+
Pregunta de revisión: si esta dependencia se cae a las 3am del sábado,
|
|
228
|
+
**¿cuántos usuarios se ven afectados y por cuánto tiempo?**
|
|
229
|
+
|
|
230
|
+
---
|
|
231
|
+
|
|
232
|
+
## Observabilidad obligatoria
|
|
233
|
+
|
|
234
|
+
Sin observabilidad, los patrones anteriores son invisibles cuando fallan.
|
|
235
|
+
Mínimo requerido:
|
|
236
|
+
|
|
237
|
+
- **Métricas RED por endpoint**: Rate (req/s), Errors (count/rate), Duration
|
|
238
|
+
(p50/p95/p99).
|
|
239
|
+
- **Estado de circuit breakers**: gauge por dependencia (0=closed, 1=open).
|
|
240
|
+
- **Saturación de pools**: utilización de connection pool, queue depth.
|
|
241
|
+
- **Latencia por dependencia externa**: histograma separado por upstream.
|
|
242
|
+
- **Logs estructurados** con correlation ID que cruce el request completo.
|
|
243
|
+
- **Trazas distribuidas** (OpenTelemetry) para diagnosticar latencia
|
|
244
|
+
cross-service.
|
|
245
|
+
|
|
246
|
+
Si un patrón de resiliencia se activa (CB abre, retry consume budget,
|
|
247
|
+
load shedding descarta) DEBE quedar registrado con suficiente contexto
|
|
248
|
+
para diagnóstico post-mortem.
|
|
249
|
+
|
|
250
|
+
---
|
|
251
|
+
|
|
252
|
+
## Anti-patrones
|
|
253
|
+
|
|
254
|
+
- **Retry sin jitter**: causa retry storm sincronizado que tira la
|
|
255
|
+
dependencia justo cuando se está recuperando.
|
|
256
|
+
- **Timeout en el caller pero no en el callee**: el callee sigue
|
|
257
|
+
procesando una petición ya abandonada — desperdicia recursos.
|
|
258
|
+
- **Catch-all `except Exception` con log y continue**: oculta fallas
|
|
259
|
+
reales, hace el servicio "imposible de diagnosticar".
|
|
260
|
+
- **Cola en memoria sin límite**: tarde o temprano OOM.
|
|
261
|
+
- **Reintentar 4xx**: errores del cliente no se arreglan reintentando.
|
|
262
|
+
- **Misma dependencia compartiendo pool con todas las demás**: cuando
|
|
263
|
+
esa dependencia lenta llega, mata todo el servicio.
|
|
264
|
+
- **CB sin métricas**: nadie se entera cuando abre, falla en silencio.
|
|
265
|
+
|
|
266
|
+
---
|
|
267
|
+
|
|
268
|
+
## Gotchas / Errores comunes no obvios
|
|
269
|
+
|
|
270
|
+
- **`asyncio.wait_for` no cancela la operación interna en algunas librerías**: el timeout dispara pero la operación sigue corriendo en background consumiendo recursos. Causa: la librería interna no propaga `CancelledError`. Solución: verificar que la librería soporta cancelación cooperativa; si no, ejecutar en thread separado con `loop.run_in_executor` y matarlo explícitamente.
|
|
271
|
+
- **Reintento sobre POST sin idempotency key duplica órdenes**: si la red corta antes de recibir la respuesta, el caller no sabe si se procesó. Causa: POST por defecto no es idempotente. Solución: requerir `Idempotency-Key: <uuid>` en POST que muten estado, persistir el key con la respuesta, devolver la misma respuesta si llega una repetición.
|
|
272
|
+
- **Circuit breaker con threshold absoluto en lugar de tasa**: el CB nunca abre porque "10 errores" tarda en alcanzarse en bajo tráfico, pero abre falsamente con "10 errores en 1000 req". Causa: threshold absoluto sin ventana temporal. Solución: usar tasa de error sobre ventana deslizante (ej: 50% de errores en últimas 20 peticiones o últimos 10s).
|
|
273
|
+
- **Backoff exponencial sin cap**: tras varios fallos, el delay crece a 30 minutos y el caller percibe como cuelgue. Causa: olvidar `max_delay`. Solución: siempre acotar con `min(cap, base * 2**n)` (capped exponential backoff).
|
|
274
|
+
- **Bulkhead omitido entre tenants**: un tenant grande consume todo el pool y deja a los demás esperando. Causa: pool global, no por tenant. Solución: pool por tenant o tenant pesos en admission control.
|
|
275
|
+
|
|
276
|
+
## Checklist antes de poner un servicio en producción
|
|
277
|
+
|
|
278
|
+
- [ ] Toda llamada externa tiene timeout explícito (no default).
|
|
279
|
+
- [ ] Retries acotados, con jitter+backoff, solo en operaciones idempotentes.
|
|
280
|
+
- [ ] Circuit breaker configurado para cada dependencia externa crítica.
|
|
281
|
+
- [ ] Pools separados por dependencia (bulkheads).
|
|
282
|
+
- [ ] Rate limiting en endpoints públicos.
|
|
283
|
+
- [ ] Cola interna con límite (rechazar 503 al exceder).
|
|
284
|
+
- [ ] Catálogo de dependencias críticas vs. mejoradoras documentado.
|
|
285
|
+
- [ ] Métricas RED + estado CB + saturación pools instrumentadas.
|
|
286
|
+
- [ ] Logs estructurados con correlation ID.
|
|
287
|
+
- [ ] Trazas distribuidas configuradas (OpenTelemetry).
|
|
288
|
+
- [ ] Test de chaos: simular latencia/caída de cada dependencia y verificar comportamiento.
|